There's no need for typechecks on the second and third argument of
new.instancemethod() -- the instancemethod object is now a perfectly general container. This fixes SF bug ##503091 (Pedro Rodriquez): new.instancemethod fails for new classes This is a 2.2.1 candidate.
This commit is contained in:
parent
5e99731ab9
commit
4f3a62d9bc
|
@ -25,8 +25,7 @@ the object will be in a consistent state.
|
|||
\begin{funcdesc}{instancemethod}{function, instance, class}
|
||||
This function will return a method object, bound to \var{instance}, or
|
||||
unbound if \var{instance} is \code{None}. \var{function} must be
|
||||
callable, and \var{instance} must be an instance object or
|
||||
\code{None}.
|
||||
callable.
|
||||
\end{funcdesc}
|
||||
|
||||
\begin{funcdesc}{function}{code, globals\optional{, name\optional{, argdefs}}}
|
||||
|
|
|
@ -40,10 +40,8 @@ new_instancemethod(PyObject* unused, PyObject* args)
|
|||
PyObject* self;
|
||||
PyObject* classObj;
|
||||
|
||||
if (!PyArg_ParseTuple(args, "OOO!:instancemethod",
|
||||
&func,
|
||||
&self,
|
||||
&PyClass_Type, &classObj))
|
||||
if (!PyArg_ParseTuple(args, "OOO:instancemethod",
|
||||
&func, &self, &classObj))
|
||||
return NULL;
|
||||
if (!PyCallable_Check(func)) {
|
||||
PyErr_SetString(PyExc_TypeError,
|
||||
|
@ -52,11 +50,6 @@ new_instancemethod(PyObject* unused, PyObject* args)
|
|||
}
|
||||
if (self == Py_None)
|
||||
self = NULL;
|
||||
else if (!PyInstance_Check(self)) {
|
||||
PyErr_SetString(PyExc_TypeError,
|
||||
"second argument must be instance or None");
|
||||
return NULL;
|
||||
}
|
||||
return PyMethod_New(func, self, classObj);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue