diff options
Diffstat (limited to 'checkers/variables.py')
| -rw-r--r-- | checkers/variables.py | 17 | 
1 files changed, 9 insertions, 8 deletions
| diff --git a/checkers/variables.py b/checkers/variables.py index 71b4be404..bcb5bb271 100644 --- a/checkers/variables.py +++ b/checkers/variables.py @@ -33,6 +33,7 @@ from pylint.checkers.utils import (      is_defined_before, is_error, is_func_default, is_func_decorator,      assign_parent, check_messages, is_inside_except, clobber_in_except,      get_all_elements, has_known_bases) +import six  SPECIAL_OBJ = re.compile("^_{2}[a-z]+_{2}$") @@ -45,7 +46,7 @@ def in_for_else_branch(parent, stmt):  def overridden_method(klass, name):      """get overridden method if any"""      try: -        parent = klass.local_attr_ancestors(name).next() +        parent = next(klass.local_attr_ancestors(name))      except (StopIteration, KeyError):          return None      try: @@ -145,7 +146,7 @@ def _fix_dot_imports(not_consumed):      """      # TODO: this should be improved in issue astroid #46      names = {} -    for name, stmts in not_consumed.iteritems(): +    for name, stmts in six.iteritems(not_consumed):          if any(isinstance(stmt, astroid.AssName)                 and isinstance(stmt.ass_type(), astroid.AugAssign)                 for stmt in stmts): @@ -296,7 +297,7 @@ builtins. Remember that you should avoid to define new builtins when possible.'          checks globals doesn't overrides builtins          """          self._to_consume = [(copy(node.locals), {}, 'module')] -        for name, stmts in node.locals.iteritems(): +        for name, stmts in six.iteritems(node.locals):              if is_builtin(name) and not is_inside_except(stmts[0]):                  # do not print Redefining builtin for additional builtins                  self.add_message('redefined-builtin', args=name, node=stmts[0]) @@ -311,11 +312,11 @@ builtins. Remember that you should avoid to define new builtins when possible.'          not_consumed = self._to_consume.pop()[0]          # attempt to check for __all__ if defined          if '__all__' in node.locals: -            assigned = node.igetattr('__all__').next() +            assigned = next(node.igetattr('__all__'))              if assigned is not astroid.YES:                  for elt in getattr(assigned, 'elts', ()):                      try: -                        elt_name = elt.infer().next() +                        elt_name = next(elt.infer())                      except astroid.InferenceError:                          continue @@ -503,7 +504,7 @@ builtins. Remember that you should avoid to define new builtins when possible.'          for nonlocal_stmt in node.nodes_of_class(astroid.Nonlocal):              nonlocal_names.update(set(nonlocal_stmt.names)) -        for name, stmts in not_consumed.iteritems(): +        for name, stmts in six.iteritems(not_consumed):              # ignore some special names specified by user configuration              if authorized_rgx.match(name):                  continue @@ -829,7 +830,7 @@ builtins. Remember that you should avoid to define new builtins when possible.'          for name, _ in node.names:              parts = name.split('.')              try: -                module = node.infer_name_module(parts[0]).next() +                module = next(node.infer_name_module(parts[0]))              except astroid.ResolveError:                  continue              self._check_module_attrs(node, module, parts[1:]) @@ -916,7 +917,7 @@ builtins. Remember that you should avoid to define new builtins when possible.'                  module = None                  break              try: -                module = module.getattr(name)[0].infer().next() +                module = next(module.getattr(name)[0].infer())                  if module is astroid.YES:                      return None              except astroid.NotFoundError: | 
