summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xpackages/rpm-changelog79
1 files changed, 35 insertions, 44 deletions
diff --git a/packages/rpm-changelog b/packages/rpm-changelog
index 80db94c5..8acaa5b9 100755
--- a/packages/rpm-changelog
+++ b/packages/rpm-changelog
@@ -1,61 +1,49 @@
#!/usr/bin/python
# vi: ts=4 expandtab
-import sys
+# A crappy little script
+# that changes bzr 'log'
+# into someting that rpm spec files can use (best effort)
+
import os
import re
-
-import textwrap
+import sys
from datetime import datetime
from datetime import date
import subprocess
+E_TYPES = ['tags', 'revno', 'author', 'timestamp', 'committer']
+
+
def tiny_p(cmd):
+ # Darn python 2.6 doesn't have check_output (argggg)
sp = subprocess.Popen(cmd, stdout=subprocess.PIPE,
stderr=subprocess.PIPE, stdin=None)
(out, err) = sp.communicate()
return (out, err)
-# This util converts a bzr log into a useful rpm changelog
-
-def cut_up(entry, maxline=80):
- if len(entry) < maxline:
- return entry
- else:
- c = entry[0:maxline]
- return "%s..." % (c)
-
-
-def adj_iter(elems):
- if not elems:
- raise StopIteration()
- curr = elems[0]
- yield curr
- for i in range(1, len(elems)):
- e = elems[i]
- if e != curr:
- yield e
- curr = e
def extract_entry(collecting):
- a_entry = {}
- for t in ['tags', 'revno', 'author', 'timestamp', 'committer']:
+ entry = {}
+ for t in E_TYPES:
look_for = "%s:" % (t)
for v in collecting:
if v.startswith(look_for):
- a_entry[t] = v[len(look_for):].strip()
+ entry[t] = v[len(look_for):].strip()
break
i = -1
+ # Messages seem to be the last element so suck
+ # those all up
for a, v in enumerate(collecting):
if v.startswith("message:"):
i = a
break
if i != -1:
msg_lines = collecting[i + 1:]
- a_entry['message'] = "\n".join(msg_lines)
- return a_entry
+ entry['message'] = "\n".join(msg_lines)
+ return entry
def clean_authors(authors):
@@ -143,6 +131,7 @@ def clean_messages(messages):
def build_changelog(history=-1):
cmd = ['bzr', 'log', '--timezone=utc']
(stdout, _stderr) = tiny_p(cmd)
+
# Clean the format up
entries = stdout.splitlines()
all_entries = []
@@ -157,9 +146,10 @@ def build_changelog(history=-1):
else:
collecting.append(e)
- a_entry = extract_entry(collecting)
- if a_entry:
- all_entries.append(a_entry)
+ # Anything that we left behind??
+ entry = extract_entry(collecting)
+ if entry:
+ all_entries.append(entry)
if history > 0:
take_entries = list(all_entries[0:history])
@@ -186,25 +176,26 @@ def build_changelog(history=-1):
# http://bugs.python.org/issue6641
timestamp = timestamp.replace("+0000", '').strip()
ds = datetime.strptime(timestamp, '%a %Y-%m-%d %H:%M:%S')
- c_ds = ds.date()
- if c_ds not in date_entries:
- ap_entry = {}
- ap_entry['messages'] = []
- ap_entry['authors'] = []
- ap_entry['revnos'] = []
- date_entries[c_ds] = ap_entry
- ap_entry = date_entries[c_ds]
- ap_entry['messages'].append(msg)
- ap_entry['authors'].append(author)
- ap_entry['revnos'].append(revno)
-
+ ds = ds.date()
+ if ds not in date_entries:
+ entry = {}
+ entry['messages'] = []
+ entry['authors'] = []
+ entry['revnos'] = []
+ date_entries[ds] = entry
+ entry = date_entries[ds]
+ entry['messages'].append(msg)
+ entry['authors'].append(author)
+ entry['revnos'].append(revno)
+
+ # It wants them in chronological order...
dates = sorted(date_entries.keys())
chglog = []
for ds in reversed(dates):
e = date_entries[ds]
authors = clean_authors(e['authors'])
revnos = clean_revnos(e['revnos'])
- top_line = "%s %s - %s" % (ds.strftime("%a %b %d %Y"),
+ top_line = "%s %s - [revison %s]" % (ds.strftime("%a %b %d %Y"),
authors, revnos)
chglog.append("* %s" % (top_line))
chglog.append(clean_messages(e['messages']))