Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar
This commit is contained in:
		
						commit
						1152a086f9
					
				| @ -82,6 +82,10 @@ class Activity(DBusGObject): | |||||||
|         if self.props.local and not self.props.valid: |         if self.props.local and not self.props.valid: | ||||||
|             raise RuntimeError("local activities require color, type, and name") |             raise RuntimeError("local activities require color, type, and name") | ||||||
| 
 | 
 | ||||||
|  |         # If not yet valid, query activity properties | ||||||
|  |         if not self.props.valid: | ||||||
|  |             tp.update_activity_properties(self._id) | ||||||
|  | 
 | ||||||
|     def do_get_property(self, pspec): |     def do_get_property(self, pspec): | ||||||
|         if pspec.name == "id": |         if pspec.name == "id": | ||||||
|             return self._id |             return self._id | ||||||
|  | |||||||
| @ -159,20 +159,7 @@ class PresenceService(dbus.service.Object): | |||||||
|             return None |             return None | ||||||
| 
 | 
 | ||||||
|         activity.connect("validity-changed", self._activity_validity_changed_cb) |         activity.connect("validity-changed", self._activity_validity_changed_cb) | ||||||
| 
 |  | ||||||
|         self._activities[activity_id] = activity |         self._activities[activity_id] = activity | ||||||
| 
 |  | ||||||
|         # FIXME |  | ||||||
|         # Use values from the network |  | ||||||
|         #import random |  | ||||||
|         #names = ["Tommy", "Susie", "Jill", "Bryan", "Nathan", "Sophia", "Haley", "Jimmy"] |  | ||||||
|         #name = names[random.randint(0, len(names) - 1)] |  | ||||||
|         #activity.props.name = "Chat with %s" % name |  | ||||||
|         #activity.props.type = "org.laptop.Sugar.Chat" |  | ||||||
|         #from sugar.graphics import xocolor |  | ||||||
|         #color = xocolor.XoColor().to_string() |  | ||||||
|         #activity.props.color = color |  | ||||||
| 
 |  | ||||||
|         return activity |         return activity | ||||||
| 
 | 
 | ||||||
|     def _remove_activity(self, activity): |     def _remove_activity(self, activity): | ||||||
| @ -201,7 +188,7 @@ class PresenceService(dbus.service.Object): | |||||||
| 
 | 
 | ||||||
|         activities_joined = new_activities - old_activities |         activities_joined = new_activities - old_activities | ||||||
|         for act in activities_joined: |         for act in activities_joined: | ||||||
|             logging.debug("Buddy", contact_handle, "joined", act) |             logging.debug("Handle %s joined activity %s" % (contact_handle, act)) | ||||||
|             activity = self._activities.get(act) |             activity = self._activities.get(act) | ||||||
|             if not activity: |             if not activity: | ||||||
|                 # new activity, can fail |                 # new activity, can fail | ||||||
| @ -213,7 +200,7 @@ class PresenceService(dbus.service.Object): | |||||||
| 
 | 
 | ||||||
|         activities_left = old_activities - new_activities |         activities_left = old_activities - new_activities | ||||||
|         for act in activities_left: |         for act in activities_left: | ||||||
|             logging.debug("Buddy", contact_handle, "left", act) |             logging.debug("Handle %s left activity %s" % (contact_handle, act)) | ||||||
|             activity = self._activities.get(act) |             activity = self._activities.get(act) | ||||||
|             if not activity: |             if not activity: | ||||||
|                 continue |                 continue | ||||||
| @ -321,6 +308,12 @@ class PresenceService(dbus.service.Object): | |||||||
|         self._activities[actid] = activity |         self._activities[actid] = activity | ||||||
|         activity._share(callbacks) |         activity._share(callbacks) | ||||||
| 
 | 
 | ||||||
|  |         # local activities are valid at creation by definition, but we can't | ||||||
|  |         # connect to the activity's validity-changed signal until its already | ||||||
|  |         # issued the signal, which happens in the activity's constructor | ||||||
|  |         # for local activities. | ||||||
|  |         self._activity_validity_changed_cb(activity, activity.props.valid) | ||||||
|  | 
 | ||||||
