Commit b7a94dfd authored by Haoyu Bai's avatar Haoyu Bai Committed by Robert Bradshaw

add py2_import directive to control import level

parent cf7ae767
...@@ -1749,12 +1749,19 @@ class ImportNode(ExprNode): ...@@ -1749,12 +1749,19 @@ class ImportNode(ExprNode):
# 0: absolute import; # 0: absolute import;
# >0: the number of parent directories to search # >0: the number of parent directories to search
# relative to the current module. # relative to the current module.
# None: decide the level according to language level and
# directives
type = py_object_type type = py_object_type
subexprs = ['module_name', 'name_list'] subexprs = ['module_name', 'name_list']
def analyse_types(self, env): def analyse_types(self, env):
if self.level is None:
if env.directives['language_level'] < 3 or env.directives['py2_import']:
self.level = -1
else:
self.level = 0
self.module_name.analyse_types(env) self.module_name.analyse_types(env)
self.module_name = self.module_name.coerce_to_pyobject(env) self.module_name = self.module_name.coerce_to_pyobject(env)
if self.name_list: if self.name_list:
......
...@@ -81,6 +81,7 @@ directive_defaults = { ...@@ -81,6 +81,7 @@ directive_defaults = {
'autotestdict.all': False, 'autotestdict.all': False,
'language_level': 2, 'language_level': 2,
'fast_getattr': False, # Undocumented until we come up with a better way to handle this everywhere. 'fast_getattr': False, # Undocumented until we come up with a better way to handle this everywhere.
'py2_import': False, # For backward compatibility of Cython's source code
'warn': None, 'warn': None,
'warn.undeclared': False, 'warn.undeclared': False,
......
...@@ -1189,11 +1189,6 @@ def p_raise_statement(s): ...@@ -1189,11 +1189,6 @@ def p_raise_statement(s):
return Nodes.ReraiseStatNode(pos) return Nodes.ReraiseStatNode(pos)
def p_import_statement(s): def p_import_statement(s):
# will do absolute import in Py3 and try both relative and absolute in Py2.
if s.context.language_level >= 3:
level = 0
else:
level = -1
# s.sy in ('import', 'cimport') # s.sy in ('import', 'cimport')
pos = s.position() pos = s.position()
kind = s.sy kind = s.sy
...@@ -1221,7 +1216,7 @@ def p_import_statement(s): ...@@ -1221,7 +1216,7 @@ def p_import_statement(s):
rhs = ExprNodes.ImportNode(pos, rhs = ExprNodes.ImportNode(pos,
module_name = ExprNodes.IdentifierStringNode( module_name = ExprNodes.IdentifierStringNode(
pos, value = dotted_name), pos, value = dotted_name),
level = level, level = None,
name_list = name_list)) name_list = name_list))
stats.append(stat) stats.append(stat)
return Nodes.StatListNode(pos, stats = stats) return Nodes.StatListNode(pos, stats = stats)
...@@ -1236,18 +1231,16 @@ def p_from_import_statement(s, first_statement = 0): ...@@ -1236,18 +1231,16 @@ def p_from_import_statement(s, first_statement = 0):
while s.sy == '.': while s.sy == '.':
level += 1 level += 1
s.next() s.next()
if s.sy == 'cimport':
s.error("Relative cimport is not supported yet")
else: else:
# will do absolute import in Py3 and try both relative and absolute in Py2. level = None
if s.context.language_level >= 3: if level is not None and s.sy == 'import':
level = 0
else:
level = -1
if level > 0 and s.sy == 'cimport':
s.error("Relative cimport is not supported yet")
if level > 0 and s.sy == 'import':
# we are dealing with "from .. import foo, bar" # we are dealing with "from .. import foo, bar"
dotted_name_pos, dotted_name = s.position(), '' dotted_name_pos, dotted_name = s.position(), ''
elif level is not None and s.sy == 'cimport':
# "from .. cimport"
s.error("Relative cimport is not supported yet")
else: else:
(dotted_name_pos, _, dotted_name, _) = \ (dotted_name_pos, _, dotted_name, _) = \
p_dotted_name(s, as_allowed = 0) p_dotted_name(s, as_allowed = 0)
......
# cython: language_level=3 # cython: language_level=3
__name__='distutils.baregg' # fool Python we are in distutils import sys
# fool Python we are in distutils
if sys.version_info >= (3,):
__package__='distutils'
else:
__package__=b'distutils'
from distutils import cmd, core, version from distutils import cmd, core, version
from .core import * from .core import *
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment