1
0
forked from VimPlug/jedi

Move get_statement_of_position out of the parser tree.

This commit is contained in:
Dave Halter
2017-04-15 02:23:08 +02:00
parent 1cfe5c2945
commit deb028c3fb
5 changed files with 24 additions and 22 deletions

View File

@@ -16,7 +16,7 @@ import sys
from jedi.parser.python import load_grammar from jedi.parser.python import load_grammar
from jedi.parser.python import tree from jedi.parser.python import tree
from jedi.parser.python import parse from jedi.parser.python import parse
from jedi.parser_utils import get_executable_nodes from jedi.parser_utils import get_executable_nodes, get_statement_of_position
from jedi import debug from jedi import debug
from jedi import settings from jedi import settings
from jedi import common from jedi import common
@@ -194,7 +194,7 @@ class Script(object):
:rtype: list of :class:`classes.Definition` :rtype: list of :class:`classes.Definition`
""" """
module_node = self._get_module_node() module_node = self._get_module_node()
leaf = module_node.name_for_position(self._pos) leaf = module_node.get_name_of_position(self._pos)
if leaf is None: if leaf is None:
leaf = module_node.get_leaf_for_position(self._pos) leaf = module_node.get_leaf_for_position(self._pos)
if leaf is None: if leaf is None:
@@ -238,7 +238,7 @@ class Script(object):
""" """
Used for goto_assignments and usages. Used for goto_assignments and usages.
""" """
name = self._get_module_node().name_for_position(self._pos) name = self._get_module_node().get_name_of_position(self._pos)
if name is None: if name is None:
return [] return []
context = self._evaluator.create_context(self._get_module(), name) context = self._evaluator.create_context(self._get_module(), name)
@@ -259,13 +259,13 @@ class Script(object):
settings.dynamic_flow_information, False settings.dynamic_flow_information, False
try: try:
module_node = self._get_module_node() module_node = self._get_module_node()
user_stmt = module_node.get_statement_for_position(self._pos) user_stmt = get_statement_of_position(module_node, self._pos)
definition_names = self._goto() definition_names = self._goto()
if not definition_names and isinstance(user_stmt, tree.Import): if not definition_names and isinstance(user_stmt, tree.Import):
# For not defined imports (goto doesn't find something, we take # For not defined imports (goto doesn't find something, we take
# the name as a definition. This is enough, because every name # the name as a definition. This is enough, because every name
# points to it. # points to it.
name = user_stmt.name_for_position(self._pos) name = user_stmt.get_name_of_position(self._pos)
if name is None: if name is None:
# Must be syntax # Must be syntax
return [] return []

View File

@@ -8,6 +8,7 @@ from jedi.evaluate import imports
from jedi.api import keywords from jedi.api import keywords
from jedi.evaluate.helpers import evaluate_call_of_leaf from jedi.evaluate.helpers import evaluate_call_of_leaf
from jedi.evaluate.filters import get_global_filters from jedi.evaluate.filters import get_global_filters
from jedi.parser_utils import get_statement_of_position
def get_call_signature_param_names(call_signatures): def get_call_signature_param_names(call_signatures):
@@ -51,7 +52,7 @@ def get_user_scope(module_context, position):
""" """
Returns the scope in which the user resides. This includes flows. Returns the scope in which the user resides. This includes flows.
""" """
user_stmt = module_context.tree_node.get_statement_for_position(position) user_stmt = get_statement_of_position(module_context.tree_node, position)
if user_stmt is None: if user_stmt is None:
def scan(scope): def scan(scope):
for s in scope.children: for s in scope.children:

View File

@@ -137,30 +137,17 @@ class PythonMixin(object):
# Default is not being a scope. Just inherit from Scope. # Default is not being a scope. Just inherit from Scope.
return False return False
def name_for_position(self, position): def get_name_of_position(self, position):
for c in self.children: for c in self.children:
if isinstance(c, Leaf): if isinstance(c, Leaf):
if isinstance(c, Name) and c.start_pos <= position <= c.end_pos: if isinstance(c, Name) and c.start_pos <= position <= c.end_pos:
return c return c
else: else:
result = c.name_for_position(position) result = c.get_name_of_position(position)
if result is not None: if result is not None:
return result return result
return None return None
def get_statement_for_position(self, pos):
for c in self.children:
if c.start_pos <= pos <= c.end_pos:
if c.type not in ('decorated', 'simple_stmt', 'suite') \
and not isinstance(c, (Flow, ClassOrFunc)):
return c
else:
try:
return c.get_statement_for_position(pos)
except AttributeError:
pass # Must be a non-scope
return None
class PythonLeaf(Leaf, PythonMixin): class PythonLeaf(Leaf, PythonMixin):
__slots__ = () __slots__ = ()

View File

@@ -82,3 +82,16 @@ def get_flow_branch_keyword(flow_node, node):
if first_leaf in _FLOW_KEYWORDS: if first_leaf in _FLOW_KEYWORDS:
keyword = first_leaf keyword = first_leaf
return 0 return 0
def get_statement_of_position(node, pos):
for c in node.children:
if c.start_pos <= pos <= c.end_pos:
if c.type not in ('decorated', 'simple_stmt', 'suite') \
and not isinstance(c, (tree.Flow, tree.ClassOrFunc)):
return c
else:
try:
return get_statement_of_position(c, pos)
except AttributeError:
pass # Must be a non-scope
return None

View File

@@ -9,6 +9,7 @@ from jedi._compatibility import u, is_py3
from jedi.parser.python import parse, load_grammar from jedi.parser.python import parse, load_grammar
from jedi.parser.python import tree from jedi.parser.python import tree
from jedi.common import splitlines from jedi.common import splitlines
from jedi.parser_utils import get_statement_of_position
def test_user_statement_on_import(): def test_user_statement_on_import():
@@ -18,7 +19,7 @@ def test_user_statement_on_import():
for pos in [(2, 1), (2, 4)]: for pos in [(2, 1), (2, 4)]:
p = parse(s) p = parse(s)
stmt = p.get_statement_for_position(pos) stmt = get_statement_of_position(p, pos)
assert isinstance(stmt, tree.Import) assert isinstance(stmt, tree.Import)
assert [n.value for n in stmt.get_defined_names()] == ['time'] assert [n.value for n in stmt.get_defined_names()] == ['time']