mirror of
https://github.com/python/cpython.git
synced 2025-10-27 16:57:08 +00:00
SF patch #1438387, PEP 328: relative and absolute imports.
- IMPORT_NAME takes an extra argument from the stack: the relativeness of the import. Only passed to __import__ when it's not -1. - __import__() takes an optional 5th argument for the same thing; it __defaults to -1 (old semantics: try relative, then absolute) - 'from . import name' imports name (be it module or regular attribute) from the current module's *package*. Likewise, 'from .module import name' will import name from a sibling to the current module. - Importing from outside a package is not allowed; 'from . import sys' in a toplevel module will not work, nor will 'from .. import sys' in a (single-level) package. - 'from __future__ import absolute_import' will turn on the new semantics for import and from-import: imports will be absolute, except for from-import with dots. Includes tests for regular imports and importhooks, parser changes and a NEWS item, but no compiler-package changes or documentation changes.
This commit is contained in:
parent
d3188639c3
commit
f7f438ba3b
20 changed files with 270 additions and 73 deletions
|
|
@ -513,34 +513,45 @@ static arc arcs_26_0[1] = {
|
|||
{74, 1},
|
||||
};
|
||||
static arc arcs_26_1[2] = {
|
||||
{75, 1},
|
||||
{12, 2},
|
||||
{75, 2},
|
||||
{12, 3},
|
||||
};
|
||||
static arc arcs_26_2[1] = {
|
||||
{72, 3},
|
||||
static arc arcs_26_2[3] = {
|
||||
{75, 4},
|
||||
{12, 3},
|
||||
{72, 5},
|
||||
};
|
||||
static arc arcs_26_3[3] = {
|
||||
{28, 4},
|
||||
{13, 5},
|
||||
{76, 4},
|
||||
static arc arcs_26_3[1] = {
|
||||
{72, 5},
|
||||
};
|
||||
static arc arcs_26_4[1] = {
|
||||
{0, 4},
|
||||
static arc arcs_26_4[2] = {
|
||||
{75, 4},
|
||||
{12, 3},
|
||||
};
|
||||
static arc arcs_26_5[1] = {
|
||||
static arc arcs_26_5[3] = {
|
||||
{28, 6},
|
||||
{13, 7},
|
||||
{76, 6},
|
||||
};
|
||||
static arc arcs_26_6[1] = {
|
||||
{15, 4},
|
||||
{0, 6},
|
||||
};
|
||||
static state states_26[7] = {
|
||||
static arc arcs_26_7[1] = {
|
||||
{76, 8},
|
||||
};
|
||||
static arc arcs_26_8[1] = {
|
||||
{15, 6},
|
||||
};
|
||||
static state states_26[9] = {
|
||||
{1, arcs_26_0},
|
||||
{2, arcs_26_1},
|
||||
{1, arcs_26_2},
|
||||
{3, arcs_26_3},
|
||||
{1, arcs_26_4},
|
||||
{1, arcs_26_5},
|
||||
{3, arcs_26_2},
|
||||
{1, arcs_26_3},
|
||||
{2, arcs_26_4},
|
||||
{3, arcs_26_5},
|
||||
{1, arcs_26_6},
|
||||
{1, arcs_26_7},
|
||||
{1, arcs_26_8},
|
||||
};
|
||||
static arc arcs_27_0[1] = {
|
||||
{19, 1},
|
||||
|
|
@ -1825,7 +1836,7 @@ static dfa dfas[84] = {
|
|||
"\000\000\000\000\000\000\000\000\000\005\000\000\000\000\000\000\000\000\000\000\000"},
|
||||
{281, "import_name", 0, 3, states_25,
|
||||
"\000\000\000\000\000\000\000\000\000\001\000\000\000\000\000\000\000\000\000\000\000"},
|
||||
{282, "import_from", 0, 7, states_26,
|
||||
{282, "import_from", 0, 9, states_26,
|
||||
"\000\000\000\000\000\000\000\000\000\004\000\000\000\000\000\000\000\000\000\000\000"},
|
||||
{283, "import_as_name", 0, 4, states_27,
|
||||
"\000\000\010\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000"},
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue