~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to turbozpt/zptsupport.py

browse.pt -> metal and some fixes

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
"TurboGears support for Zope Page Templates"
 
2
 
 
3
from template import zpt
 
4
import pkg_resources
 
5
 
 
6
import logging
 
7
log = logging.getLogger("turbogears.zptsupport")
 
8
 
 
9
class TurboZpt(object):
 
10
    extension = "pt"
 
11
 
 
12
    def __init__(self, extra_vars_func=None):
 
13
        self.get_extra_vars = extra_vars_func
 
14
 
 
15
    def load_template(self, classname, loadingSite=False):
 
16
        """Searches for a template along the Python path.
 
17
 
 
18
        Template files must end in ".pt" and be in legitimate packages.
 
19
        Templates are automatically checked for changes and reloaded as
 
20
        neccessary.
 
21
        """
 
22
        divider = classname.rfind(".")
 
23
        if divider > -1:
 
24
            package = classname[0:divider]
 
25
            basename = classname[divider+1:]
 
26
        else:
 
27
            raise ValueError, "All templates must be in a package"
 
28
 
 
29
        tfile = pkg_resources.resource_filename(
 
30
            package, "%s.%s" % (basename, self.extension))
 
31
        return zpt(tfile)
 
32
 
 
33
    def render(self, info, format="html", fragment=False, template=None):
 
34
        """Renders data in the desired format.
 
35
 
 
36
        @param info: the data / context itself
 
37
        @type info: dict
 
38
        @para format: "html"
 
39
        @type format: "string"
 
40
        @para template: name of the template to use
 
41
        @type template: string
 
42
        """
 
43
        tinstance = self.load_template(template)
 
44
        log.debug("Applying template %s" % (tinstance.filename))
 
45
        data = dict()
 
46
        if self.get_extra_vars:
 
47
            data.update(self.get_extra_vars())
 
48
        data.update(info)
 
49
        return tinstance(**data).encode('utf-8')
 
50