forked from VimPlug/jedi
combine power-or-atom_expr statements into one statement
This commit is contained in:
@@ -291,7 +291,7 @@ class Evaluator(object):
|
|||||||
types = set([element]) # TODO this is no real evaluation.
|
types = set([element]) # TODO this is no real evaluation.
|
||||||
elif element.type == 'expr_stmt':
|
elif element.type == 'expr_stmt':
|
||||||
types = self.eval_statement(element)
|
types = self.eval_statement(element)
|
||||||
elif element.type == 'power' or element.type == 'atom_expr':
|
elif element.type in ('power', 'atom_expr'):
|
||||||
types = self._eval_atom(element.children[0])
|
types = self._eval_atom(element.children[0])
|
||||||
for trailer in element.children[1:]:
|
for trailer in element.children[1:]:
|
||||||
if trailer == '**': # has a power operation.
|
if trailer == '**': # has a power operation.
|
||||||
|
|||||||
@@ -174,7 +174,7 @@ def _check_for_exception_catch(evaluator, jedi_obj, exception, payload=None):
|
|||||||
def check_hasattr(node, suite):
|
def check_hasattr(node, suite):
|
||||||
try:
|
try:
|
||||||
assert suite.start_pos <= jedi_obj.start_pos < suite.end_pos
|
assert suite.start_pos <= jedi_obj.start_pos < suite.end_pos
|
||||||
assert node.type == 'power' or node.type == 'atom_expr'
|
assert node.type in ('power', 'atom_expr')
|
||||||
base = node.children[0]
|
base = node.children[0]
|
||||||
assert base.type == 'name' and base.value == 'hasattr'
|
assert base.type == 'name' and base.value == 'hasattr'
|
||||||
trailer = node.children[1]
|
trailer = node.children[1]
|
||||||
|
|||||||
@@ -89,8 +89,7 @@ def search_function_call(evaluator, func):
|
|||||||
parent = parent.parent
|
parent = parent.parent
|
||||||
|
|
||||||
trailer = None
|
trailer = None
|
||||||
if tree.is_node(parent, 'power') or \
|
if tree.is_node(parent, 'power', 'atom_expr'):
|
||||||
tree.is_node(parent, 'atom_expr'):
|
|
||||||
for t in parent.children[1:]:
|
for t in parent.children[1:]:
|
||||||
if t == '**':
|
if t == '**':
|
||||||
break
|
break
|
||||||
|
|||||||
@@ -448,7 +448,7 @@ def check_flow_information(evaluator, flow, search_name, pos):
|
|||||||
|
|
||||||
def _check_isinstance_type(evaluator, element, search_name):
|
def _check_isinstance_type(evaluator, element, search_name):
|
||||||
try:
|
try:
|
||||||
assert element.type == 'power' or element.type == 'atom_expr'
|
assert element.type in ('power', 'atom_expr')
|
||||||
# this might be removed if we analyze and, etc
|
# this might be removed if we analyze and, etc
|
||||||
assert len(element.children) == 2
|
assert len(element.children) == 2
|
||||||
first, trailer = element.children
|
first, trailer = element.children
|
||||||
|
|||||||
@@ -88,7 +88,7 @@ def call_of_name(name, cut_own_trailer=False):
|
|||||||
return name
|
return name
|
||||||
|
|
||||||
power = par.parent
|
power = par.parent
|
||||||
if (tree.is_node(power, 'power') or tree.is_node(power, 'atom_expr')) \
|
if tree.is_node(power, 'power', 'atom_expr') \
|
||||||
and power.children[0] != name \
|
and power.children[0] != name \
|
||||||
and not (power.children[-2] == '**' and
|
and not (power.children[-2] == '**' and
|
||||||
name.start_pos > power.children[-1].start_pos):
|
name.start_pos > power.children[-1].start_pos):
|
||||||
|
|||||||
@@ -1342,7 +1342,7 @@ def _defined_names(current):
|
|||||||
names += _defined_names(child)
|
names += _defined_names(child)
|
||||||
elif is_node(current, 'atom'):
|
elif is_node(current, 'atom'):
|
||||||
names += _defined_names(current.children[1])
|
names += _defined_names(current.children[1])
|
||||||
elif is_node(current, 'power') or is_node(current, 'atom_expr'):
|
elif is_node(current, 'power', 'atom_expr'):
|
||||||
if current.children[-2] != '**': # Just if there's no operation
|
if current.children[-2] != '**': # Just if there's no operation
|
||||||
trailer = current.children[-1]
|
trailer = current.children[-1]
|
||||||
if trailer.children[0] == '.':
|
if trailer.children[0] == '.':
|
||||||
|
|||||||
Reference in New Issue
Block a user