Commit 3e2b8eb3 authored by Marius Wachtler's avatar Marius Wachtler

imp.find_module should not call into sys.meta_path & sys.path_hook

parent 3a81033b
...@@ -184,22 +184,25 @@ struct SearchResult { ...@@ -184,22 +184,25 @@ struct SearchResult {
SearchResult(Box* loader) : loader(loader), type(IMP_HOOK) {} SearchResult(Box* loader) : loader(loader), type(IMP_HOOK) {}
}; };
SearchResult findModule(const std::string& name, BoxedString* full_name, BoxedList* path_list) { SearchResult findModule(const std::string& name, BoxedString* full_name, BoxedList* path_list, bool call_import_hooks) {
static BoxedString* meta_path_str = internStringImmortal("meta_path");
BoxedList* meta_path = static_cast<BoxedList*>(sys_module->getattr(meta_path_str));
if (!meta_path || meta_path->cls != list_cls)
raiseExcHelper(RuntimeError, "sys.meta_path must be a list of import hooks");
static BoxedString* findmodule_str = internStringImmortal("find_module"); static BoxedString* findmodule_str = internStringImmortal("find_module");
for (int i = 0; i < meta_path->size; i++) {
Box* finder = meta_path->elts->elts[i];
auto path_pass = path_list ? path_list : None; if (call_import_hooks) {
CallattrFlags callattr_flags{.cls_only = false, .null_on_nonexistent = false, .argspec = ArgPassSpec(2) }; static BoxedString* meta_path_str = internStringImmortal("meta_path");
Box* loader = callattr(finder, findmodule_str, callattr_flags, full_name, path_pass, NULL, NULL, NULL); BoxedList* meta_path = static_cast<BoxedList*>(sys_module->getattr(meta_path_str));
if (!meta_path || meta_path->cls != list_cls)
raiseExcHelper(RuntimeError, "sys.meta_path must be a list of import hooks");
for (int i = 0; i < meta_path->size; i++) {
Box* finder = meta_path->elts->elts[i];
auto path_pass = path_list ? path_list : None;
CallattrFlags callattr_flags{.cls_only = false, .null_on_nonexistent = false, .argspec = ArgPassSpec(2) };
Box* loader = callattr(finder, findmodule_str, callattr_flags, full_name, path_pass, NULL, NULL, NULL);
if (loader != None) if (loader != None)
return SearchResult(loader); return SearchResult(loader);
}
} }
if (!path_list) if (!path_list)
...@@ -240,15 +243,19 @@ SearchResult findModule(const std::string& name, BoxedString* full_name, BoxedLi ...@@ -240,15 +243,19 @@ SearchResult findModule(const std::string& name, BoxedString* full_name, BoxedLi
llvm::sys::path::append(joined_path, "__init__.py"); llvm::sys::path::append(joined_path, "__init__.py");
std::string fn(joined_path.str()); std::string fn(joined_path.str());
PyObject* importer = get_path_importer(path_importer_cache, path_hooks, _p); if (call_import_hooks) {
if (importer == NULL) PyObject* importer = get_path_importer(path_importer_cache, path_hooks, _p);
throwCAPIException(); if (importer == NULL)
throwCAPIException();
if (importer != None) { if (importer != None) {
CallattrFlags callattr_flags{.cls_only = false, .null_on_nonexistent = false, .argspec = ArgPassSpec(1) }; CallattrFlags callattr_flags{.cls_only = false,
Box* loader = callattr(importer, findmodule_str, callattr_flags, full_name, NULL, NULL, NULL, NULL); .null_on_nonexistent = false,
if (loader != None) .argspec = ArgPassSpec(1) };
return SearchResult(loader); Box* loader = callattr(importer, findmodule_str, callattr_flags, full_name, NULL, NULL, NULL, NULL);
if (loader != None)
return SearchResult(loader);
}
} }
if (pathExists(fn)) if (pathExists(fn))
...@@ -405,7 +412,7 @@ static Box* importSub(const std::string& name, BoxedString* full_name, Box* pare ...@@ -405,7 +412,7 @@ static Box* importSub(const std::string& name, BoxedString* full_name, Box* pare
} }
} }
SearchResult sr = findModule(name, full_name, path_list); SearchResult sr = findModule(name, full_name, path_list, true /* call_import_hooks */);
if (sr.type != SearchResult::SEARCH_ERROR) { if (sr.type != SearchResult::SEARCH_ERROR) {
Box* module; Box* module;
...@@ -721,7 +728,7 @@ Box* impFindModule(Box* _name, BoxedList* path) { ...@@ -721,7 +728,7 @@ Box* impFindModule(Box* _name, BoxedList* path) {
BoxedString* name = static_cast<BoxedString*>(_name); BoxedString* name = static_cast<BoxedString*>(_name);
BoxedList* path_list = path && path != None ? path : getSysPath(); BoxedList* path_list = path && path != None ? path : getSysPath();
SearchResult sr = findModule(name->s(), name, path_list); SearchResult sr = findModule(name->s(), name, path_list, false /* call_import_hooks */);
if (sr.type == SearchResult::SEARCH_ERROR) if (sr.type == SearchResult::SEARCH_ERROR)
raiseExcHelper(ImportError, "%s", name->data()); raiseExcHelper(ImportError, "%s", name->data());
......
...@@ -42,18 +42,29 @@ except ImportError, e: ...@@ -42,18 +42,29 @@ except ImportError, e:
# So unfortunately we can't print out the error message. # So unfortunately we can't print out the error message.
print "caught import error 1" print "caught import error 1"
def ImportErrorPathHook(a):
print "ImportErrorPathHook", a
raise ImportError
sys.path_hooks.insert(0, ImportErrorPathHook)
sys.path_hooks.append(Finder2) sys.path_hooks.append(Finder2)
try: try:
import a.b.test import a.b.test
except ImportError, e: except ImportError, e:
print "caught import error 2" print "caught import error 2"
# this should not call into ImportErrorPathHook
try:
imp.find_module("foobar", ["/"])
except ImportError, e:
print "caught import error 3"
sys.path.append("/my_magic_directory") sys.path.append("/my_magic_directory")
try: try:
import a.b.test import a.b.test
except ImportError, e: except ImportError, e:
print "caught import error 3" print "caught import error 4"
sys.meta_path.append(Finder()) sys.meta_path.append(Finder())
import a import a
...@@ -62,3 +73,11 @@ import a.b.test as test ...@@ -62,3 +73,11 @@ import a.b.test as test
print test print test
import a.b as b import a.b as b
print b print b
class RecursiveLoader(object):
def find_module(self, name, path=None):
print "RecursiveLoader", name, path
imp.find_module(name, path)
return Loader()
sys.meta_path.insert(0, RecursiveLoader())
import subprocess
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