Kaydet (Commit) dc3c239b authored tarafından Benjamin Peterson's avatar Benjamin Peterson

#5037 proxy __unicode__ correctly

üst 9eac119b
...@@ -188,6 +188,17 @@ class ReferencesTestCase(TestBase): ...@@ -188,6 +188,17 @@ class ReferencesTestCase(TestBase):
self.assertEqual(L3[:5], p3[:5]) self.assertEqual(L3[:5], p3[:5])
self.assertEqual(L3[2:5], p3[2:5]) self.assertEqual(L3[2:5], p3[2:5])
def test_proxy_unicode(self):
# See bug 5037
class C(object):
def __str__(self):
return "string"
def __unicode__(self):
return u"unicode"
instance = C()
self.assertTrue("__unicode__" in dir(weakref.proxy(instance)))
self.assertEqual(unicode(weakref.proxy(instance)), u"unicode")
def test_proxy_index(self): def test_proxy_index(self):
class C: class C:
def __index__(self): def __index__(self):
......
...@@ -440,6 +440,9 @@ Core and Builtins ...@@ -440,6 +440,9 @@ Core and Builtins
Library Library
------- -------
- Issue #5037: Proxy the __unicode__ special method instead to __unicode__
instead of __str__.
- Issue #7341: Close the internal file object in the TarFile constructor in - Issue #7341: Close the internal file object in the TarFile constructor in
case of an error. case of an error.
......
...@@ -433,6 +433,13 @@ proxy_checkref(PyWeakReference *proxy) ...@@ -433,6 +433,13 @@ proxy_checkref(PyWeakReference *proxy)
return generic(proxy, v, w); \ return generic(proxy, v, w); \
} }
#define WRAP_METHOD(method, special) \
static PyObject * \
method(PyObject *proxy) { \
UNWRAP(proxy); \
return PyObject_CallMethod(proxy, special, ""); \
}
/* direct slots */ /* direct slots */
...@@ -593,6 +600,15 @@ proxy_iternext(PyWeakReference *proxy) ...@@ -593,6 +600,15 @@ proxy_iternext(PyWeakReference *proxy)
} }
WRAP_METHOD(proxy_unicode, "__unicode__");
static PyMethodDef proxy_methods[] = {
{"__unicode__", (PyCFunction)proxy_unicode, METH_NOARGS},
{NULL, NULL}
};
static PyNumberMethods proxy_as_number = { static PyNumberMethods proxy_as_number = {
proxy_add, /*nb_add*/ proxy_add, /*nb_add*/
proxy_sub, /*nb_subtract*/ proxy_sub, /*nb_subtract*/
...@@ -684,6 +700,7 @@ _PyWeakref_ProxyType = { ...@@ -684,6 +700,7 @@ _PyWeakref_ProxyType = {
0, /* tp_weaklistoffset */ 0, /* tp_weaklistoffset */
(getiterfunc)proxy_iter, /* tp_iter */ (getiterfunc)proxy_iter, /* tp_iter */
(iternextfunc)proxy_iternext, /* tp_iternext */ (iternextfunc)proxy_iternext, /* tp_iternext */
proxy_methods, /* tp_methods */
}; };
......
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