diff options
author | Tamito Kajiyama <rd6t-kjym@asahi-net.or.jp> | 2013-02-16 18:21:40 +0400 |
---|---|---|
committer | Tamito Kajiyama <rd6t-kjym@asahi-net.or.jp> | 2013-02-16 18:21:40 +0400 |
commit | b35a893249bed1a70f40b86615531d7d75fe12f3 (patch) | |
tree | b3e8bbbad81873f6270f4dd00d35bc3a0526f3af /source/blender/freestyle/intern/python/BPy_Iterator.cpp | |
parent | aa9c01f384d38a8e75bfd25bbdadba3fe2246e5b (diff) |
Freestyle Python API improvements - part 4.
Major API updates were made as in part 3 to address code review comments.
This revision focuses on Python wrappers of C++ iterators.
* Most getter/setter methods were reimplemented as attributes using PyGetSetDef.
* The naming of methods and attributes was fixed to follow the naming conventions
of the Blender Python API (i.e., lower case + underscores for methods and attributes,
and CamelCase for classes). The only irregular naming change is the following, to
better indicate the functionality:
- ChainingIterator: getVertex --> next_vertex
* In addition, some code clean-up was done in both C++ and Python. Also duplicated
definitions of predicate classes were removed.
Diffstat (limited to 'source/blender/freestyle/intern/python/BPy_Iterator.cpp')
-rw-r--r-- | source/blender/freestyle/intern/python/BPy_Iterator.cpp | 159 |
1 files changed, 77 insertions, 82 deletions
diff --git a/source/blender/freestyle/intern/python/BPy_Iterator.cpp b/source/blender/freestyle/intern/python/BPy_Iterator.cpp index dd7d3783d81..0e2f4b3fd43 100644 --- a/source/blender/freestyle/intern/python/BPy_Iterator.cpp +++ b/source/blender/freestyle/intern/python/BPy_Iterator.cpp @@ -12,8 +12,6 @@ #include "Iterator/BPy_ChainPredicateIterator.h" #include "Iterator/BPy_ChainSilhouetteIterator.h" - - #ifdef __cplusplus extern "C" { #endif @@ -21,64 +19,64 @@ extern "C" { /////////////////////////////////////////////////////////////////////////////////////////// //-------------------MODULE INITIALIZATION-------------------------------- -int Iterator_Init( PyObject *module ) -{ - if( module == NULL ) +int Iterator_Init(PyObject *module) +{ + if (module == NULL) return -1; - if( PyType_Ready( &Iterator_Type ) < 0 ) + if (PyType_Ready(&Iterator_Type) < 0) return -1; - Py_INCREF( &Iterator_Type ); + Py_INCREF(&Iterator_Type); PyModule_AddObject(module, "Iterator", (PyObject *)&Iterator_Type); - if( PyType_Ready( &AdjacencyIterator_Type ) < 0 ) + if (PyType_Ready(&AdjacencyIterator_Type) < 0) return -1; - Py_INCREF( &AdjacencyIterator_Type ); + Py_INCREF(&AdjacencyIterator_Type); PyModule_AddObject(module, "AdjacencyIterator", (PyObject *)&AdjacencyIterator_Type); - if( PyType_Ready( &Interface0DIterator_Type ) < 0 ) + if (PyType_Ready(&Interface0DIterator_Type) < 0) return -1; - Py_INCREF( &Interface0DIterator_Type ); + Py_INCREF(&Interface0DIterator_Type); PyModule_AddObject(module, "Interface0DIterator", (PyObject *)&Interface0DIterator_Type); - if( PyType_Ready( &CurvePointIterator_Type ) < 0 ) + if (PyType_Ready(&CurvePointIterator_Type) < 0) return -1; - Py_INCREF( &CurvePointIterator_Type ); + Py_INCREF(&CurvePointIterator_Type); PyModule_AddObject(module, "CurvePointIterator", (PyObject *)&CurvePointIterator_Type); - if( PyType_Ready( &StrokeVertexIterator_Type ) < 0 ) + if (PyType_Ready(&StrokeVertexIterator_Type) < 0) return -1; - Py_INCREF( &StrokeVertexIterator_Type ); + Py_INCREF(&StrokeVertexIterator_Type); PyModule_AddObject(module, "StrokeVertexIterator", (PyObject *)&StrokeVertexIterator_Type); - if( PyType_Ready( &SVertexIterator_Type ) < 0 ) + if (PyType_Ready(&SVertexIterator_Type) < 0) return -1; - Py_INCREF( &SVertexIterator_Type ); + Py_INCREF(&SVertexIterator_Type); PyModule_AddObject(module, "SVertexIterator", (PyObject *)&SVertexIterator_Type); - if( PyType_Ready( &orientedViewEdgeIterator_Type ) < 0 ) + if (PyType_Ready(&orientedViewEdgeIterator_Type) < 0) return -1; - Py_INCREF( &orientedViewEdgeIterator_Type ); + Py_INCREF(&orientedViewEdgeIterator_Type); PyModule_AddObject(module, "orientedViewEdgeIterator", (PyObject *)&orientedViewEdgeIterator_Type); - if( PyType_Ready( &ViewEdgeIterator_Type ) < 0 ) + if (PyType_Ready(&ViewEdgeIterator_Type) < 0) return -1; - Py_INCREF( &ViewEdgeIterator_Type ); + Py_INCREF(&ViewEdgeIterator_Type); PyModule_AddObject(module, "ViewEdgeIterator", (PyObject *)&ViewEdgeIterator_Type); - if( PyType_Ready( &ChainingIterator_Type ) < 0 ) + if (PyType_Ready(&ChainingIterator_Type) < 0) return -1; - Py_INCREF( &ChainingIterator_Type ); + Py_INCREF(&ChainingIterator_Type); PyModule_AddObject(module, "ChainingIterator", (PyObject *)&ChainingIterator_Type); - if( PyType_Ready( &ChainPredicateIterator_Type ) < 0 ) + if (PyType_Ready(&ChainPredicateIterator_Type) < 0) return -1; - Py_INCREF( &ChainPredicateIterator_Type ); + Py_INCREF(&ChainPredicateIterator_Type); PyModule_AddObject(module, "ChainPredicateIterator", (PyObject *)&ChainPredicateIterator_Type); - if( PyType_Ready( &ChainSilhouetteIterator_Type ) < 0 ) + if (PyType_Ready(&ChainSilhouetteIterator_Type) < 0) return -1; - Py_INCREF( &ChainSilhouetteIterator_Type ); + Py_INCREF(&ChainSilhouetteIterator_Type); PyModule_AddObject(module, "ChainSilhouetteIterator", (PyObject *)&ChainSilhouetteIterator_Type); return 0; @@ -86,95 +84,94 @@ int Iterator_Init( PyObject *module ) //------------------------INSTANCE METHODS ---------------------------------- -static char Iterator___doc__[] = -"Base class to define iterators.\n"; +PyDoc_STRVAR(Iterator_doc, +"Base class to define iterators."); -static void Iterator___dealloc__(BPy_Iterator* self) +static void Iterator_dealloc(BPy_Iterator* self) { if (self->it) delete self->it; - Py_TYPE(self)->tp_free((PyObject*)self); + Py_TYPE(self)->tp_free((PyObject*)self); } -static PyObject * Iterator___repr__(BPy_Iterator* self) +static PyObject * Iterator_repr(BPy_Iterator* self) { - return PyUnicode_FromFormat("type: %s - address: %p", self->it->getExactTypeName().c_str(), self->it ); + return PyUnicode_FromFormat("type: %s - address: %p", self->it->getExactTypeName().c_str(), self->it); } -static char Iterator_getExactTypeName___doc__[] = -".. method:: getExactTypeName()\n" -"\n" -" Returns the name of the iterator.\n" -"\n" -" :return: The name of the iterator.\n" -" :rtype: str\n"; - -static PyObject * Iterator_getExactTypeName(BPy_Iterator* self) { - return PyUnicode_FromString( self->it->getExactTypeName().c_str() ); -} - -static char Iterator_increment___doc__[] = +PyDoc_STRVAR(Iterator_increment_doc, ".. method:: increment()\n" "\n" -" Makes the iterator point the next element.\n"; +" Makes the iterator point the next element."); -static PyObject * Iterator_increment(BPy_Iterator* self) { +static PyObject * Iterator_increment(BPy_Iterator* self) +{ if (self->it->isEnd()) { PyErr_SetString(PyExc_RuntimeError , "cannot increment any more"); return NULL; } self->it->increment(); - Py_RETURN_NONE; } -static char Iterator_decrement___doc__[] = +PyDoc_STRVAR(Iterator_decrement_doc, ".. method:: decrement()\n" "\n" -" Makes the iterator point the previous element.\n"; +" Makes the iterator point the previous element."); -static PyObject * Iterator_decrement(BPy_Iterator* self) { +static PyObject * Iterator_decrement(BPy_Iterator* self) +{ if (self->it->isBegin()) { PyErr_SetString(PyExc_RuntimeError , "cannot decrement any more"); return NULL; } self->it->decrement(); - Py_RETURN_NONE; } -static char Iterator_isBegin___doc__[] = -".. method:: isBegin()\n" -"\n" -" Returns true if the interator points the first element.\n" +static PyMethodDef BPy_Iterator_methods[] = { + {"increment", (PyCFunction) Iterator_increment, METH_NOARGS, Iterator_increment_doc}, + {"decrement", (PyCFunction) Iterator_decrement, METH_NOARGS, Iterator_decrement_doc}, + {NULL, NULL, 0, NULL} +}; + +/*----------------------Iterator get/setters ----------------------------*/ + +PyDoc_STRVAR(Iterator_exact_type_name_doc, +"The string of the name of this iterator.\n" "\n" -" :return: True if the interator points the first element.\n" -" :rtype: bool\n"; +":type: str"); -static PyObject * Iterator_isBegin(BPy_Iterator* self) { - return PyBool_from_bool( self->it->isBegin() ); +static PyObject *Iterator_exact_type_name_get(BPy_Iterator *self, void *UNUSED(closure)) +{ + return PyUnicode_FromString(self->it->getExactTypeName().c_str()); } -static char Iterator_isEnd___doc__[] = -".. method:: isEnd()\n" +PyDoc_STRVAR(Iterator_is_begin_doc, +"True if the interator points the first element.\n" "\n" -" Returns true if the interator points the last element.\n" +":type: bool"); + +static PyObject *Iterator_is_begin_get(BPy_Iterator *self, void *UNUSED(closure)) +{ + return PyBool_from_bool(self->it->isBegin()); +} + +PyDoc_STRVAR(Iterator_is_end_doc, +"True if the interator points the last element.\n" "\n" -" :return: True if the interator points the last element.\n" -" :rtype: bool\n"; +":type: bool"); -static PyObject * Iterator_isEnd(BPy_Iterator* self) { - return PyBool_from_bool( self->it->isEnd() ); +static PyObject *Iterator_is_end_get(BPy_Iterator *self, void *UNUSED(closure)) +{ + return PyBool_from_bool(self->it->isEnd()); } -/*----------------------Iterator instance definitions ----------------------------*/ -static PyMethodDef BPy_Iterator_methods[] = { - {"getExactTypeName", ( PyCFunction ) Iterator_getExactTypeName, METH_NOARGS, Iterator_getExactTypeName___doc__}, - {"increment", ( PyCFunction ) Iterator_increment, METH_NOARGS, Iterator_increment___doc__}, - {"decrement", ( PyCFunction ) Iterator_decrement, METH_NOARGS, Iterator_decrement___doc__}, - {"isBegin", ( PyCFunction ) Iterator_isBegin, METH_NOARGS, Iterator_isBegin___doc__}, - {"isEnd", ( PyCFunction ) Iterator_isEnd, METH_NOARGS, Iterator_isEnd___doc__}, - {NULL, NULL, 0, NULL} +static PyGetSetDef BPy_Iterator_getseters[] = { + {(char *)"exact_type_name", (getter)Iterator_exact_type_name_get, (setter)NULL, (char *)Iterator_exact_type_name_doc, NULL}, + {(char *)"is_begin", (getter)Iterator_is_begin_get, (setter)NULL, (char *)Iterator_is_begin_doc, NULL}, + {(char *)"is_end", (getter)Iterator_is_end_get, (setter)NULL, (char *)Iterator_is_end_doc, NULL}, + {NULL, NULL, NULL, NULL, NULL} /* Sentinel */ }; /*-----------------------BPy_Iterator type definition ------------------------------*/ @@ -184,12 +181,12 @@ PyTypeObject Iterator_Type = { "Iterator", /* tp_name */ sizeof(BPy_Iterator), /* tp_basicsize */ 0, /* tp_itemsize */ - (destructor)Iterator___dealloc__, /* tp_dealloc */ + (destructor)Iterator_dealloc, /* tp_dealloc */ 0, /* tp_print */ 0, /* tp_getattr */ 0, /* tp_setattr */ 0, /* tp_reserved */ - (reprfunc)Iterator___repr__, /* tp_repr */ + (reprfunc)Iterator_repr, /* tp_repr */ 0, /* tp_as_number */ 0, /* tp_as_sequence */ 0, /* tp_as_mapping */ @@ -200,7 +197,7 @@ PyTypeObject Iterator_Type = { 0, /* tp_setattro */ 0, /* tp_as_buffer */ Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */ - Iterator___doc__, /* tp_doc */ + Iterator_doc, /* tp_doc */ 0, /* tp_traverse */ 0, /* tp_clear */ 0, /* tp_richcompare */ @@ -209,7 +206,7 @@ PyTypeObject Iterator_Type = { 0, /* tp_iternext */ BPy_Iterator_methods, /* tp_methods */ 0, /* tp_members */ - 0, /* tp_getset */ + BPy_Iterator_getseters, /* tp_getset */ 0, /* tp_base */ 0, /* tp_dict */ 0, /* tp_descr_get */ @@ -225,5 +222,3 @@ PyTypeObject Iterator_Type = { #ifdef __cplusplus } #endif - - |