diff options
author | Guido van Rossum <guido@python.org> | 2007-07-23 03:16:50 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2007-07-23 03:16:50 (GMT) |
commit | 13d7799f87ac3da61dfb3437b0768cfedc1d763b (patch) | |
tree | a239946cdc183af43176c0a18aa6a6ee5c410931 | |
parent | 3698746585c1e06d43f231da51175dabba35250f (diff) | |
download | cpython-13d7799f87ac3da61dfb3437b0768cfedc1d763b.zip cpython-13d7799f87ac3da61dfb3437b0768cfedc1d763b.tar.gz cpython-13d7799f87ac3da61dfb3437b0768cfedc1d763b.tar.bz2 |
Fix import of frozen package submodules to use Unicode. Fixes test_frozen.
-rw-r--r-- | Python/import.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/Python/import.c b/Python/import.c index cd76fa2..25c768f 100644 --- a/Python/import.c +++ b/Python/import.c @@ -1188,15 +1188,16 @@ find_module(char *fullname, char *subname, PyObject *path, char *buf, Py_DECREF(meta_path); } - if (path != NULL && PyString_Check(path)) { + if (path != NULL && PyUnicode_Check(path)) { /* The only type of submodule allowed inside a "frozen" package are other frozen modules or packages. */ - if (PyString_Size(path) + 1 + strlen(name) >= (size_t)buflen) { + char *p = PyUnicode_AsString(path); + if (strlen(p) + 1 + strlen(name) >= (size_t)buflen) { PyErr_SetString(PyExc_ImportError, "full frozen module name too long"); return NULL; } - strcpy(buf, PyString_AsString(path)); + strcpy(buf, p); strcat(buf, "."); strcat(buf, name); strcpy(name, buf); |