From 128d932efff6c92ddee2095ec43b7382f4d2c7f1 Mon Sep 17 00:00:00 2001 From: Nelson Elhage Date: Wed, 30 Dec 2009 00:34:35 -0500 Subject: [PATCH] render.py: Wrap in a __name__ check. --- render.py | 91 +++++++++++++++++++++++++++++-------------------------- 1 file changed, 48 insertions(+), 43 deletions(-) diff --git a/render.py b/render.py index d5c9e51..f8cdd7a 100755 --- a/render.py +++ b/render.py @@ -7,59 +7,64 @@ import sys import os from mako.template import Template -if len(sys.argv) < 2: - print >>sys.stderr, "Usage: %s TEMPLATE [WEEK]" - sys.exit(1) - -template = sys.argv[1] START = datetime.datetime(2009, 12, 21, 6) -if len(sys.argv) == 3: - week = parse(sys.argv[2], default=START) -else: - week = START +def render_template(path, week=None): + with open('out/report.yml') as r: + report = yaml.safe_load(r) + + with open('bloggers.yml') as f: + users = yaml.safe_load(f) + if week: + week = parse(week, default=START) + else: + week = START -with open('out/report.yml') as r: - report = yaml.safe_load(r) + week = (week - START).days / 7 + week_start = START + (week * datetime.timedelta(7)) + week_end = START + ((week + 1) * datetime.timedelta(7)) -with open('bloggers.yml') as f: - users = yaml.safe_load(f) + good = [] + lame = [] + skip = [] + userlist = [] -week = (week - START).days / 7 -week_start = START + (week * datetime.timedelta(7)) -week_end = START + ((week + 1) * datetime.timedelta(7)) + class User(object): + pass -good = [] -lame = [] -skip = [] -userlist = [] + for (un, rec) in users.items(): + u = User() + u.username = un + u.links = rec['links'] + u.start = rec['start'] + u.weeks = report.get(un, []) -class User(object): - pass + userlist.append(u) -for (un, rec) in users.items(): - u = User() - u.username = un - u.links = rec['links'] - u.start = rec['start'] - u.weeks = report.get(un, []) + def user_key(u): + return (u.start, u.username) - userlist.append(u) + userlist.sort(key=user_key) -def user_key(u): - return (u.start, u.username) + 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.sort(key=user_key) + 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) -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) +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) -- 2.39.5