diff options
author | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2002-11-24 01:34:49 (GMT) |
---|---|---|
committer | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2002-11-24 01:34:49 (GMT) |
commit | b808c5cf2da088e66f43de61d3c5d741b134f419 (patch) | |
tree | 2c507444d7ecde345d8b0b4c3282f47ff6972b27 | |
parent | e6b49025c174bf283c12f5dccf992a11eedec3f0 (diff) | |
download | cpython-b808c5cf2da088e66f43de61d3c5d741b134f419.zip cpython-b808c5cf2da088e66f43de61d3c5d741b134f419.tar.gz cpython-b808c5cf2da088e66f43de61d3c5d741b134f419.tar.bz2 |
Simplify use of NB_BINOP and NB_TERNOP by making them do the pointer
dereference rather than the caller.
-rw-r--r-- | Objects/abstract.c | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/Objects/abstract.c b/Objects/abstract.c index 8845dce..5f98a4c 100644 --- a/Objects/abstract.c +++ b/Objects/abstract.c @@ -318,9 +318,9 @@ PyNumber_Check(PyObject *o) #define NB_SLOT(x) offsetof(PyNumberMethods, x) #define NB_BINOP(nb_methods, slot) \ - ((binaryfunc*)(& ((char*)nb_methods)[slot] )) + (*(binaryfunc*)(& ((char*)nb_methods)[slot])) #define NB_TERNOP(nb_methods, slot) \ - ((ternaryfunc*)(& ((char*)nb_methods)[slot] )) + (*(ternaryfunc*)(& ((char*)nb_methods)[slot])) /* Calling scheme used for binary operations: @@ -352,10 +352,10 @@ binary_op1(PyObject *v, PyObject *w, const int op_slot) binaryfunc slotw = NULL; if (v->ob_type->tp_as_number != NULL && NEW_STYLE_NUMBER(v)) - slotv = *NB_BINOP(v->ob_type->tp_as_number, op_slot); + slotv = NB_BINOP(v->ob_type->tp_as_number, op_slot); if (w->ob_type != v->ob_type && w->ob_type->tp_as_number != NULL && NEW_STYLE_NUMBER(w)) { - slotw = *NB_BINOP(w->ob_type->tp_as_number, op_slot); + slotw = NB_BINOP(w->ob_type->tp_as_number, op_slot); if (slotw == slotv) slotw = NULL; } @@ -387,7 +387,7 @@ binary_op1(PyObject *v, PyObject *w, const int op_slot) PyNumberMethods *mv = v->ob_type->tp_as_number; if (mv) { binaryfunc slot; - slot = *NB_BINOP(mv, op_slot); + slot = NB_BINOP(mv, op_slot); if (slot) { PyObject *x = slot(v, w); Py_DECREF(v); @@ -466,10 +466,10 @@ ternary_op(PyObject *v, mv = v->ob_type->tp_as_number; mw = w->ob_type->tp_as_number; if (mv != NULL && NEW_STYLE_NUMBER(v)) - slotv = *NB_TERNOP(mv, op_slot); + slotv = NB_TERNOP(mv, op_slot); if (w->ob_type != v->ob_type && mv != NULL && NEW_STYLE_NUMBER(w)) { - slotw = *NB_TERNOP(mw, op_slot); + slotw = NB_TERNOP(mw, op_slot); if (slotw == slotv) slotw = NULL; } @@ -494,7 +494,7 @@ ternary_op(PyObject *v, } mz = z->ob_type->tp_as_number; if (mz != NULL && NEW_STYLE_NUMBER(z)) { - slotz = *NB_TERNOP(mz, op_slot); + slotz = NB_TERNOP(mz, op_slot); if (slotz == slotv || slotz == slotw) slotz = NULL; if (slotz) { @@ -519,8 +519,8 @@ ternary_op(PyObject *v, treated as absent argument and not coerced. */ if (z == Py_None) { if (v->ob_type->tp_as_number) { - slotz = *NB_TERNOP(v->ob_type->tp_as_number, - op_slot); + slotz = NB_TERNOP(v->ob_type->tp_as_number, + op_slot); if (slotz) x = slotz(v, w, z); else @@ -542,8 +542,8 @@ ternary_op(PyObject *v, goto error1; if (v1->ob_type->tp_as_number != NULL) { - slotv = *NB_TERNOP(v1->ob_type->tp_as_number, - op_slot); + slotv = NB_TERNOP(v1->ob_type->tp_as_number, + op_slot); if (slotv) x = slotv(v1, w2, z2); else @@ -673,9 +673,9 @@ binary_iop(PyObject *v, PyObject *w, const int iop_slot, const int op_slot, { PyNumberMethods *mv = v->ob_type->tp_as_number; if (mv != NULL && HASINPLACE(v)) { - binaryfunc *slot = NB_BINOP(mv, iop_slot); - if (*slot) { - PyObject *x = (*slot)(v, w); + binaryfunc slot = NB_BINOP(mv, iop_slot); + if (slot) { + PyObject *x = (slot)(v, w); if (x != Py_NotImplemented) { return x; } |