Commit 7e586778 authored by Marius Wachtler's avatar Marius Wachtler

Merge pull request #1037 from LoyukiL/sys_path_unicode

Fix #599 by allowing subclasses of string and unicode in sys.path
parents 7fc37201 65388a29
...@@ -222,8 +222,15 @@ SearchResult findModule(const std::string& name, BoxedString* full_name, BoxedLi ...@@ -222,8 +222,15 @@ SearchResult findModule(const std::string& name, BoxedString* full_name, BoxedLi
llvm::SmallString<128> joined_path; llvm::SmallString<128> joined_path;
for (int i = 0; i < path_list->size; i++) { for (int i = 0; i < path_list->size; i++) {
Box* _p = path_list->elts->elts[i]; Box* _p = path_list->elts->elts[i];
if (_p->cls != str_cls) if (isSubclass(_p->cls, unicode_cls)) {
_p = PyUnicode_AsEncodedString(_p, Py_FileSystemDefaultEncoding, NULL);
if (_p == NULL) {
continue; continue;
}
}
if (!isSubclass(_p->cls, str_cls)) {
continue;
}
BoxedString* p = static_cast<BoxedString*>(_p); BoxedString* p = static_cast<BoxedString*>(_p);
joined_path.clear(); joined_path.clear();
...@@ -686,7 +693,7 @@ static int isdir(const char* path) { ...@@ -686,7 +693,7 @@ static int isdir(const char* path) {
Box* nullImporterInit(Box* self, Box* _path) { Box* nullImporterInit(Box* self, Box* _path) {
RELEASE_ASSERT(self->cls == null_importer_cls, ""); RELEASE_ASSERT(self->cls == null_importer_cls, "");
if (_path->cls != str_cls) if (!isSubclass(_path->cls, str_cls))
raiseExcHelper(TypeError, "must be string, not %s", getTypeName(_path)); raiseExcHelper(TypeError, "must be string, not %s", getTypeName(_path));
BoxedString* path = (BoxedString*)_path; BoxedString* path = (BoxedString*)_path;
......
import sys
sys.path.append("test_package")
import import_target
import sys
class TestClass(str):
pass
t = TestClass("test_package")
sys.path.append(t)
import import_target
import sys
sys.path.append(u"test_package")
import import_target
import sys
class TestClass(unicode):
pass
t = TestClass("test_package")
sys.path.append(t)
import import_target
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