Commit 0353b956 authored by Stefan Behnel's avatar Stefan Behnel

clean up some code redundancy

parent bdb7757f
...@@ -3319,8 +3319,8 @@ class IndexNode(ExprNode): ...@@ -3319,8 +3319,8 @@ class IndexNode(ExprNode):
elif self.is_temp: elif self.is_temp:
if self.type.is_pyobject: if self.type.is_pyobject:
error_value = 'NULL'
if self.index.type.is_int: if self.index.type.is_int:
index_code = self.index.result()
if self.base.type is list_type: if self.base.type is list_type:
function = "__Pyx_GetItemInt_List" function = "__Pyx_GetItemInt_List"
elif self.base.type is tuple_type: elif self.base.type is tuple_type:
...@@ -3330,57 +3330,46 @@ class IndexNode(ExprNode): ...@@ -3330,57 +3330,46 @@ class IndexNode(ExprNode):
code.globalstate.use_utility_code( code.globalstate.use_utility_code(
TempitaUtilityCode.load_cached("GetItemInt", "ObjectHandling.c")) TempitaUtilityCode.load_cached("GetItemInt", "ObjectHandling.c"))
else: else:
index_code = self.index.py_result()
if self.base.type is dict_type: if self.base.type is dict_type:
function = "__Pyx_PyDict_GetItem" function = "__Pyx_PyDict_GetItem"
code.globalstate.use_utility_code( code.globalstate.use_utility_code(
UtilityCode.load_cached("DictGetItem", "ObjectHandling.c")) UtilityCode.load_cached("DictGetItem", "ObjectHandling.c"))
else: else:
function = "PyObject_GetItem" function = "PyObject_GetItem"
code.putln(
"%s = %s(%s, %s%s); if (!%s) %s" % (
self.result(),
function,
self.base.py_result(),
index_code,
self.extra_index_params(code),
self.result(),
code.error_goto(self.pos)))
code.put_gotref(self.py_result())
elif self.type.is_unicode_char and self.base.type is unicode_type: elif self.type.is_unicode_char and self.base.type is unicode_type:
assert self.index.type.is_int assert self.index.type.is_int
index_code = self.index.result()
function = "__Pyx_GetItemInt_Unicode" function = "__Pyx_GetItemInt_Unicode"
error_value = '(Py_UCS4)-1'
code.globalstate.use_utility_code( code.globalstate.use_utility_code(
UtilityCode.load_cached("GetItemIntUnicode", "StringTools.c")) UtilityCode.load_cached("GetItemIntUnicode", "StringTools.c"))
code.putln(
"%s = %s(%s, %s%s); if (unlikely(%s == (Py_UCS4)-1)) %s;" % (
self.result(),
function,
self.base.py_result(),
index_code,
self.extra_index_params(code),
self.result(),
code.error_goto(self.pos)))
elif self.base.type is bytearray_type: elif self.base.type is bytearray_type:
assert self.index.type.is_int assert self.index.type.is_int
assert self.type.is_int assert self.type.is_int
index_code = self.index.result()
function = "__Pyx_GetItemInt_ByteArray" function = "__Pyx_GetItemInt_ByteArray"
error_value = '-1'
code.globalstate.use_utility_code( code.globalstate.use_utility_code(
UtilityCode.load_cached("GetItemIntByteArray", "StringTools.c")) UtilityCode.load_cached("GetItemIntByteArray", "StringTools.c"))
else:
assert False, "unexpected type %s and base type %s for indexing" % (
self.type, self.base.type)
if self.index.type.is_int:
index_code = self.index.result()
else:
index_code = self.index.py_result()
code.putln( code.putln(
"%s = %s(%s, %s%s); if (unlikely(%s == -1)) %s;" % ( "%s = %s(%s, %s%s); if (unlikely(%s == %s)) %s;" % (
self.result(), self.result(),
function, function,
self.base.py_result(), self.base.py_result(),
index_code, index_code,
self.extra_index_params(code), self.extra_index_params(code),
self.result(), self.result(),
error_value,
code.error_goto(self.pos))) code.error_goto(self.pos)))
else: if self.type.is_pyobject:
assert False, "unexpected type %s and base type %s for indexing" % ( code.put_gotref(self.py_result())
self.type, self.base.type)
def generate_setitem_code(self, value_code, code): def generate_setitem_code(self, value_code, code):
if self.index.type.is_int: if self.index.type.is_int:
......
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