X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=signal_cbs.pxd;h=ed1ab7173b36bb9ba7d054076f1673ea079547b9;hp=0e496b80279bf0f40e41e7f5a1c0d26640d91140;hb=d5dc2da1bd703c2cadbadde95994c17f44a86a0e;hpb=e0793149ffd4ba0271c21a63795f510cacb0730d diff --git a/signal_cbs.pxd b/signal_cbs.pxd index 0e496b8..ed1ab71 100644 --- a/signal_cbs.pxd +++ b/signal_cbs.pxd @@ -21,23 +21,26 @@ cimport purple signal_cbs = {} +cdef extern from *: + ctypedef char const_gchar "const gchar" + cdef void signal_signed_on_cb(connection.PurpleConnection *gc, \ glib.gpointer null): """ Emitted when a connection has signed on. @params gc The connection that has signed on. """ - cdef account.PurpleAccount *acc = connection.c_purple_connection_get_account(gc) + cdef account.PurpleAccount *acc = connection.purple_connection_get_account(gc) cdef char *c_username = NULL cdef char *c_protocol_id = NULL - c_username = account.c_purple_account_get_username(acc) + c_username = account.purple_account_get_username(acc) if c_username == NULL: username = None else: username = c_username - c_protocol_id = account.c_purple_account_get_protocol_id(acc) + c_protocol_id = account.purple_account_get_protocol_id(acc) if c_protocol_id == NULL: protocol_id = None else: @@ -52,17 +55,17 @@ cdef void signal_signed_off_cb(connection.PurpleConnection *gc, \ Emitted when a connection has signed off. @params gc The connection that has signed off. """ - cdef account.PurpleAccount *acc = connection.c_purple_connection_get_account(gc) + cdef account.PurpleAccount *acc = connection.purple_connection_get_account(gc) cdef char *c_username = NULL cdef char *c_protocol_id = NULL - c_username = account.c_purple_account_get_username(acc) + c_username = account.purple_account_get_username(acc) if c_username == NULL: username = None else: username = c_username - c_protocol_id = account.c_purple_account_get_protocol_id(acc) + c_protocol_id = account.purple_account_get_protocol_id(acc) if c_protocol_id == NULL: protocol_id = None else: @@ -72,13 +75,28 @@ cdef void signal_signed_off_cb(connection.PurpleConnection *gc, \ ( signal_cbs["signed-off"])(username, protocol_id) cdef void signal_connection_error_cb(connection.PurpleConnection *gc, \ - connection.PurpleConnectionError err, char *c_desc): + connection.PurpleConnectionError err, const_gchar *c_desc): """ Emitted when a connection error occurs, before signed-off. @params gc The connection on which the error has occured @params err The error that occured @params desc A description of the error, giving more information """ + cdef account.PurpleAccount *acc = connection.purple_connection_get_account(gc) + cdef char *c_username = NULL + cdef char *c_protocol_id = NULL + + c_username = account.purple_account_get_username(acc) + if c_username: + username = c_username + else: + username = None + + c_protocol_id = account.purple_account_get_protocol_id(acc) + if c_protocol_id: + protocol_id = c_protocol_id + else: + protocol_id = None short_desc = { 0: "Network error", @@ -97,15 +115,16 @@ cdef void signal_connection_error_cb(connection.PurpleConnection *gc, \ 13: "SSL certificate fingerprint mismatch", 14: "SSL certificate self signed", 15: "SSL certificate other error", - 16: "Other error" }[err] + 16: "Other error" }[ err] - if c_desc == NULL: - desc = None + if c_desc: + desc = str( c_desc) else: - desc = c_desc + desc = None if signal_cbs.has_key("connection-error"): - ( signal_cbs["connection-error"])(short_desc, desc) + ( signal_cbs["connection-error"])(username, protocol_id, \ + short_desc, desc) cdef void signal_buddy_signed_on_cb(blist.PurpleBuddy *buddy): """ @@ -115,13 +134,13 @@ cdef void signal_buddy_signed_on_cb(blist.PurpleBuddy *buddy): cdef char *c_name = NULL cdef char *c_alias = NULL - c_name = blist.c_purple_buddy_get_name(buddy) + c_name = blist.purple_buddy_get_name(buddy) if c_name == NULL: name = None else: name = c_name - c_alias = blist.c_purple_buddy_get_alias_only(buddy) + c_alias = blist.purple_buddy_get_alias_only(buddy) if c_alias == NULL: alias = None else: @@ -138,13 +157,13 @@ cdef void signal_buddy_signed_off_cb(blist.PurpleBuddy *buddy): cdef char *c_name = NULL cdef char *c_alias = NULL - c_name = blist.c_purple_buddy_get_name(buddy) + c_name = blist.purple_buddy_get_name(buddy) if c_name == NULL: name = None else: name = c_name - c_alias = blist.c_purple_buddy_get_alias_only(buddy) + c_alias = blist.purple_buddy_get_alias_only(buddy) if c_alias == NULL: alias = None else: @@ -168,16 +187,16 @@ cdef glib.gboolean signal_receiving_im_msg_cb(account.PurpleAccount *account, \ @params conv The IM conversation. @params flags A pointer to the IM message flags. """ - cdef blist.PurpleBuddy *buddy = blist.c_purple_find_buddy(account, sender[0]) + cdef blist.PurpleBuddy *buddy = blist.purple_find_buddy(account, sender[0]) cdef char *c_alias = NULL - c_alias = blist.c_purple_buddy_get_alias_only(buddy) + c_alias = blist.purple_buddy_get_alias_only(buddy) if c_alias == NULL: alias = None else: alias = c_alias - stripped = util.c_purple_markup_strip_html(message[0]) + stripped = util.purple_markup_strip_html(message[0]) if signal_cbs.has_key("receiving-im-msg"): return ( signal_cbs["receiving-im-msg"])(sender[0], alias, stripped)