]> projects.mako.cc - iron-blogger/blobdiff - render.py
AUTOPUNT
[iron-blogger] / render.py
index dc4ad3d560cd36767802a7b4d3fd346d4d594531..cacd90da6360c8fe2b799eb21f4f81b05d6ce826 100755 (executable)
--- a/render.py
+++ b/render.py
@@ -12,7 +12,28 @@ from mako.template import Template
 START = datetime.datetime(2009, 12, 21, 6)
 HERE  = os.path.dirname(__file__)
 
-def render_template(path, week=None):
+def get_balance(acct):
+    p = subprocess.Popen(['ledger', '-f', os.path.join(HERE,'ledger'),
+                          '-n', 'balance', acct],
+                         stdout=subprocess.PIPE)
+    (out, _) = p.communicate()
+    return float(out.split()[0][1:])
+
+def get_debts():
+    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  = float(val[len("$"):])
+        debts.append((user, val))
+    return debts
+
+def render_template(path, week=None, **kwargs):
     with open('out/report.yml') as r:
         report = yaml.safe_load(r)
 
@@ -41,6 +62,8 @@ def render_template(path, week=None):
         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, [])
 
         userlist.append(u)
@@ -55,23 +78,22 @@ def render_template(path, week=None):
         if u.end and parse(u.end, default=START) <= week_start:
             continue
 
-        if user_start > week_start:
+        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)
 
-    p = subprocess.Popen(['ledger', '-f', os.path.join(HERE,'ledger'),
-                          '-n', 'balance', 'Pool'],
-                         stdout=subprocess.PIPE)
-    (out, _) = p.communicate()
-    pool = int(out.split()[0][1:])
+    debts = get_debts()
 
     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=pool)
+        pool=get_balance('Pool'), paid=get_balance('Pool:Paid'),
+        debts=debts, **kwargs)
 
 if __name__ == '__main__':
     if len(sys.argv) < 2:

Benjamin Mako Hill || Want to submit a patch?