Commit e1d01bec authored by Stefan Behnel's avatar Stefan Behnel

fix bytes.decode() without arguments

parent 827fff94
...@@ -1944,6 +1944,9 @@ class OptimizeBuiltinCalls(Visitor.EnvTransform): ...@@ -1944,6 +1944,9 @@ class OptimizeBuiltinCalls(Visitor.EnvTransform):
return None return None
def _unpack_encoding_and_error_mode(self, pos, args): def _unpack_encoding_and_error_mode(self, pos, args):
null_node = ExprNodes.NullNode(pos)
if len(args) >= 2:
encoding_node = args[1] encoding_node = args[1]
if isinstance(encoding_node, ExprNodes.CoerceToPyTypeNode): if isinstance(encoding_node, ExprNodes.CoerceToPyTypeNode):
encoding_node = encoding_node.arg encoding_node = encoding_node.arg
...@@ -1956,8 +1959,10 @@ class OptimizeBuiltinCalls(Visitor.EnvTransform): ...@@ -1956,8 +1959,10 @@ class OptimizeBuiltinCalls(Visitor.EnvTransform):
encoding = None encoding = None
else: else:
return None return None
else:
encoding = None
encoding_node = null_node
null_node = ExprNodes.NullNode(pos)
if len(args) == 3: if len(args) == 3:
error_handling_node = args[2] error_handling_node = args[2]
if isinstance(error_handling_node, ExprNodes.CoerceToPyTypeNode): if isinstance(error_handling_node, ExprNodes.CoerceToPyTypeNode):
......
...@@ -17,6 +17,19 @@ def slice_charptr_decode(): ...@@ -17,6 +17,19 @@ def slice_charptr_decode():
cstring[:3].decode('UTF-8'), cstring[:3].decode('UTF-8'),
cstring[:9].decode('UTF-8')) cstring[:9].decode('UTF-8'))
@cython.test_assert_path_exists("//PythonCapiCallNode")
@cython.test_fail_if_path_exists("//AttributeNode")
def slice_charptr_decode_platform_encoding():
"""
>>> print(str(slice_charptr_decode()).replace("u'", "'"))
('a', 'abc', 'abcABCqtp')
"""
cdef bytes s = u'abcABCqtp'.encode()
cdef char* cstr = s
return (cstr[:1].decode(),
cstr[:3].decode(),
cstr[:9].decode())
@cython.test_assert_path_exists("//PythonCapiCallNode") @cython.test_assert_path_exists("//PythonCapiCallNode")
@cython.test_fail_if_path_exists("//AttributeNode") @cython.test_fail_if_path_exists("//AttributeNode")
def slice_charptr_decode_unknown_encoding(): def slice_charptr_decode_unknown_encoding():
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment