diff options
Diffstat (limited to 'Lib/rlcompleter.py')
| -rw-r--r-- | Lib/rlcompleter.py | 41 | 
1 files changed, 31 insertions, 10 deletions
| diff --git a/Lib/rlcompleter.py b/Lib/rlcompleter.py index d517c0e2d3..613848f7ad 100644 --- a/Lib/rlcompleter.py +++ b/Lib/rlcompleter.py @@ -106,6 +106,12 @@ class Completer:          n = len(text)          for word in keyword.kwlist:              if word[:n] == text: +                if word in {'finally', 'try'}: +                    word = word + ':' +                elif word not in {'False', 'None', 'True', +                                  'break', 'continue', 'pass', +                                  'else'}: +                    word = word + ' '                  matches.append(word)          for nspace in [builtins.__dict__, self.namespace]:              for word, val in nspace.items(): @@ -136,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): | 
