Commit 25b78a7a authored by Stefan Behnel's avatar Stefan Behnel

implement minor special case of indexing into an inferred 1-char Unicode string

--HG--
extra : amend_source : 068dca3eae20906b495571f1d80548dc5f99ed51
parent 09fecb5d
...@@ -3011,15 +3011,16 @@ class IndexNode(ExprNode): ...@@ -3011,15 +3011,16 @@ class IndexNode(ExprNode):
if base_type.is_unicode_char: if base_type.is_unicode_char:
# we infer Py_UNICODE/Py_UCS4 for unicode strings in some # we infer Py_UNICODE/Py_UCS4 for unicode strings in some
# cases, but indexing must still work for them # cases, but indexing must still work for them
if self.index.constant_result in (0, -1): if setting:
# FIXME: we know that this node is redundant - warning(self.pos, "cannot assign to Unicode string index", level=1)
# currently, this needs to get handled in Optimize.py elif self.index.constant_result in (0, -1):
pass # uchar[0] => uchar
return self.base
self.base = self.base.coerce_to_pyobject(env) self.base = self.base.coerce_to_pyobject(env)
base_type = self.base.type base_type = self.base.type
if base_type.is_pyobject: if base_type.is_pyobject:
if self.index.type.is_int: if self.index.type.is_int:
if (not setting if (getting
and (base_type in (list_type, tuple_type, bytearray_type)) and (base_type in (list_type, tuple_type, bytearray_type))
and (not self.index.type.signed and (not self.index.type.signed
or not env.directives['wraparound'] or not env.directives['wraparound']
......
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