Mercurial > getan
view scripts/getan-eval.py @ 429:5ee2ce059338
getan-eval.py: improves diagnosis.
* (minor) In case of missing -u/--user parameter, scripts/getan-eval.py
will output an error message.
author | Bernhard Reiter <bernhard@intevation.de> |
---|---|
date | Mon, 29 May 2017 14:22:06 +0200 |
parents | da9a400848fd |
children | e2b05afaf1bc |
line wrap: on
line source
#!/usr/bin/env python # -*- coding: utf-8 -*- # # (c) 2013, 2014 by Björn Ricks <bjoern.ricks@intevation.de> # # This is Free Software licensed under the terms of GPLv3 or later. # For details see LICENSE coming with the source of 'getan'. import codecs import locale import sys from datetime import date, datetime, timedelta from optparse import OptionParser from getan.template import render def main(): parser = OptionParser() parser.add_option("-d", "--database", dest="database", help="getan database", metavar="DATABASE") parser.add_option("-t", "--template", dest="template", metavar="TEMPLATE", help="name of getan template") parser.add_option("-u", "--user", dest="user", help="[REQUIRED] name of user") parser.add_option("-p", "--project", dest="project", help="key of output project") parser.add_option("-w", "--week", type="int", dest="week", help="week of year") parser.add_option("-y", "--year", type="int", dest="year", help="year") parser.add_option("-c", "--lastweek", dest="lastweek", help="entries of last working week", action="store_true") parser.add_option("-m", "--empty", dest="empty", help="show projects without an entries", action="store_true") parser.add_option("--encoding", dest="encoding", help="encoding of output", metavar="ENCODING") (options, args) = parser.parse_args() if options.lastweek: week = (datetime.now() - timedelta(7)).isocalendar()[1] year = int(date.today().strftime("%Y")) else: year = options.year week = options.week template_name = options.template or "wochenbericht" if not options.encoding: encoding = locale.getdefaultlocale()[1] Writer = codecs.getwriter(encoding) sys.stdout = Writer(sys.stdout) if options.user: user = options.user.decode(encoding) else: parser.error("You have to give the -u/--user parameter.") print render(database=options.database, user=user, template=template_name, year=year, week=week, project=options.project, empty_projects=options.empty) if __name__ == '__main__': main() # vim:set ts=4 sw=4 si et sta sts=4 :