diff options
Diffstat (limited to 'objects/connect-object.c')
-rw-r--r-- | objects/connect-object.c | 187 |
1 files changed, 187 insertions, 0 deletions
diff --git a/objects/connect-object.c b/objects/connect-object.c new file mode 100644 index 0000000..2db0e13 --- /dev/null +++ b/objects/connect-object.c @@ -0,0 +1,187 @@ +#include <Python.h> +#include "pymodule.h" +#include "base-objects.h" +#include "connect-object.h" +#include "pyirssi.h" +#include "pycore.h" +#include "pyutils.h" + +/* member IDs */ +enum +{ + M_CONNECT_ADDRESS, + M_CONNECT_PORT, + M_CONNECT_CHATNET, + M_CONNECT_PASSWORD, + M_CONNECT_WANTED_NICK, + M_CONNECT_USERNAME, + M_CONNECT_REALNAME, +}; + +static void connect_cleanup(SERVER_CONNECT_REC *connect) +{ + PyConnect *pyconn = signal_get_user_data(); + + /* + if (server == pyconn->data) + { + pyserver->data = NULL; + pyserver->cleanup_installed = 0; + signal_remove_data("server disconnected", connect_cleanup, pyserver); + } + */ +} + +static void PyConnect_dealloc(PyConnect *self) +{ + if (self->cleanup_installed) + signal_remove_data("server disconnected", connect_cleanup, self); + + self->ob_type->tp_free((PyObject*)self); +} + +static PyObject *PyConnect_get(PyConnect *self, void *closure) +{ + int member = GPOINTER_TO_INT(closure); + + RET_NULL_IF_INVALID(self->data); + + switch (member) + { + case M_CONNECT_ADDRESS: + RET_AS_STRING_OR_NONE(self->data->address); + case M_CONNECT_PORT: + return PyInt_FromLong(self->data->port); + case M_CONNECT_CHATNET: + RET_AS_STRING_OR_NONE(self->data->chatnet); + case M_CONNECT_PASSWORD: + RET_AS_STRING_OR_NONE(self->data->password); + case M_CONNECT_WANTED_NICK: + RET_AS_STRING_OR_NONE(self->data->nick); + case M_CONNECT_USERNAME: + RET_AS_STRING_OR_NONE(self->data->username); + case M_CONNECT_REALNAME: + RET_AS_STRING_OR_NONE(self->data->realname); + } + + /* This shouldn't be reached... but... */ + return PyErr_Format(PyExc_RuntimeError, "invalid member id, %d", member); +} + +static PyGetSetDef PyConnect_getseters[] = { + {"address", (getter)PyConnect_get, NULL, + "Address where we connected (irc.blah.org)", + GINT_TO_POINTER(M_CONNECT_ADDRESS)}, + + {"port", (getter)PyConnect_get, NULL, + "Port where we connected", + GINT_TO_POINTER(M_CONNECT_PORT)}, + + {"chatnet", (getter)PyConnect_get, NULL, + "Chat network", + GINT_TO_POINTER(M_CONNECT_CHATNET)}, + + {"password", (getter)PyConnect_get, NULL, + "Password we used in connection.", + GINT_TO_POINTER(M_CONNECT_PASSWORD)}, + + {"wanted_nick", (getter)PyConnect_get, NULL, + "Nick which we would prefer to use", + GINT_TO_POINTER(M_CONNECT_WANTED_NICK)}, + + {"username", (getter)PyConnect_get, NULL, + "User name", + GINT_TO_POINTER(M_CONNECT_USERNAME)}, + + {"realname", (getter)PyConnect_get, NULL, + "Real name", + GINT_TO_POINTER(M_CONNECT_REALNAME)}, + + {NULL} +}; + +PyTypeObject PyConnectType = { + PyObject_HEAD_INIT(NULL) + 0, /*ob_size*/ + "Connect", /*tp_name*/ + sizeof(PyConnect), /*tp_basicsize*/ + 0, /*tp_itemsize*/ + (destructor)PyConnect_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*/ + "PyConnect objects", /* tp_doc */ + 0, /* tp_traverse */ + 0, /* tp_clear */ + 0, /* tp_richcompare */ + 0, /* tp_weaklistoffset */ + 0, /* tp_iter */ + 0, /* tp_iternext */ + 0, /* tp_methods */ + 0, /* tp_members */ + PyConnect_getseters, /* tp_getset */ + &PyIrssiChatBaseType, /* tp_base */ + 0, /* tp_dict */ + 0, /* tp_descr_get */ + 0, /* tp_descr_set */ + 0, /* tp_dictoffset */ + 0, /* tp_init */ + 0, /* tp_alloc */ + 0, /* tp_new */ +}; + + +/* server connect factory function (managed == 0, don't do signal cleanup, 1 == do sig cleanup */ +PyObject *pyconnect_sub_new(void *connect, PyTypeObject *subclass, int managed) +{ + static const char *CONNECT_TYPE = "SERVER CONNECT"; + PyConnect *pyconn = NULL; + + g_return_val_if_fail(connect != NULL, NULL); + + pyconn = py_instp(PyConnect, subclass); + if (!pyconn) + return NULL; + + pyconn->base_name = CONNECT_TYPE; + pyconn->data = connect; + + if (managed) + { + //XXX: how to handle cleanup? + //signal_add_last_data("server disconnected", connect_cleanup, pyconn); + //pyconn->cleanup_installed = 1; + } + + return (PyObject *)pyconn; +} + +PyObject *pyconnect_new(void *connect, int managed) +{ + return pyconnect_sub_new(connect, &PyConnectType, managed); +} + +int connect_object_init(void) +{ + g_return_val_if_fail(py_module != NULL, 0); + + if (PyType_Ready(&PyConnectType) < 0) + return 0; + + Py_INCREF(&PyConnectType); + PyModule_AddObject(py_module, "Connect", (PyObject *)&PyConnectType); + + return 1; +} |