1
0
forked from VimPlug/jedi

Add a temporary api._names, to make it possible to annotate a full script with types.

This commit is contained in:
Dave Halter
2014-09-01 18:10:40 +02:00
parent bbf1070ad9
commit be9e77d7d3
3 changed files with 26 additions and 1 deletions

View File

@@ -32,7 +32,7 @@ from jedi.evaluate import Evaluator, filter_private_variable
from jedi.evaluate import representation as er
from jedi.evaluate import compiled
from jedi.evaluate import imports
from jedi.evaluate.helpers import FakeName
from jedi.evaluate.helpers import FakeName, get_module_name_parts
from jedi.evaluate.finder import get_names_of_scope
from jedi.evaluate.helpers import search_call_signatures
from jedi.evaluate import analysis
@@ -688,6 +688,14 @@ def defined_names(source, path=None, encoding='utf-8'):
return classes.defined_names(Evaluator(), parser.module)
def _names(source=None, path=None, encoding='utf-8'):
# Set line/column to a random position, because they don't matter.
script = Script(source, line=1, column=0, path=path, encoding=encoding)
defs = [classes.Definition(script._evaluator, name_part)
for name_part in get_module_name_parts(script._parser.module())]
return sorted(defs, key=lambda x: (x.line, x.column))
def preload_module(*modules):
"""
Preloading modules tells Jedi to load a module now, instead of lazy parsing