[Zope-Checkins] SVN: Zope/branches/2.10/ Fixed Collector #2223: Evaluation of booleans in TALES and the 'default' variable.

Philipp von Weitershausen philikon at philikon.de
Mon Jan 8 08:18:21 EST 2007


Log message for revision 71799:
  Fixed Collector #2223: Evaluation of booleans in TALES and the 'default' variable.
  
  That consisted of forwardporting r70918 and r71797 from the 2.9 branch and providing
  a fix.
  

Changed:
  U   Zope/branches/2.10/doc/CHANGES.txt
  U   Zope/branches/2.10/lib/python/Products/PageTemplates/Expressions.py
  A   Zope/branches/2.10/lib/python/Products/PageTemplates/tests/input/BooleanAttributesAndDefault.html
  A   Zope/branches/2.10/lib/python/Products/PageTemplates/tests/output/BooleanAttributesAndDefault.html
  U   Zope/branches/2.10/lib/python/Products/PageTemplates/tests/testHTMLTests.py

-=-
Modified: Zope/branches/2.10/doc/CHANGES.txt
===================================================================
--- Zope/branches/2.10/doc/CHANGES.txt	2007-01-08 13:16:22 UTC (rev 71798)
+++ Zope/branches/2.10/doc/CHANGES.txt	2007-01-08 13:18:19 UTC (rev 71799)
@@ -8,6 +8,9 @@
 
     Bugs fixed
 
+      - Fixed Collector #2223: Evaluation of booleans in TALES and the
+        'default' variable.
+
       - Reverted backward-incompatible fix for Collector #2191.
 
       - Fixed the creation of lib/python/Zope2/version.txt

Modified: Zope/branches/2.10/lib/python/Products/PageTemplates/Expressions.py
===================================================================
--- Zope/branches/2.10/lib/python/Products/PageTemplates/Expressions.py	2007-01-08 13:16:22 UTC (rev 71798)
+++ Zope/branches/2.10/lib/python/Products/PageTemplates/Expressions.py	2007-01-08 13:18:19 UTC (rev 71799)
@@ -182,12 +182,20 @@
             domain, msgid, mapping=mapping,
             context=context, default=default)
 
+    def evaluateBoolean(self, expr):
+        value = self.evaluate(expr)
+        # here we override the normal Zope 3 behaviour.  Zope 3
+        # doesn't care about the default in a boolean expression,
+        # while we do (Zope 2 legacy, see the
+        # BooleanAttributesAndDefault.html test case)
+        if value is self.getDefault():
+            return value
+        return bool(value)
 
     def evaluateText(self, expr):
         """ customized version in order to get rid of unicode
             errors for all and ever
         """
-
         text = self.evaluate(expr)
 
         if text is self.getDefault() or text is None:

Copied: Zope/branches/2.10/lib/python/Products/PageTemplates/tests/input/BooleanAttributesAndDefault.html (from rev 71797, Zope/branches/2.9/lib/python/Products/PageTemplates/tests/input/BooleanAttributesAndDefault.html)

Copied: Zope/branches/2.10/lib/python/Products/PageTemplates/tests/output/BooleanAttributesAndDefault.html (from rev 71797, Zope/branches/2.9/lib/python/Products/PageTemplates/tests/output/BooleanAttributesAndDefault.html)

Modified: Zope/branches/2.10/lib/python/Products/PageTemplates/tests/testHTMLTests.py
===================================================================
--- Zope/branches/2.10/lib/python/Products/PageTemplates/tests/testHTMLTests.py	2007-01-08 13:16:22 UTC (rev 71798)
+++ Zope/branches/2.10/lib/python/Products/PageTemplates/tests/testHTMLTests.py	2007-01-08 13:18:19 UTC (rev 71799)
@@ -173,6 +173,12 @@
     def checkRepeatVariable(self):
         self.assert_expected(self.folder.t, 'RepeatVariable.html')
 
+    def checkBooleanAttributesAndDefault(self):
+        # Zope 2.9 and below support the semantics that an HTML
+        # "boolean" attribute (e.g. 'selected', 'disabled', etc.) can
+        # be used together with 'default'.
+        self.assert_expected(self.folder.t, 'BooleanAttributesAndDefault.html')
+
 def test_suite():
     return unittest.makeSuite(HTMLTests, 'check')
 



More information about the Zope-Checkins mailing list