]> projects.mako.cc - iron-blogger/blobdiff - render.py
update the rest of the code to support the new config format
[iron-blogger] / render.py
index d5c9e51798bd5a560d00dd205a5684dfc6dff572..6d6415eea204e612606aa966cb93394d2fa423d0 100755 (executable)
--- a/render.py
+++ b/render.py
@@ -5,61 +5,132 @@ import datetime
 import dateutil.tz as tz
 import sys
 import os
 import dateutil.tz as tz
 import sys
 import os
+import os.path
+import subprocess
+import re
 from mako.template import Template
 
 from mako.template import Template
 
-if len(sys.argv) < 2:
-    print >>sys.stderr, "Usage: %s TEMPLATE [WEEK]" 
-    sys.exit(1)
+from config import *
 
 
-template = sys.argv[1]
-START = datetime.datetime(2009, 12, 21, 6)
+def get_balance(acct):
+    balance_cmd_tmp = BALANCE_CMD
+    balance_cmd_tmp.append(acct)
+    p = subprocess.Popen(balance_cmd_tmp,
+                         stdout=subprocess.PIPE)
+    (out, _) = p.communicate()
+    return float(re.sub(r'\s*(\d+)\s+.*', r'\1', out))
 
 
-if len(sys.argv) == 3:
-    week = parse(sys.argv[2], default=START)
-else:
-    week = START
+def get_debts():
+    p = subprocess.Popen(DEBTS_CMD,
+                         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:"):]
+        if not user: continue
+        val = float(re.sub(r'(\D)?(\d+)$', r'\2', val))
+        debts.append((user, val))
+    return debts
 
 
-with open('out/report.yml') as r:
-    report = yaml.safe_load(r)
+def to_week_num(date):
+    return (parse(date, default=START) - START).days / 7
 
 
-with open('bloggers.yml') as f:
-    users = yaml.safe_load(f)
+def parse_skip(rec):
+    spec = rec.get('skip', [])
+    out = []
+    for s in spec:
+        if isinstance(s, list):
+            out.append(map(to_week_num, s))
+        else:
+            out.append(to_week_num(s))
+    return out
 
 
-week = (week - START).days / 7
-week_start = START + (week * datetime.timedelta(7))
-week_end   = START + ((week + 1) * datetime.timedelta(7))
+def should_skip(skips, week):
+    for e in skips:
+        if e == week:
+            return True
+        if isinstance(e, list) and e[0] <= week and e[1] > week:
+            return True
+    return False
 
 
-good = []
-lame = []
-skip = []
-userlist = []
+def render_template(path, week=None, **kwargs):
+    with open('out/report.yml') as r:
+        report = yaml.safe_load(r)
 
 
-class User(object):
-    pass
+    with open('bloggers.yml') as f:
+        users = yaml.safe_load(f)
+    if week:
+        week = parse(week, default=START)
+    else:
+        week = START
 
 
-for (un, rec) in users.items():
-    u = User()
-    u.username = un
-    u.links = rec['links']
-    u.start = rec['start']
-    u.weeks = report.get(un, [])
+    week = (week - START).days / 7
+    week_start = START + (week * datetime.timedelta(7))
+    week_end   = START + ((week + 1) * datetime.timedelta(7))
 
 
-    userlist.append(u)
+    good = []
+    lame = []
+    skip = []
+    userlist = []
+    punted = []
 
 
-def user_key(u):
-    return (u.start, u.username)
+    class User(object):
+        pass
 
 
-userlist.sort(key=user_key)
+    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_skip(rec)
+        u.weeks = report.get(un, [])
 
 
-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)
+        userlist.append(u)
+
+        # create a subset of punted users
+        if u.end:
+            punted.append(u)
+
+    def user_key(u):
+        return (u.start, u.username)
+
+    userlist.sort(key=user_key)
+    punted.sort(key=user_key)
+
+    for u in userlist:
+        user_start = datetime.datetime(*(u.start.timetuple()[:6]))
+        if u.end and datetime.datetime(*(u.end.timetuple()[:6])) <= week_start:
+            continue
+        
+        if should_skip(u.skip, week):
+            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)
+
+    debts = get_debts()
+
+    return Template(filename=path, input_encoding='utf-8',
+                    output_encoding='utf-8',
+                    default_filters=['decode.utf8']).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, punted=punted, currency=CURRENCY, fine=FINE_SIZE,
+        **kwargs)
+
+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)

Benjamin Mako Hill || Want to submit a patch?