Import completion improvements.

This commit is contained in:
Dave Halter
2014-12-08 13:47:23 +01:00
parent 7cc2a07cd3
commit 6cc4d71822
3 changed files with 27 additions and 16 deletions

View File

@@ -131,30 +131,33 @@ class Script(object):
:rtype: list of :class:`classes.Completion`
"""
def get_completions(user_stmt, bs):
if user_stmt is None:
module = self._parser.module()
importer, only_modules = helpers.check_error_statements(
self._evaluator, module, self._pos
)
#print(importer.completion_names(self._evaluator, True))
if importer is not None:
names = importer.completion_names(self._evaluator, only_modules)
return [(name, module) for name in names]
elif isinstance(user_stmt, pr.Import):
module = self._parser.module()
importer, only_modules = helpers.check_error_statements(
self._evaluator, module, self._pos
)
completions = []
#print(importer.completion_names(self._evaluator, True))
if importer is not None:
names = importer.completion_names(self._evaluator, only_modules)
completions = [(name, module) for name in names]
if isinstance(user_stmt, pr.Import):
# TODO this paragraph is necessary, but not sure it works.
context = self._user_context.get_context()
next(context) # skip the path
if next(context) == 'from':
if False and next(context) == 'from':
# completion is just "import" if before stands from ..
return ((k, bs) for k in keywords.keyword_names('import'))
completions += ((k, bs) for k in keywords.keyword_names('import'))
module = self._parser.module()
name = user_stmt.name_for_position(self._pos)
imp = imports.ImportWrapper(self._evaluator, name)
return [(n, module) for n in imp.get_defined_names()]
completions += [(n, module) for n in imp.completions()]
if importer or isinstance(user_stmt, pr.Import):
return completions
return self._simple_complete(path, dot, like)
debug.speed('completions start')
path = self._user_context.get_path_until_cursor()
# dots following an int are not the start of a completion but a float

View File

@@ -47,13 +47,17 @@ class ImportWrapper(pr.Base):
self.import_path = self._import.path_for_name(name)
self.is_like_search = False # TODO REMOVE
def get_defined_names(self):
def completions(self):
# The import path needs to be reduced by one, because we're completing.
import_path = self.import_path[:-1]
module = self._import.get_parent_until()
importer = get_importer(self._evaluator, tuple(import_path),
module, self._import.level)
only_modules = isinstance(self._import, pr.ImportName)
if isinstance(self._import, pr.ImportFrom):
c = self._import.children
only_modules = c[c.index('import')].start_pos >= self._name.start_pos
else:
only_modules = True
return importer.completion_names(self._evaluator, only_modules)
@memoize_default()

View File

@@ -25,6 +25,8 @@ import classes
#? ['timedelta']
from datetime import timedel
#? 21 []
from datetime.timedel import timedel
# should not be possible, because names can only be looked up 1 level deep.
#? []
@@ -59,7 +61,9 @@ import datetime.
#? []
import datetime.date
#? 18 ['import']
#? 17 ['import']
from import_tree import pkg
#? 18 ['import', 'pkg']
from import_tree. import pkg
#? 17 ['mod1', 'mod2', 'random', 'pkg', 'rename1', 'rename2', 'recurse_class1', 'recurse_class2']
from import_tree. import pkg