diff options
| author | Jelmer Vernooij <jelmer@samba.org> | 2008-12-23 03:24:39 +0100 | 
|---|---|---|
| committer | Jelmer Vernooij <jelmer@samba.org> | 2008-12-23 03:25:51 +0100 | 
| commit | 998d58819201954a78eb123d6f9d2bc0c6bd579c (patch) | |
| tree | e9709d8e576b010f427b5f6b3c9c51607d8caa33 | |
| parent | 619f32018389ed0b04ae35683352c3b69832d5d7 (diff) | |
| download | samba-998d58819201954a78eb123d6f9d2bc0c6bd579c.tar.gz samba-998d58819201954a78eb123d6f9d2bc0c6bd579c.tar.bz2 samba-998d58819201954a78eb123d6f9d2bc0c6bd579c.zip | |
python/tevent: Remove use of pytalloc.h.
| -rw-r--r-- | lib/tevent/pytevent.c | 29 | 
1 files changed, 21 insertions, 8 deletions
| diff --git a/lib/tevent/pytevent.c b/lib/tevent/pytevent.c index 4f18c87a90..54f6799845 100644 --- a/lib/tevent/pytevent.c +++ b/lib/tevent/pytevent.c @@ -19,9 +19,13 @@  #include <Python.h>  #include <tevent.h>  #include <stdbool.h> -#include <../talloc/pytalloc.h>  #include <tevent_util.h> +typedef struct { +	PyObject_HEAD +	struct event_context *ev_ctx; +} PyEventContextObject; +  PyAPI_DATA(PyTypeObject) PyEventContext;  static PyObject *py_set_default_backend(PyObject *self, PyObject *args) @@ -62,6 +66,7 @@ static PyObject *py_event_ctx_new(PyTypeObject *type, PyObject *args, PyObject *      const char *kwnames[] = { "name", NULL };      char *name = NULL;      struct event_context *ev_ctx; +    PyEventContextObject *ret;      if (!PyArg_ParseTupleAndKeywords(args, kwargs, "|s", (char **)kwnames, &name))          return NULL; @@ -70,17 +75,19 @@ static PyObject *py_event_ctx_new(PyTypeObject *type, PyObject *args, PyObject *      else          ev_ctx = event_context_init_byname(NULL, name); -    return py_talloc_import(&PyEventContext, ev_ctx); +    ret = (PyEventContextObject *)type->tp_alloc(type, 0); +    ret->ev_ctx = ev_ctx; +    return (PyObject *)ret;  } -static PyObject *py_event_ctx_loop_once(py_talloc_Object *self) +static PyObject *py_event_ctx_loop_once(PyEventContextObject *self)  { -    return PyInt_FromLong(event_loop_once(self->ptr)); +    return PyInt_FromLong(event_loop_once(self->ev_ctx));  } -static PyObject *py_event_ctx_loop_wait(py_talloc_Object *self) +static PyObject *py_event_ctx_loop_wait(PyEventContextObject *self)  { -    return PyInt_FromLong(event_loop_wait(self->ptr)); +    return PyInt_FromLong(event_loop_wait(self->ev_ctx));  }  static PyMethodDef py_event_ctx_methods[] = { @@ -91,11 +98,17 @@ static PyMethodDef py_event_ctx_methods[] = {      { NULL }  }; +static void py_event_ctx_dealloc(PyEventContextObject * self) +{ +	talloc_free(self->ev_ctx); +	self->ob_type->tp_free(self); +} +  PyTypeObject PyEventContext = {      .tp_name = "EventContext",      .tp_methods = py_event_ctx_methods, -    .tp_basicsize = sizeof(py_talloc_Object), -    .tp_dealloc = py_talloc_dealloc, +    .tp_basicsize = sizeof(PyEventContextObject), +    .tp_dealloc = (destructor)py_event_ctx_dealloc,      .tp_flags = Py_TPFLAGS_DEFAULT,      .tp_new = py_event_ctx_new,  }; | 
