diff options
author | erikkay@google.com <erikkay@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-12-10 22:34:33 +0000 |
---|---|---|
committer | erikkay@google.com <erikkay@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-12-10 22:34:33 +0000 |
commit | c2778c9435f4eaa6c3c44c34ec294cea6d48aca2 (patch) | |
tree | 55dca39eabae67fb48520b558f88891cdc85ca3f /chrome/tools/extensions | |
parent | 9bd491ee6e4c3695b2a96079c6607756bb0b13c0 (diff) | |
download | chromium_src-c2778c9435f4eaa6c3c44c34ec294cea6d48aca2.zip chromium_src-c2778c9435f4eaa6c3c44c34ec294cea6d48aca2.tar.gz chromium_src-c2778c9435f4eaa6c3c44c34ec294cea6d48aca2.tar.bz2 |
A simple script to create an extension package and to verify its contents.
Review URL: http://codereview.chromium.org/13351
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@6749 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/tools/extensions')
-rw-r--r-- | chrome/tools/extensions/chromium_extension.py | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/chrome/tools/extensions/chromium_extension.py b/chrome/tools/extensions/chromium_extension.py new file mode 100644 index 0000000..078c6e2 --- /dev/null +++ b/chrome/tools/extensions/chromium_extension.py @@ -0,0 +1,108 @@ +#!/bin/env python +# Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +# chromium_extension.py + +import logging +import optparse +import os +import re +import shutil +import sys +import zipfile + +ignore_dirs = [".svn", "CVS"] +ignore_files = [re.compile(".*~")] + +class ExtensionDir: + def __init__(self, path): + self._root = os.path.abspath(path) + self._dirs = [] + self._files = [] + for root, dirs, files in os.walk(path, topdown=True): + for dir in ignore_dirs: + if dir in dirs: + dirs.remove(dir) + root = os.path.abspath(root) + for dir in dirs: + self._dirs.append(os.path.join(root, dir)) + for f in files: + for match in ignore_files: + if not match.match(f): + self._files.append(os.path.join(root, f)) + + def validate(self): + if os.path.join(self._root, "manifest") not in self._files: + logging.error("package is missing a valid manifest") + return False + return True + + def writeToPackage(self, path): + if not self.validate(): + return False + try: + if os.path.exists(path): + os.remove(path) + shutil.copy(os.path.join(self._root, "manifest"), path) + # This is a bit odd - we're actually appending a new zip file to the end + # of the manifest. Believe it or not, this is actually an explicit + # feature of the zipfile package, and most zip utilities (this library + # and three others I tried) can still read the underlying zip file. + zip = zipfile.ZipFile(path, "a") + (root, dir) = os.path.split(self._root) + root_len = len(root) + for file in self._files: + arcname = file[root_len+1:] + logging.debug("%s: %s" % (arcname, file)) + zip.write(file, arcname) + zip.close() + logging.info("created extension package %s" % path) + except IOError, (errno, strerror): + logging.error("error creating extension %s (%d, %s)" % (path, errno, + strerror)) + try: + if os.path.exists(path): + os.remove(path) + except: + pass + return False + return True + + +class ExtensionPackage: + def __init__(self, path): + zip = zipfile.ZipFile(path) + error = zip.testzip() + if error: + logging.error("error reading extension: %s", error) + return + logging.info("%s contents:" % path) + files = zip.namelist() + for f in files: + logging.info(f) + + +def Run(): + logging.basicConfig(level=logging.INFO, format="[%(levelname)s] %(message)s") + + parser = optparse.OptionParser("usage: %prog --indir=<dir> --outfile=<file>") + parser.add_option("", "--indir", + help="an input directory where the extension lives") + parser.add_option("", "--outfile", + help="extension package filename to create") + (options, args) = parser.parse_args() + if not options.indir: + parser.error("missing required option --indir") + if not options.outfile: + parser.error("missing required option --outfile") + ext = ExtensionDir(options.indir) + ext.writeToPackage(options.outfile) + pkg = ExtensionPackage(options.outfile) + return 0 + + +if __name__ == "__main__": + retcode = Run() + sys.exit(retcode) |