Skip to content

Commit

Permalink
Catch an additional case for get_context where the cursor is e.g. on …
Browse files Browse the repository at this point in the history
…the function name
  • Loading branch information
davidhalter committed Dec 22, 2019
1 parent fcf8506 commit f2a64e2
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 5 deletions.
17 changes: 14 additions & 3 deletions jedi/api/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -420,14 +420,25 @@ def find_signatures(self, line=None, column=None):

@validate_line_column
def get_context(self, line=None, column=None):
leaf = self._module_node.get_leaf_for_position((line, column), include_prefixes=True)
if leaf.start_pos > (line, column) or leaf.type == 'endmarker':
pos = (line, column)
leaf = self._module_node.get_leaf_for_position(pos, include_prefixes=True)
if leaf.start_pos > pos or leaf.type == 'endmarker':
previous_leaf = leaf.get_previous_leaf()
if previous_leaf is not None:
leaf = previous_leaf

module_context = self._get_module_context()
context = module_context.create_context(leaf)

n = tree.search_ancestor(leaf, 'funcdef', 'classdef')
if n is not None and n.start_pos < pos <= n.children[-1].start_pos:
# This is a bit of a special case. The context of a function/class
# name/param/keyword is always it's parent context, not the
# function itself. Catch all the cases here where we are before the
# suite object, but still in the function.
context = module_context.create_value(n).as_context()
else:
context = module_context.create_context(leaf)

while context.name is None:
context = context.parent_context # comprehensions

Expand Down
6 changes: 4 additions & 2 deletions test/test_api/test_context.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,9 @@ def x():
(func_code, 1, 0, 'myfile', []),
(func_code, 1, None, 'myfile.func1', ['func1']),
#(func_code, 1, 4, 'myfile.func1', ['func1']),
#(func_code, 1, 10, 'myfile.func1', ['func1']),
(func_code, 1, 1, 'myfile.func1', ['func1']),
(func_code, 1, 4, 'myfile.func1', ['func1']),
(func_code, 1, 10, 'myfile.func1', ['func1']),
(func_code, 3, 0, 'myfile', []),
(func_code, 5, None, 'myfile.func2', ['func2']),
Expand All @@ -84,6 +85,7 @@ def x():
(cls_code, 4, 5, 'myfile.Foo.x', ['Foo', 'x']),
(cls_code, 4, 8, 'myfile.Foo.x', ['Foo', 'x']),
(cls_code, 4, 12, None, ['Foo', 'x', 'y']),
(cls_code, 1, 1, 'myfile.Foo', ['Foo']),
(cls_nested, 4, None, 'myfile.C.D.f', ['C', 'D', 'f']),
(cls_nested, 4, 3, 'myfile.C', ['C']),
Expand Down

0 comments on commit f2a64e2

Please sign in to comment.