view en/fblinks @ 401:e281bd9a8e47

Fix sample output for test 'tour-merge-conflict'. Fix test itself as well (now requires 'hg resolve').
author Guido Ostkamp <hg@ostkamp.fastmail.fm>
date Wed, 20 Aug 2008 22:00:46 +0200
parents 9457add294b8
children
line wrap: on
line source

#!/usr/bin/python

import errno
import os
import re
import sys

hg_id = sys.argv[1]

dest_dir = sys.argv[2]

empty_re = re.compile(r'^\s*$')
line_re = re.compile(r'^(\w+)(.*)')

try:
    os.makedirs(dest_dir)
except OSError, err:
    if err.errno != errno.EEXIST:
        raise

def feedback(name, text, ctx_id):
    return r'\marginpar{\scriptsize \href{http://demesne:8000/book/feedback/submit/%s/%s/%d/}{Feedback}}' % (hg_id, name, ctx_id)

ctxs = {}
try:
    cfp = open(os.path.join(dest_dir, 'rev-' + hg_id + '.ctx'), 'r+')
    for line in cfp:
        f, l, c = line.split(':', 2)
        ctxs[(f, int(l))] = c.strip()
except IOError, err:
    if err.errno != errno.ENOENT: raise
    cfp = open(os.path.join(dest_dir, 'rev-' + hg_id + '.ctx'), 'w+')

changes = 0

for name in sys.argv[3:]:
    if not name.endswith('.tex'):
        continue
    dest_name = os.path.join(dest_dir, name)
    ifp = open(name)
    ofp = open(dest_name, 'w')
    new_par = True
    line_num = 0
    par_num = 0
    for line in ifp:
        line_num += 1
        if new_par:
            m = line_re.match(line)
            if m:
                par_num += 1
                ls = line.strip()
                if ctxs.get((name, par_num)) != ls:
                    ctxs[(name, par_num)] = ls
                    changes += 1
                line = m.group(1) + feedback(name, line, par_num) + m.group(2)
                new_par = False
        elif not line.strip():
            new_par = True
        ofp.write(line)

if changes:
    cfp.seek(0)
    print '%s: %d changes' % (cfp.name, changes)
    ctxs = ctxs.items()
    ctxs.sort()
    for ((file, line), content) in ctxs:
        cfp.write('%s:%d: %s\n' % (file, line, content))