X-Git-Url: https://projects.mako.cc/source/iron-blogger/blobdiff_plain/75eca5ec298ea59b5dbd3f968f5104cd2a690579..4b123d38b4f031e226e03d3780432f92b153e6e1:/render.py diff --git a/render.py b/render.py index d5c9e51..0a7bf46 100755 --- a/render.py +++ b/render.py @@ -5,61 +5,98 @@ import datetime import dateutil.tz as tz import sys import os +import os.path +import subprocess from mako.template import Template -if len(sys.argv) < 2: - print >>sys.stderr, "Usage: %s TEMPLATE [WEEK]" - sys.exit(1) - -template = sys.argv[1] START = datetime.datetime(2009, 12, 21, 6) +HERE = os.path.dirname(__file__) + +def render_template(path, week=None): + with open('out/report.yml') as r: + report = yaml.safe_load(r) -if len(sys.argv) == 3: - week = parse(sys.argv[2], default=START) -else: - week = START + with open('bloggers.yml') as f: + users = yaml.safe_load(f) + if week: + week = parse(week, default=START) + else: + week = START -with open('out/report.yml') as r: - report = yaml.safe_load(r) + week = (week - START).days / 7 + week_start = START + (week * datetime.timedelta(7)) + week_end = START + ((week + 1) * datetime.timedelta(7)) -with open('bloggers.yml') as f: - users = yaml.safe_load(f) + good = [] + lame = [] + skip = [] + userlist = [] -week = (week - START).days / 7 -week_start = START + (week * datetime.timedelta(7)) -week_end = START + ((week + 1) * datetime.timedelta(7)) + class User(object): + pass -good = [] -lame = [] -skip = [] -userlist = [] + for (un, rec) in users.items(): + u = User() + u.username = un + u.links = rec['links'] + u.start = rec['start'] + u.end = rec.get('end') + u.skip = [(parse(x, default=START) - START).days / 7 + for x in rec.get('skip', [])] + u.weeks = report.get(un, []) -class User(object): - pass + userlist.append(u) -for (un, rec) in users.items(): - u = User() - u.username = un - u.links = rec['links'] - u.start = rec['start'] - u.weeks = report.get(un, []) + def user_key(u): + return (u.start, u.username) - userlist.append(u) + userlist.sort(key=user_key) -def user_key(u): - return (u.start, u.username) + for u in userlist: + user_start = parse(u.start, default=START) + if u.end and parse(u.end, default=START) <= week_start: + continue -userlist.sort(key=user_key) + if week in u.skip: + pass + elif user_start > week_start: + skip.append(u) + elif len(u.weeks) <= week or not u.weeks[week]: + lame.append(u) + else: + good.append(u) -for u in userlist: - user_start = parse(u.start, default=START) - if user_start > week_start: - skip.append(u) - elif len(u.weeks) <= week or not u.weeks[week]: - lame.append(u) - else: - good.append(u) + def get_balance(acct): + p = subprocess.Popen(['ledger', '-f', os.path.join(HERE,'ledger'), + '-n', 'balance', acct], + stdout=subprocess.PIPE) + (out, _) = p.communicate() + return int(out.split()[0][1:]) + + p = subprocess.Popen(['ledger', '-f', os.path.join(HERE,'ledger'), + '-n', 'balance', 'Pool:Owed:'], + stdout=subprocess.PIPE) + (out, _) = p.communicate() + debts = [] + for line in out.split("\n"): + if not line: continue + (val, acct) = line.split() + user = acct[len("Pool:Owed:"):] + val = int(val[len("$"):]) + debts.append((user, val)) + + return Template(filename=path, output_encoding='utf-8').render( + week=week, week_start=week_start,week_end=week_end, + good=good, lame=lame, skip=skip, userlist=userlist, + pool=get_balance('Pool'), paid=get_balance('Pool:Paid'), + debts=debts) + +if __name__ == '__main__': + if len(sys.argv) < 2: + print >>sys.stderr, "Usage: %s TEMPLATE [WEEK]" + sys.exit(1) -print Template(filename=template, output_encoding='utf-8').render( - week=week, week_start=week_start,week_end=week_end, - good=good, lame=lame, skip=skip, userlist=userlist) + template = sys.argv[1] + week = None + if len(sys.argv) > 2: week = sys.argv[2] + print render_template(template, week)