Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar/activity/activityfactory.py
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <mpg@redhat.com>2007-10-09 13:25:24 (GMT)
committer Marco Pesenti Gritti <mpg@redhat.com>2007-10-09 13:25:24 (GMT)
commitc2982f27748ce40abd3aefdfa2bcb0cc059c8cbc (patch)
tree21bdaec0774c20ed26bae202d011b14b15e89047 /sugar/activity/activityfactory.py
parent6073a396b36c7d3da15ee361b601e94b010c6e92 (diff)
Implement a sugar-launch command. Works like the old sugar-activity
but should deal fine with native activities too.
Diffstat (limited to 'sugar/activity/activityfactory.py')
-rw-r--r--sugar/activity/activityfactory.py44
1 files changed, 29 insertions, 15 deletions
diff --git a/sugar/activity/activityfactory.py b/sugar/activity/activityfactory.py
index d5936e9..addaf95 100644
--- a/sugar/activity/activityfactory.py
+++ b/sugar/activity/activityfactory.py
@@ -77,6 +77,30 @@ def create_activity_id():
return act_id
raise RuntimeError("Cannot generate unique activity id.")
+def get_environment(activity):
+ environ = os.environ.copy()
+
+ bin_path = os.path.join(activity.path, 'bin')
+ environ['SUGAR_BUNDLE_PATH'] = activity.path
+ environ['PATH'] = bin_path + ':' + environ['PATH']
+
+ return environ
+
+def get_command(activity, activity_id=None, object_id=None, uri=None):
+ if not activity_id:
+ activity_id = create_activity_id()
+
+ command = activity.command
+ command += ' -b %s' % activity.bundle_id
+ command += ' -a %s' % activity_id
+
+ if object_id is not None:
+ command += ' -o %s' % object_id
+ if uri is not None:
+ command += ' -u %s' % uri
+
+ return command
+
class ActivityCreationHandler(gobject.GObject):
"""Sugar-side activity creation interface
@@ -151,21 +175,11 @@ class ActivityCreationHandler(gobject.GObject):
activity_registry = registry.get_registry()
activity = activity_registry.get_activity(self._service_name)
if activity:
- bin_path = os.path.join(activity.path, 'bin')
-
- env = os.environ.copy()
- env['SUGAR_BUNDLE_PATH'] = activity.path
- env['PATH'] = bin_path + ':' + env['PATH']
-
- command = activity.command
- command += ' -b %s' % activity.bundle_id
- if self._handle.activity_id is not None:
- command += ' -a %s' % self._handle.activity_id
- if self._handle.object_id is not None:
- command += ' -o %s' % self._handle.object_id
- if self._handle.uri is not None:
- command += ' -u %s' % self._handle.uri
-
+ env = get_environment(activity)
+ command = get_command(activity,
+ self._handle.activity_id,
+ self._handle.object_id,
+ self._handle.uri)
process = subprocess.Popen(command, env=env, shell=True,
cwd=activity.path)
else: