From fc000346e45b352d58d2ce4fa8388ebd5f46f06b Mon Sep 17 00:00:00 2001 From: Marco Pesenti Gritti Date: Fri, 22 Sep 2006 19:50:20 +0000 Subject: Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar --- (limited to 'shell') diff --git a/shell/model/BuddyModel.py b/shell/model/BuddyModel.py index 0d36a4e..9e6c6bd 100644 --- a/shell/model/BuddyModel.py +++ b/shell/model/BuddyModel.py @@ -3,13 +3,19 @@ from sugar.canvas.IconColor import IconColor class BuddyModel: def __init__(self, buddy=None): - if buddy: - self.set_name(buddy.get_name()) - self.set_color(buddy.get_color()) - self._buddy = buddy self._cur_activity = None self._pservice = PresenceService.get_instance() - self._pservice.connect('buddy-appeared', self.__buddy_appeared_cb) + + self._buddy = buddy + if self._buddy: + self.set_name(self._buddy.get_name()) + self.set_color(self._buddy.get_color()) + self._buddy.connect('property-changed', + self.__buddy_property_changed_cb) + else: + # if we don't have a buddy yet, connect to the PS + # and wait until the buddy pops up on the network + self._pservice.connect('buddy-appeared', self.__buddy_appeared_cb) def set_name(self, name): self._name = name @@ -24,18 +30,24 @@ class BuddyModel: return self._color def get_buddy(self): - if not self._buddy: - self._buddy = self._pservice.get_buddy_by_name(self._name) - if self._buddy: - self._buddy.connect('property-changed', - self.__buddy_property_changed_cb) + # If we have a buddy already, just return + if self._buddy: + return self._buddy + + # Otherwise try to get the buddy from the PS + self._buddy = self._pservice.get_buddy_by_name(self._name) + if self._buddy: + self._buddy.connect('property-changed', + self.__buddy_property_changed_cb) return self._buddy def __buddy_appeared_cb(self, pservice, buddy): + # FIXME: use public key rather than buddy name if not self._buddy and buddy.get_name() == self._name: self.get_buddy() def __buddy_property_changed_cb(self, buddy, keys): + # all we care about right now is current activity curact = self._buddy.get_current_activity() self._cur_activity = self._pservice.get_activity(curact) -- cgit v0.9.1