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'],
+ '-n', 'balance', 'Pool:Owed:'],
stdout=subprocess.PIPE)
(out, _) = p.communicate()
- pool = int(out.split()[0][1:])
+ 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=pool)
+ pool=get_balance('Pool'), paid=get_balance('Pool:Paid'),
+ debts=debts)
if __name__ == '__main__':
if len(sys.argv) < 2:
<h2>Beer pool:</h2>
<table>
<tr> <td> This week: </td> <td> $${5 * len(lame)}.00 </td> </tr>
- <tr> <td> Total: </td> <td> ${pool}.00 </td> </tr>
+ <tr> <td> Total: </td> <td> $${pool}.00 </td> </tr>
+ <tr> <td> Paid: </td> <td> $${paid}.00 </td> </tr>
+</table>
+
+<h2>Debts:</h2>
+<table>
+% for (u, v) in sorted(debts, key=lambda p:p[1], reverse=True):
+<tr><td>${u}</td> <td>${v}</td></tr>
+% endfor
</table>