[ostree] ostbuild: add --diffstat option for source-diff
- From: Colin Walters <walters src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [ostree] ostbuild: add --diffstat option for source-diff
- Date: Fri, 25 May 2012 19:02:23 +0000 (UTC)
commit 1ef6bb0ef678a4327e2545c76d0ec039a4184bcf
Author: Colin Walters <walters verbum org>
Date: Fri May 25 15:01:41 2012 -0400
ostbuild: add --diffstat option for source-diff
src/ostbuild/pyostbuild/builtin_source_diff.py | 37 +++++++++++++++++------
1 files changed, 27 insertions(+), 10 deletions(-)
---
diff --git a/src/ostbuild/pyostbuild/builtin_source_diff.py b/src/ostbuild/pyostbuild/builtin_source_diff.py
index d35f018..0e3ff07 100755
--- a/src/ostbuild/pyostbuild/builtin_source_diff.py
+++ b/src/ostbuild/pyostbuild/builtin_source_diff.py
@@ -36,24 +36,41 @@ class OstbuildSourceDiff(builtins.Builtin):
def __init__(self):
builtins.Builtin.__init__(self)
- def _diff(self, name, mirrordir, from_revision, to_revision):
+ def _diff(self, name, mirrordir, from_revision, to_revision,
+ diffstat=False):
+ diff_replace_re = re.compile(' [ab]')
+
env = dict(os.environ)
env['LANG'] = 'C'
spacename = ' ' + name
- proc = subprocess.Popen(['git', 'diff', from_revision, to_revision],
- env=env, cwd=mirrordir, stdout=subprocess.PIPE)
- for line in proc.stdout:
+ sys.stdout.write('diff of %s revision range %s..%s\n' % (name, from_revision, to_revision))
+ sys.stdout.flush()
+
+ diff_proc = subprocess.Popen(['git', 'diff', from_revision, to_revision],
+ env=env, cwd=mirrordir, stdout=subprocess.PIPE)
+ if diffstat:
+ diffstat_proc = subprocess.Popen(['diffstat', '-p0'],
+ stdin=subprocess.PIPE,
+ stdout=sys.stdout)
+ diff_pipe = diffstat_proc.stdin
+ else:
+ diffstat_proc = None
+ diff_pipe = sys.stdout
+ for line in diff_proc.stdout:
if (line.startswith('diff --git ')
or line.startswith('--- a/')
or line.startswith('+++ b/')
or line.startswith('Binary files /dev/null and b/')):
line = diff_replace_re.sub(spacename, line)
- sys.stdout.write(line)
+ diff_pipe.write(line)
else:
- sys.stdout.write(line)
- proc.wait()
+ diff_pipe.write(line)
+ diff_proc.wait()
+ if diffstat_proc is not None:
+ diffstat_proc.stdin.close()
+ diffstat_proc.wait()
def _log(self, opts, name, mirrordir, from_revision, to_revision):
env = dict(os.environ)
@@ -80,6 +97,7 @@ class OstbuildSourceDiff(builtins.Builtin):
parser = argparse.ArgumentParser(description=self.short_description)
parser.add_argument('--log', action='store_true')
parser.add_argument('--logp', action='store_true')
+ parser.add_argument('--diffstat', action='store_true')
parser.add_argument('--rev-from')
parser.add_argument('--rev-to')
parser.add_argument('--snapshot-from')
@@ -108,8 +126,6 @@ class OstbuildSourceDiff(builtins.Builtin):
else:
fatal("One of --rev-from/--snapshot-from must be given")
- diff_replace_re = re.compile(' [ab]')
-
for from_component in from_snap['components']:
name = from_component['name']
src = from_component['src']
@@ -140,6 +156,7 @@ class OstbuildSourceDiff(builtins.Builtin):
elif args.logp:
self._log(['-p'], name, mirrordir, from_revision, to_revision)
else:
- self._diff(name, mirrordir, from_revision, to_revision)
+ self._diff(name, mirrordir, from_revision, to_revision,
+ diffstat=args.diffstat)
builtins.register(OstbuildSourceDiff)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]