Skip to content

Commit

Permalink
Merge pull request web2py#1446 from ilvalle/fix_xmlescape
Browse files Browse the repository at this point in the history
fix py3.5 xmlescape with bytes
  • Loading branch information
mdipierro authored Sep 11, 2016
2 parents d96fe29 + 1623328 commit 0d646fa
Show file tree
Hide file tree
Showing 3 changed files with 5 additions and 4 deletions.
6 changes: 3 additions & 3 deletions gluon/html.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
import base64
from gluon import sanitizer, decoder
import itertools
from gluon._compat import reduce, pickle, copyreg, HTMLParser, name2codepoint, iteritems, unichr, unicodeT, urllib_quote, to_bytes, to_native, to_unicode, basestring, urlencode, implements_bool
from gluon._compat import reduce, pickle, copyreg, HTMLParser, name2codepoint, iteritems, unichr, unicodeT, urllib_quote, to_bytes, to_native, to_unicode, basestring, urlencode, implements_bool, text_type
from gluon.utils import local_html_escape
import marshal

Expand Down Expand Up @@ -122,7 +122,7 @@ def xmlescape(data, quote=True):
if hasattr(data, 'xml') and callable(data.xml):
return to_bytes(data.xml())

if not(isinstance(data, basestring)):
if not(isinstance(data, (text_type, bytes))):
# i.e., integers
data=str(data)
data = to_bytes(data, 'utf8', 'xmlcharrefreplace')
Expand Down Expand Up @@ -1040,7 +1040,7 @@ def elements(self, *args, **kargs):
hello
>>> a.elements('a[u:v=$]')[0].xml()
'<a id="1-1" u:v="$">hello</a>'
>>> a=FORM( INPUT(_type='text'), SELECT(range(1)), TEXTAREA() )
>>> a=FORM( INPUT(_type='text'), SELECT(list(range(1))), TEXTAREA() )
>>> for c in a.elements('input, select, textarea'): c['_disabled'] = 'disabled'
>>> a.xml()
'<form action="#" enctype="multipart/form-data" method="post"><input disabled="disabled" type="text" /><select disabled="disabled"><option value="0">0</option></select><textarea cols="40" disabled="disabled" rows="10"></textarea></form>'
Expand Down
2 changes: 1 addition & 1 deletion gluon/sqlhtml.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
import re

import os
from gluon._compat import StringIO, unichr, urllib_quote, iteritems, basestring, long, unicodeT, to_native
from gluon._compat import StringIO, unichr, urllib_quote, iteritems, basestring, long, unicodeT, to_native, to_unicode
from gluon.http import HTTP, redirect
from gluon.html import XmlComponent, truncate_string
from gluon.html import XML, SPAN, TAG, A, DIV, CAT, UL, LI, TEXTAREA, BR, IMG
Expand Down
1 change: 1 addition & 0 deletions gluon/tests/test_html.py
Original file line number Diff line number Diff line change
Expand Up @@ -253,6 +253,7 @@ def test_DIV(self):

# test .get('attrib')
self.assertEqual(DIV('<p>Test</p>', _class="class_test").get('_class'), 'class_test')
self.assertEqual(DIV(b'a').xml(), b'<div>a</div>')

def test_CAT(self):
# Empty CAT()
Expand Down

0 comments on commit 0d646fa

Please sign in to comment.