diff options
Diffstat (limited to 'objects/ignore-object.c')
| -rw-r--r-- | objects/ignore-object.c | 284 |
1 files changed, 0 insertions, 284 deletions
diff --git a/objects/ignore-object.c b/objects/ignore-object.c deleted file mode 100644 index 979c9b1..0000000 --- a/objects/ignore-object.c +++ /dev/null @@ -1,284 +0,0 @@ -#include <Python.h> -#include "pyirssi_irc.h" -#include "pymodule.h" -#include "ignore-object.h" -#include "factory.h" -#include "pycore.h" - -/* monitor "ignore destroy" signal */ -static void ignore_cleanup(IGNORE_REC *ignore) -{ - PyIgnore *pyignore = signal_get_user_data(); - - if (ignore == pyignore->data) - { - pyignore->data = NULL; - pyignore->cleanup_installed = 0; - signal_remove_data("ignore destroy", ignore_cleanup, pyignore); - } -} - -static void PyIgnore_dealloc(PyIgnore *self) -{ - if (self->cleanup_installed) - signal_remove_data("ignore destroy", ignore_cleanup, self); - - self->ob_type->tp_free((PyObject*)self); -} - -static PyObject *PyIgnore_new(PyTypeObject *type, PyObject *args, PyObject *kwds) -{ - PyIgnore *self; - - self = (PyIgnore *)type->tp_alloc(type, 0); - if (!self) - return NULL; - - return (PyObject *)self; -} - -/* Getters */ -PyDoc_STRVAR(PyIgnore_mask_doc, - "Ignore mask" -); -static PyObject *PyIgnore_mask_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - RET_AS_STRING_OR_NONE(self->data->mask); -} - -PyDoc_STRVAR(PyIgnore_servertag_doc, - "Ignore only in server" -); -static PyObject *PyIgnore_servertag_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - RET_AS_STRING_OR_NONE(self->data->servertag); -} - -PyDoc_STRVAR(PyIgnore_pattern_doc, - "Ignore text patern" -); -static PyObject *PyIgnore_pattern_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - RET_AS_STRING_OR_NONE(self->data->pattern); -} - -PyDoc_STRVAR(PyIgnore_level_doc, - "Ignore level" -); -static PyObject *PyIgnore_level_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - return PyInt_FromLong(self->data->level); -} - -PyDoc_STRVAR(PyIgnore_exception_doc, - "This is an exception ignore" -); -static PyObject *PyIgnore_exception_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - return PyBool_FromLong(self->data->exception); -} - -PyDoc_STRVAR(PyIgnore_regexp_doc, - "Regexp pattern matching" -); -static PyObject *PyIgnore_regexp_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - return PyBool_FromLong(self->data->regexp); -} - -PyDoc_STRVAR(PyIgnore_fullword_doc, - "Pattern matches only full words" -); -static PyObject *PyIgnore_fullword_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - return PyBool_FromLong(self->data->fullword); -} - -PyDoc_STRVAR(PyIgnore_replies_doc, - "Ignore replies to nick in channel" -); -static PyObject *PyIgnore_replies_get(PyIgnore *self, void *closure) -{ - RET_NULL_IF_INVALID(self->data); - return PyBool_FromLong(self->data->replies); -} - -/* specialized getters/setters */ -static PyGetSetDef PyIgnore_getseters[] = { - {"mask", (getter)PyIgnore_mask_get, NULL, - PyIgnore_mask_doc, NULL}, - {"servertag", (getter)PyIgnore_servertag_get, NULL, - PyIgnore_servertag_doc, NULL}, - {"pattern", (getter)PyIgnore_pattern_get, NULL, - PyIgnore_pattern_doc, NULL}, - {"level", (getter)PyIgnore_level_get, NULL, - PyIgnore_level_doc, NULL}, - {"exception", (getter)PyIgnore_exception_get, NULL, - PyIgnore_exception_doc, NULL}, - {"regexp", (getter)PyIgnore_regexp_get, NULL, - PyIgnore_regexp_doc, NULL}, - {"fullword", (getter)PyIgnore_fullword_get, NULL, - PyIgnore_fullword_doc, NULL}, - {"replies", (getter)PyIgnore_replies_get, NULL, - PyIgnore_replies_doc, NULL}, - {NULL} -}; - -/* Methods */ -PyDoc_STRVAR(PyIgnore_channels_doc, - "channels() -> list of str\n" - "\n" - "Ignore only in channels (list of names)\n" -); -static PyObject *PyIgnore_channels(PyIgnore *self, PyObject *args) -{ - char **p; - PyObject *list; - - RET_NULL_IF_INVALID(self->data); - - list = PyList_New(0); - if (!list) - return NULL; - - for (p = self->data->channels; *p; p++) - { - int ret; - PyObject *str; - - str = PyString_FromString(*p); - if (!str) - { - Py_XDECREF(list); - return NULL; - } - - ret = PyList_Append(list, str); - Py_DECREF(str); - if (ret != 0) - { - Py_XDECREF(list); - return NULL; - } - } - - return list; -} - -PyDoc_STRVAR(PyIgnore_add_rec_doc, - "add_rec() -> None\n" - "\n" - "Add ignore record" -); -static PyObject *PyIgnore_add_rec(PyIgnore *self, PyObject *args) -{ - RET_NULL_IF_INVALID(self->data); - - ignore_add_rec(self->data); - - Py_RETURN_NONE; -} - -PyDoc_STRVAR(PyIgnore_update_rec_doc, - "update_rec() -> None\n" - "\n" - "Update ignore record in configuration" -); -static PyObject *PyIgnore_update_rec(PyIgnore *self, PyObject *args) -{ - RET_NULL_IF_INVALID(self->data); - - ignore_update_rec(self->data); - - Py_RETURN_NONE; -} - -/* Methods for object */ -static PyMethodDef PyIgnore_methods[] = { - {"add_rec", (PyCFunction)PyIgnore_add_rec, METH_NOARGS, - PyIgnore_add_rec_doc}, - {"update_rec", (PyCFunction)PyIgnore_update_rec, METH_NOARGS, - PyIgnore_update_rec_doc}, - {"channels", (PyCFunction)PyIgnore_channels, METH_NOARGS, - PyIgnore_channels_doc}, - {NULL} /* Sentinel */ -}; - -PyTypeObject PyIgnoreType = { - PyObject_HEAD_INIT(NULL) - 0, /*ob_size*/ - "Ignore", /*tp_name*/ - sizeof(PyIgnore), /*tp_basicsize*/ - 0, /*tp_itemsize*/ - (destructor)PyIgnore_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*/ - "PyIgnore objects", /* tp_doc */ - 0, /* tp_traverse */ - 0, /* tp_clear */ - 0, /* tp_richcompare */ - 0, /* tp_weaklistoffset */ - 0, /* tp_iter */ - 0, /* tp_iternext */ - PyIgnore_methods, /* tp_methods */ - 0, /* tp_members */ - PyIgnore_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 */ - PyIgnore_new, /* tp_new */ -}; - - -/* ignore factory function */ -PyObject *pyignore_new(void *ignore) -{ - PyIgnore *pyignore; - - pyignore = py_inst(PyIgnore, PyIgnoreType); - if (!pyignore) - return NULL; - - pyignore->data = ignore; - pyignore->cleanup_installed = 1; - signal_add_last_data("ignore destroy", ignore_cleanup, pyignore); - - return (PyObject *)pyignore; -} - -int ignore_object_init(void) -{ - g_return_val_if_fail(py_module != NULL, 0); - - if (PyType_Ready(&PyIgnoreType) < 0) - return 0; - - Py_INCREF(&PyIgnoreType); - PyModule_AddObject(py_module, "Ignore", (PyObject *)&PyIgnoreType); - - return 1; -} |
