-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 = 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, punted=punted, **kwargs)
+
+if __name__ == '__main__':
+ if len(sys.argv) < 2:
+ print >>sys.stderr, "Usage: %s TEMPLATE [WEEK]"
+ sys.exit(1)