|     def _activity_validity_changed_cb(self, activity, valid): |     def _activity_validity_changed_cb(self, activity, valid): | ||||||
|         if valid: |         if valid: | ||||||
|             self.ActivityAppeared(activity.object_path()) |             self.ActivityAppeared(activity.object_path()) | ||||||
|  | |||||||
| @ -293,7 +293,7 @@ class ServerPlugin(gobject.GObject): | |||||||
|         img_data = _get_buddy_icon_at_size(icon_data, min(maxw, 96), min(maxh, 96), maxsize) |         img_data = _get_buddy_icon_at_size(icon_data, min(maxw, 96), min(maxh, 96), maxsize) | ||||||
|         self._conn[CONN_INTERFACE_AVATARS].SetAvatar(img_data, "image/jpeg", |         self._conn[CONN_INTERFACE_AVATARS].SetAvatar(img_data, "image/jpeg", | ||||||
|                 reply_handler=self._set_self_avatar_cb, |                 reply_handler=self._set_self_avatar_cb, | ||||||
|                 error_handler=lambda *args: self._log_error_cb("avatar", *args)) |                 error_handler=lambda *args: self._log_error_cb("setting avatar", *args)) | ||||||
| 
 | 
 | ||||||
|     def _join_activity_create_channel_cb(self, activity_id, signal, handle, userdata, chan_path): |     def _join_activity_create_channel_cb(self, activity_id, signal, handle, userdata, chan_path): | ||||||
|         channel = Channel(self._conn._dbus_object._named_service, chan_path) |         channel = Channel(self._conn._dbus_object._named_service, chan_path) | ||||||
| @ -340,7 +340,7 @@ class ServerPlugin(gobject.GObject): | |||||||
|         pass |         pass | ||||||
| 
 | 
 | ||||||
|     def _log_error_cb(self, msg, err): |     def _log_error_cb(self, msg, err): | ||||||
|         logging.debug("Error setting %s: %s" % (msg, err)) |         logging.debug("Error %s: %s" % (msg, err)) | ||||||
| 
 | 
 | ||||||
|     def _set_self_olpc_properties(self, set_key=False): |     def _set_self_olpc_properties(self, set_key=False): | ||||||
|         props = {} |         props = {} | ||||||
| @ -349,19 +349,19 @@ class ServerPlugin(gobject.GObject): | |||||||
|             props['key'] = dbus.ByteArray(self._owner.props.key) |             props['key'] = dbus.ByteArray(self._owner.props.key) | ||||||
|         self._conn[CONN_INTERFACE_BUDDY_INFO].SetProperties(props, |         self._conn[CONN_INTERFACE_BUDDY_INFO].SetProperties(props, | ||||||
|                 reply_handler=self._ignore_success_cb, |                 reply_handler=self._ignore_success_cb, | ||||||
|                 error_handler=lambda *args: self._log_error_cb("properties", *args)) |                 error_handler=lambda *args: self._log_error_cb("setting properties", *args)) | ||||||
| 
 | 
 | ||||||
|     def _set_self_alias(self): |     def _set_self_alias(self): | ||||||
|         alias = self._owner.props.nick |         alias = self._owner.props.nick | ||||||
|         self_handle = self._conn[CONN_INTERFACE].GetSelfHandle() |         self_handle = self._conn[CONN_INTERFACE].GetSelfHandle() | ||||||
|         self._conn[CONN_INTERFACE_ALIASING].SetAliases({self_handle : alias}, |         self._conn[CONN_INTERFACE_ALIASING].SetAliases({self_handle : alias}, | ||||||
|                 reply_handler=self._ignore_success_cb, |                 reply_handler=self._ignore_success_cb, | ||||||
|                 error_handler=lambda *args: self._log_error_cb("alias", *args)) |                 error_handler=lambda *args: self._log_error_cb("setting alias", *args)) | ||||||
| 
 | 
 | ||||||
|     def _set_self_activities(self): |     def _set_self_activities(self): | ||||||
|         self._conn[CONN_INTERFACE_BUDDY_INFO].SetActivities(self._joined_activities, |         self._conn[CONN_INTERFACE_BUDDY_INFO].SetActivities(self._joined_activities, | ||||||
|                 reply_handler=self._ignore_success_cb, |                 reply_handler=self._ignore_success_cb, | ||||||
|                 error_handler=lambda *args: self._log_error_cb("activities", *args)) |                 error_handler=lambda *args: self._log_error_cb("setting activities", *args)) | ||||||
| 
 | 
 | ||||||
