[PATCH V2] [utils] Backport of the changeset 9d62d9fed785 to support the fonctionnality in cubicweb 3.26.14

Guillaume Vandevelde guillaume.vandevelde at logilab.fr
Wed Feb 12 11:05:42 CET 2020


# HG changeset patch
# User Guillaume Vandevelde <gvandevelde at logilab.fr>
# Date 1581350162 -3600
#      Mon Feb 10 16:56:02 2020 +0100
# Branch 3.26
# Node ID 86873441f2e40a2aafa1a47d3a99c18966995a46
# Parent  9fa65579520f0c2dba413cfa791e0419fbd6105e
# Available At http://hg.logilab.org/review/cubicweb
#              hg pull http://hg.logilab.org/review/cubicweb -r 86873441f2e4
[utils] Backport of the changeset 9d62d9fed785 to support the fonctionnality in cubicweb 3.26.14

diff -r 9fa65579520f -r 86873441f2e4 cubicweb/utils.py
--- a/cubicweb/utils.py	Tue Aug 27 20:16:01 2019 +0200
+++ b/cubicweb/utils.py	Mon Feb 10 16:56:02 2020 +0100
@@ -33,6 +33,7 @@
     from inspect import getfullargspec as getargspec
 else:
     from inspect import getargspec
+from functools import wraps
 from itertools import repeat
 from uuid import uuid4
 from warnings import warn
@@ -191,6 +192,22 @@
         self._size -= 1
 
 
+def handle_writing_constraints(method):
+    @wraps(method)
+    def wrapper(self, value):
+        assert isinstance(value, text_type), u"unicode required not %s : %s"\
+            % (type(value).__name__, repr(value))
+        if self.tracewrites:
+            from traceback import format_stack
+            stack = format_stack(None)[:-1]
+            escaped_stack = xml_escape(json_dumps(u'\n'.join(stack)))
+            escaped_html = xml_escape(value).replace('\n', '<br/>\n')
+            tpl = u'<span onclick="alert(%s)">%s</span>'
+            value = tpl % (escaped_stack, escaped_html)
+        return method(self, value)
+    return wrapper
+
+
 class UStringIO(list):
     """a file wrapper which automatically encode unicode string to an encoding
     specifed in the constructor
@@ -205,18 +222,14 @@
 
     __nonzero__ = __bool__
 
+    @handle_writing_constraints
     def write(self, value):
-        assert isinstance(value, text_type), u"unicode required not %s : %s"\
-                                     % (type(value).__name__, repr(value))
-        if self.tracewrites:
-            from traceback import format_stack
-            stack = format_stack(None)[:-1]
-            escaped_stack = xml_escape(json_dumps(u'\n'.join(stack)))
-            escaped_html = xml_escape(value).replace('\n', '<br/>\n')
-            tpl = u'<span onclick="alert(%s)">%s</span>'
-            value = tpl % (escaped_stack, escaped_html)
         self.append(value)
 
+    @handle_writing_constraints
+    def write_front(self, value):
+        self.insert(0, value)
+
     def getvalue(self):
         return u''.join(self)
 



More information about the cubicweb-devel mailing list