Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar/activity/bundle.py
diff options
context:
space:
mode:
Diffstat (limited to 'sugar/activity/bundle.py')
-rw-r--r--sugar/activity/bundle.py26
1 files changed, 22 insertions, 4 deletions
diff --git a/sugar/activity/bundle.py b/sugar/activity/bundle.py
index 286c979..72d50fe 100644
--- a/sugar/activity/bundle.py
+++ b/sugar/activity/bundle.py
@@ -1,15 +1,25 @@
import logging
+import os
+
from ConfigParser import ConfigParser
class Bundle:
"""Info about an activity bundle. Wraps the activity.info file."""
- def __init__(self, info_path):
+ def __init__(self, path):
self._name = None
self._icon = None
self._service_name = None
self._show_launcher = False
self._valid = True
+ self._path = path
+
+ info_path = os.path.join(path, 'activity', 'activity.info')
+ if os.path.isfile(info_path):
+ self._parse_info(info_path)
+ else:
+ self._valid = False
+ def _parse_info(self, info_path):
cp = ConfigParser()
cp.read([info_path])
@@ -19,19 +29,19 @@ class Bundle:
self._service_name = cp.get(section, 'service_name')
else:
self._valid = False
- logging.error('%s must specify a service name' % info_path)
+ logging.error('%s must specify a service name' % self._path)
if cp.has_option(section, 'name'):
self._name = cp.get(section, 'name')
else:
self._valid = False
- logging.error('%s must specify a name' % info_path)
+ logging.error('%s must specify a name' % self._path)
if cp.has_option(section, 'exec'):
self._exec = cp.get(section, 'exec')
else:
self._valid = False
- logging.error('%s must specify an exec' % info_path)
+ logging.error('%s must specify an exec' % self._path)
if cp.has_option(section, 'show_launcher'):
if cp.get(section, 'show_launcher') == 'yes':
@@ -43,6 +53,10 @@ class Bundle:
def is_valid(self):
return self._valid
+ def get_path(self):
+ """Get the activity bundle path."""
+ return self._path
+
def get_name(self):
"""Get the activity user visible name."""
return self._name
@@ -62,3 +76,7 @@ class Bundle:
def get_show_launcher(self):
"""Get whether there should be a visible launcher for the activity"""
return self._show_launcher
+
+ # Compatibility with the old activity registry, remove after BTest-1
+ def get_id(self):
+ return self._service_name