diff options
author | Martin Panter <vadmium+py@gmail.com> | 2015-11-13 23:48:17 (GMT) |
---|---|---|
committer | Martin Panter <vadmium+py@gmail.com> | 2015-11-13 23:48:17 (GMT) |
commit | f4ad5f5dea172d91ed21d2a330a72e77013bb279 (patch) | |
tree | 2c28246fa5914ba939d7aed732b01a5860a0cb1e | |
parent | 8adaec56714c0ca902862d8b6279e1e3c969d664 (diff) | |
parent | fa9ea046732eff86408aba477d557c8fc92bc864 (diff) | |
download | cpython-f4ad5f5dea172d91ed21d2a330a72e77013bb279.zip cpython-f4ad5f5dea172d91ed21d2a330a72e77013bb279.tar.gz cpython-f4ad5f5dea172d91ed21d2a330a72e77013bb279.tar.bz2 |
Issue #25590: Merge rlcompleter getattr change from 3.5
-rw-r--r-- | Lib/rlcompleter.py | 8 | ||||
-rw-r--r-- | Lib/test/test_rlcompleter.py | 13 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 21 insertions, 3 deletions
diff --git a/Lib/rlcompleter.py b/Lib/rlcompleter.py index 613848f..d368876 100644 --- a/Lib/rlcompleter.py +++ b/Lib/rlcompleter.py @@ -159,9 +159,11 @@ class Completer: while True: for word in words: if (word[:n] == attr and - not (noprefix and word[:n+1] == noprefix) and - hasattr(thisobject, word)): - val = getattr(thisobject, word) + not (noprefix and word[:n+1] == noprefix)): + try: + val = getattr(thisobject, word) + except Exception: + continue # Exclude properties that are not set word = self._callable_postfix(val, "%s.%s" % (expr, word)) matches.append(word) if matches or not noprefix: diff --git a/Lib/test/test_rlcompleter.py b/Lib/test/test_rlcompleter.py index 2ff0788..fee39bc 100644 --- a/Lib/test/test_rlcompleter.py +++ b/Lib/test/test_rlcompleter.py @@ -79,6 +79,19 @@ class TestRlcompleter(unittest.TestCase): ['egg.{}('.format(x) for x in dir(str) if x.startswith('s')]) + def test_excessive_getattr(self): + # Ensure getattr() is invoked no more than once per attribute + class Foo: + calls = 0 + @property + def bar(self): + self.calls += 1 + return None + f = Foo() + completer = rlcompleter.Completer(dict(f=f)) + self.assertEqual(completer.complete('f.b', 0), 'f.bar') + self.assertEqual(f.calls, 1) + def test_complete(self): completer = rlcompleter.Completer() self.assertEqual(completer.complete('', 0), '\t') @@ -402,6 +402,9 @@ Core and Builtins Library ------- +- Issue #25590: In the Readline completer, only call getattr() once per + attribute. + - Issue #25498: Fix a crash when garbage-collecting ctypes objects created by wrapping a memoryview. This was a regression made in 3.5a1. Based on patch by Eryksun. |