X-Git-Url: https://git.distorted.org.uk/~mdw/pyke/blobdiff_plain/d4a9e7e71495a1180062371cbac5353795d1fe47..0156e4020eb3b13a1b9bcfa9887eb922ba5d9fa2:/util.c diff --git a/util.c b/util.c index 7201401..8a0c06c 100644 --- a/util.c +++ b/util.c @@ -1,13 +1,11 @@ /* -*-c-*- * - * $Id$ - * * Miscellaneous utilities (not Catacomb-specific) * * (c) 2005 Straylight/Edgeware */ -/*----- Licensing notice --------------------------------------------------* +/*----- Licensing notice --------------------------------------------------* * * This file is part of the Python interface to Catacomb. * @@ -15,12 +13,12 @@ * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. - * + * * Catacomb/Python is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. - * + * * You should have received a copy of the GNU General Public License * along with Catacomb/Python; if not, write to the Free Software Foundation, * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. @@ -30,6 +28,10 @@ #include "catacomb-python.h" +/*----- External values ---------------------------------------------------*/ + +static PyObject *modname = 0; + /*----- Conversions -------------------------------------------------------*/ PyObject *getulong(unsigned long w) @@ -165,16 +167,22 @@ void *newtype(PyTypeObject *metaty, ty->ht_name = PyString_FromString(ty->ht_type.tp_name); if (ty->ht_name) ty->ht_type.tp_name = PyString_AS_STRING(ty->ht_name); - PyObject_INIT(&ty->ht_type, metaty); + DISCARD(PyObject_INIT(&ty->ht_type, metaty)); Py_INCREF(metaty); return (ty); } +void typeready(PyTypeObject *ty) +{ + PyType_Ready(ty); + PyDict_SetItemString(ty->tp_dict, "__module__", modname); +} + PyTypeObject *inittype(PyTypeObject *tyskel) { PyTypeObject *ty = newtype(&PyType_Type, tyskel, 0); ty->tp_flags |= Py_TPFLAGS_HEAPTYPE; - PyType_Ready(ty); + typeready(ty); return (ty); } @@ -278,7 +286,7 @@ static void iter_pydealloc(PyObject *me) static PyObject *itemiter_pynext(PyObject *me) { PyObject *k = 0, *v = 0, *rc = 0; - + if ((k = PyIter_Next(ITER_I(me))) != 0 && (v = PyObject_GetItem(ITER_MAP(me), k)) != 0) rc = Py_BuildValue("(OO)", k, v); @@ -337,7 +345,7 @@ static PyTypeObject itemiter_pytype_skel = { static PyObject *valiter_pynext(PyObject *me) { PyObject *k = 0, *rc = 0; - + if ((k = PyIter_Next(ITER_I(me))) != 0) rc = PyObject_GetItem(ITER_MAP(me), k); Py_XDECREF(k); @@ -403,7 +411,7 @@ PySequenceMethods gmap_pysequence = { PyMapping_HasKey, /* @sq_contains@ */ 0, /* @sq_inplace_concat@ */ 0 /* @sq_inplace_repeat@ */ -}; +}; int gmap_pysize(PyObject *me) { @@ -454,7 +462,7 @@ PyObject *gmapmeth_values(PyObject *me, PyObject *arg) (l = PyList_New(0)) == 0 || (i = PyObject_GetIter(me)) == 0) goto done; - while ((k = PyIter_Next(i)) != 0) { + while ((k = PyIter_Next(i)) != 0) { if ((v = PyObject_GetItem(me, k)) == 0 || PyList_Append(l, v)) err = -1; @@ -634,13 +642,14 @@ PyMethodDef gmap_pymethods[] = { /*----- Initialization ----------------------------------------------------*/ -void util_init(void) +void util_pyinit(void) { + modname = PyString_FromString("catacomb"); INITTYPE(itemiter, root); INITTYPE(valiter, root); } -void util_insert(PyObject *mod) +void util_pyinsert(PyObject *mod) { INSERT("ItemIter", itemiter_pytype); INSERT("ValueIter", valiter_pytype);