-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
81 lines (59 loc) · 2.16 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# -*- coding: utf-8 -*-
import os
from os import path
from pprint import pprint
import json
import timeit
import memory_profiler
from engine import TmplEngineJinja, TmplEngineFest
jinja = None
fest = None
data = None
def main():
global jinja
global fest
global data
loops = 100
# jinja = TmplEngineJinja("tmpl/jinja", use_cache=use_cache)
# jinja_tmpl = jinja.get_template("test.tmpl")
# jinja_tmpl.render(data=data)
# fest = TmplEngineFest("tmpl/fest", use_cache=use_cache)
# fest_tmpl = fest.get_template("test.xml")
# fest_tmpl.render(**data)
for use_cache in (False, True):
jinja = TmplEngineJinja("tmpl/jinja", use_cache=use_cache)
fest = TmplEngineFest("tmpl/fest", use_cache=use_cache)
tmplname = "answer_results.tmpl"
s_build = """
tmpl = engine.get_template("%s")
"""
sres_build = "tmpl: %s, gen: %.2f usec/pass"
setup_build = "from __main__ import jinja as engine"
stmt = s_build % tmplname
# t = timeit.Timer(stmt, setup_build)
# print sres_build % (tmplname, 10**6 * t.timeit(number=1))
s = """
tmpl = engine.get_template("%s")
tmpl.render(**data)
"""
sres = "tmpl: %s, cache: %i, %.2f usec/pass"
from data import answer_results
stmt = s % tmplname
setup = "from __main__ import jinja as engine, data"
for result in answer_results:
data = result
t = timeit.Timer(stmt, setup)
print sres % (tmplname, use_cache, 10**6 * t.timeit(number=loops)/loops)
tmplname = "answer_results.xml"
setup_build = "from __main__ import fest as engine"
stmt = s_build % tmplname
t = timeit.Timer(stmt, setup_build)
print sres_build % (tmplname, 10**6 * t.timeit(number=1))
stmt = s % tmplname
setup = "from __main__ import fest as engine, data"
for result in answer_results:
data = result
t = timeit.Timer(stmt, setup)
print sres % (tmplname, use_cache, 10**6 * t.timeit(number=loops)/loops)
if __name__ == "__main__":
main()