summaryrefslogtreecommitdiff
path: root/packages/brpm
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@yahoo-inc.com>2012-06-26 00:48:55 -0700
committerJoshua Harlow <harlowja@yahoo-inc.com>2012-06-26 00:48:55 -0700
commitec8ca070c3be9ef8622d1a618d78f6cacfb9653f (patch)
tree529b626331eebfd6212ab91873e8930f306f3bd7 /packages/brpm
parent33812679bb6950986f18ee88d8dae86062aa319f (diff)
downloadvyos-cloud-init-ec8ca070c3be9ef8622d1a618d78f6cacfb9653f.tar.gz
vyos-cloud-init-ec8ca070c3be9ef8622d1a618d78f6cacfb9653f.zip
Just use the base changelog.
Diffstat (limited to 'packages/brpm')
-rwxr-xr-xpackages/brpm60
1 files changed, 57 insertions, 3 deletions
diff --git a/packages/brpm b/packages/brpm
index bbe637e8..081d092b 100755
--- a/packages/brpm
+++ b/packages/brpm
@@ -7,9 +7,11 @@ import shutil
import subprocess
import sys
import tempfile
+import re
import tempita
+from datetime import datetime
# Mapping of expected packages to there full name...
PKG_MP = {
@@ -53,6 +55,46 @@ def tiny_p(cmd, capture=True):
% (cmd, sp.returncode, out, err))
return (out, err)
+def get_log_header(version):
+ cmd = ['bzr', 'tags']
+ (stdout, _stderr) = tiny_p(cmd)
+ a_rev = None
+ for t in stdout.splitlines():
+ ver, rev = t.split(None)
+ if ver == version:
+ a_rev = rev
+ break
+ if not a_rev:
+ return format_change_line(datetime.now(),
+ '??', version)
+ cmd = ['bzr', 'log', '-r%s' % (a_rev), '--timezone=utc']
+ (stdout, _stderr) = tiny_p(cmd)
+ kvs = {
+ 'comment': version,
+ }
+ for line in stdout.splitlines():
+ if line.startswith('committer:'):
+ kvs['who'] = line[len('committer:'):].strip()
+ if line.startswith('timestamp:'):
+ ts = line[len('timestamp:'):]
+ ts = ts.strip()
+ # http://bugs.python.org/issue6641
+ ts = ts.replace("+0000", '').strip()
+ ds = datetime.strptime(ts, '%a %Y-%m-%d %H:%M:%S')
+ kvs['ds'] = ds
+ return format_change_line(**kvs)
+
+def format_change_line(ds, who, comment=None):
+ d = format_rpm_date(ds)
+ d += " - %s" % (who)
+ if comment:
+ d += " - %s" % (comment)
+ return "* %s" % (d)
+
+
+def format_rpm_date(ds):
+ return ds.strftime("%a %b %d %Y")
+
def info(msg):
print("INFO: %s" % (msg))
@@ -93,9 +135,21 @@ def generate_spec_contents(tmpl_fn, revno, version):
base_name = 'cloud-init-%s-%s' % (version, subs['revno'])
subs['requires'] = requires
- (stdout, _stderr) = tiny_p([sys.executable,
- join(os.getcwd(), 'rpm-changelog')])
- subs['changelog'] = stdout.strip()
+ # Format a nice changelog (as best as we can)
+ changelog = ''
+ with open(join(os.pardir, 'ChangeLog')) as fh:
+ changelog = fh.read()
+ ch_lines = []
+ for line in changelog.splitlines():
+ if not line.strip():
+ continue
+ if re.match(r"^\s*[\d][.][\d][.][\d]:\s*", line):
+ line = line.strip(":")
+ header = get_log_header(line)
+ ch_lines.append(header)
+ else:
+ ch_lines.append(line)
+ subs['changelog'] = "\n".join(ch_lines)
# See: http://www.zarb.org/~jasonc/macros.php
# Pickup any special files