]> granicus.if.org Git - python/commitdiff
the nb_long slot on classobject instances now defaults to call the nb_int slot member...
authorKristján Valur Jónsson <kristjan@ccpgames.com>
Mon, 7 May 2007 18:36:39 +0000 (18:36 +0000)
committerKristján Valur Jónsson <kristjan@ccpgames.com>
Mon, 7 May 2007 18:36:39 +0000 (18:36 +0000)
Objects/classobject.c

index 8560b6842cec2213488ee0c1796ce9a1c1785069..89cca5969df506d713f5b47d0e8496c76e535210 100644 (file)
@@ -1539,6 +1539,18 @@ static PyObject *funcname(PyInstanceObject *self) { \
        return generic_unary_op(self, o); \
 }
 
+/* unary function with a fallback */
+#define UNARY_FB(funcname, methodname, funcname_fb) \
+static PyObject *funcname(PyInstanceObject *self) { \
+       static PyObject *o; \
+       if (o == NULL) { o = PyString_InternFromString(methodname); \
+                        if (o == NULL) return NULL; } \
+       if (PyObject_HasAttr((PyObject*)self, o)) \
+               return generic_unary_op(self, o); \
+       else \
+               return funcname_fb(self); \
+}
+
 #define BINARY(f, m, n) \
 static PyObject *f(PyObject *v, PyObject *w) { \
        return do_binop(v, w, "__" m "__", "__r" m "__", n); \
@@ -1777,7 +1789,7 @@ instance_index(PyInstanceObject *self)
 
 UNARY(instance_invert, "__invert__")
 UNARY(instance_int, "__int__")
-UNARY(instance_long, "__long__")
+UNARY_FB(instance_long, "__long__", instance_int)
 UNARY(instance_float, "__float__")
 UNARY(instance_oct, "__oct__")
 UNARY(instance_hex, "__hex__")