-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)
+ 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, [])
+
+ userlist.append(u)
+
+ def user_key(u):
+ return (u.start, u.username)
+
+ userlist.sort(key=user_key)
+
+ for u in userlist:
+ user_start = parse(u.start, default=START)
+ if u.end and parse(u.end, default=START) <= 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, 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, **kwargs)
+
+if __name__ == '__main__':
+ if len(sys.argv) < 2:
+ print >>sys.stderr, "Usage: %s TEMPLATE [WEEK]"
+ sys.exit(1)