diff options
author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2013-08-15 18:04:39 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-08-16 11:44:17 +0100 |
commit | 2a9d9b6a99253a80d6c5471b6cb99915a2fff887 (patch) | |
tree | c148ea7b1f8fbc70c515b27d87950185dbdeab40 | |
parent | c5d2e9caca2827a6b763b51913e46f2b2c1df129 (diff) | |
download | poky-2a9d9b6a99253a80d6c5471b6cb99915a2fff887.tar.gz |
buildhistory-diff: improve command-line handling
Improve command-line argument handling of buildhistory-diff to make it
easier to use.
* Default buildhistory directory to buildhistory/ under the current
directory and require an option to set it (since most users will
likely run buildhistory-diff from the build directory and keep
BUILDHISTORY_DIR at its default location)
* Default from-revision to "build-minus-1" to get the difference from
the previous build with no arguments
* Allow from/to revisions to be specified by from..to (since git accepts
this form).
(From OE-Core rev: 5e2be70e89820ffc74208d225fe4414fe5182050)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rwxr-xr-x | scripts/buildhistory-diff | 54 |
1 files changed, 39 insertions, 15 deletions
diff --git a/scripts/buildhistory-diff b/scripts/buildhistory-diff index 30c2c0826c..b82240d763 100755 --- a/scripts/buildhistory-diff +++ b/scripts/buildhistory-diff | |||
@@ -7,6 +7,7 @@ | |||
7 | 7 | ||
8 | import sys | 8 | import sys |
9 | import os | 9 | import os |
10 | import optparse | ||
10 | from distutils.version import LooseVersion | 11 | from distutils.version import LooseVersion |
11 | 12 | ||
12 | # Ensure PythonGit is installed (buildhistory_analysis needs it) | 13 | # Ensure PythonGit is installed (buildhistory_analysis needs it) |
@@ -17,14 +18,30 @@ except ImportError: | |||
17 | sys.exit(1) | 18 | sys.exit(1) |
18 | 19 | ||
19 | def main(): | 20 | def main(): |
21 | parser = optparse.OptionParser( | ||
22 | description = "Reports significant differences in the buildhistory repository.", | ||
23 | usage = """ | ||
24 | %prog [options] [from-revision [to-revision]] | ||
25 | (if not specified, from-revision defaults to build-minus-1, and to-revision defaults to HEAD)""") | ||
26 | |||
27 | parser.add_option("-p", "--buildhistory-dir", | ||
28 | help = "Specify path to buildhistory directory (defaults to buildhistory/ under cwd)", | ||
29 | action="store", dest="buildhistory_dir", default='buildhistory/') | ||
30 | |||
31 | options, args = parser.parse_args(sys.argv) | ||
32 | |||
33 | if len(args) > 3: | ||
34 | sys.stderr.write('Invalid argument(s) specified: %s\n\n' % ' '.join(args[3:])) | ||
35 | parser.print_help() | ||
36 | sys.exit(1) | ||
37 | |||
20 | if LooseVersion(git.__version__) < '0.3.1': | 38 | if LooseVersion(git.__version__) < '0.3.1': |
21 | sys.stderr.write("Version of GitPython is too old, please install GitPython (python-git) 0.3.1 or later in order to use this script\n") | 39 | sys.stderr.write("Version of GitPython is too old, please install GitPython (python-git) 0.3.1 or later in order to use this script\n") |
22 | sys.exit(1) | 40 | sys.exit(1) |
23 | 41 | ||
24 | if len(sys.argv) < 3 or '--help' in sys.argv: | 42 | if not os.path.exists(options.buildhistory_dir): |
25 | print("Report significant differences in the buildhistory repository") | 43 | sys.stderr.write('Buildhistory directory "%s" does not exist\n\n' % options.buildhistory_dir) |
26 | print("Syntax: %s <buildhistory-path> <since-revision> [to-revision]" % os.path.basename(sys.argv[0])) | 44 | parser.print_help() |
27 | print("If to-revision is not specified, it defaults to HEAD") | ||
28 | sys.exit(1) | 45 | sys.exit(1) |
29 | 46 | ||
30 | # Set path to OE lib dir so we can import the buildhistory_analysis module | 47 | # Set path to OE lib dir so we can import the buildhistory_analysis module |
@@ -47,21 +64,28 @@ def main(): | |||
47 | sys.path[0:0] = [newpath, bitbakepath + '/lib'] | 64 | sys.path[0:0] = [newpath, bitbakepath + '/lib'] |
48 | import oe.buildhistory_analysis | 65 | import oe.buildhistory_analysis |
49 | 66 | ||
50 | buildhistory_dir = sys.argv[1] | 67 | fromrev = 'build-minus-1' |
51 | if not os.path.exists(buildhistory_dir): | 68 | torev = 'HEAD' |
52 | sys.stderr.write('Specified buildhistory directory "%s" does not exist\n' % buildhistory_dir) | 69 | if len(args) > 1: |
53 | sys.exit(1) | 70 | if len(args) == 2 and '..' in args[1]: |
54 | 71 | revs = args[1].split('..') | |
55 | if len(sys.argv) > 3: | 72 | fromrev = revs[0] |
56 | torev = sys.argv[3] | 73 | if revs[1]: |
57 | else: | 74 | torev = revs[1] |
58 | torev = 'HEAD' | 75 | else: |
76 | fromrev = args[1] | ||
77 | if len(args) > 2: | ||
78 | torev = args[2] | ||
59 | 79 | ||
60 | import gitdb | 80 | import gitdb |
61 | try: | 81 | try: |
62 | changes = oe.buildhistory_analysis.process_changes(buildhistory_dir, sys.argv[2], torev) | 82 | changes = oe.buildhistory_analysis.process_changes(options.buildhistory_dir, fromrev, torev) |
63 | except gitdb.exc.BadObject as e: | 83 | except gitdb.exc.BadObject as e: |
64 | sys.stderr.write('Specified git revision "%s" is not valid\n' % e.args[0]) | 84 | if len(args) == 1: |
85 | sys.stderr.write("Unable to find previous build revision in buildhistory repository\n\n") | ||
86 | parser.print_help() | ||
87 | else: | ||
88 | sys.stderr.write('Specified git revision "%s" is not valid\n' % e.args[0]) | ||
65 | sys.exit(1) | 89 | sys.exit(1) |
66 | 90 | ||
67 | for chg in changes: | 91 | for chg in changes: |