mirror of
https://github.com/python/cpython.git
synced 2025-08-03 00:23:06 +00:00
Merged revisions 72461 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r72461 | benjamin.peterson | 2009-05-07 22:06:00 -0500 (Thu, 07 May 2009) | 1 line add _PyObject_LookupSpecial to handle fetching special method lookup ........
This commit is contained in:
parent
c04dad772c
commit
224205fde2
4 changed files with 63 additions and 9 deletions
|
@ -474,12 +474,6 @@ PyObject_Bytes(PyObject *v)
|
|||
PyObject *result, *func;
|
||||
static PyObject *bytesstring = NULL;
|
||||
|
||||
if (bytesstring == NULL) {
|
||||
bytesstring = PyUnicode_InternFromString("__bytes__");
|
||||
if (bytesstring == NULL)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
if (v == NULL)
|
||||
return PyBytes_FromString("<NULL>");
|
||||
|
||||
|
@ -488,10 +482,10 @@ PyObject_Bytes(PyObject *v)
|
|||
return v;
|
||||
}
|
||||
|
||||
/* Doesn't create a reference */
|
||||
func = _PyType_Lookup(Py_TYPE(v), bytesstring);
|
||||
func = _PyObject_LookupSpecial(v, "__bytes__", &bytesstring);
|
||||
if (func != NULL) {
|
||||
result = PyObject_CallFunctionObjArgs(func, v, NULL);
|
||||
Py_DECREF(func);
|
||||
if (result == NULL)
|
||||
return NULL;
|
||||
if (!PyBytes_Check(result)) {
|
||||
|
@ -503,7 +497,6 @@ PyObject_Bytes(PyObject *v)
|
|||
}
|
||||
return result;
|
||||
}
|
||||
PyErr_Clear();
|
||||
return PyBytes_FromObject(v);
|
||||
}
|
||||
|
||||
|
|
|
@ -1125,6 +1125,8 @@ PyType_IsSubtype(PyTypeObject *a, PyTypeObject *b)
|
|||
when the _PyType_Lookup() call fails;
|
||||
|
||||
- lookup_method() always raises an exception upon errors.
|
||||
|
||||
- _PyObject_LookupSpecial() exported for the benefit of other places.
|
||||
*/
|
||||
|
||||
static PyObject *
|
||||
|
@ -1157,6 +1159,12 @@ lookup_method(PyObject *self, char *attrstr, PyObject **attrobj)
|
|||
return res;
|
||||
}
|
||||
|
||||
PyObject *
|
||||
_PyObject_LookupSpecial(PyObject *self, char *attrstr, PyObject **attrobj)
|
||||
{
|
||||
return lookup_maybe(self, attrstr, attrobj);
|
||||
}
|
||||
|
||||
/* A variation of PyObject_CallMethod that uses lookup_method()
|
||||
instead of PyObject_GetAttrString(). This uses the same convention
|
||||
as lookup_method to cache the interned name string object. */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue