Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@localhost.localdomain>2006-09-22 19:50:20 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-09-22 19:50:20 (GMT)
commitfc000346e45b352d58d2ce4fa8388ebd5f46f06b (patch)
treec39d7da6e94fe5a0e1fb700369eb79a9b5bad9c9 /shell
parenta2489b49d4ad6aa1b33df8563cde8041b8dc524b (diff)
parent2d445fcc5f9914a8969fbc10cc1f974e719eb3aa (diff)
Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar
Diffstat (limited to 'shell')
-rw-r--r--shell/model/BuddyModel.py32
1 files changed, 22 insertions, 10 deletions
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)