Commit 92f34b49 authored by Stefan Behnel's avatar Stefan Behnel

unpack redundantly coerced int/float literals during optimisation cleanup

parent 60968850
...@@ -1790,7 +1790,11 @@ class OptimizeBuiltinCalls(Visitor.MethodDispatcherTransform): ...@@ -1790,7 +1790,11 @@ class OptimizeBuiltinCalls(Visitor.MethodDispatcherTransform):
return arg.coerce_to(node.type, self.current_env()) return arg.coerce_to(node.type, self.current_env())
if isinstance(arg, ExprNodes.PyTypeTestNode): if isinstance(arg, ExprNodes.PyTypeTestNode):
arg = arg.arg arg = arg.arg
if isinstance(arg, ExprNodes.CoerceToPyTypeNode): if arg.is_literal:
if (node.type.is_int and isinstance(arg, ExprNodes.IntNode) or
node.type.is_float and isinstance(arg, ExprNodes.FloatNode)):
return arg.coerce_to(node.type, self.current_env())
elif isinstance(arg, ExprNodes.CoerceToPyTypeNode):
if arg.type is PyrexTypes.py_object_type: if arg.type is PyrexTypes.py_object_type:
if node.type.assignable_from(arg.arg.type): if node.type.assignable_from(arg.arg.type):
# completely redundant C->Py->C coercion # completely redundant C->Py->C coercion
......
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