[Zope-Checkins] CVS: Zope3/lib/python/Zope/App/OFS/Content/ZPTPage/Views/Browser - ZPTPageEdit.py:1.1.2.3 ZPTPageEval.py:1.1.2.4
Jim Fulton
jim@zope.com
Thu, 23 May 2002 14:01:43 -0400
Update of /cvs-repository/Zope3/lib/python/Zope/App/OFS/Content/ZPTPage/Views/Browser
In directory cvs.zope.org:/tmp/cvs-serv26429/lib/python/Zope/App/OFS/Content/ZPTPage/Views/Browser
Modified Files:
Tag: Zope-3x-branch
ZPTPageEdit.py ZPTPageEval.py
Log Message:
This all started with wanting to be able to use url;view in a ZPT path. :)
That lead me to:
- Massive traversal refactoring.
Namespace handling is now centralized in Zope.App.Traversing.
- ZPT refactoring, including some renaming that touches pretty much everything. :)
- The application specific ZPT support was moved into
Zope.App.PageTemplate.
- To get page template files (for use in views):
from Zope.App.PageTemplate import ViewPageTemplateFile
- Fixed up security so that ZPT expressions only have access to
safe builtins and so that modules namespace does imports safely.
- Got ZPTPage working!
- renaming url to absolute_url and got absolute_url to work in paths.
- Cleaned up the (as yet unused) RestrictedInterpreter module in
Zope.Security. In particular, changed to use a separate
RestrictedBuiltins module.
=== Zope3/lib/python/Zope/App/OFS/Content/ZPTPage/Views/Browser/ZPTPageEdit.py 1.1.2.2 => 1.1.2.3 ===
from Zope.App.Formulator.Form import Form
-from Zope.PageTemplate.PageTemplateFile import PageTemplateFile
+from Zope.App.PageTemplate import ViewPageTemplateFile
class ZPTPageEdit(Form):
@@ -30,4 +30,4 @@
'source code of this ZPT Page.')
_fieldViewNames = ['SourceFieldView']
- template = PageTemplateFile('edit.pt')
+ template = ViewPageTemplateFile('edit.pt')
=== Zope3/lib/python/Zope/App/OFS/Content/ZPTPage/Views/Browser/ZPTPageEval.py 1.1.2.3 => 1.1.2.4 ===
#
##############################################################################
-"""
- Define view component for ZPT page eval results.
+"""Define view component for ZPT page eval results.
+
+$Id$
"""
from Zope.Publisher.Browser.AttributePublisher import AttributePublisher
+from Zope.Proxy.ContextWrapper import getWrapperContainer
-
-class ZPTPageEval( AttributePublisher ):
+class ZPTPageEval(AttributePublisher):
__implements__ = AttributePublisher.__implements__
- def __init__( self, zptpage ):
+ def __init__(self, zptpage):
self._zptpage = zptpage
- def getContext( self ):
+ def getContext(self):
return self._zptpage
- def pt_getContext(self, inst=None, REQUEST=None):
- #root = self.getPhysicalRoot()
- c = {'template': self.getContext(),
- 'nothing': None,
- }
- if inst is not None:
- c['context'] = inst.getContext()
- c['view'] = inst
- c['views'] = ViewMapper(inst.getContext(), REQUEST)
- return c
-
-
- def index(self, inst=None, REQUEST=None, **kw):
+ def index(self, REQUEST=None, **kw):
"""Call a Page Template"""
- bound_names = {}
- bound_names.update(self.pt_getContext(inst, REQUEST))
- bound_names['options'] = kw
- bound_names['request'] = REQUEST
-
- try:
- self.REQUEST.getResponse().setHeader('content-type',
- self.getContext().content_type)
- except AttributeError:
- pass
-
- # Execute the template in a new security context.
- self.getContext()._cook()
- return self.getContext().pt_render(bound_names)
-
- def document_src(self, REQUEST=None):
- """Return expanded document source."""
+ template = self.getContext()
if REQUEST is not None:
- REQUEST.getResponse().setHeader('Content-Type', self.content_type)
- return self.read()
+ REQUEST.getResponse().setHeader('content-type',
+ template.content_type)
+
+ return template.render(REQUEST, **kw)