blist_cbs = {}
+cdef void __group_node_cb(blist.PurpleBlistNode *node, object callback):
+ cdef blist.PurpleGroup *group = <blist.PurpleGroup *>node
+
+ if group.name:
+ name = group.name
+ else:
+ name = ""
+
+ try:
+ callback(node.type, name, group.totalsize, group.currentsize, \
+ group.online)
+ except KeyError:
+ pass
+
+cdef void __contact_node_cb(blist.PurpleBlistNode *node, object callback):
+ cdef blist.PurpleContact *contact = <blist.PurpleContact *>node
+
+ if contact.alias:
+ alias = contact.alias
+ else:
+ alias = ""
+
+ name = ""
+
+ try:
+ callback(node.type, name, alias, contact.totalsize, contact.currentsize, \
+ contact.online)
+ except KeyError:
+ pass
+
+cdef void __buddy_node_cb(blist.PurpleBlistNode *node, object callback):
+ cdef blist.PurpleBuddy *buddy = <blist.PurpleBuddy *>node
+
+ if buddy.server_alias:
+ alias = buddy.server_alias
+ elif buddy.alias:
+ alias = buddy.alias
+ else:
+ alias = ""
+
+ if buddy.name:
+ name = buddy.name
+ else:
+ name = ""
+
+ try:
+ callback(node.type, name, alias)
+ except KeyError:
+ pass
+
+cdef void __chat_node_cb(blist.PurpleBlistNode *node, object callback):
+ cdef blist.PurpleChat *chat = <blist.PurpleChat *>node
+
+ if chat.alias:
+ alias = chat.alias
+ else:
+ alias = ""
+
+ try:
+ callback(node.type, alias)
+ except KeyError:
+ pass
+
+cdef void __other_node_cb(blist.PurpleBlistNode *node, object callback):
+ try:
+ callback(node.type)
+ except KeyError:
+ pass
+
cdef void new_list (blist.PurpleBuddyList *list):
debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "blist", "new_list\n")
try:
cdef void new_node (blist.PurpleBlistNode *node):
debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "blist", "new_node\n")
+
try:
- (<object>blist_cbs["new_node"])("new_node")
+ if node.type == blist.PURPLE_BLIST_GROUP_NODE:
+ __group_node_cb(node, blist_cbs["new_node"])
+ elif node.type == blist.PURPLE_BLIST_CONTACT_NODE:
+ __contact_node_cb(node, blist_cbs["new_node"])
+ elif node.type == blist.PURPLE_BLIST_BUDDY_NODE:
+ __buddy_node_cb(node, blist_cbs["new_node"])
+ elif node.type == blist.PURPLE_BLIST_CHAT_NODE:
+ __chat_node_cb(node, blist_cbs["new_node"])
+ elif node.type == blist.PURPLE_BLIST_OTHER_NODE:
+ __other_node_cb(node, blist_cbs["new_node"])
+ else:
+ (<object>blist_cbs["new_node"])(node.type)
except KeyError:
pass
cdef void update (blist.PurpleBuddyList *list, blist.PurpleBlistNode *node):
debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "blist", "update\n")
+
try:
- (<object>blist_cbs["update"])("update")
+ if node.type == blist.PURPLE_BLIST_GROUP_NODE:
+ __group_node_cb(node, blist_cbs["update"])
+ elif node.type == blist.PURPLE_BLIST_CONTACT_NODE:
+ __contact_node_cb(node, blist_cbs["update"])
+ elif node.type == blist.PURPLE_BLIST_BUDDY_NODE:
+ __buddy_node_cb(node, blist_cbs["update"])
+ elif node.type == blist.PURPLE_BLIST_CHAT_NODE:
+ __chat_node_cb(node, blist_cbs["update"])
+ elif node.type == blist.PURPLE_BLIST_OTHER_NODE:
+ __other_node_cb(node, blist_cbs["update"])
+ else:
+ (<object>blist_cbs["update"])(node.type)
except KeyError:
pass
cdef void remove (blist.PurpleBuddyList *list, blist.PurpleBlistNode *node):
debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "blist", "remove\n")
+
try:
- (<object>blist_cbs["remove"])("remove")
+ if node.type == blist.PURPLE_BLIST_GROUP_NODE:
+ __group_node_cb(node, blist_cbs["remove"])
+ elif node.type == blist.PURPLE_BLIST_CONTACT_NODE:
+ __contact_node_cb(node, blist_cbs["remove"])
+ elif node.type == blist.PURPLE_BLIST_BUDDY_NODE:
+ __buddy_node_cb(node, blist_cbs["remove"])
+ elif node.type == blist.PURPLE_BLIST_CHAT_NODE:
+ __chat_node_cb(node, blist_cbs["remove"])
+ elif node.type == blist.PURPLE_BLIST_OTHER_NODE:
+ __other_node_cb(node, blist_cbs["remove"])
+ else:
+ (<object>blist_cbs["remove"])(node.type)
except KeyError:
pass