diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2005-01-29 13:29:23 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2005-01-29 13:29:23 (GMT) |
commit | 1d11de6dbd247689c508de2ec28f0f3fc35ecabc (patch) | |
tree | 62a7f160f4a339382f748a8cfdb655522b16f289 | |
parent | 3069dbb8ec9c287c2ff6b3a1c8bfde83af81c11b (diff) | |
download | cpython-1d11de6dbd247689c508de2ec28f0f3fc35ecabc.zip cpython-1d11de6dbd247689c508de2ec28f0f3fc35ecabc.tar.gz cpython-1d11de6dbd247689c508de2ec28f0f3fc35ecabc.tar.bz2 |
Revert os.py 1.75, and directly implement update.
Fixes #1110478 and #1100235.
-rw-r--r-- | Lib/os.py | 22 | ||||
-rw-r--r-- | Lib/test/test_os.py | 7 | ||||
-rw-r--r-- | Misc/NEWS | 2 |
3 files changed, 31 insertions, 0 deletions
@@ -442,6 +442,17 @@ else: return key.upper() in self.data def get(self, key, failobj=None): return self.data.get(key.upper(), failobj) + def update(self, dict=None, **kwargs): + if dict: + try: + items = dict.items() + except AttributeError: + # List of (key, value) + items = dict + for k, v in items: + self[k] = v + if kwargs: + self.update(kwargs) def copy(self): return dict(self) @@ -453,6 +464,17 @@ else: def __setitem__(self, key, item): putenv(key, item) self.data[key] = item + def update(self, dict=None, **kwargs): + if dict: + try: + items = dict.items() + except AttributeError: + # List of (key, value) + items = dict + for k, v in items: + self[k] = v + if kwargs: + self.update(kwargs) try: unsetenv except NameError: diff --git a/Lib/test/test_os.py b/Lib/test/test_os.py index 472d13f..cce6926 100644 --- a/Lib/test/test_os.py +++ b/Lib/test/test_os.py @@ -226,6 +226,13 @@ class EnvironTests(mapping_tests.BasicTestMappingProtocol): os.environ.clear() os.environ.update(self.__save) + # Bug 1110478 + def test_update(self): + if os.path.exists("/bin/sh"): + os.environ.update(HELLO="World") + value = os.popen("/bin/sh -c 'echo $HELLO'").read().strip() + self.assertEquals(value, "World") + class WalkTests(unittest.TestCase): """Tests for os.walk().""" @@ -45,6 +45,8 @@ Extension Modules Library ------- +- Bug #1110478: Revert os.environ.update to do putenv again. + - Bug #1103844: fix distutils.install.dump_dirs() with negated options. - os.{SEEK_SET, SEEK_CUR, SEEK_END} have been added for convenience. |