|     def _set_self_current_activity(self): |     def _set_self_current_activity(self): | ||||||
|         cur_activity = self._owner.props.current_activity |         cur_activity = self._owner.props.current_activity | ||||||
| @ -378,7 +378,7 @@ class ServerPlugin(gobject.GObject): | |||||||
|         self._conn[CONN_INTERFACE_BUDDY_INFO].SetCurrentActivity(cur_activity, |         self._conn[CONN_INTERFACE_BUDDY_INFO].SetCurrentActivity(cur_activity, | ||||||
|                 cur_activity_handle, |                 cur_activity_handle, | ||||||
|                 reply_handler=self._ignore_success_cb, |                 reply_handler=self._ignore_success_cb, | ||||||
|                 error_handler=lambda *args: self._log_error_cb("current activity", *args)) |                 error_handler=lambda *args: self._log_error_cb("setting current activity", *args)) | ||||||
| 
 | 
 | ||||||
|     def _get_handle_for_activity(self, activity_id): |     def _get_handle_for_activity(self, activity_id): | ||||||
|         for (act, handle) in self._joined_activities: |         for (act, handle) in self._joined_activities: | ||||||
| @ -444,10 +444,6 @@ class ServerPlugin(gobject.GObject): | |||||||
|         del self._online_contacts[handle] |         del self._online_contacts[handle] | ||||||
| 
 | 
 | ||||||
|     def _contact_online_activities_cb(self, handle, activities): |     def _contact_online_activities_cb(self, handle, activities): | ||||||
|         if not activities or not len(activities): |  | ||||||
|             logging.debug("Handle %s - No activities" % handle) |  | ||||||
|             self._contact_offline(handle) |  | ||||||
|             return |  | ||||||
|         self._buddy_activities_changed_cb(handle, activities) |         self._buddy_activities_changed_cb(handle, activities) | ||||||
| 
 | 
 | ||||||
|     def _contact_online_activities_error_cb(self, handle, err): |     def _contact_online_activities_error_cb(self, handle, err): | ||||||
| @ -598,16 +594,26 @@ class ServerPlugin(gobject.GObject): | |||||||
|             channel_type in [CHANNEL_TYPE_TEXT, CHANNEL_TYPE_STREAMED_MEDIA]: |             channel_type in [CHANNEL_TYPE_TEXT, CHANNEL_TYPE_STREAMED_MEDIA]: | ||||||
|             self.emit("private-invitation", object_path) |             self.emit("private-invitation", object_path) | ||||||
| 
 | 
 | ||||||
|  |     def update_activity_properties(self, act_id): | ||||||
|  |         handle = self._activities.get(act_id) | ||||||
|  |         if not handle: | ||||||
|  |             raise RuntimeError("Unknown activity %s: couldn't find handle.") | ||||||
|  | 
 | ||||||
|  |         self._conn[CONN_INTERFACE_ACTIVITY_PROPERTIES].GetProperties(handle, | ||||||
|  |                 reply_handler=lambda *args: self._activity_properties_changed_cb(handle, *args), | ||||||
|  |                 error_handler=lambda *args: self._log_error_cb("getting activity properties", *args)) | ||||||
|  | 
 | ||||||
|     def set_activity_properties(self, act_id, props): |     def set_activity_properties(self, act_id, props): | ||||||
|         handle = self._activities.get(act_id) |         handle = self._activities.get(act_id) | ||||||
|         if not handle: |         if not handle: | ||||||
|             logging.debug("set_activity_properties: handle unknown") |             raise RuntimeError("Unknown activity %s: couldn't find handle.") | ||||||
|             return | 
 | ||||||
|         self._conn[CONN_INTERFACE_ACTIVITY_PROPERTIES].SetProperties(handle, props, |         self._conn[CONN_INTERFACE_ACTIVITY_PROPERTIES].SetProperties(handle, props, | ||||||
|                 reply_handler=self._ignore_success_cb, |                 reply_handler=self._ignore_success_cb, | ||||||
|                 error_handler=lambda *args: self._log_error_cb("activity properties", *args)) |                 error_handler=lambda *args: self._log_error_cb("setting activity properties", *args)) | ||||||
| 
 | 
 | ||||||
|     def _activity_properties_changed_cb(self, room, properties): |     def _activity_properties_changed_cb(self, room, properties): | ||||||
|         for act_id, act_handle in self._activities.items(): |         for act_id, act_handle in self._activities.items(): | ||||||
|             if room == act_handle: |             if room == act_handle: | ||||||
|                 self.emit("activity-properties-changed", act_id, properties) |                 self.emit("activity-properties-changed", act_id, properties) | ||||||
|  |                 return | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Marco Pesenti Gritti
						Marco Pesenti Gritti