+eApplication* eApp = 0;
+
+#include "structmember.h"
+
+extern "C" {
+
+// eTimer replacement
+
+struct eTimerPy
+{
+ PyObject_HEAD
+ eTimer *tm;
+ PyObject *in_weakreflist; /* List of weak references */
+};
+
+static int
+eTimerPy_traverse(eTimerPy *self, visitproc visit, void *arg)
+{
+ PyObject *obj = self->tm->timeout.get();
+ Py_VISIT(obj);
+ return 0;
+}
+
+static int
+eTimerPy_clear(eTimerPy *self)
+{
+ PyObject *obj = self->tm->timeout.get();
+ Py_CLEAR(obj);
+ return 0;
+}
+
+static void
+eTimerPy_dealloc(eTimerPy* self)
+{
+ if (self->in_weakreflist != NULL)
+ PyObject_ClearWeakRefs((PyObject *) self);
+ eTimerPy_clear(self);
+ delete self->tm;
+ self->ob_type->tp_free((PyObject*)self);
+}
+
+static PyObject *
+eTimerPy_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
+{
+ eTimerPy *self = (eTimerPy *)type->tp_alloc(type, 0);
+ self->tm = new eTimer(eApp);
+ self->in_weakreflist = NULL;
+ return (PyObject *)self;
+}
+
+static PyObject *
+eTimerPy_is_active(eTimerPy* self)
+{
+ PyObject *ret = NULL;
+ ret = self->tm->isActive() ? Py_True : Py_False;
+ Org_Py_INCREF(ret);
+ return ret;
+}
+
+static PyObject *
+eTimerPy_start(eTimerPy* self, PyObject *args)
+{
+ long v=0;
+ long singleShot=0;
+ if (PyTuple_Size(args) > 1)
+ {
+ if (!PyArg_ParseTuple(args, "ll", &v, &singleShot)) // when 2nd arg is a value
+ {
+ PyObject *obj=0;
+ if (!PyArg_ParseTuple(args, "lO", &v, &obj)) // get 2nd arg as python object
+ return NULL;
+ else if (obj == Py_True)
+ singleShot=1;
+ else if (obj != Py_False)
+ return NULL;
+ }
+ }
+ else if (!PyArg_ParseTuple(args, "l", &v))
+ return NULL;
+ self->tm->start(v, singleShot);
+ Py_RETURN_NONE;
+}
+
+static PyObject *
+eTimerPy_start_long(eTimerPy* self, PyObject *args)
+{
+ long v=0;
+ if (!PyArg_ParseTuple(args, "l", &v)) {
+ return NULL;
+ }
+ self->tm->startLongTimer(v);
+ Py_RETURN_NONE;
+}
+
+static PyObject *
+eTimerPy_change_interval(eTimerPy* self, PyObject *args)
+{
+ long v=0;
+ if (!PyArg_ParseTuple(args, "l", &v)) {
+ return NULL;
+ }
+ self->tm->changeInterval(v);
+ Py_RETURN_NONE;
+}
+
+static PyObject *
+eTimerPy_stop(eTimerPy* self)
+{
+ self->tm->stop();
+ Py_RETURN_NONE;
+}
+
+static PyObject *
+eTimerPy_get_callback_list(eTimerPy *self)
+{ //used for compatibilty with the old eTimer
+ return self->tm->timeout.get();
+}
+
+static PyMethodDef eTimerPy_methods[] = {
+ {"isActive", (PyCFunction)eTimerPy_is_active, METH_NOARGS,
+ "returns the timer state"
+ },
+ {"start", (PyCFunction)eTimerPy_start, METH_VARARGS,
+ "start timer with interval in msecs"
+ },
+ {"startLongTimer", (PyCFunction)eTimerPy_start_long, METH_VARARGS,
+ "start timer with interval in secs"
+ },
+ {"changeInterval", (PyCFunction)eTimerPy_change_interval, METH_VARARGS,
+ "change interval of a timer (in msecs)"
+ },
+ {"stop", (PyCFunction)eTimerPy_stop, METH_NOARGS,
+ "stops the timer"
+ },
+ //used for compatibilty with the old eTimer
+ {"get", (PyCFunction)eTimerPy_get_callback_list, METH_NOARGS,
+ "get timeout callback list"
+ },
+ {NULL} /* Sentinel */
+};
+
+static PyObject *
+eTimerPy_get_cb_list(eTimerPy *self, void *closure)
+{
+ return self->tm->timeout.get();
+}
+
+static PyObject *
+eTimerPy_timeout(eTimerPy *self, void *closure)
+{ //used for compatibilty with the old eTimer
+ Org_Py_INCREF((PyObject*)self);
+ return (PyObject*)self;
+}
+
+static PyGetSetDef eTimerPy_getseters[] = {
+ {"callback",
+ (getter)eTimerPy_get_cb_list, (setter)0,
+ "returns the callback python list",
+ NULL},
+
+ {"timeout", //used for compatibilty with the old eTimer
+ (getter)eTimerPy_timeout, (setter)0,
+ "synonym for our self",
+ NULL},
+
+ {NULL} /* Sentinel */
+};
+
+static PyTypeObject eTimerPyType = {
+ PyObject_HEAD_INIT(NULL)
+ 0, /*ob_size*/
+ "eBaseImpl.eTimer", /*tp_name*/
+ sizeof(eTimerPy), /*tp_basicsize*/
+ 0, /*tp_itemsize*/
+ (destructor)eTimerPy_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_HAVE_GC, /*tp_flags*/
+ "eTimer objects", /* tp_doc */
+ (traverseproc)eTimerPy_traverse, /* tp_traverse */
+ (inquiry)eTimerPy_clear, /* tp_clear */
+ 0, /* tp_richcompare */
+ offsetof(eTimerPy, in_weakreflist), /* tp_weaklistoffset */
+ 0, /* tp_iter */
+ 0, /* tp_iternext */
+ eTimerPy_methods, /* tp_methods */
+ 0, /* tp_members */
+ eTimerPy_getseters, /* tp_getset */
+ 0, /* tp_base */
+ 0, /* tp_dict */
+ 0, /* tp_descr_get */
+ 0, /* tp_descr_set */
+ 0, /* tp_dictoffset */
+ 0, /* tp_init */
+ 0, /* tp_alloc */
+ eTimerPy_new, /* tp_new */
+};
+
+// eSocketNotifier replacement
+
+struct eSocketNotifierPy
+{
+ PyObject_HEAD
+ eSocketNotifier *sn;
+ PyObject *in_weakreflist; /* List of weak references */
+};
+
+static int
+eSocketNotifierPy_traverse(eSocketNotifierPy *self, visitproc visit, void *arg)
+{
+ PyObject *obj = self->sn->activated.get();
+ Py_VISIT(obj);
+ return 0;
+}
+
+static int
+eSocketNotifierPy_clear(eSocketNotifierPy *self)
+{
+ PyObject *obj = self->sn->activated.get();
+ Py_CLEAR(obj);
+ return 0;
+}
+
+static void
+eSocketNotifierPy_dealloc(eSocketNotifierPy* self)
+{
+ if (self->in_weakreflist != NULL)
+ PyObject_ClearWeakRefs((PyObject *) self);
+ eSocketNotifierPy_clear(self);
+ delete self->sn;
+ self->ob_type->tp_free((PyObject*)self);
+}
+
+static PyObject *
+eSocketNotifierPy_new(PyTypeObject *type, PyObject *args, PyObject *kwds)