2010-03-11 18:53:45 -04:00
|
|
|
#! /usr/bin/env python3
|
1996-07-30 16:05:41 -03:00
|
|
|
|
|
|
|
"""Turn a pile of RCS log output into ChangeLog file entries.
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import string
|
2006-04-21 07:40:58 -03:00
|
|
|
import re
|
1996-07-30 16:05:41 -03:00
|
|
|
import getopt
|
|
|
|
import time
|
|
|
|
|
|
|
|
def main():
|
|
|
|
args = sys.argv[1:]
|
|
|
|
opts, args = getopt.getopt(args, 'p:')
|
|
|
|
prefix = ''
|
|
|
|
for o, a in opts:
|
1998-09-14 13:44:15 -03:00
|
|
|
if p == '-p': prefix = a
|
1996-07-30 16:05:41 -03:00
|
|
|
|
|
|
|
f = sys.stdin
|
|
|
|
allrevs = []
|
|
|
|
while 1:
|
1998-09-14 13:44:15 -03:00
|
|
|
file = getnextfile(f)
|
|
|
|
if not file: break
|
|
|
|
revs = []
|
|
|
|
while 1:
|
|
|
|
rev = getnextrev(f, file)
|
|
|
|
if not rev:
|
|
|
|
break
|
|
|
|
revs.append(rev)
|
|
|
|
if revs:
|
|
|
|
allrevs[len(allrevs):] = revs
|
1996-07-30 16:05:41 -03:00
|
|
|
allrevs.sort()
|
|
|
|
allrevs.reverse()
|
|
|
|
for rev in allrevs:
|
1998-09-14 13:44:15 -03:00
|
|
|
formatrev(rev, prefix)
|
1996-07-30 16:05:41 -03:00
|
|
|
|
2006-04-21 07:40:58 -03:00
|
|
|
parsedateprog = re.compile(
|
|
|
|
'^date: ([0-9]+)/([0-9]+)/([0-9]+) ' +
|
|
|
|
'([0-9]+):([0-9]+):([0-9]+); author: ([^ ;]+)')
|
1996-07-30 16:05:41 -03:00
|
|
|
|
|
|
|
authormap = {
|
|
|
|
'guido': 'Guido van Rossum <guido@cnri.reston.va.us>',
|
|
|
|
'jack': 'Jack Jansen <jack@cwi.nl>',
|
|
|
|
'sjoerd': 'Sjoerd Mullender <sjoerd@cwi.nl>',
|
|
|
|
}
|
|
|
|
|
|
|
|
def formatrev(rev, prefix):
|
|
|
|
dateline, file, revline, log = rev
|
|
|
|
if parsedateprog.match(dateline) >= 0:
|
1998-09-14 13:44:15 -03:00
|
|
|
fields = parsedateprog.group(1, 2, 3, 4, 5, 6)
|
|
|
|
author = parsedateprog.group(7)
|
2007-07-17 17:59:35 -03:00
|
|
|
if author in authormap: author = authormap[author]
|
|
|
|
tfields = list(map(string.atoi, fields)) + [0, 0, 0]
|
1998-09-14 13:44:15 -03:00
|
|
|
tfields[5] = tfields[5] - time.timezone
|
|
|
|
t = time.mktime(tuple(tfields))
|
2007-07-17 17:59:35 -03:00
|
|
|
print(time.ctime(t), '', author)
|
1998-09-14 13:44:15 -03:00
|
|
|
words = string.split(log)
|
|
|
|
words[:0] = ['*', prefix + file + ':']
|
|
|
|
maxcol = 72-8
|
|
|
|
col = maxcol
|
|
|
|
for word in words:
|
|
|
|
if col > 0 and col + len(word) >= maxcol:
|
2007-07-17 17:59:35 -03:00
|
|
|
print()
|
|
|
|
print('\t' + word, end=' ')
|
1998-09-14 13:44:15 -03:00
|
|
|
col = -1
|
|
|
|
else:
|
2007-07-17 17:59:35 -03:00
|
|
|
print(word, end=' ')
|
1998-09-14 13:44:15 -03:00
|
|
|
col = col + 1 + len(word)
|
2007-07-17 17:59:35 -03:00
|
|
|
print()
|
|
|
|
print()
|
1996-07-30 16:05:41 -03:00
|
|
|
|
2006-04-21 07:40:58 -03:00
|
|
|
startprog = re.compile("^Working file: (.*)$")
|
1996-07-30 16:05:41 -03:00
|
|
|
|
|
|
|
def getnextfile(f):
|
|
|
|
while 1:
|
1998-09-14 13:44:15 -03:00
|
|
|
line = f.readline()
|
|
|
|
if not line: return None
|
|
|
|
if startprog.match(line) >= 0:
|
|
|
|
file = startprog.group(1)
|
|
|
|
# Skip until first revision
|
|
|
|
while 1:
|
|
|
|
line = f.readline()
|
|
|
|
if not line: return None
|
|
|
|
if line[:10] == '='*10: return None
|
|
|
|
if line[:10] == '-'*10: break
|
|
|
|
## print "Skipped", line,
|
|
|
|
return file
|
|
|
|
## else:
|
|
|
|
## print "Ignored", line,
|
1996-07-30 16:05:41 -03:00
|
|
|
|
|
|
|
def getnextrev(f, file):
|
|
|
|
# This is called when we are positioned just after a '---' separator
|
|
|
|
revline = f.readline()
|
|
|
|
dateline = f.readline()
|
|
|
|
log = ''
|
|
|
|
while 1:
|
1998-09-14 13:44:15 -03:00
|
|
|
line = f.readline()
|
|
|
|
if not line: break
|
|
|
|
if line[:10] == '='*10:
|
|
|
|
# Ignore the *last* log entry for each file since it
|
|
|
|
# is the revision since which we are logging.
|
|
|
|
return None
|
|
|
|
if line[:10] == '-'*10: break
|
|
|
|
log = log + line
|
1996-07-30 16:05:41 -03:00
|
|
|
return dateline, file, revline, log
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|