/* irssi-python Copyright (C) 2006 Christopher Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include #include "pymodule.h" #include "pyirssi_irc.h" #include "factory.h" #include "pyutils.h" #include "pysignals.h" #include "pyloader.h" #include "pythemes.h" #include "pystatusbar.h" /* * This module is some what different than the Perl's. * Script specific operations are handled by the Script object * instead of by a function in this module. command_bind, * signal_add, etc require data to be saved about the script * for cleanup purposes, so I moved those functions to the script * object. */ /* Main embedded module */ PyObject *py_module = NULL; /* Module functions */ /*XXX: prefix PY to avoid ambiguity with py_command function */ PyDoc_STRVAR(PY_command_doc, "command(cmd) -> None\n" "\n" "Execute command\n" ); static PyObject *PY_command(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"cmd", NULL}; char *cmd = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &cmd)) return NULL; py_command(cmd, NULL, NULL); Py_RETURN_NONE; } PyDoc_STRVAR(py_prnt_doc, "prnt(text, msglvl=MSGLEVEL_CLIENTNOTICE) -> None\n" "\n" "print output\n" ); /*XXX: print is a python keyword, so abbreviate it */ static PyObject *py_prnt(PyObject *self, PyObject *args, PyObject *kwargs) { static char *kwlist[] = {"text", "msglvl", NULL}; int msglvl = MSGLEVEL_CLIENTNOTICE; char *text = NULL; if (!PyArg_ParseTupleAndKeywords(args, kwargs, "s|i:prnt", kwlist, &text, &msglvl)) return NULL; printtext_string(NULL, NULL, msglvl, text); Py_RETURN_NONE; } PyDoc_STRVAR(py_get_script_doc, "get_script() -> Script object\n" "\n" "Find current Irssi script object\n" ); static PyObject *py_get_script(PyObject *self, PyObject *args) { PyObject *ret = pyloader_find_script_obj(); /* XXX: type check */ if (!ret) PyErr_SetString(PyExc_RuntimeError, "unable to find script object"); else Py_INCREF(ret); return ret; } PyDoc_STRVAR(py_chatnet_find_doc, "chatnet_find(name) -> Chatnet object or None\n" "\n" "Find chat network with name\n" ); static PyObject *py_chatnet_find(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; return py_irssi_chat_new(chatnet_find(name), 1); } PyDoc_STRVAR(py_chatnets_doc, "chatnets() -> list of Chatnet objects\n" "\n" "Return a list of all chatnets\n" ); static PyObject *py_chatnets(PyObject *self, PyObject *args) { return py_irssi_chatlist_new(chatnets, 1); } PyDoc_STRVAR(py_reconnects_doc, "reconnects() -> list of Reconnect objects\n" "\n" "Return a list of all reconnects\n" ); static PyObject *py_reconnects(PyObject *self, PyObject *args) { return py_irssi_objlist_new(reconnects, 1, (InitFunc)pyreconnect_new); } PyDoc_STRVAR(py_servers_doc, "servers() -> list of Server objects\n" "\n" "Return a list of all servers\n" ); static PyObject *py_servers(PyObject *self, PyObject *args) { return py_irssi_chatlist_new(servers, 1); } PyDoc_STRVAR(py_channels_doc, "channels() -> list of Channel objects\n" "\n" "Return channel list\n" ); static PyObject *py_channels(PyObject *self, PyObject *args) { return py_irssi_chatlist_new(channels, 1); } PyDoc_STRVAR(py_channel_find_doc, "channel_find(name) -> Channel object or None\n" "\n" "Find channel from any server\n" ); static PyObject *py_channel_find(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; return py_irssi_chat_new(channel_find(NULL, name), 1); } PyDoc_STRVAR(py_windows_doc, "windows() -> list of Window objects\n" "\n" "Get a list of all windows\n" ); static PyObject *py_windows(PyObject *self, PyObject *args) { return py_irssi_objlist_new(windows, 1, (InitFunc)pywindow_new); } PyDoc_STRVAR(py_active_win_doc, "active_win() -> Window object\n" "\n" "Return active window\n" ); static PyObject *py_active_win(PyObject *self, PyObject *args) { if (active_win) return pywindow_new(active_win); Py_RETURN_NONE; } PyDoc_STRVAR(py_active_server_doc, "active_server() -> Server object or None\n" "\n" "Return active server\n" ); static PyObject *py_active_server(PyObject *self, PyObject *args) { if (active_win) return py_irssi_chat_new(active_win->active_server, 1); Py_RETURN_NONE; } PyDoc_STRVAR(py_window_find_name_doc, "window_find_name(name) -> Window object or None\n" "\n" "Find window with name\n" ); static PyObject *py_window_find_name(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; WINDOW_REC *win; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; win = window_find_name(name); if (win) return pywindow_new(win); Py_RETURN_NONE; } PyDoc_STRVAR(py_window_find_refnum_doc, "window_find_refnum(refnum) -> Window object or None\n" "\n" "Find window with reference number\n" ); static PyObject *py_window_find_refnum(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"refnum", NULL}; int refnum = 0; WINDOW_REC *win; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &refnum)) return NULL; win = window_find_refnum(refnum); if (win) return pywindow_new(win); Py_RETURN_NONE; } PyDoc_STRVAR(py_window_refnum_prev_doc, "window_refnum_prev(refnum, wrap) -> int\n" "\n" "Return refnum for window that's previous in window list\n" ); static PyObject *py_window_refnum_prev(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"refnum", "wrap", NULL}; int refnum = 0; int wrap = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ii", kwlist, &refnum, &wrap)) return NULL; return PyInt_FromLong(window_refnum_prev(refnum, wrap)); } PyDoc_STRVAR(py_window_refnum_next_doc, "window_refnum_next(refnum, wrap) -> int\n" "\n" "Return refnum for window that's next in window list\n" ); static PyObject *py_window_refnum_next(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"refnum", "wrap", NULL}; int refnum = 0; int wrap = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ii", kwlist, &refnum, &wrap)) return NULL; return PyInt_FromLong(window_refnum_next(refnum, wrap)); } PyDoc_STRVAR(py_windows_refnum_last_doc, "windows_refnum_last() -> int\n" "\n" "Return refnum for last window.\n" ); static PyObject *py_windows_refnum_last(PyObject *self, PyObject *args) { return PyInt_FromLong(windows_refnum_last()); } PyDoc_STRVAR(py_window_find_level_doc, "window_find_level(level) -> Window object or None\n" "\n" "Find window with level.\n" ); static PyObject *py_window_find_level(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"level", NULL}; int level = 0; WINDOW_REC *win; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &level)) return NULL; win = window_find_level(NULL, level); if (win) return pywindow_new(win); Py_RETURN_NONE; } PyDoc_STRVAR(py_window_find_item_doc, "window_find_item(name) -> Window object or None\n" "\n" "Find window which contains window item with specified name.\n" ); static PyObject *py_window_find_item(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; WINDOW_REC *win; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; win = window_find_item(NULL, name); if (win) return pywindow_new(win); Py_RETURN_NONE; } PyDoc_STRVAR(py_window_find_closest_doc, "window_find_closest(name, level) -> Window object or None\n" "\n" "Find window that matches best to given arguments. `name' can be either\n" "window name or name of one of the window items.\n" ); static PyObject *py_window_find_closest(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", "level", NULL}; char *name = ""; int level = 0; WINDOW_REC *win; if (!PyArg_ParseTupleAndKeywords(args, kwds, "si", kwlist, &name, &level)) return NULL; win = window_find_closest(NULL, name, level); if (win) return pywindow_new(win); Py_RETURN_NONE; } PyDoc_STRVAR(py_window_item_find_doc, "window_item_find(name) -> WindowItem object or None\n" "\n" "Find window item that matches best to given arguments.\n" ); static PyObject *py_window_item_find(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; return py_irssi_chat_new(window_item_find(NULL, name), 1); } /*XXX: this could be __init__ for Window */ PyDoc_STRVAR(py_window_create_doc, "window_create(item=None, automatic=False) -> Window object\n" "\n" "Create a new window\n" ); static PyObject *py_window_create(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"item", "automatic", NULL}; PyObject *item = NULL; int automatic = 0; WI_ITEM_REC *witem = NULL; WINDOW_REC *win; if (!PyArg_ParseTupleAndKeywords(args, kwds, "|Oi", kwlist, &item, &automatic)) return NULL; if (item) { if (pywindow_item_check(item)) { witem = ((PyWindowItem*)item)->data; if (!witem) return PyErr_Format(PyExc_TypeError, "invalid window item"); else if (witem->server != NULL) return PyErr_Format(PyExc_TypeError, "window item already assigned to window"); } else if (item == Py_None) ; else return PyErr_Format(PyExc_TypeError, "item must be window item or None"); } win = window_create(witem, automatic); if (win) return pywindow_new(win); Py_RETURN_NONE; } PyDoc_STRVAR(py_server_find_tag_doc, "server_find_tag(tag) -> Server object or None\n" "\n" "Find server with tag\n" ); static PyObject *py_server_find_tag(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"tag", NULL}; char *tag = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &tag)) return NULL; return py_irssi_chat_new(server_find_tag(tag), 1); } PyDoc_STRVAR(py_server_find_chatnet_doc, "server_find_chatnet(chatnet) -> Server object or None\n" "\n" "Find first server that is in chatnet\n" ); static PyObject *py_server_find_chatnet(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"chatnet", NULL}; char *chatnet = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &chatnet)) return NULL; return py_irssi_chat_new(server_find_chatnet(chatnet), 1); } PyDoc_STRVAR(py_queries_doc, "queries() -> list of Query objects\n" "\n" "Return a list of open queries.\n" ); static PyObject *py_queries(PyObject *self, PyObject *args) { return py_irssi_chatlist_new(queries, 1); } PyDoc_STRVAR(py_query_find_doc, "query_find(nick) -> Query object or None\n" "\n" "Find a query from any server.\n" ); static PyObject *py_query_find(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"nick", NULL}; char *nick = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &nick)) return NULL; return py_irssi_chat_new(query_find(NULL, nick), 1); } PyDoc_STRVAR(py_mask_match_doc, "mask_match(mask, nick, user, host) -> bool\n" "\n" "Return true if mask matches nick!user@host\n" ); static PyObject *py_mask_match(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"mask", "nick", "user", "host", NULL}; char *mask = ""; char *nick = ""; char *user = ""; char *host = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ssss", kwlist, &mask, &nick, &user, &host)) return NULL; return PyBool_FromLong(mask_match(NULL, mask, nick, user, host)); } PyDoc_STRVAR(py_mask_match_address_doc, "mask_match_address(mask, nick, address) -> bool\n" "\n" "Return True if mask matches nick!address\n" ); static PyObject *py_mask_match_address(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"mask", "nick", "address", NULL}; char *mask = ""; char *nick = ""; char *address = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "sss", kwlist, &mask, &nick, &address)) return NULL; return PyBool_FromLong(mask_match_address(NULL, mask, nick, address)); } PyDoc_STRVAR(py_masks_match_doc, "masks_match(masks, nick, address) -> bool\n" "\n" "Return True if any mask in the masks (string separated by spaces)\n" "matches nick!address\n" ); static PyObject *py_masks_match(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"masks", "nick", "address", NULL}; char *masks = ""; char *nick = ""; char *address = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "sss", kwlist, &masks, &nick, &address)) return NULL; return PyBool_FromLong(masks_match(NULL, masks, nick, address)); } PyDoc_STRVAR(py_rawlog_set_size_doc, "rawlog_set_size(lines) -> None\n" "\n" "Set the default rawlog size for new rawlogs.\n" ); static PyObject *py_rawlog_set_size(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"lines", NULL}; int lines = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &lines)) return NULL; rawlog_set_size(lines); Py_RETURN_NONE; } PyDoc_STRVAR(py_logs_doc, "logs() -> list of Log objects\n" "\n" "Return list of logs.\n" ); static PyObject *py_logs(PyObject *self, PyObject *args) { return py_irssi_objlist_new(logs, 1, (InitFunc)pylog_new); } PyDoc_STRVAR(py_log_find_doc, "log_find(fname) -> Log object or None\n" "\n" "Find log by file name.\n" ); static PyObject *py_log_find(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"fname", NULL}; char *fname = ""; LOG_REC *log; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &fname)) return NULL; log = log_find(fname); if (log) return pylog_new(log); Py_RETURN_NONE; } PyDoc_STRVAR(py_ignores_doc, "ignores() -> list of Ignore objects\n" "\n" "Return a list of ignore entries\n" ); static PyObject *py_ignores(PyObject *self, PyObject *args) { return py_irssi_objlist_new(ignores, 1, (InitFunc)pyignore_new); } PyDoc_STRVAR(py_ignore_check_doc, "ignore_check(nick, host, channel, text, level) -> bool\n" "\n" "Return True if ignore matches\n" ); static PyObject *py_ignore_check(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"nick", "host", "channel", "text", "level", NULL}; char *nick = ""; char *host = ""; char *channel = ""; char *text = ""; int level = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ssssi", kwlist, &nick, &host, &channel, &text, &level)) return NULL; return PyBool_FromLong(ignore_check(NULL, nick, host, channel, text, level)); } PyDoc_STRVAR(py_dccs_doc, "dccs() -> list of Dcc objects\n" "\n" "Return list of active DCCs\n" ); static PyObject *py_dccs(PyObject *self, PyObject *args) { return py_irssi_list_new(dcc_conns, 1); } PyDoc_STRVAR(py_dcc_register_type_doc, "dcc_register_type(type) -> None\n" "\n" "???\n" ); static PyObject *py_dcc_register_type(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"type", NULL}; char *type = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &type)) return NULL; dcc_register_type(type); Py_RETURN_NONE; } PyDoc_STRVAR(py_dcc_unregister_type_doc, "dcc_unregister_type(type) -> None\n" "\n" "???\n" ); static PyObject *py_dcc_unregister_type(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"type", NULL}; char *type = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &type)) return NULL; dcc_unregister_type(type); Py_RETURN_NONE; } PyDoc_STRVAR(py_dcc_find_request_latest_doc, "dcc_find_request_latest(type) -> Dcc object or None\n" "\n" "???\n" ); static PyObject *py_dcc_find_request_latest(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"type", NULL}; int type = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &type)) return NULL; return py_irssi_new(dcc_find_request_latest(type), 1); } PyDoc_STRVAR(py_dcc_find_request_doc, "dcc_find_request(type, nick, arg) -> Dcc object or None\n" "\n" "???\n" ); static PyObject *py_dcc_find_request(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"type", "nick", "arg", NULL}; int type = 0; char *nick = ""; char *arg = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "iss", kwlist, &type, &nick, &arg)) return NULL; return py_irssi_new(dcc_find_request(type, nick, arg), 1); } PyDoc_STRVAR(py_dcc_chat_find_id_doc, "dcc_chat_find_id(id) -> Dcc object or None\n" "\n" "???\n" ); static PyObject *py_dcc_chat_find_id(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"id", NULL}; char *id = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &id)) return NULL; return py_irssi_new(dcc_chat_find_id(id), 1); } PyDoc_STRVAR(py_dcc_str2type_doc, "dcc_str2type(type) -> int\n" "\n" "???\n" ); static PyObject *py_dcc_str2type(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"type", NULL}; char *type = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &type)) return NULL; return PyInt_FromLong(dcc_str2type(type)); } PyDoc_STRVAR(py_dcc_type2str_doc, "dcc_type2str(type) -> str or None\n" "\n" "???\n" ); static PyObject *py_dcc_type2str(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"type", NULL}; int type = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &type)) return NULL; RET_AS_STRING_OR_NONE(dcc_type2str(type)); } PyDoc_STRVAR(py_dcc_get_download_path_doc, "dcc_get_download(fname) -> str\n" "\n" "???\n" ); static PyObject *py_dcc_get_download_path(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"fname", NULL}; char *fname = ""; char *path; PyObject *pypath; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &fname)) return NULL; path = dcc_get_download_path(fname); if (!path) Py_RETURN_NONE; /*XXX: how to handle? */ pypath = PyString_FromString(path); g_free(path); return pypath; } PyDoc_STRVAR(py_notifies_doc, "notifies() -> list of Notifylist objects\n" "\n" "Return list of notifies\n" ); static PyObject *py_notifies(PyObject *self, PyObject *args) { return py_irssi_objlist_new(notifies, 1, (InitFunc)pynotifylist_new); } PyDoc_STRVAR(py_notifylist_add_doc, "notifylist_add(mask, ircnets=None, away_check=0, idle_time_check=0) -> Notifylist object\n" "\n" "Add new item to notify list\n" ); static PyObject *py_notifylist_add(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"mask", "ircnets", "away_check", NULL}; char *mask = ""; char *ircnets = NULL; int away_check = 0; NOTIFYLIST_REC *rec; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s|zi", kwlist, &mask, &ircnets, &away_check)) return NULL; rec = notifylist_add(mask, ircnets, away_check); if (rec) return pynotifylist_new(rec); Py_RETURN_NONE; } PyDoc_STRVAR(py_notifylist_remove_doc, "notifylist_remove(mask) -> None\n" "\n" "Remove notify item from notify list\n" ); static PyObject *py_notifylist_remove(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"mask", NULL}; char *mask = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &mask)) return NULL; notifylist_remove(mask); Py_RETURN_NONE; } PyDoc_STRVAR(py_notifylist_ison_doc, "notifylist_ison(nick, serverlist=\"\") -> IrcServer object\n" "\n" "Check if nick is in IRC. serverlist is a space separated list of server tags.\n" "If it's empty string, all servers will be checked\n" ); static PyObject *py_notifylist_ison(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"nick", "serverlist", NULL}; char *nick = ""; char *serverlist = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s|s", kwlist, &nick, &serverlist)) return NULL; return py_irssi_chat_new(notifylist_ison(nick, serverlist), 1); } PyDoc_STRVAR(py_notifylist_find_doc, "notifylist_find(mask, ircnet=None) -> Notifylist object\n" "\n" "Find notify\n" ); static PyObject *py_notifylist_find(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"mask", "ircnet", NULL}; char *mask = ""; char *ircnet = NULL; NOTIFYLIST_REC *rec; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s|z", kwlist, &mask, &ircnet)) return NULL; rec = notifylist_find(mask, ircnet); if (rec) return pynotifylist_new(rec); Py_RETURN_NONE; } PyDoc_STRVAR(py_commands_doc, "commands() -> list of Command objects\n" "\n" "Return a list of all commands.\n" ); static PyObject *py_commands(PyObject *self, PyObject *args) { return py_irssi_objlist_new(commands, 1, (InitFunc)pycommand_new); } PyDoc_STRVAR(py_level2bits_doc, "level2bits(level) -> long\n" "\n" "Level string -> number\n" ); static PyObject *py_level2bits(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"level", NULL}; char *level = ""; int error = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &level)) return NULL; return PyLong_FromUnsignedLong(level2bits(level, &error)); } PyDoc_STRVAR(py_bits2level_doc, "bits2level(bits) -> str\n" "\n" "Level number -> string\n" ); static PyObject *py_bits2level(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"bits", NULL}; unsigned bits; char *str; PyObject *ret; if (!PyArg_ParseTupleAndKeywords(args, kwds, "I", kwlist, &bits)) return NULL; str = bits2level(bits); if (str) { ret = PyString_FromString(str); g_free(str); return ret; } Py_RETURN_NONE; } PyDoc_STRVAR(py_combine_level_doc, "combine_level(level, str) -> long\n" "\n" "Combine level number to level string ('+level -level'). Return new level number.\n" ); static PyObject *py_combine_level(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"level", "str", NULL}; int level = 0; char *str = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "is", kwlist, &level, &str)) return NULL; return PyLong_FromUnsignedLong(combine_level(level, str)); } PyDoc_STRVAR(py_signal_emit_doc, "signal_emit(signal, *args) -> None\n" "\n" "Emit an Irssi signal with up to 6 arguments\n" ); static PyObject *py_signal_emit(PyObject *self, PyObject *args) { PyObject *pysig; PyObject *sigargs; char *name; int ret; if (PyTuple_Size(args) < 1) return PyErr_Format(PyExc_TypeError, "signal name required"); if (PyTuple_Size(args) > SIGNAL_MAX_ARGUMENTS+1) return PyErr_Format(PyExc_TypeError, "no more than %d arguments for signal accepted", SIGNAL_MAX_ARGUMENTS); pysig = PyTuple_GET_ITEM(args, 0); if (!PyString_Check(pysig)) return PyErr_Format(PyExc_TypeError, "signal must be string"); name = PyString_AsString(pysig); if (!name) return NULL; sigargs = PySequence_GetSlice(args, 1, PyTuple_Size(args)); if (!sigargs) return NULL; ret = pysignals_emit(name, sigargs); Py_DECREF(sigargs); if (!ret) return NULL; Py_RETURN_NONE; } PyDoc_STRVAR(py_signal_continue_doc, "signal_continue(*args) -> None\n" "\n" "Continue (reemit?) the current Irssi signal with up to 6 arguments\n" ); static PyObject *py_signal_continue(PyObject *self, PyObject *args) { if (PyTuple_Size(args) > SIGNAL_MAX_ARGUMENTS) return PyErr_Format(PyExc_TypeError, "no more than %d arguments for signal accepted", SIGNAL_MAX_ARGUMENTS); if (!pysignals_continue(args)) return NULL; Py_RETURN_NONE; } PyDoc_STRVAR(py_signal_stop_doc, "signal_stop() -> None\n" "\n" "Stop the signal that's currently being emitted.\n" ); static PyObject *py_signal_stop(PyObject *self, PyObject *args) { signal_stop(); Py_RETURN_NONE; } PyDoc_STRVAR(py_signal_stop_by_name_doc, "signal_stop_by_name(signal) -> None\n" "\n" "Stop the signal, 'signal', thats currently being emitted by name\n" ); static PyObject *py_signal_stop_by_name(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"signal", NULL}; char *signal = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &signal)) return NULL; signal_stop_by_name(signal); Py_RETURN_NONE; } PyDoc_STRVAR(py_signal_get_emitted_doc, "signal_get_emmited() -> signal name string\n" "\n" "Get name of current signal\n" ); static PyObject *py_signal_get_emitted(PyObject *self, PyObject *args) { RET_AS_STRING_OR_NONE(signal_get_emitted()); } PyDoc_STRVAR(py_signal_get_emitted_id_doc, "signal_get_emmited_id() -> signal id int\n" "\n" "Get id of current signal\n" ); static PyObject *py_signal_get_emitted_id(PyObject *self, PyObject *args) { return PyInt_FromLong(signal_get_emitted_id()); } PyDoc_STRVAR(py_settings_get_str_doc, "settings_get_str(key) -> str\n" "\n" "Get value for setting.\n" ); static PyObject *py_settings_get_str(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", NULL}; char *key = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &key)) return NULL; RET_AS_STRING_OR_NONE(settings_get_str(key)); } PyDoc_STRVAR(py_settings_get_int_doc, "settings_get_int(key) -> int\n" "\n" "Get value for setting." ); static PyObject *py_settings_get_int(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", NULL}; char *key = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &key)) return NULL; return PyInt_FromLong(settings_get_int(key)); } PyDoc_STRVAR(py_settings_get_bool_doc, "settings_get_bool(key) -> bool\n" "\n" "Get value for setting.\n" ); static PyObject *py_settings_get_bool(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", NULL}; char *key = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &key)) return NULL; return PyBool_FromLong(settings_get_bool(key)); } PyDoc_STRVAR(py_settings_get_time_doc, "settings_get_time(key) -> long\n" "\n" "Get value for setting.\n" ); static PyObject *py_settings_get_time(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", NULL}; char *key = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &key)) return NULL; return PyLong_FromLong(settings_get_time(key)); } PyDoc_STRVAR(py_settings_get_level_doc, "settings_get_level(key) -> int\n" "\n" "Get value for setting.\n" ); static PyObject *py_settings_get_level(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", NULL}; char *key = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &key)) return NULL; return PyInt_FromLong(settings_get_level(key)); } PyDoc_STRVAR(py_settings_get_size_doc, "settings_get_size(key) -> long\n" "\n" "Get value for setting.\n" ); static PyObject *py_settings_get_size(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", NULL}; char *key = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &key)) return NULL; return PyLong_FromLong(settings_get_size(key)); } PyDoc_STRVAR(py_settings_set_str_doc, "settings_set_str(key, value) -> None\n" "\n" "Set string value for setting\n" ); static PyObject *py_settings_set_str(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", "value", NULL}; char *key = ""; char *value = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ss", kwlist, &key, &value)) return NULL; settings_set_str(key, value); Py_RETURN_NONE; } PyDoc_STRVAR(py_settings_set_int_doc, "settings_set_int(key, value) -> None\n" "\n" "Set int value for setting" ); static PyObject *py_settings_set_int(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", "value", NULL}; char *key = ""; int value = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "si", kwlist, &key, &value)) return NULL; settings_set_int(key, value); Py_RETURN_NONE; } PyDoc_STRVAR(py_settings_set_bool_doc, "settings_set_bool(key, value) -> None\n" "\n" "Set bool value for setting\n" ); static PyObject *py_settings_set_bool(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", "value", NULL}; char *key = ""; int value = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "si", kwlist, &key, &value)) return NULL; settings_set_bool(key, value); Py_RETURN_NONE; } PyDoc_STRVAR(py_settings_set_time_doc, "settings_set_time(key, value) -> bool\n" "\n" "Set string value for setting\n" ); static PyObject *py_settings_set_time(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", "value", NULL}; char *key = ""; char *value = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ss", kwlist, &key, &value)) return NULL; return PyBool_FromLong(settings_set_time(key, value)); } PyDoc_STRVAR(py_settings_set_level_doc, "settings_set_level(key, value) -> bool\n" "\n" "Set string value for setting\n" ); static PyObject *py_settings_set_level(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", "value", NULL}; char *key = ""; char *value = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ss", kwlist, &key, &value)) return NULL; return PyBool_FromLong(settings_set_level(key, value)); } PyDoc_STRVAR(py_settings_set_size_doc, "settings_set_size(key, value) -> bool\n" "\n" "Set string value for setting\n" ); static PyObject *py_settings_set_size(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"key", "value", NULL}; char *key = ""; char *value = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ss", kwlist, &key, &value)) return NULL; return PyBool_FromLong(settings_set_size(key, value)); } PyDoc_STRVAR(py_pidwait_add_doc, "pidwait_add(pid) -> None\n" "\n" "Add pid to wait list\n" ); static PyObject *py_pidwait_add(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"pid", NULL}; int pid = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &pid)) return NULL; pidwait_add(pid); Py_RETURN_NONE; } PyDoc_STRVAR(py_pidwait_remove_doc, "pidwait_remove(pid) -> None\n" "\n" "Remove pid from wait list\n" ); static PyObject *py_pidwait_remove(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"pid", NULL}; int pid = 0; if (!PyArg_ParseTupleAndKeywords(args, kwds, "i", kwlist, &pid)) return NULL; pidwait_remove(pid); Py_RETURN_NONE; } PyDoc_STRVAR(py_format_get_length_doc, "format_get_length(str) -> int length\n" ); static PyObject *py_format_get_length(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"str", NULL}; char *str = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &str)) return NULL; return PyInt_FromLong(format_get_length(str)); } PyDoc_STRVAR(py_format_real_length_doc, "format_real_length(str, len) -> int length\n" ); static PyObject *py_format_real_length(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"str", "len", NULL}; char *str = ""; int len; if (!PyArg_ParseTupleAndKeywords(args, kwds, "sl", kwlist, &str, &len)) return NULL; return PyInt_FromLong(format_real_length(str, len)); } PyDoc_STRVAR(py_strip_codes_doc, "strip_codes(input) -> str\n" ); static PyObject *py_strip_codes(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"input", NULL}; char *input = ""; char *ret; PyObject *pyret; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &input)) return NULL; ret = strip_codes(input); if (ret) { pyret = PyString_FromString(ret); g_free(ret); return pyret; } Py_RETURN_NONE; } #if 0 PyDoc_STRVAR(py_format_get_text_doc, "format_get_text(textdest, module, formatnum, ...) -> str\n" "\n" "Return a substituted format string from module and formatnum.\n" "module is a string.\n" "\n" "Example:\n" "TODO\n" ); static PyObject *py_format_get_text(PyObject *self, PyObject *varargs) { PyTextDest *textdest = NULL; char *module = ""; unsigned int formatnum = 0; PyObject *args = NULL, *pycharargs = NULL; THEME_REC *theme; MODULE_THEME_REC *modtheme; char **charargs = NULL; char *ret; int i; args = PySequence_GetSlice(varargs, 0, 3); if (!args) goto error; pycharargs = PySequence_GetSlice(varargs, 3, PyTuple_Size(varargs)); if (!pycharargs) goto error; if (!PyArg_ParseTuple(args, "OsI", &textdest, &module, &formatnum)) goto error; if (!pytextdest_check((PyObject *)textdest)) { PyErr_Format(PyExc_TypeError, "arg 1 must be TextDest"); goto error; } /* Bleh, check that formatnum is within range */ theme = window_get_theme(textdest->data->window); /* FIXME: how to boundscheck formatnum ?? */ /* size + 1 for terminating NULL ptr */ charargs = g_new0(char *, PyTuple_Size(pycharargs) + 1); for (i = 0; i < PyTuple_Size(pycharargs); i++) { PyObject *obj = PyTuple_GET_ITEM(pycharargs, i); char *str; if (!PyString_Check(obj)) { PyErr_Format(PyExc_TypeError, "non string in string argument list (arg %d)", i + 4); goto error; } str = PyString_AsString(obj); if (!str) goto error; charargs[i] = str; } /* return string, or if string is NULL, return None */ ret = format_get_text_theme_charargs(theme, module, DATA(textdest), formatnum, charargs); Py_DECREF(args); Py_DECREF(pycharargs); g_free(charargs); if (ret) { PyObject *pyret; pyret = PyString_FromString(ret); g_free(ret); return pyret; } Py_RETURN_NONE; error: Py_XDECREF(args); Py_XDECREF(pycharargs); g_free(charargs); return NULL; } #endif PyDoc_STRVAR(py_themes_reload_doc, "themes_reload() -> None\n" ); static PyObject *py_themes_reload(PyObject *self, PyObject *args) { themes_reload(); Py_RETURN_NONE; } PyDoc_STRVAR(py_current_theme_doc, "current_theme() -> Theme object\n" ); static PyObject *py_current_theme(PyObject *self, PyObject *args) { if (current_theme) return pytheme_new(current_theme); Py_RETURN_NONE; } PyDoc_STRVAR(py_statusbar_items_redraw_doc, "statusbar_items_redraw(name) -> None\n" ); static PyObject *py_statusbar_items_redraw(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; statusbar_items_redraw(name); Py_RETURN_NONE; } PyDoc_STRVAR(py_statusbars_recreate_items_doc, "statusbars_recreate_items() -> None" ); static PyObject *py_statusbars_recreate_items(PyObject *self, PyObject *args) { statusbars_recreate_items(); Py_RETURN_NONE; } /* XXX: we can unregister any statusbar items, not just the ones from this script */ PyDoc_STRVAR(py_statusbar_item_unregister_doc, "statusbar_item_unregister(name) -> None" ); static PyObject *py_statusbar_item_unregister(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"name", NULL}; char *name = ""; if (!PyArg_ParseTupleAndKeywords(args, kwds, "s", kwlist, &name)) return NULL; pystatusbar_item_unregister(name); Py_RETURN_NONE; } PyDoc_STRVAR(py_active_mainwin_doc, "active_mainwin() -> MainWindow object\n" "\n" "return active main window\n" ); static PyObject *py_active_mainwin(PyObject *self, PyObject *args) { if (!active_mainwin) Py_RETURN_NONE; return pymain_window_new(active_mainwin); } PyDoc_STRVAR(py_mainwindows_doc, "mainwindows() -> list of MainWindow objects\n" "\n" "return a list of mainwindows\n" ); static PyObject *py_mainwindows(PyObject *self, PyObject *args) { return py_irssi_objlist_new(mainwindows, 1, (InitFunc)pymain_window_new); } /* expect a list of tuples [('str', 0), ...] */ static GSList *py_register_conv(PyObject *list) { int i; GSList *ret = NULL; if (list == Py_None) return NULL; if (!PyList_Check(list)) { PyErr_Format(PyExc_TypeError, "expect a list of tuples of string and int"); return NULL; } for (i = 0; i < PyList_Size(list); i++) { char *key; int val; PyObject *tup = PyList_GET_ITEM(list, i); if (!PyTuple_Check(tup) || !PyArg_ParseTuple(tup, "si", &key, &val)) { if (!PyErr_Occurred() || PyErr_ExceptionMatches(PyExc_TypeError)) { PyErr_Clear(); PyErr_SetString(PyExc_TypeError, "expect a list of tuples of string and int"); } /* return the list so far; caller will clear it on error */ break; } ret = g_slist_append(ret, g_strdup(key)); ret = g_slist_append(ret, GINT_TO_POINTER(val)); } return ret; } PyDoc_STRVAR(py_server_redirect_register_doc, "server_redirect_register(command, stop, start=None, opt=None, remote=False, timeout=0) -> None\n" "\n" "Register new redirection command. By default irssi has already\n" "registered at least: whois, whowas, who, list, ison, userhost, ping,\n" "\"mode channel\" (/MODE #channel), \"mode b\" (/MODE #channel b), \"mode e\"\n" "and \"mode I\".\n" "\n" "`command' specifies the name of the command to register, it doesn't\n" "have to be a real command name, but something you just specify to\n" "Server.redirect_event() when using this redirection.\n" "\n" "`start', `stop', `opt' - lists of ('event', argpos) tuples.\n" "List of events that start and stop this redirection.\n" "Start event list may be empty, but there must be at least one\n" "stop event. Optional events are checked only if they are received\n" "immediately after one of the stop-events. `argpos' specifies the\n" "word number in event string which is compared to wanted argument,\n" "-1 = don't compare, TRUE always.\n" "\n" "`remote' specifies if the command is by default a remote command\n" "(eg. sent to another server). Server.redirect_event() may override this.\n" "\n" "`timeout' - If remote is TRUE, specifies how many seconds to wait for\n" "reply before aborting.\n" "\n" "Example (already done by irssi):\n" "\n" "server_redirect_register('mode channel',\n" " start = None,\n" " stop = [ \n" " ('event 324', 1), # MODE-reply\n" " ('event 403', 1), # no such channel\n" " ('event 442', 1), # \"you're not on that channel\"\n" " ('event 479', 1) # \"Cannot join channel (illegal name)\"\n" " ], \n" " opt = [ \n" " ('event 329', 1) # Channel create time\n" " ] \n" ")\n" ); static PyObject *py_server_redirect_register(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"command", "stop", "start", "opt", "remote", "timeout", NULL}; char *command = ""; int remote = 0; int timeout = 0; PyObject *start = NULL; PyObject *stop = NULL; PyObject *opt = NULL; GSList *node; GSList *gstart = NULL; GSList *gstop = NULL; GSList *gopt = NULL; if (!PyArg_ParseTupleAndKeywords(args, kwds, "sO|OOii", kwlist, &command, &stop, &start, &opt, &remote, &timeout)) return NULL; gstart = py_register_conv(start); if (PyErr_Occurred()) goto error; gstop = py_register_conv(stop); if (!gstop || PyErr_Occurred()) { if (!PyErr_Occurred()) PyErr_SetString(PyExc_TypeError, "stop list must be provided"); goto error; } gopt = py_register_conv(opt); if (PyErr_Occurred()) goto error; server_redirect_register_list(command, remote, timeout, gstart, gstop, gopt); Py_RETURN_NONE; error: /* clean up all lists */ for (node = gstart; node; node = node->next->next) g_free(node->data); for (node = gstop; node; node = node->next->next) g_free(node->data); for (node = gopt; node; node = node->next->next) g_free(node->data); g_slist_free(gstart); g_slist_free(gstop); g_slist_free(gopt); return NULL; } PyDoc_STRVAR(py_command_runsub_doc, "command_runsub(cmd, data, server=None, item=None) -> None\n" "\n" "Run subcommands for `cmd'. First word in `data' is parsed as\n" "subcommand. `server' is Server object for current\n" "WindowItem `item'.\n" "\n" "Call command_runsub in handler function for `cmd' and bind\n" "with command_bind(\"`cmd' `subcmd'\", subcmdfunc[, category]);\n" ); static PyObject *py_command_runsub(PyObject *self, PyObject *args, PyObject *kwds) { static char *kwlist[] = {"cmd", "data", "server", "item", NULL}; char *cmd = ""; char *data = ""; PyObject *pserver = Py_None; PyObject *pitem = Py_None; SERVER_REC *server = NULL; WI_ITEM_REC *item = NULL; if (!PyArg_ParseTupleAndKeywords(args, kwds, "ss|OO", kwlist, &cmd, &data, &pserver, &pitem)) return NULL; if (pserver != Py_None && !pyserver_check(pserver)) return PyErr_Format(PyExc_TypeError, "server must be a server"); if (pitem != Py_None && !pywindow_item_check(pitem)) return PyErr_Format(PyExc_TypeError, "item must be a window item"); if (pserver != Py_None) server = DATA(pserver); if (pitem != Py_None) item = DATA(pitem); command_runsub(cmd, data, server, item); Py_RETURN_NONE; } static PyMethodDef ModuleMethods[] = { {"prnt", (PyCFunction)py_prnt, METH_VARARGS | METH_KEYWORDS, py_prnt_doc}, {"get_script", (PyCFunction)py_get_script, METH_NOARGS, py_get_script_doc}, {"chatnet_find", (PyCFunction)py_chatnet_find, METH_VARARGS | METH_KEYWORDS, py_chatnet_find_doc}, {"chatnets", (PyCFunction)py_chatnets, METH_NOARGS, py_chatnets_doc}, {"reconnects", (PyCFunction)py_reconnects, METH_NOARGS, py_reconnects_doc}, {"servers", (PyCFunction)py_servers, METH_NOARGS, py_servers_doc}, {"windows", (PyCFunction)py_windows, METH_NOARGS, py_windows_doc}, {"active_win", (PyCFunction)py_active_win, METH_NOARGS, py_active_win_doc}, {"active_server", (PyCFunction)py_active_server, METH_NOARGS, py_active_server_doc}, {"window_find_name", (PyCFunction)py_window_find_name, METH_VARARGS | METH_KEYWORDS, py_window_find_name_doc}, {"window_find_refnum", (PyCFunction)py_window_find_refnum, METH_VARARGS | METH_KEYWORDS, py_window_find_refnum_doc}, {"window_refnum_prev", (PyCFunction)py_window_refnum_prev, METH_VARARGS | METH_KEYWORDS, py_window_refnum_prev_doc}, {"window_refnum_next", (PyCFunction)py_window_refnum_next, METH_VARARGS | METH_KEYWORDS, py_window_refnum_next_doc}, {"windows_refnum_last", (PyCFunction)py_windows_refnum_last, METH_NOARGS, py_windows_refnum_last_doc}, {"window_find_level", (PyCFunction)py_window_find_level, METH_VARARGS | METH_KEYWORDS, py_window_find_level_doc}, {"window_find_item", (PyCFunction)py_window_find_item, METH_VARARGS | METH_KEYWORDS, py_window_find_item_doc}, {"window_find_closest", (PyCFunction)py_window_find_closest, METH_VARARGS | METH_KEYWORDS, py_window_find_closest_doc}, {"window_item_find", (PyCFunction)py_window_item_find, METH_VARARGS | METH_KEYWORDS, py_window_item_find_doc}, {"window_create", (PyCFunction)py_window_create, METH_VARARGS | METH_KEYWORDS, py_window_create_doc}, {"server_find_tag", (PyCFunction)py_server_find_tag, METH_VARARGS | METH_KEYWORDS, py_server_find_tag_doc}, {"server_find_chatnet", (PyCFunction)py_server_find_chatnet, METH_VARARGS | METH_KEYWORDS, py_server_find_chatnet_doc}, {"command", (PyCFunction)PY_command, METH_VARARGS | METH_KEYWORDS, PY_command_doc}, {"channels", (PyCFunction)py_channels, METH_NOARGS, py_channels_doc}, {"channel_find", (PyCFunction)py_channel_find, METH_VARARGS | METH_KEYWORDS, py_channel_find_doc}, {"query_find", (PyCFunction)py_query_find, METH_VARARGS | METH_KEYWORDS, py_query_find_doc}, {"queries", (PyCFunction)py_queries, METH_NOARGS, py_queries_doc}, {"mask_match", (PyCFunction)py_mask_match, METH_VARARGS | METH_KEYWORDS, py_mask_match_doc}, {"mask_match_address", (PyCFunction)py_mask_match_address, METH_VARARGS | METH_KEYWORDS, py_mask_match_address_doc}, {"masks_match", (PyCFunction)py_masks_match, METH_VARARGS | METH_KEYWORDS, py_masks_match_doc}, {"rawlog_set_size", (PyCFunction)py_rawlog_set_size, METH_VARARGS | METH_KEYWORDS, py_rawlog_set_size_doc}, {"logs", (PyCFunction)py_logs, METH_NOARGS, py_logs_doc}, {"log_find", (PyCFunction)py_log_find, METH_VARARGS | METH_KEYWORDS, py_log_find_doc}, {"ignores", (PyCFunction)py_ignores, METH_NOARGS, py_ignores_doc}, {"ignore_check", (PyCFunction)py_ignore_check, METH_VARARGS | METH_KEYWORDS, py_ignore_check_doc}, {"dccs", (PyCFunction)py_dccs, METH_NOARGS, py_dccs_doc}, {"dcc_register_type", (PyCFunction)py_dcc_register_type, METH_VARARGS | METH_KEYWORDS, py_dcc_register_type_doc}, {"dcc_unregister_type", (PyCFunction)py_dcc_unregister_type, METH_VARARGS | METH_KEYWORDS, py_dcc_unregister_type_doc}, {"dcc_find_request_latest", (PyCFunction)py_dcc_find_request_latest, METH_VARARGS | METH_KEYWORDS, py_dcc_find_request_latest_doc}, {"dcc_find_request", (PyCFunction)py_dcc_find_request, METH_VARARGS | METH_KEYWORDS, py_dcc_find_request_doc}, {"dcc_chat_find_id", (PyCFunction)py_dcc_chat_find_id, METH_VARARGS | METH_KEYWORDS, py_dcc_chat_find_id_doc}, {"dcc_str2type", (PyCFunction)py_dcc_str2type, METH_VARARGS | METH_KEYWORDS, py_dcc_str2type_doc}, {"dcc_type2str", (PyCFunction)py_dcc_type2str, METH_VARARGS | METH_KEYWORDS, py_dcc_type2str_doc}, {"dcc_get_download_path", (PyCFunction)py_dcc_get_download_path, METH_VARARGS | METH_KEYWORDS, py_dcc_get_download_path_doc}, {"notifies", (PyCFunction)py_notifies, METH_NOARGS, py_notifies_doc}, {"notifylist_add", (PyCFunction)py_notifylist_add, METH_VARARGS | METH_KEYWORDS, py_notifylist_add_doc}, {"notifylist_remove", (PyCFunction)py_notifylist_remove, METH_VARARGS | METH_KEYWORDS, py_notifylist_remove_doc}, {"notifylist_ison", (PyCFunction)py_notifylist_ison, METH_VARARGS | METH_KEYWORDS, py_notifylist_ison_doc}, {"notifylist_find", (PyCFunction)py_notifylist_find, METH_VARARGS | METH_KEYWORDS, py_notifylist_find_doc}, {"commands", (PyCFunction)py_commands, METH_NOARGS, py_commands_doc}, {"level2bits", (PyCFunction)py_level2bits, METH_VARARGS | METH_KEYWORDS, py_level2bits_doc}, {"bits2level", (PyCFunction)py_bits2level, METH_VARARGS | METH_KEYWORDS, py_bits2level_doc}, {"combine_level", (PyCFunction)py_combine_level, METH_VARARGS | METH_KEYWORDS, py_combine_level_doc}, {"signal_emit", (PyCFunction)py_signal_emit, METH_VARARGS, py_signal_emit_doc}, {"signal_stop", (PyCFunction)py_signal_stop, METH_NOARGS, py_signal_stop_doc}, {"signal_stop_by_name", (PyCFunction)py_signal_stop_by_name, METH_VARARGS | METH_KEYWORDS, py_signal_stop_by_name_doc}, {"signal_get_emitted", (PyCFunction)py_signal_get_emitted, METH_NOARGS, py_signal_get_emitted_doc}, {"signal_get_emitted_id", (PyCFunction)py_signal_get_emitted_id, METH_NOARGS, py_signal_get_emitted_id_doc}, {"signal_continue", (PyCFunction)py_signal_continue, METH_VARARGS, py_signal_continue_doc}, {"settings_get_str", (PyCFunction)py_settings_get_str, METH_VARARGS | METH_KEYWORDS, py_settings_get_str_doc}, {"settings_get_int", (PyCFunction)py_settings_get_int, METH_VARARGS | METH_KEYWORDS, py_settings_get_int_doc}, {"settings_get_bool", (PyCFunction)py_settings_get_bool, METH_VARARGS | METH_KEYWORDS, py_settings_get_bool_doc}, {"settings_get_time", (PyCFunction)py_settings_get_time, METH_VARARGS | METH_KEYWORDS, py_settings_get_time_doc}, {"settings_get_level", (PyCFunction)py_settings_get_level, METH_VARARGS | METH_KEYWORDS, py_settings_get_level_doc}, {"settings_get_size", (PyCFunction)py_settings_get_size, METH_VARARGS | METH_KEYWORDS, py_settings_get_size_doc}, {"settings_set_str", (PyCFunction)py_settings_set_str, METH_VARARGS | METH_KEYWORDS, py_settings_set_str_doc}, {"settings_set_int", (PyCFunction)py_settings_set_int, METH_VARARGS | METH_KEYWORDS, py_settings_set_int_doc}, {"settings_set_bool", (PyCFunction)py_settings_set_bool, METH_VARARGS | METH_KEYWORDS, py_settings_set_bool_doc}, {"settings_set_time", (PyCFunction)py_settings_set_time, METH_VARARGS | METH_KEYWORDS, py_settings_set_time_doc}, {"settings_set_level", (PyCFunction)py_settings_set_level, METH_VARARGS | METH_KEYWORDS, py_settings_set_level_doc}, {"settings_set_size", (PyCFunction)py_settings_set_size, METH_VARARGS | METH_KEYWORDS, py_settings_set_size_doc}, {"pidwait_add", (PyCFunction)py_pidwait_add, METH_VARARGS | METH_KEYWORDS, py_pidwait_add_doc}, {"pidwait_remove", (PyCFunction)py_pidwait_remove, METH_VARARGS | METH_KEYWORDS, py_pidwait_remove_doc}, {"format_get_length", (PyCFunction)py_format_get_length, METH_VARARGS | METH_KEYWORDS, py_format_get_length_doc}, {"format_real_length", (PyCFunction)py_format_real_length, METH_VARARGS | METH_KEYWORDS, py_format_real_length_doc}, {"strip_codes", (PyCFunction)py_strip_codes, METH_VARARGS | METH_KEYWORDS, py_strip_codes_doc}, /*{"format_get_text", (PyCFunction)py_format_get_text, METH_VARARGS, py_format_get_text_doc},*/ {"themes_reload", (PyCFunction)py_themes_reload, METH_NOARGS, py_themes_reload_doc}, {"current_theme", (PyCFunction)py_current_theme, METH_NOARGS, py_current_theme_doc}, {"statusbar_items_redraw", (PyCFunction)py_statusbar_items_redraw, METH_VARARGS | METH_KEYWORDS, py_statusbar_items_redraw_doc}, {"statusbars_recreate_items", (PyCFunction)py_statusbars_recreate_items, METH_NOARGS, py_statusbars_recreate_items_doc}, {"statusbar_item_unregister", (PyCFunction)py_statusbar_item_unregister, METH_VARARGS | METH_KEYWORDS, py_statusbar_item_unregister_doc}, {"active_mainwin", (PyCFunction)py_active_mainwin, METH_NOARGS, py_active_mainwin_doc}, {"mainwindows", (PyCFunction)py_mainwindows, METH_NOARGS, py_mainwindows_doc}, {"server_redirect_register", (PyCFunction)py_server_redirect_register, METH_VARARGS | METH_KEYWORDS, py_server_redirect_register_doc}, {"command_runsub", (PyCFunction)py_command_runsub, METH_VARARGS | METH_KEYWORDS, py_command_runsub_doc}, {NULL, NULL, 0, NULL} /* Sentinel */ }; int pymodule_init(void) { g_return_val_if_fail(py_module == NULL, 0); py_module = Py_InitModule("_irssi", ModuleMethods); if (!py_module) return 0; return 1; } void pymodule_deinit(void) { g_return_if_fail(py_module != NULL); Py_DECREF(py_module); py_module = NULL; }