diff options
author | Benjamin Peterson <benjamin@python.org> | 2012-02-24 11:49:07 -0500 |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2012-02-24 11:49:07 -0500 |
commit | c6fbf47b28173c7bbac9a9e19201876d945859d3 (patch) | |
tree | 8bfa5742c45c72766c61f80c875abd6c34652902 | |
parent | 6eaaeff00e43fe86ea2b832fdb9bf497eab742f7 (diff) | |
parent | 625cd23da4e760311bd81d8f3f7edba809e981d8 (diff) | |
download | cpython-git-c6fbf47b28173c7bbac9a9e19201876d945859d3.tar.gz |
merge heads
-rw-r--r-- | Lib/importlib/_bootstrap.py | 16 |
1 files changed, 5 insertions, 11 deletions
diff --git a/Lib/importlib/_bootstrap.py b/Lib/importlib/_bootstrap.py index d880d31aac..de3df2ebed 100644 --- a/Lib/importlib/_bootstrap.py +++ b/Lib/importlib/_bootstrap.py @@ -890,17 +890,11 @@ class _ImportLockContext: def _resolve_name(name, package, level): """Resolve a relative module name to an absolute one.""" - dot = len(package) - for x in range(level, 1, -1): - try: - dot = package.rindex('.', 0, dot) - except ValueError: - raise ValueError("attempted relative import beyond " - "top-level package") - if name: - return "{0}.{1}".format(package[:dot], name) - else: - return package[:dot] + bits = package.rsplit('.', level-1) + if len(bits) < level: + raise ValueError('attempted relative import beyond top-level package') + base = bits[0] + return '{0}.{1}'.format(base, name) if name else base def _find_module(name, path): |