summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2011-09-15 17:38:54 (GMT)
committerVictor Stinner <victor.stinner@haypocalc.com>2011-09-15 17:38:54 (GMT)
commit84b8e40fd7229303ddc76f13b33f5fa00687de2a (patch)
tree2ad6e07598d4d59f1c834360f220ceeccd5aa4a7 /Python
parent37ccd6f794539e0678b7a7ad938e571cc73e106c (diff)
parent1619132e5dba825cdfae200cf619470129116c3d (diff)
downloadcpython-84b8e40fd7229303ddc76f13b33f5fa00687de2a.zip
cpython-84b8e40fd7229303ddc76f13b33f5fa00687de2a.tar.gz
cpython-84b8e40fd7229303ddc76f13b33f5fa00687de2a.tar.bz2
Merge 3.2: Fix the import machinery if there is an error on sys.path or sys.meta_path
find_module() now raises a RuntimeError, instead of ImportError, on an error on sys.path or sys.meta_path because load_package() and import_submodule() returns None and clear the exception if a ImportError occurred.
Diffstat (limited to 'Python')
-rw-r--r--Python/import.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/Python/import.c b/Python/import.c
index 1411248..7902721 100644
--- a/Python/import.c
+++ b/Python/import.c
@@ -1992,7 +1992,7 @@ find_module(PyObject *fullname, PyObject *name, PyObject *search_path_list,
meta_path = PySys_GetObject("meta_path");
if (meta_path == NULL || !PyList_Check(meta_path)) {
- PyErr_SetString(PyExc_ImportError,
+ PyErr_SetString(PyExc_RuntimeError,
"sys.meta_path must be a list of "
"import hooks");
return NULL;
@@ -2044,14 +2044,14 @@ find_module(PyObject *fullname, PyObject *name, PyObject *search_path_list,
}
if (search_path_list == NULL || !PyList_Check(search_path_list)) {
- PyErr_SetString(PyExc_ImportError,
+ PyErr_SetString(PyExc_RuntimeError,
"sys.path must be a list of directory names");
return NULL;
}
path_hooks = PySys_GetObject("path_hooks");
if (path_hooks == NULL || !PyList_Check(path_hooks)) {
- PyErr_SetString(PyExc_ImportError,
+ PyErr_SetString(PyExc_RuntimeError,
"sys.path_hooks must be a list of "
"import hooks");
return NULL;
@@ -2059,7 +2059,7 @@ find_module(PyObject *fullname, PyObject *name, PyObject *search_path_list,
path_importer_cache = PySys_GetObject("path_importer_cache");
if (path_importer_cache == NULL ||
!PyDict_Check(path_importer_cache)) {
- PyErr_SetString(PyExc_ImportError,
+ PyErr_SetString(PyExc_RuntimeError,
"sys.path_importer_cache must be a dict");
return NULL;
}