X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=purple.pyx;h=26a972fa49733504e05b58b51381b2bb158ca9ef;hp=62f441b36161ef6d5d0f22802cf4e72c06d5283d;hb=d5b85c24f1ac2d3fb582e79c995396c4043e7763;hpb=58e62d6e2dade04d4fb010a244447d2b36b669dc diff --git a/purple.pyx b/purple.pyx index 62f441b..26a972f 100644 --- a/purple.pyx +++ b/purple.pyx @@ -36,6 +36,7 @@ cdef core.PurpleCoreUiOps c_core_ui_ops cdef eventloop.PurpleEventLoopUiOps c_eventloop_ui_ops #cdef ft.PurpleXferUiOps c_ft_ui_ops cdef notify.PurpleNotifyUiOps c_notify_ui_ops +#cdef privacy.PurplePrivacyUiOps c_privacy_ui_ops cdef request.PurpleRequestUiOps c_request_ui_ops #cdef roomlist.PurpleRoomlistUiOps c_rlist_ui_ops @@ -49,10 +50,13 @@ include "connection_cbs.pxd" include "conversation_cbs.pxd" #include "xfer_cbs.pxd" include "notify_cbs.pxd" +#include "privacy_cbs.pxd" include "request_cbs.pxd" #include "roomlist_cbs.pxd" include "signal_cbs.pxd" +include "util.pxd" + cdef class Purple: """ Purple class. @@ -68,47 +72,54 @@ cdef class Purple: if default_path is not __DEFAULT_PATH__: __DEFAULT_PATH__ = default_path - debug.c_purple_debug_set_enabled(debug_enabled) - util.c_purple_util_set_user_dir(default_path) + debug.purple_debug_set_enabled(debug_enabled) + util.purple_util_set_user_dir(default_path) plugin.c_purple_plugins_add_search_path(default_path) # adds glib iteration inside ecore main loop ecore.timer_add(0.001, self.__glib_iteration_when_idle) - def __del__(self): + def __get_ui_name(self): + return __APP_NAME__ + ui_name = property(__get_ui_name) + + def destroy(self): core.c_purple_core_quit() cdef void __core_ui_ops_ui_prefs_init(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "ui_prefs_init\n") + debug.purple_debug_info("core_ui_ops", "%s", "ui_prefs_init\n") prefs.c_purple_prefs_load() prefs.c_purple_prefs_add_none("/carman") cdef void __core_ui_ops_debug_init(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "debug_ui_init\n") + debug.purple_debug_info("core_ui_ops", "%s", "debug_ui_init\n") + pass cdef void __core_ui_ops_ui_init(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "ui_init\n") + debug.purple_debug_info("core_ui_ops", "%s", "ui_init\n") - account.c_purple_accounts_set_ui_ops(&c_account_ui_ops) + account.purple_accounts_set_ui_ops(&c_account_ui_ops) connection.c_purple_connections_set_ui_ops(&c_conn_ui_ops) blist.c_purple_blist_set_ui_ops(&c_blist_ui_ops) conversation.c_purple_conversations_set_ui_ops(&c_conv_ui_ops) notify.c_purple_notify_set_ui_ops(&c_notify_ui_ops) + #privacy.c_purple_privacy_set_ui_ops(&c_privacy_ui_ops) request.c_purple_request_set_ui_ops(&c_request_ui_ops) #ft.c_purple_xfers_set_ui_ops(&c_ft_ui_ops) #roomlist.c_purple_roomlist_set_ui_ops(&c_rlist_ui_ops) cdef void __core_ui_ops_quit(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "quit\n") + debug.purple_debug_info("core_ui_ops", "%s", "quit\n") global c_ui_info - account.c_purple_accounts_set_ui_ops(NULL) + account.purple_accounts_set_ui_ops(NULL) connection.c_purple_connections_set_ui_ops(NULL) blist.c_purple_blist_set_ui_ops(NULL) conversation.c_purple_conversations_set_ui_ops(NULL) notify.c_purple_notify_set_ui_ops(NULL) + #privacy.c_purple_privacy_set_ui_ops(NULL) request.c_purple_request_set_ui_ops(NULL) #ft.c_purple_xfers_set_ui_ops(NULL) #roomlist.c_purple_roomlist_set_ui_ops(NULL) @@ -130,24 +141,9 @@ cdef class Purple: glib.g_main_context_iteration(NULL, False) return True - def purple_init(self, callbacks_dict=None): + def purple_init(self): """ Initializes libpurple """ - if callbacks_dict is not None: - global account_cbs - global blist_cbs - global connection_cbs - global conversation_cbs - global notify_cbs - global request_cbs - - account_cbs = callbacks_dict["account"] - blist_cbs = callbacks_dict["blist"] - connection_cbs = callbacks_dict["connection"] - conversation_cbs = callbacks_dict["conversation"] - notify_cbs = callbacks_dict["notify"] - request_cbs = callbacks_dict["request"] - c_account_ui_ops.notify_added = notify_added c_account_ui_ops.status_changed = status_changed c_account_ui_ops.request_add = request_add @@ -219,7 +215,7 @@ cdef class Purple: c_eventloop_ui_ops.input_add = glib_input_add c_eventloop_ui_ops.input_remove = glib.g_source_remove c_eventloop_ui_ops.input_get_error = NULL - c_eventloop_ui_ops.timeout_add_seconds = glib.g_timeout_add_seconds + c_eventloop_ui_ops.timeout_add_seconds = NULL core.c_purple_core_set_ui_ops(&c_core_ui_ops) eventloop.c_purple_eventloop_set_ui_ops(&c_eventloop_ui_ops) @@ -227,12 +223,14 @@ cdef class Purple: # initialize purple core ret = core.c_purple_core_init(__APP_NAME__) if ret is False: - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "main", "Exiting because libpurple initialization failed.\n") + debug.purple_debug_fatal("main", "%s", "libpurple " \ + "initialization failed.\n") return False # check if there is another instance of libpurple running if core.c_purple_core_ensure_single_instance() == False: - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "main", "Exiting because another instance of libpurple is already running.\n") + debug.purple_debug_fatal("main", "%s", "Another instance of " \ + "libpurple is already running.\n") core.c_purple_core_quit() return False @@ -245,40 +243,117 @@ cdef class Purple: return ret - def get_protocols(self): + def add_callback(self, type, name, callback): + """ + Adds a callback with given name inside callback's type. + + @param type Callback type (e.g. "account") + @param name Callback name (e.g. "notify-added") + @param callback Callback to be called + """ + global account_cbs + global blist_cbs + global connection_cbs + global conversation_cbs + global notify_cbs + global request_cbs + + { "account": account_cbs, + "blist": blist_cbs, + "connection": connection_cbs, + "conversation": conversation_cbs, + "notify": notify_cbs, + "request": request_cbs }[type][name] = callback + + def signal_connect(self, name=None, cb=None): + cdef int handle + cdef plugin.PurplePlugin *jabber + + if name is None: + return + + jabber = prpl.c_purple_find_prpl("prpl-jabber") + if jabber == NULL: + return + + global signal_cbs + signal_cbs[name] = cb + + if name == "signed-on": + signals.c_purple_signal_connect( + connection.c_purple_connections_get_handle(), + "signed-on", &handle, + signal_signed_on_cb, NULL) + elif name == "signed-off": + signals.c_purple_signal_connect( + connection.c_purple_connections_get_handle(), + "signed-off", &handle, + signal_signed_off_cb, NULL) + elif name == "connection-error": + signals.c_purple_signal_connect( + connection.c_purple_connections_get_handle(), + "connection-error", &handle, + signal_connection_error_cb, NULL) + elif name == "buddy-signed-on": + signals.c_purple_signal_connect( + blist.c_purple_blist_get_handle(), + "buddy-signed-on", &handle, + signal_buddy_signed_on_cb, NULL) + elif name == "buddy-signed-off": + signals.c_purple_signal_connect( + blist.c_purple_blist_get_handle(), + "buddy-signed-off", &handle, + signal_buddy_signed_off_cb, NULL) + elif name == "receiving-im-msg": + signals.c_purple_signal_connect( + conversation.c_purple_conversations_get_handle(), + "receiving-im-msg", &handle, + signal_receiving_im_msg_cb, NULL) + elif name == "jabber-receiving-xmlnode": + signals.c_purple_signal_connect( + jabber, "jabber-receiving-xmlnode", &handle, + jabber_receiving_xmlnode_cb, NULL) + + def accounts_get_all(self): cdef glib.GList *iter - cdef plugin.PurplePlugin *__plugin - protocols = [] - iter = plugin.c_purple_plugins_get_protocols() + cdef account.PurpleAccount *acc + cdef char *username + cdef char *protocol_id + + iter = account.purple_accounts_get_all() + account_list = [] + while iter: - __plugin = iter.data - if __plugin.info and __plugin.info.name: - protocols += [(__plugin.info.id, __plugin.info.name)] - iter = iter.next - return protocols + acc = iter.data - def connect(self): - conn = Connection() - conn.connect() + if acc: + username = account.purple_account_get_username(acc) + protocol_id = account.purple_account_get_protocol_id(acc) - def attach_signals(self, __signal_cbs=None): - if __signal_cbs is not None: - global signal_cbs - signal_cbs = __signal_cbs + if username != NULL and protocol_id != NULL: + account_list.append(Account(self, username, protocol_id)) + iter = iter.next - cdef int handle + return account_list - signals.c_purple_signal_connect(blist.c_purple_blist_get_handle(), - "buddy-signed-off", &handle, - signal_buddy_signed_off_cb, NULL) + def protocols_get_all(self): + cdef glib.GList *iter + cdef plugin.PurplePlugin *pp - signals.c_purple_signal_connect( - conversation.c_purple_conversations_get_handle(), - "receiving-im-msg", &handle, - signal_receiving_im_msg_cb, NULL) + iter = plugin.c_purple_plugins_get_protocols() + protocol_list = [] + while iter: + pp = iter.data + if pp.info and pp.info.name: + protocol_list.append[Protocol(pp.info.id)] + iter = iter.next + return protocol_list +include "protocol.pyx" +#include "plugin.pyx" include "proxy.pyx" +#include "protocol.pyx" include "account.pyx" include "buddy.pyx" -include "connection.pyx" +#include "connection.pyx" include "conversation.pyx"