summaryrefslogtreecommitdiff
path: root/Python/import.c
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2011-10-25 00:21:02 +0200
committerAntoine Pitrou <solipsis@pitrou.net>2011-10-25 00:21:02 +0200
commit9ab76944255d2498c50789b1d0582aec1e417ad9 (patch)
treede0a5a136dc2948b989e0f35e9357ea7efb62656 /Python/import.c
parent348c2a557a7175eaa86a510099bf6c0355142074 (diff)
downloadcpython-9ab76944255d2498c50789b1d0582aec1e417ad9.tar.gz
Fix test_imp failure under Windows
Diffstat (limited to 'Python/import.c')
-rw-r--r--Python/import.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/Python/import.c b/Python/import.c
index e21ae39359..3842c63c2e 100644
--- a/Python/import.c
+++ b/Python/import.c
@@ -938,12 +938,19 @@ make_compiled_pathname(PyObject *pathstr, int debug)
Py_ssize_t pycache_len = sizeof(CACHEDIR) - 1;
int kind;
void *data;
+ Py_UCS4 lastsep;
/* Compute the output string size. */
len = PyUnicode_GET_LENGTH(pathstr);
/* If there is no separator, this returns -1, so
- lastsep will be 0. */
+ fname will be 0. */
fname = rightmost_sep_obj(pathstr, 0, len) + 1;
+ /* Windows: re-use the last separator character (/ or \\) when
+ appending the __pycache__ path. */
+ if (fname > 0)
+ lastsep = PyUnicode_READ_CHAR(pathstr, fname -1);
+ else
+ lastsep = SEP;
ext = fname - 1;
for(i = fname; i < len; i++)
if (PyUnicode_READ_CHAR(pathstr, i) == '.')
@@ -965,7 +972,7 @@ make_compiled_pathname(PyObject *pathstr, int debug)
pos = fname;
for (i = 0; i < pycache_len; i++)
PyUnicode_WRITE(kind, data, pos++, CACHEDIR[i]);
- PyUnicode_WRITE(kind, data, pos++, SEP);
+ PyUnicode_WRITE(kind, data, pos++, lastsep);
PyUnicode_CopyCharacters(result, pos, pathstr,
fname, ext - fname);
pos += ext - fname;