summaryrefslogtreecommitdiffstats
path: root/Lib/rlcompleter.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-09-27 10:43:50 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2015-09-27 10:43:50 (GMT)
commitab824222d1356ce731f18e9d585d58d84a64637d (patch)
treef03cef8249baef6d39b3c1207bc2c39ee4f21119 /Lib/rlcompleter.py
parent8ace8e99b375f978111b62f2cc976ce4f55ecd6b (diff)
downloadcpython-ab824222d1356ce731f18e9d585d58d84a64637d.zip
cpython-ab824222d1356ce731f18e9d585d58d84a64637d.tar.gz
cpython-ab824222d1356ce731f18e9d585d58d84a64637d.tar.bz2
Issue #25011: rlcomplete now omits private and special attribute names unless
the prefix starts with underscores.
Diffstat (limited to 'Lib/rlcompleter.py')
-rw-r--r--Lib/rlcompleter.py35
1 files changed, 25 insertions, 10 deletions
diff --git a/Lib/rlcompleter.py b/Lib/rlcompleter.py
index 568cf36..613848f 100644
--- a/Lib/rlcompleter.py
+++ b/Lib/rlcompleter.py
@@ -142,20 +142,35 @@ class Completer:
return []
# get the content of the object, except __builtins__
- words = dir(thisobject)
- if "__builtins__" in words:
- words.remove("__builtins__")
+ words = set(dir(thisobject))
+ words.discard("__builtins__")
if hasattr(thisobject, '__class__'):
- words.append('__class__')
- words.extend(get_class_members(thisobject.__class__))
+ words.add('__class__')
+ words.update(get_class_members(thisobject.__class__))
matches = []
n = len(attr)
- for word in words:
- if word[:n] == attr and hasattr(thisobject, word):
- val = getattr(thisobject, word)
- word = self._callable_postfix(val, "%s.%s" % (expr, word))
- matches.append(word)
+ if attr == '':
+ noprefix = '_'
+ elif attr == '_':
+ noprefix = '__'
+ else:
+ noprefix = None
+ 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)
+ word = self._callable_postfix(val, "%s.%s" % (expr, word))
+ matches.append(word)
+ if matches or not noprefix:
+ break
+ if noprefix == '_':
+ noprefix = '__'
+ else:
+ noprefix = None
+ matches.sort()
return matches
def get_class_members(klass):