Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar
diff options
context:
space:
mode:
authorOwen Williams <owen@ywwg.localdomain>2006-12-04 20:44:15 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-12-04 21:05:09 (GMT)
commitb8f44c00c7166e7ebf0fa8142100d6ab028f8b2a (patch)
treefb891fa54ac0d9d5f61acc475d9ddd8a5acd4469 /sugar
parent37853ad836a6cd3b7e6999269b996eb16c4f1c3f (diff)
Added support for MANIFEST-OLPC files in bundlebuilder
Diffstat (limited to 'sugar')
-rw-r--r--sugar/activity/bundlebuilder.py33
1 files changed, 26 insertions, 7 deletions
diff --git a/sugar/activity/bundlebuilder.py b/sugar/activity/bundlebuilder.py
index 4ab4f7d..566dbf4 100644
--- a/sugar/activity/bundlebuilder.py
+++ b/sugar/activity/bundlebuilder.py
@@ -41,6 +41,12 @@ class _GitFileList(list):
if not filename.startswith('.'):
self.append(filename)
f.close()
+
+class _ManifestFileList(list):
+ def __init__(self):
+ f = open('MANIFEST-OLPC','r')
+ for line in f.readlines():
+ self.append(line[:-1])
def _extract_bundle(source_file, dest_dir):
if not os.path.exists(dest_dir):
@@ -82,6 +88,10 @@ def _get_package_name():
bundle = Bundle(_get_source_path())
zipname = '%s-%d.xo' % (bundle.get_name(), bundle.get_activity_version())
return zipname
+
+def _get_bundle_name():
+ bundle = Bundle(_get_source_path())
+ return bundle.get_name()
def _delete_backups(arg, dirname, names):
for name in names:
@@ -108,18 +118,24 @@ def cmd_dev():
print 'ERROR - A bundle with the same name is already installed.'
def cmd_dist():
- if os.path.isdir('.git'):
- file_list = _GitFileList()
- elif os.path.isdir('.svn'):
- file_list = _SvnFileList()
- else:
- print 'ERROR - The command works only with git or svn repositories.'
+ try:
+ os.stat('MANIFEST-OLPC')
+ file_list = _ManifestFileList()
+ except:
+ if os.path.isdir('.git'):
+ file_list = _GitFileList()
+ elif os.path.isdir('.svn'):
+ file_list = _SvnFileList()
+ else:
+ print 'ERROR - The command works only with git or svn\
+repositories, or MANIFEST-OLPC file lists.'
+ return
zipname = _get_package_name()
bundle_zip = zipfile.ZipFile(zipname, 'w', zipfile.ZIP_DEFLATED)
for filename in file_list:
- arcname = os.path.join(_get_bundle_dir(), filename)
+ arcname = os.path.join(_get_bundle_name()+'.activity', filename)
bundle_zip.write(filename, arcname)
bundle_zip.close()
@@ -154,3 +170,6 @@ def start():
cmd_clean()
else:
cmd_help()
+
+if __name__ == '__main__':
+ start()