mirror of
https://github.com/python/cpython.git
synced 2025-08-23 10:16:01 +00:00
Patch #1272, by Christian Heimes and Alexandre Vassalotti.
Changes to make __file__ a proper Unicode object, using the default filesystem encoding. This is a bit tricky because the default filesystem encoding isn't set by the time we import the first modules; at that point we fudge things a bit. This is okay since __file__ isn't really used much except for error reporting. Tested on OSX and Linux only so far.
This commit is contained in:
parent
cdadf242ba
commit
00bc0e0a2d
17 changed files with 96 additions and 41 deletions
|
@ -50,6 +50,7 @@ PyCode_New(int argcount, int kwonlyargcount,
|
|||
{
|
||||
PyCodeObject *co;
|
||||
Py_ssize_t i;
|
||||
|
||||
/* Check argument types */
|
||||
if (argcount < 0 || nlocals < 0 ||
|
||||
code == NULL ||
|
||||
|
@ -58,20 +59,16 @@ PyCode_New(int argcount, int kwonlyargcount,
|
|||
varnames == NULL || !PyTuple_Check(varnames) ||
|
||||
freevars == NULL || !PyTuple_Check(freevars) ||
|
||||
cellvars == NULL || !PyTuple_Check(cellvars) ||
|
||||
name == NULL || (!PyString_Check(name) && !PyUnicode_Check(name)) ||
|
||||
filename == NULL || !PyString_Check(filename) ||
|
||||
name == NULL || !PyUnicode_Check(name) ||
|
||||
filename == NULL || !PyUnicode_Check(filename) ||
|
||||
lnotab == NULL || !PyString_Check(lnotab) ||
|
||||
!PyObject_CheckReadBuffer(code)) {
|
||||
PyErr_BadInternalCall();
|
||||
return NULL;
|
||||
}
|
||||
if (PyString_Check(name)) {
|
||||
name = PyUnicode_FromString(PyString_AS_STRING(name));
|
||||
if (name == NULL)
|
||||
return NULL;
|
||||
} else {
|
||||
Py_INCREF(name);
|
||||
}
|
||||
Py_INCREF(name);
|
||||
Py_INCREF(filename);
|
||||
|
||||
intern_strings(names);
|
||||
intern_strings(varnames);
|
||||
intern_strings(freevars);
|
||||
|
@ -299,8 +296,8 @@ code_repr(PyCodeObject *co)
|
|||
|
||||
if (co->co_firstlineno != 0)
|
||||
lineno = co->co_firstlineno;
|
||||
if (co->co_filename && PyString_Check(co->co_filename))
|
||||
filename = PyString_AS_STRING(co->co_filename);
|
||||
if (co->co_filename && PyUnicode_Check(co->co_filename))
|
||||
filename = PyUnicode_AsString(co->co_filename);
|
||||
return PyUnicode_FromFormat(
|
||||
"<code object %.100U at %p, file \"%.300s\", line %d>",
|
||||
co->co_name, co, filename, lineno);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue