mirror of
https://github.com/davidhalter/jedi.git
synced 2025-12-23 13:51:27 +08:00
Fix some of the newer call_signature tests.
This commit is contained in:
@@ -196,30 +196,38 @@ CallSignatureDetails = namedtuple(
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def _get_index_and_key(node, position):
|
||||||
|
"""
|
||||||
|
Returns the amount of commas and the keyword argument string.
|
||||||
|
"""
|
||||||
|
nodes_before = [c for c in node.children if c.start_pos < position]
|
||||||
|
if nodes_before[-1].type == 'arglist':
|
||||||
|
node = nodes_before[-1]
|
||||||
|
nodes_before = [c for c in node.children if c.start_pos < position]
|
||||||
|
|
||||||
|
key_str = None
|
||||||
|
|
||||||
|
if nodes_before:
|
||||||
|
last = nodes_before[-1]
|
||||||
|
print('xxxxx', last)
|
||||||
|
if last.type == 'argument' and last.children[1].end_pos <= position:
|
||||||
|
# Checked if the argument
|
||||||
|
key_str = last.children[0].value
|
||||||
|
elif last == '=':
|
||||||
|
key_str = nodes_before[-2].value
|
||||||
|
|
||||||
|
return nodes_before.count(','), key_str
|
||||||
|
|
||||||
|
|
||||||
def _get_call_signature_details_from_error_node(node, position):
|
def _get_call_signature_details_from_error_node(node, position):
|
||||||
for index, element in reversed(list(enumerate(node.children))):
|
for index, element in reversed(list(enumerate(node.children))):
|
||||||
# `index > 0` means that it's a trailer and not an atom.
|
# `index > 0` means that it's a trailer and not an atom.
|
||||||
if element == '(' and element.end_pos <= position and index > 0:
|
if element == '(' and element.end_pos <= position and index > 0:
|
||||||
name = element.get_previous_leaf()
|
name = element.get_previous_leaf()
|
||||||
if name.type == 'name':
|
if name.type == 'name':
|
||||||
if node.children[-1].type == 'arglist':
|
|
||||||
node = node.children[-1]
|
|
||||||
children = node.children
|
|
||||||
else:
|
|
||||||
# It's an error node, we don't want to match too much, just
|
|
||||||
# until the parentheses is enough.
|
|
||||||
children = node.children[index:]
|
|
||||||
nodes_before = [c for c in children if c.start_pos < position]
|
|
||||||
key_str = None
|
|
||||||
if nodes_before:
|
|
||||||
if nodes_before[-1].type == 'argument':
|
|
||||||
key_str = nodes_before[-1].children[0].value
|
|
||||||
elif nodes_before[-1] == '=':
|
|
||||||
key_str = nodes_before[-2].value
|
|
||||||
return CallSignatureDetails(
|
return CallSignatureDetails(
|
||||||
element,
|
element,
|
||||||
nodes_before.count(','),
|
*_get_index_and_key(node, position)
|
||||||
key_str
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@@ -245,8 +253,8 @@ def get_call_signature_details(module, position):
|
|||||||
|
|
||||||
if node.type == 'trailer' and node.children[0] == '(':
|
if node.type == 'trailer' and node.children[0] == '(':
|
||||||
leaf = node.get_previous_leaf()
|
leaf = node.get_previous_leaf()
|
||||||
nodes_before = [c for c in node.children if c.start_pos < position]
|
return CallSignatureDetails(
|
||||||
return CallSignatureDetails(node.children[0], nodes_before.count(','), None)
|
node.children[0], *_get_index_and_key(node, position))
|
||||||
|
|
||||||
node = node.parent
|
node = node.parent
|
||||||
|
|
||||||
|
|||||||
@@ -324,6 +324,15 @@ def test_keyword_argument_index():
|
|||||||
assert get('sorted([], key=').index == 2
|
assert get('sorted([], key=').index == 2
|
||||||
assert get('sorted([], no_key=a').index is None
|
assert get('sorted([], no_key=a').index is None
|
||||||
|
|
||||||
|
kw_func = 'def foo(a, b): pass\nfoo(b=3, a=4)'
|
||||||
|
assert get(kw_func, column=len('foo(b')).index == 0
|
||||||
|
assert get(kw_func, column=len('foo(b=')).index == 1
|
||||||
|
assert get(kw_func, column=len('foo(b=3, a=')).index == 0
|
||||||
|
|
||||||
|
kw_func_simple = 'def foo(a, b): pass\nfoo(b=4)'
|
||||||
|
assert get(kw_func_simple, column=len('foo(b')).index == 0
|
||||||
|
assert get(kw_func_simple, column=len('foo(b=')).index == 1
|
||||||
|
|
||||||
args_func = 'def foo(*kwargs): pass\n'
|
args_func = 'def foo(*kwargs): pass\n'
|
||||||
assert get(args_func + 'foo(a').index == 0
|
assert get(args_func + 'foo(a').index == 0
|
||||||
assert get(args_func + 'foo(a, b').index == 0
|
assert get(args_func + 'foo(a, b').index == 0
|
||||||
@@ -335,6 +344,7 @@ def test_keyword_argument_index():
|
|||||||
both = 'def foo(*args, **kwargs): pass\n'
|
both = 'def foo(*args, **kwargs): pass\n'
|
||||||
assert get(both + 'foo(a=2').index == 1
|
assert get(both + 'foo(a=2').index == 1
|
||||||
assert get(both + 'foo(a=2, b=2').index == 1
|
assert get(both + 'foo(a=2, b=2').index == 1
|
||||||
|
assert get(both + 'foo(a=2, b=2)', column=len('foo(b=2, a=2')).index == 1
|
||||||
assert get(both + 'foo(a, b, c').index == 0
|
assert get(both + 'foo(a, b, c').index == 0
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user