Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/chat
diff options
context:
space:
mode:
authorDan Williams <dcbw@redhat.com>2006-04-24 17:42:01 (GMT)
committer Dan Williams <dcbw@redhat.com>2006-04-24 17:42:01 (GMT)
commitf9e2a73b9aa8ea9129629a1f772434edd6616569 (patch)
treeb2e13434c9c65b735bd754dc7e4dc5fc22181d1b /chat
parent6c188f1f0f5b0d429473e7e21c67e2aabd7cdbcd (diff)
Don't add duplicate buddies, and fix up buddy disappearance
Diffstat (limited to 'chat')
-rw-r--r--chat/BuddyList.py10
-rwxr-xr-xchat/chat.py12
2 files changed, 14 insertions, 8 deletions
diff --git a/chat/BuddyList.py b/chat/BuddyList.py
index fa3afb0..e5fd076 100644
--- a/chat/BuddyList.py
+++ b/chat/BuddyList.py
@@ -62,9 +62,11 @@ class BuddyList(object):
def _add_buddy(self, host, address, port, servicename, data):
if len(data) > 0 and 'name' in data.keys():
- buddy = Buddy(data['name'], data['realname'], servicename, host, address, port)
- self._buddies[data['name']] = buddy
- self._notify_listeners(ACTION_BUDDY_ADDED, buddy)
+ buddy = self._find_buddy_by_service_name(servicename)
+ if not buddy:
+ buddy = Buddy(data['name'], data['realname'], servicename, host, address, port)
+ self._buddies[data['name']] = buddy
+ self._notify_listeners(ACTION_BUDDY_ADDED, buddy)
def _remove_buddy(self, buddy):
nick = buddy.nick()
@@ -72,7 +74,7 @@ class BuddyList(object):
del self._buddies[nick]
def _find_buddy_by_service_name(self, servicename):
- for buddy in self._buddies.keys():
+ for buddy in self._buddies.values():
if buddy.servicename() == servicename:
return buddy
return None
diff --git a/chat/chat.py b/chat/chat.py
index 5305723..b990ae9 100755
--- a/chat/chat.py
+++ b/chat/chat.py
@@ -270,10 +270,14 @@ class ChatActivity(activity.Activity):
if action == BuddyList.ACTION_BUDDY_ADDED:
aniter = self._buddy_list_model.append(None)
self._buddy_list_model.set(aniter, 0, buddy.nick(), 1, buddy)
- elif action == BuddyList.ACCTION_BUDDY_REMOVED:
- aniter = self._buddy_list_model.get_iter(buddy.nick())
- if aniter:
- self._buddy_list_model.remove(iter)
+ elif action == BuddyList.ACTION_BUDDY_REMOVED:
+ aniter = self._buddy_list_model.get_iter_first()
+ while aniter:
+ list_buddy = self._buddy_list_model.get_value(aniter, 1)
+ if buddy == list_buddy:
+ self._buddy_list_model.remove(aniter)
+ break
+ aniter = self._buddy_list_model.iter_next(aniter)
def find_buddy_by_address(self, address):
return self._buddy_list.find_buddy_by_address(address)