Commit 556d8001 authored by Benjamin Peterson's avatar Benjamin Peterson

Merged revisions 81380 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r81380 | brett.cannon | 2010-05-20 13:37:55 -0500 (Thu, 20 May 2010) | 8 lines

  Turned out that if you used explicit relative import syntax
  (e.g. from .os import sep) and it failed, import would still try the implicit
  relative import semantics of an absolute import (from os import sep). That's
  not right, so when level is negative, only do explicit relative import
  semantics.

  Fixes issue #7902. Thanks to Meador Inge for the patch.
........
parent d7c3ed54
...@@ -468,6 +468,17 @@ class RelativeImportTests(unittest.TestCase): ...@@ -468,6 +468,17 @@ class RelativeImportTests(unittest.TestCase):
ns = dict(__package__=object()) ns = dict(__package__=object())
self.assertRaises(ValueError, check_relative) self.assertRaises(ValueError, check_relative)
def test_absolute_import_without_future(self):
# If absolute import syntax is used, then do not try to perform
# a relative import in the face of failure.
# Issue #7902.
try:
from .os import sep
except ImportError:
pass
else:
self.fail("explicit relative import triggered an "
"implicit relative import")
class OverridingImportBuiltinTests(unittest.TestCase): class OverridingImportBuiltinTests(unittest.TestCase):
def test_override_builtin(self): def test_override_builtin(self):
......
...@@ -2385,7 +2385,8 @@ import_module_level(char *name, PyObject *globals, PyObject *locals, ...@@ -2385,7 +2385,8 @@ import_module_level(char *name, PyObject *globals, PyObject *locals,
if (parent == NULL) if (parent == NULL)
return NULL; return NULL;
head = load_next(parent, Py_None, &name, buf, &buflen); head = load_next(parent, level < 0 ? Py_None : parent, &name, buf,
&buflen);
if (head == NULL) if (head == NULL)
return NULL; return NULL;
......
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