~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to turbosimpletal/zptsupport.py

mostly more unicode fixes

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
"""Support for Zope Page Templates using the simpletal library."""
 
1
"TurboGears support for Zope Page Templates"
2
2
 
 
3
import StringIO
3
4
import logging
4
 
import os
5
5
import pkg_resources
6
 
import StringIO
7
6
 
 
7
#from zope.pagetemplate.pagetemplatefile import PageTemplateFile
8
8
from simpletal import simpleTAL, simpleTALES
9
9
 
10
 
logging.getLogger("simpleTAL").setLevel(logging.INFO)
11
 
logging.getLogger("simpleTALES").setLevel(logging.INFO)
12
 
 
 
10
log = logging.getLogger("turbogears.zptsupport")
13
11
 
14
12
_zpt_cache = {}
 
13
 
15
14
def zpt(tfile):
16
15
    tinstance = _zpt_cache.get(tfile)
17
 
    stat = os.stat(tfile)
18
 
    if tinstance is None or tinstance.stat != stat:
 
16
    if tinstance is None:
19
17
        tinstance = _zpt_cache[tfile] = TemplateWrapper(
20
 
            simpleTAL.compileXMLTemplate(open(tfile)), tfile, stat)
 
18
            simpleTAL.compileXMLTemplate(open(tfile)), tfile)
21
19
    return tinstance
22
20
 
23
 
 
24
21
class TemplateWrapper(object):
25
22
 
26
 
    def __init__(self, template, filename, stat):
 
23
    def __init__(self, template, filename):
27
24
        self.template = template
28
25
        self.filename = filename
29
 
        self.stat = stat
30
26
 
31
27
    def expand(self, **info):
32
28
        context = simpleTALES.Context(allowPythonPath=1)
36
32
        self.template.expandInline(context, s)
37
33
        return s.getvalue()
38
34
 
39
 
    def expand_into(self, f, **info):
40
 
        context = simpleTALES.Context(allowPythonPath=1)
41
 
        for k, v in info.iteritems():
42
 
            context.addGlobal(k, v)
43
 
        self.template.expand(context, f, 'utf-8')
44
 
 
45
35
    @property
46
36
    def macros(self):
47
37
        return self.template.macros
48
38
 
49
 
 
50
 
def load_template(classname):
51
 
    """Searches for a template along the Python path.
52
 
 
53
 
    Template files must end in ".pt" and be in legitimate packages.
54
 
    Templates are automatically checked for changes and reloaded as
55
 
    neccessary.
56
 
    """
57
 
    divider = classname.rfind(".")
58
 
    if divider > -1:
59
 
        package = classname[0:divider]
60
 
        basename = classname[divider+1:]
61
 
    else:
62
 
        raise ValueError, "All templates must be in a package"
63
 
 
64
 
    tfile = pkg_resources.resource_filename(
65
 
        package, "%s.%s" % (basename, "pt"))
66
 
    return zpt(tfile)
 
39
## class TGPageTemplateFile(PageTemplateFile):
 
40
 
 
41
##     def pt_getContext(self, args=(), options={}, **ignored):
 
42
##         namespace = super(TGPageTemplateFile, self).pt_getContext(
 
43
##             args, options, **ignored)
 
44
##         namespace.update(options)
 
45
##         return namespace
 
46
 
 
47
class TurboZpt(object):
 
48
    extension = "pt"
 
49
 
 
50
    def __init__(self, extra_vars_func=None):
 
51
        self.get_extra_vars = extra_vars_func
 
52
 
 
53
    def load_template(self, classname, loadingSite=False):
 
54
        """Searches for a template along the Python path.
 
55
 
 
56
        Template files must end in ".pt" and be in legitimate packages.
 
57
        Templates are automatically checked for changes and reloaded as
 
58
        neccessary.
 
59
        """
 
60
        divider = classname.rfind(".")
 
61
        if divider > -1:
 
62
            package = classname[0:divider]
 
63
            basename = classname[divider+1:]
 
64
        else:
 
65
            raise ValueError, "All templates must be in a package"
 
66
 
 
67
        tfile = pkg_resources.resource_filename(
 
68
            package, "%s.%s" % (basename, self.extension))
 
69
        return zpt(tfile)
 
70
 
 
71
    def render(self, info, format="html", fragment=False, template=None):
 
72
        """Renders data in the desired format.
 
73
 
 
74
        @param info: the data / context itself
 
75
        @type info: dict
 
76
        @para format: "html"
 
77
        @type format: "string"
 
78
        @para template: name of the template to use
 
79
        @type template: string
 
80
        """
 
81
        tinstance = self.load_template(template)
 
82
        log.debug("Applying template %s" % (tinstance.filename))
 
83
        data = dict()
 
84
        if self.get_extra_vars:
 
85
            data.update(self.get_extra_vars())
 
86
        data.update(info)
 
87
        return tinstance.expand(**data).encode('utf-8')