+ 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.getSteal();
+ if (obj)
+ Py_VISIT(obj);
+ return 0;
+}
+
+static int
+eSocketNotifierPy_clear(eSocketNotifierPy *self)
+{
+ PyObject *obj = self->sn->activated.getSteal(true);
+ if (obj)
+ Py_CLEAR(obj);
+ return 0;
+}
+
+static void
+eSocketNotifierPy_dealloc(eSocketNotifierPy* self)
+{
+ if (self->in_weakreflist != NULL)
+ PyObject_ClearWeakRefs((PyObject *) self);
+ eSocketNotifierPy_clear(self);
+ self->sn->Release();
+ self->ob_type->tp_free((PyObject*)self);