diff options
author | Dan Williams <dcbw@redhat.com> | 2007-04-09 20:05:32 (GMT) |
---|---|---|
committer | Dan Williams <dcbw@redhat.com> | 2007-04-09 20:05:32 (GMT) |
commit | 76a0f45aa82ba49138449826ea7b006c784eaa62 (patch) | |
tree | a621a1307bc04b406acbb2452439dd25a5807688 /shell/model/MeshModel.py | |
parent | 4cf8f321f03317c6156e8fe8544b4b3a9d16bb7a (diff) |
More new PS fixes
Diffstat (limited to 'shell/model/MeshModel.py')
-rw-r--r-- | shell/model/MeshModel.py | 43 |
1 files changed, 20 insertions, 23 deletions
diff --git a/shell/model/MeshModel.py b/shell/model/MeshModel.py index 619a4f3..b9d1629 100644 --- a/shell/model/MeshModel.py +++ b/shell/model/MeshModel.py @@ -25,8 +25,7 @@ from hardware import hardwaremanager from hardware import nmclient class ActivityModel: - def __init__(self, activity, bundle, service): - self._service = service + def __init__(self, activity, bundle): self._activity = activity self._bundle = bundle @@ -39,8 +38,6 @@ class ActivityModel: def get_color(self): return XoColor(self._activity.get_color()) - def get_service(self): - return self._service class MeshModel(gobject.GObject): __gsignals__ = { @@ -75,8 +72,8 @@ class MeshModel(gobject.GObject): self._bundle_registry = bundleregistry.get_registry() self._pservice = presenceservice.get_instance() - self._pservice.connect("service-appeared", - self._service_appeared_cb) + self._pservice.connect("activity-appeared", + self._activity_appeared_cb) self._pservice.connect('activity-disappeared', self._activity_disappeared_cb) self._pservice.connect("buddy-appeared", @@ -88,8 +85,8 @@ class MeshModel(gobject.GObject): for buddy in self._pservice.get_buddies(): self._buddy_appeared_cb(self._pservice, buddy) - for service in self._pservice.get_services(): - self._check_service(service) + for activity in self._pservice.get_activities(): + self._check_activity(activity) network_manager = hardwaremanager.get_network_manager() if network_manager: @@ -196,18 +193,18 @@ class MeshModel(gobject.GObject): self.emit('buddy-removed', buddy) del self._buddies[buddy.get_name()] - def _service_appeared_cb(self, pservice, service): - self._check_service(service) + def _activity_appeared_cb(self, pservice, activity): + self._check_activity(activity) - def _check_service(self, service): - service_type = service.get_type() - bundle = self._bundle_registry.find_by_default_type(service_type) - if bundle != None: - activity_id = service.get_activity_id() - if not self.has_activity(activity_id): - activity = self._pservice.get_activity(activity_id) - if activity != None: - self.add_activity(bundle, activity, service) + def _check_activity(self, activity): + atype = activity.get_type() + bundle = self._bundle_registry.get_bundle(atype) + if not bundle: + return + activity_id = activity.get_id() + if self.has_activity(activity_id): + return + self.add_activity(bundle, activity) def has_activity(self, activity_id): return self._activities.has_key(activity_id) @@ -218,14 +215,14 @@ class MeshModel(gobject.GObject): else: return None - def add_activity(self, bundle, activity, service): - model = ActivityModel(activity, bundle, service) + def add_activity(self, bundle, activity): + model = ActivityModel(activity, bundle) self._activities[model.get_id()] = model self.emit('activity-added', model) for buddy in self._pservice.get_buddies(): - cur_activity = buddy.get_current_activity() - name = buddy.get_name() + cur_activity = buddy.props.current_activity + name = buddy.props.nick if cur_activity == activity and self._buddies.has_key(name): buddy_model = self._buddies[name] self.emit('buddy-moved', buddy_model, model) |