~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to loggerhead/zptsupport.py

  • Committer: Michael Hudson
  • Date: 2008-06-30 23:24:32 UTC
  • mto: This revision was merged to the branch mainline in revision 180.
  • Revision ID: michael.hudson@canonical.com-20080630232432-qjggfrg58qghxk0m
updates to logging setup in start-loggerhead.py

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
"""Support for Zope Page Templates using the simpletal library."""
 
2
 
 
3
import logging
 
4
import os
 
5
import pkg_resources
 
6
import StringIO
 
7
 
 
8
from simpletal import simpleTAL, simpleTALES
 
9
 
 
10
logging.getLogger("simpleTAL").setLevel(logging.INFO)
 
11
logging.getLogger("simpleTALES").setLevel(logging.INFO)
 
12
 
 
13
 
 
14
_zpt_cache = {}
 
15
def zpt(tfile):
 
16
    tinstance = _zpt_cache.get(tfile)
 
17
    stat = os.stat(tfile)
 
18
    if tinstance is None or tinstance.stat != stat:
 
19
        tinstance = _zpt_cache[tfile] = TemplateWrapper(
 
20
            simpleTAL.compileXMLTemplate(open(tfile)), tfile, stat)
 
21
    return tinstance
 
22
 
 
23
 
 
24
class TemplateWrapper(object):
 
25
 
 
26
    def __init__(self, template, filename, stat):
 
27
        self.template = template
 
28
        self.filename = filename
 
29
        self.stat = stat
 
30
 
 
31
    def expand(self, **info):
 
32
        context = simpleTALES.Context(allowPythonPath=1)
 
33
        for k, v in info.iteritems():
 
34
            context.addGlobal(k, v)
 
35
        s = StringIO.StringIO()
 
36
        self.template.expandInline(context, s)
 
37
        return s.getvalue()
 
38
 
 
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
    @property
 
46
    def macros(self):
 
47
        return self.template.macros
 
48
 
 
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)