Commit a737fd2d authored by Stefan Behnel's avatar Stefan Behnel

fix compiler crash in error case

parent 9acf70e2
...@@ -3378,10 +3378,13 @@ class IndexNode(ExprNode): ...@@ -3378,10 +3378,13 @@ class IndexNode(ExprNode):
self.type_indices = self.parse_index_as_types(env) self.type_indices = self.parse_index_as_types(env)
if base_type.templates is None: if base_type.templates is None:
error(self.pos, "Can only parameterize template functions.") error(self.pos, "Can only parameterize template functions.")
self.type = error_type
elif len(base_type.templates) != len(self.type_indices): elif len(base_type.templates) != len(self.type_indices):
error(self.pos, "Wrong number of template arguments: expected %s, got %s" % ( error(self.pos, "Wrong number of template arguments: expected %s, got %s" % (
(len(base_type.templates), len(self.type_indices)))) (len(base_type.templates), len(self.type_indices))))
self.type = base_type.specialize(dict(zip(base_type.templates, self.type_indices))) self.type = error_type
else:
self.type = base_type.specialize(dict(zip(base_type.templates, self.type_indices)))
elif base_type.is_ctuple: elif base_type.is_ctuple:
if isinstance(self.index, IntNode) and self.index.has_constant_result(): if isinstance(self.index, IntNode) and self.index.has_constant_result():
index = self.index.constant_result index = self.index.constant_result
......
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