Merge fix

This commit is contained in:
Dan Williams 2006-09-12 12:37:23 -04:00
commit 13cca4606f
6 changed files with 44 additions and 26 deletions

View File

@ -25,6 +25,7 @@ class BrowserActivity(Activity):
self._model = None
self.set_title("Web Page")
self.connect('destroy', self._destroy_cb)
vbox = gtk.VBox()
@ -123,3 +124,7 @@ class BrowserActivity(Activity):
self._notif_bar.set_action('goto_shared_location', 'Go There')
self._notif_bar.set_icon('stock_right')
self._notif_bar.show()
def _destroy_cb(self, window):
if self._model:
self._model.shutdown()

View File

@ -1,4 +1,4 @@
AC_INIT([Sugar],[0.27],[],[sugar])
AC_INIT([Sugar],[0.28],[],[sugar])
AC_PREREQ([2.59])

View File

@ -9,14 +9,15 @@ from sugar.presence import PresenceService
from home.IconLayout import IconLayout
class ActivityItem(IconItem):
def __init__(self, service):
def __init__(self, activity, service):
self._service = service
self._activity = activity
IconItem.__init__(self, icon_name=self.get_icon_name(),
color=self.get_color(), size=96)
def get_id(self):
return self._service.get_activity_id()
return self._activity.get_id()
def get_icon_name(self):
registry = conf.get_activity_registry()
@ -25,9 +26,7 @@ class ActivityItem(IconItem):
return info.get_icon()
def get_color(self):
pservice = PresenceService.get_instance()
activity = pservice.get_activity(self.get_id())
return IconColor(activity.get_color())
return IconColor(self._activity.get_color())
def get_service(self):
return self._service
@ -39,38 +38,46 @@ class MeshGroup(goocanvas.Group):
self._icon_layout = IconLayout(1200, 900)
self._activities = {}
pservice = PresenceService.get_instance()
pservice.connect("service-appeared", self.__service_appeared_cb)
self._pservice = PresenceService.get_instance()
self._pservice.connect("service-appeared", self._service_appeared_cb)
self._pservice.connect('activity-disappeared', self._activity_disappeared_cb)
for service in pservice.get_services():
self.__check_service(service)
for service in self._pservice.get_services():
self._check_service(service)
def __service_appeared_cb(self, pservice, service):
self.__check_service(service)
def _service_appeared_cb(self, pservice, service):
self._check_service(service)
def __check_service(self, service):
def _check_service(self, service):
registry = conf.get_activity_registry()
if registry.get_activity_from_type(service.get_type()) != None:
if not self.has_activity(service.get_activity_id()):
self.add_activity(service)
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(activity, service)
def has_activity(self, activity_id):
return self._activities.has_key(activity_id)
def add_activity(self, service):
item = ActivityItem(service)
item.connect('clicked', self.__activity_clicked_cb)
def add_activity(self, activity, service):
item = ActivityItem(activity, service)
item.connect('clicked', self._activity_clicked_cb)
self._icon_layout.add_icon(item)
self.add_child(item)
self._activities[item.get_id()] = item
def __activity_clicked_cb(self, item):
def _activity_disappeared_cb(self, pservice, activity):
if self._activities.has_key(activity.get_id()):
self.remove_child(self._activities[activity.get_id()])
del self._activities[activity.get_id()]
def _activity_clicked_cb(self, item):
default_type = item.get_service().get_type()
registry = conf.get_activity_registry()
bundle_id = registry.get_activity_from_type(default_type).get_id()
activity_id = item.get_service().get_activity_id()
activity_id = item.get_id()
self._shell.join_activity(bundle_id, activity_id)

View File

@ -124,7 +124,7 @@ class IconView(goocanvas.ItemViewSimple, goocanvas.ItemView):
self._buffer = None
if self._buffer == None:
size = _ICON_SIZE * scale
size = int(_ICON_SIZE * scale)
surface = cr.get_target().create_similar(
cairo.CONTENT_COLOR_ALPHA, size, size)

View File

@ -37,13 +37,16 @@ class LocalModel(AbstractModel):
self._notifier.notify(key)
def _setup_service(self):
service = self._pservice.share_activity(self._activity,
stype = LocalModel.SERVICE_TYPE)
self._setup_server(service)
self._service = self._pservice.share_activity(
self._activity, stype = LocalModel.SERVICE_TYPE)
self._setup_server(self._service)
# FIXME this is duplicated with StreamReader
def _setup_server(self, service):
port = service.get_port()
logging.debug('Start model server on port %d' % (port))
p2p_server = network.GlibXMLRPCServer(("", port))
p2p_server.register_instance(ModelRequestHandler(self))
def shutdown(self):
self._pservice.unregister_service(self._service)

View File

@ -26,3 +26,6 @@ class RemoteModel(AbstractModel):
def _setup_notification_listener(self):
self._notification = NotificationListener(self._notification_service)
self._notification.add_listener(self._notify_model_change)
def shutdown(self):
pass