More cleanups

This commit is contained in:
Marco Pesenti Gritti 2007-02-21 20:15:39 +01:00
parent 3fa653ed63
commit 70da5fa7bd
2 changed files with 3 additions and 88 deletions

View File

@ -15,77 +15,13 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330, # Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA. # Boston, MA 02111-1307, USA.
import os
import logging import logging
import dbus
import dbus.service
import gtk import gtk
import gobject
import datetime
from sugar.presence import PresenceService from sugar.presence import PresenceService
from sugar.datastore import datastore from sugar.activity.activityservice import ActivityService
from sugar import activity
from sugar import env from sugar import env
import sugar.util
_ACTIVITY_SERVICE_NAME = "org.laptop.Activity"
_ACTIVITY_SERVICE_PATH = "/org/laptop/Activity"
_ACTIVITY_INTERFACE = "org.laptop.Activity"
class ActivityDbusService(dbus.service.Object):
"""Base dbus service object that each Activity uses to export dbus methods.
The dbus service is separate from the actual Activity object so that we can
tightly control what stuff passes through the dbus python bindings."""
def __init__(self, activity):
service_name = _ACTIVITY_SERVICE_NAME + '%d' % activity.window.xid
object_path = _ACTIVITY_SERVICE_PATH + "/%s" % activity.window.xid
bus = dbus.SessionBus()
bus_name = dbus.service.BusName(service_name, bus=bus)
dbus.service.Object.__init__(self, bus_name, object_path)
self._activity = activity
self._pservice = PresenceService.get_instance()
@dbus.service.method(_ACTIVITY_INTERFACE)
def start(self, activity_id):
"""Start the activity in unshared mode."""
self._activity.start(activity_id)
@dbus.service.method(_ACTIVITY_INTERFACE)
def join(self, activity_ps_path):
"""Join the activity specified by its presence service path."""
activity_ps = self._pservice.get(activity_ps_path)
return self._activity.join(activity_ps)
@dbus.service.method(_ACTIVITY_INTERFACE)
def share(self):
"""Called by the shell to request the activity to share itself on the network."""
self._activity.share()
@dbus.service.method(_ACTIVITY_INTERFACE)
def get_id(self):
"""Get the activity identifier"""
return self._activity.get_id()
@dbus.service.method(_ACTIVITY_INTERFACE)
def get_type(self):
"""Get the activity type"""
return self._activity.get_type()
@dbus.service.method(_ACTIVITY_INTERFACE)
def get_shared(self):
"""Returns True if the activity is shared on the mesh."""
return self._activity.get_shared()
@dbus.service.method(_ACTIVITY_INTERFACE,
in_signature="sas", out_signature="b")
def execute(self, command, args):
return self._activity.execute(command, args)
class Activity(gtk.Window): class Activity(gtk.Window):
"""Base Activity class that all other Activities derive from.""" """Base Activity class that all other Activities derive from."""
@ -94,12 +30,10 @@ class Activity(gtk.Window):
gtk.Window.__init__(self) gtk.Window.__init__(self)
self.connect('destroy', self._destroy_cb) self.connect('destroy', self._destroy_cb)
#self.connect('notify::title', self._title_changed_cb)
self._shared = False self._shared = False
self._activity_id = None self._activity_id = None
self._service = None self._service = None
#self._journal_object = None
self._pservice = PresenceService.get_instance() self._pservice = PresenceService.get_instance()
self.realize() self.realize()
@ -108,7 +42,7 @@ class Activity(gtk.Window):
group.realize() group.realize()
self.window.set_group(group.window) self.window.set_group(group.window)
self._bus = ActivityDbusService(self) self._bus = ActivityService(self)
def start(self, activity_id): def start(self, activity_id):
"""Start the activity.""" """Start the activity."""
@ -118,19 +52,8 @@ class Activity(gtk.Window):
self._activity_id = activity_id self._activity_id = activity_id
#ds = datastore.get_instance()
#self._journal_object = ds.create('', {}, self._activity_id)
#
#date = datetime.datetime.now()
#self._journal_jobject.set_properties({'date' : date,
# 'title' : self.get_title()})
self.present() self.present()
# def get_journal_object(self):
# """Returns the journal object associated with the activity."""
# return self._journal_object
def get_type(self): def get_type(self):
"""Gets the activity type.""" """Gets the activity type."""
return env.get_bundle_service_name() return env.get_bundle_service_name()
@ -170,9 +93,6 @@ class Activity(gtk.Window):
else: else:
logging.error('Cannot join the activity') logging.error('Cannot join the activity')
#ds = datastore.get_instance()
#self._journal_object = ds.get_activity_object(self._activity_id)
self.present() self.present()
def share(self): def share(self):
@ -193,9 +113,3 @@ class Activity(gtk.Window):
self._bus = None self._bus = None
if self._service: if self._service:
self._pservice.unregister_service(self._service) self._pservice.unregister_service(self._service)
def _title_changed_cb(self, window, spec):
pass
# jobject = self.get_journal_object()
# if jobject:
# jobject.set_properties({'title' : self.props.title})

View File

@ -4,6 +4,7 @@ sugar_PYTHON = \
Activity.py \ Activity.py \
ActivityFactory.py \ ActivityFactory.py \
activityfactoryservice.py \ activityfactoryservice.py \
activityservice.py \
bundle.py \ bundle.py \
bundlebuilder.py \ bundlebuilder.py \
bundleregistry.py bundleregistry.py