Fix for copy-and-paste bugs in Id rich comparison. Also made code style clean-up.
This commit is contained in:
@@ -24,7 +24,7 @@ int Id_Init( PyObject *module )
|
|||||||
|
|
||||||
//------------------------INSTANCE METHODS ----------------------------------
|
//------------------------INSTANCE METHODS ----------------------------------
|
||||||
|
|
||||||
static char Id___doc__[] =
|
PyDoc_STRVAR(Id_doc,
|
||||||
".. method:: __init__()\n"
|
".. method:: __init__()\n"
|
||||||
"\n"
|
"\n"
|
||||||
" Default constructor.\n"
|
" Default constructor.\n"
|
||||||
@@ -50,9 +50,9 @@ static char Id___doc__[] =
|
|||||||
" :arg iFirst: The first Id number.\n"
|
" :arg iFirst: The first Id number.\n"
|
||||||
" :type iFirst: int\n"
|
" :type iFirst: int\n"
|
||||||
" :arg iSecond: The second Id number.\n"
|
" :arg iSecond: The second Id number.\n"
|
||||||
" :type iSecond: int\n";
|
" :type iSecond: int\n");
|
||||||
|
|
||||||
static int Id___init__(BPy_Id *self, PyObject *args, PyObject *kwds)
|
static int Id_init(BPy_Id *self, PyObject *args, PyObject *kwds)
|
||||||
{
|
{
|
||||||
int first = 0, second = 0;
|
int first = 0, second = 0;
|
||||||
static const char *kwlist[] = {"first", "second", NULL};
|
static const char *kwlist[] = {"first", "second", NULL};
|
||||||
@@ -65,24 +65,25 @@ static int Id___init__(BPy_Id *self, PyObject *args, PyObject *kwds)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Id___dealloc__(BPy_Id* self)
|
static void Id_dealloc(BPy_Id* self)
|
||||||
{
|
{
|
||||||
delete self->id;
|
delete self->id;
|
||||||
Py_TYPE(self)->tp_free((PyObject*)self);
|
Py_TYPE(self)->tp_free((PyObject*)self);
|
||||||
}
|
}
|
||||||
|
|
||||||
static PyObject * Id___repr__(BPy_Id* self)
|
static PyObject * Id_repr(BPy_Id* self)
|
||||||
{
|
{
|
||||||
return PyUnicode_FromFormat("[ first: %i, second: %i ](BPy_Id)", self->id->getFirst(), self->id->getSecond());
|
return PyUnicode_FromFormat("[ first: %i, second: %i ](BPy_Id)", self->id->getFirst(), self->id->getSecond());
|
||||||
}
|
}
|
||||||
|
|
||||||
static PyObject * Id_RichCompare(BPy_Id *o1, BPy_Id *o2, int opid) {
|
static PyObject * Id_RichCompare(BPy_Id *o1, BPy_Id *o2, int opid)
|
||||||
|
{
|
||||||
switch(opid){
|
switch(opid){
|
||||||
case Py_LT:
|
case Py_LT:
|
||||||
return PyBool_from_bool(o1->id->operator<(*(o2->id)));
|
return PyBool_from_bool(o1->id->operator<(*(o2->id)));
|
||||||
break;
|
break;
|
||||||
case Py_LE:
|
case Py_LE:
|
||||||
return PyBool_from_bool( o1->id->operator<(*(o2->id)) || o1->id->operator<(*(o2->id)) );
|
return PyBool_from_bool(o1->id->operator<(*(o2->id)) || o1->id->operator==(*(o2->id)));
|
||||||
break;
|
break;
|
||||||
case Py_EQ:
|
case Py_EQ:
|
||||||
return PyBool_from_bool(o1->id->operator==(*(o2->id)));
|
return PyBool_from_bool(o1->id->operator==(*(o2->id)));
|
||||||
@@ -91,7 +92,7 @@ static PyObject * Id_RichCompare(BPy_Id *o1, BPy_Id *o2, int opid) {
|
|||||||
return PyBool_from_bool(o1->id->operator!=(*(o2->id)));
|
return PyBool_from_bool(o1->id->operator!=(*(o2->id)));
|
||||||
break;
|
break;
|
||||||
case Py_GT:
|
case Py_GT:
|
||||||
return PyBool_from_bool(!( o1->id->operator<(*(o2->id)) || o1->id->operator<(*(o2->id)) ));
|
return PyBool_from_bool(!(o1->id->operator<(*(o2->id)) || o1->id->operator==(*(o2->id))));
|
||||||
break;
|
break;
|
||||||
case Py_GE:
|
case Py_GE:
|
||||||
return PyBool_from_bool(!(o1->id->operator<(*(o2->id))));
|
return PyBool_from_bool(!(o1->id->operator<(*(o2->id))));
|
||||||
@@ -101,7 +102,6 @@ static PyObject * Id_RichCompare(BPy_Id *o1, BPy_Id *o2, int opid) {
|
|||||||
Py_RETURN_NONE;
|
Py_RETURN_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------Id instance definitions ----------------------------*/
|
|
||||||
static PyMethodDef BPy_Id_methods[] = {
|
static PyMethodDef BPy_Id_methods[] = {
|
||||||
{NULL, NULL, 0, NULL}
|
{NULL, NULL, 0, NULL}
|
||||||
};
|
};
|
||||||
@@ -111,8 +111,7 @@ static PyMethodDef BPy_Id_methods[] = {
|
|||||||
PyDoc_STRVAR(Id_first_doc,
|
PyDoc_STRVAR(Id_first_doc,
|
||||||
"The first number constituting the Id.\n"
|
"The first number constituting the Id.\n"
|
||||||
"\n"
|
"\n"
|
||||||
":type: int"
|
":type: int");
|
||||||
);
|
|
||||||
|
|
||||||
static PyObject *Id_first_get(BPy_Id *self, void *UNUSED(closure))
|
static PyObject *Id_first_get(BPy_Id *self, void *UNUSED(closure))
|
||||||
{
|
{
|
||||||
@@ -133,8 +132,7 @@ static int Id_first_set(BPy_Id *self, PyObject *value, void *UNUSED(closure))
|
|||||||
PyDoc_STRVAR(Id_second_doc,
|
PyDoc_STRVAR(Id_second_doc,
|
||||||
"The second number constituting the Id.\n"
|
"The second number constituting the Id.\n"
|
||||||
"\n"
|
"\n"
|
||||||
":type: int"
|
":type: int");
|
||||||
);
|
|
||||||
|
|
||||||
static PyObject *Id_second_get(BPy_Id *self, void *UNUSED(closure))
|
static PyObject *Id_second_get(BPy_Id *self, void *UNUSED(closure))
|
||||||
{
|
{
|
||||||
@@ -165,12 +163,12 @@ PyTypeObject Id_Type = {
|
|||||||
"Id", /* tp_name */
|
"Id", /* tp_name */
|
||||||
sizeof(BPy_Id), /* tp_basicsize */
|
sizeof(BPy_Id), /* tp_basicsize */
|
||||||
0, /* tp_itemsize */
|
0, /* tp_itemsize */
|
||||||
(destructor)Id___dealloc__, /* tp_dealloc */
|
(destructor)Id_dealloc, /* tp_dealloc */
|
||||||
0, /* tp_print */
|
0, /* tp_print */
|
||||||
0, /* tp_getattr */
|
0, /* tp_getattr */
|
||||||
0, /* tp_setattr */
|
0, /* tp_setattr */
|
||||||
0, /* tp_reserved */
|
0, /* tp_reserved */
|
||||||
(reprfunc)Id___repr__, /* tp_repr */
|
(reprfunc)Id_repr, /* tp_repr */
|
||||||
0, /* tp_as_number */
|
0, /* tp_as_number */
|
||||||
0, /* tp_as_sequence */
|
0, /* tp_as_sequence */
|
||||||
0, /* tp_as_mapping */
|
0, /* tp_as_mapping */
|
||||||
@@ -181,7 +179,7 @@ PyTypeObject Id_Type = {
|
|||||||
0, /* tp_setattro */
|
0, /* tp_setattro */
|
||||||
0, /* tp_as_buffer */
|
0, /* tp_as_buffer */
|
||||||
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
|
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
|
||||||
Id___doc__, /* tp_doc */
|
Id_doc, /* tp_doc */
|
||||||
0, /* tp_traverse */
|
0, /* tp_traverse */
|
||||||
0, /* tp_clear */
|
0, /* tp_clear */
|
||||||
(richcmpfunc)Id_RichCompare, /* tp_richcompare */
|
(richcmpfunc)Id_RichCompare, /* tp_richcompare */
|
||||||
@@ -196,7 +194,7 @@ PyTypeObject Id_Type = {
|
|||||||
0, /* tp_descr_get */
|
0, /* tp_descr_get */
|
||||||
0, /* tp_descr_set */
|
0, /* tp_descr_set */
|
||||||
0, /* tp_dictoffset */
|
0, /* tp_dictoffset */
|
||||||
(initproc)Id___init__, /* tp_init */
|
(initproc)Id_init, /* tp_init */
|
||||||
0, /* tp_alloc */
|
0, /* tp_alloc */
|
||||||
PyType_GenericNew, /* tp_new */
|
PyType_GenericNew, /* tp_new */
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user