1
"TurboGears support for Zope Page Templates"
5
from template import PageTemplate
9
log = logging.getLogger("turbogears.zptsupport")
11
def _recompile_template(package, basename, tfile, classname):
12
log.debug("Recompiling template for %s" % classname)
13
mod = PageTemplate(tfile)
14
mtime = os.stat(tfile).st_mtime
21
def __init__(self, extra_vars_func=None, options={}):
22
self.options = options
23
self.get_extra_vars = extra_vars_func
24
self.compiledTemplates = {}
26
def load_template(self, classname, loadingSite=False):
27
"""Searches for a template along the Python path.
29
Template files must end in ".pt" and be in legitimate packages.
30
U can set "zpt.cache_templates" option to cache a loaded template
31
class and only check for updates. Templates are automatically
32
checked for changes and reloaded as neccessary.
34
ct = self.compiledTemplates
36
divider = classname.rfind(".")
38
package = classname[0:divider]
39
basename = classname[divider+1:]
41
raise ValueError, "All templates must be in a package"
43
cache_templates = self.options.get("zpt.cache_templates", True)
44
tfile = pkg_resources.resource_filename(package,
50
if ct.has_key(classname):
51
mtime = os.stat(tfile).st_mtime
53
if mod.__mtime__ != mtime:
55
mod = _recompile_template(package, basename, tfile, classname)
58
# use template from cache
61
# First time compile template
62
mod = PageTemplate(tfile)
63
mod.__mtime__ = os.stat(tfile).st_mtime
66
mod = PageTemplate(tfile)
70
def render(self, info, format="html", fragment=False, template=None):
71
"""Renders data in the desired format.
73
@param info: the data / context itself
76
@type format: "string"
77
@para template: name of the template to use
78
@type template: string
80
#if isinstance(template, type):
84
tinstance = self.load_template(template)
85
log.debug("Applying template %s" % (tinstance.filename))
87
if self.get_extra_vars:
88
data.update(self.get_extra_vars())
91
return str(tinstance(**data))
93
def transform(self, info, template):
94
"Render the output to Elements"