From bbbd4fdba2c9589588410a4d1727c031234fc2a6 Mon Sep 17 00:00:00 2001 From: Guido van Rossum Date: Thu, 17 May 2007 21:15:39 +0000 Subject: Make test_new pass. --- Lib/test/test_new.py | 2 +- Objects/funcobject.c | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/Lib/test/test_new.py b/Lib/test/test_new.py index 797a8c3..c919621 100644 --- a/Lib/test/test_new.py +++ b/Lib/test/test_new.py @@ -143,7 +143,7 @@ class NewTest(unittest.TestCase): firstlineno, lnotab) # new.code used to be a way to mutate a tuple... - class S(str): + class S(str8): pass t = (S("ab"),) d = new.code(argcount, kwonlyargcount, nlocals, stacksize, diff --git a/Objects/funcobject.c b/Objects/funcobject.c index adbb6d5..0069fc1 100644 --- a/Objects/funcobject.c +++ b/Objects/funcobject.c @@ -482,6 +482,11 @@ func_new(PyTypeObject* type, PyObject* args, PyObject* kw) &PyDict_Type, &globals, &name, &defaults, &closure)) return NULL; + if (PyUnicode_Check(name)) { + name = _PyUnicode_AsDefaultEncodedString(name, NULL); + if (name == NULL) + return NULL; + } if (name != Py_None && !PyString_Check(name)) { PyErr_SetString(PyExc_TypeError, "arg 3 (name) must be None or string"); -- cgit v0.12