From 1b59bd0d0e94622f15c47c2a4d34f679a8e023fd Mon Sep 17 00:00:00 2001 From: Andy Grover <andy@groveronline.com> Date: Mon, 12 Mar 2012 10:41:51 -0700 Subject: [PATCH] use c99 init for struct init move casts of pyobject -> kmodobject to the functions from the struct init. --- libkmod.c | 77 ++++++++++++++++++------------------------------------- 1 file changed, 25 insertions(+), 52 deletions(-) diff --git a/libkmod.c b/libkmod.c index 0d16c76..7b4e82f 100644 --- a/libkmod.c +++ b/libkmod.c @@ -23,7 +23,7 @@ typedef struct { struct kmod_ctx *ctx; } kmodobject; -static PyTypeObject LibKmodType; +static PyTypeObject KmodType; static PyObject *LibKmodError; @@ -33,15 +33,16 @@ static PyObject *LibKmodError; */ static int -libkmod_init(kmodobject *self, PyObject *arg) +libkmod_init(PyObject *self, PyObject *args, PyObject *kwds) { + kmodobject *kmod = (kmodobject *)self; char *mod_dir = NULL; - if (!PyArg_ParseTuple(arg, "|s", &mod_dir)) + if (!PyArg_ParseTuple(args, "|s", &mod_dir)) return -1; - self->ctx = kmod_new(mod_dir, NULL); - if (!self->ctx) { + kmod->ctx = kmod_new(mod_dir, NULL); + if (!kmod->ctx) { PyErr_SetFromErrno(PyExc_OSError); return -1; } @@ -50,11 +51,13 @@ libkmod_init(kmodobject *self, PyObject *arg) } static void -libkmod_dealloc(kmodobject *self) +libkmod_dealloc(PyObject *self) { + kmodobject *kmod = (kmodobject *)self; + /* if already closed, don't reclose it */ - if (self->ctx != NULL){ - kmod_unref(self->ctx); + if (kmod->ctx != NULL){ + kmod_unref(kmod->ctx); } //self->ob_type->tp_free((PyObject*)self); PyObject_Del(self); @@ -76,47 +79,17 @@ static PyMethodDef Libkmod_methods[] = { { NULL, NULL} /* sentinel */ }; -static PyTypeObject LibKmodType = { + +static PyTypeObject KmodType = { PyObject_HEAD_INIT(NULL) - 0, /*ob_size*/ - "kmod.kmod", /*tp_name*/ - sizeof(kmodobject), /*tp_basicsize*/ - 0, /*tp_itemsize*/ - (destructor)libkmod_dealloc, /*tp_dealloc*/ - 0, /*tp_print*/ - 0, /*tp_getattr*/ - 0, /*tp_setattr*/ - 0, /*tp_compare*/ - 0, /*tp_repr*/ - 0, /*tp_as_number*/ - 0, /*tp_as_sequence*/ - 0, /*tp_as_mapping*/ - 0, /*tp_hash */ - 0, /*tp_call*/ - 0, /*tp_str*/ - 0, /*tp_getattro*/ - 0, /*tp_setattro*/ - 0, /*tp_as_buffer*/ - Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /*tp_flags*/ - "Libkmod objects", /* tp_doc */ - 0, /* tp_traverse */ - 0, /* tp_clear */ - 0, /* tp_richcompare */ - 0, /* tp_weaklistoffset */ - 0, /* tp_iter */ - 0, /* tp_iternext */ - Libkmod_methods, /* tp_methods */ - 0, /* tp_members */ - 0, /* tp_getset */ - 0, /* tp_base */ - 0, /* tp_dict */ - 0, /* tp_descr_get */ - 0, /* tp_descr_set */ - 0, /* tp_dictoffset */ - (initproc)libkmod_init, /* tp_init */ - 0, /* tp_alloc */ - 0, - //(newfunc)Libkmod_new, /* tp_new */ + .tp_name = "kmod.kmod", + .tp_basicsize = sizeof(kmodobject), + //.tp_new = PyType_GenericNew, + .tp_init = libkmod_init, + .tp_dealloc = libkmod_dealloc, + .tp_flags =Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, + .tp_doc = "Libkmod objects", + .tp_methods = Libkmod_methods, }; #ifndef PyMODINIT_FUNC /* declarations for DLL import/export */ @@ -127,16 +100,16 @@ initlibkmod(void) { PyObject *m; - LibKmodType.tp_new = PyType_GenericNew; - if (PyType_Ready(&LibKmodType) < 0) + KmodType.tp_new = PyType_GenericNew; + if (PyType_Ready(&KmodType) < 0) return; m = Py_InitModule3("libkmod", Libkmod_methods, "Libkmod module"); if (m == NULL) return; - Py_INCREF(&LibKmodType); - PyModule_AddObject(m, "LibKmod", (PyObject *)&LibKmodType); + Py_INCREF(&KmodType); + PyModule_AddObject(m, "Kmod", (PyObject *)&KmodType); LibKmodError = PyErr_NewException("Libkmod.LibKmodError", NULL, NULL); -- 2.26.2