[pypy-commit] pypy unicode-utf8: mrege default into branch
mattip
pypy.commits at gmail.com
Tue Jan 1 01:46:36 EST 2019
Author: Matti Picus <matti.picus at gmail.com>
Branch: unicode-utf8
Changeset: r95547:aa0b6372c139
Date: 2019-01-01 08:45 +0200
http://bitbucket.org/pypy/pypy/changeset/aa0b6372c139/
Log: mrege default into branch
diff --git a/pypy/objspace/std/test/test_unicodeobject.py b/pypy/objspace/std/test/test_unicodeobject.py
--- a/pypy/objspace/std/test/test_unicodeobject.py
+++ b/pypy/objspace/std/test/test_unicodeobject.py
@@ -1231,9 +1231,8 @@
assert type(unicode(z)) is unicode
assert unicode(z) == u'foobaz'
#
- # two completely corner cases where we differ from CPython:
- #assert unicode(encoding='supposedly_the_encoding') == u''
- #assert unicode(errors='supposedly_the_error') == u''
+ assert unicode(encoding='supposedly_the_encoding') == u''
+ assert unicode(errors='supposedly_the_error') == u''
e = raises(TypeError, unicode, u'', 'supposedly_the_encoding')
assert str(e.value) == 'decoding Unicode is not supported'
e = raises(TypeError, unicode, u'', errors='supposedly_the_error')
diff --git a/pypy/objspace/std/unicodeobject.py b/pypy/objspace/std/unicodeobject.py
--- a/pypy/objspace/std/unicodeobject.py
+++ b/pypy/objspace/std/unicodeobject.py
@@ -197,23 +197,20 @@
return unicodedb.islinebreak(ch)
@staticmethod
- @unwrap_spec(w_string=WrappedDefault(""))
- def descr_new(space, w_unicodetype, w_string, w_encoding=None,
+ def descr_new(space, w_unicodetype, w_string=None, w_encoding=None,
w_errors=None):
- # NB. the default value of w_obj is really a *wrapped* empty string:
- # there is gateway magic at work
- w_obj = w_string
-
encoding, errors = _get_encoding_and_errors(space, w_encoding,
w_errors)
- if encoding is None and errors is None:
- # this is very quick if w_obj is already a w_unicode
- w_value = unicode_from_object(space, w_obj)
+ if w_string is None:
+ w_value = W_UnicodeObject.EMPTY
+ elif encoding is None and errors is None:
+ # this is very quick if w_string is already a w_unicode
+ w_value = unicode_from_object(space, w_string)
else:
- if space.isinstance_w(w_obj, space.w_unicode):
+ if space.isinstance_w(w_string, space.w_unicode):
raise oefmt(space.w_TypeError,
"decoding Unicode is not supported")
- w_value = unicode_from_encoded_object(space, w_obj,
+ w_value = unicode_from_encoded_object(space, w_string,
encoding, errors)
if space.is_w(w_unicodetype, space.w_unicode):
return w_value
More information about the pypy-commit
mailing list