Implement purple.Buddy()
[python-purple] / blist_cbs.pxd
index 803c0eb..c1830d6 100644 (file)
@@ -24,6 +24,75 @@ cdef extern from *:
 
 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:
@@ -33,8 +102,20 @@ cdef void new_list (blist.PurpleBuddyList *list):
 
 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
 
@@ -47,15 +128,39 @@ cdef void show (blist.PurpleBuddyList *list):
 
 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