diff options
author | Guido van Rossum <guido@python.org> | 2007-07-23 03:16:50 +0000 |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2007-07-23 03:16:50 +0000 |
commit | a9a1bf4df9d7c4cef572fcbda035af42b38d6b3a (patch) | |
tree | 622896c4a733e02c9550c1293cd69d71bf0adae0 | |
parent | 998640077665dc5a2cec87930cdeb56777ffff5d (diff) | |
download | cpython-a9a1bf4df9d7c4cef572fcbda035af42b38d6b3a.tar.gz |
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 cd76fa265b..25c768fea4 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); |