diff options
-rw-r--r-- | 055shape_shifting_container.cc | 31 |
1 files changed, 15 insertions, 16 deletions
diff --git a/055shape_shifting_container.cc b/055shape_shifting_container.cc index 044e7089..352124c7 100644 --- a/055shape_shifting_container.cc +++ b/055shape_shifting_container.cc @@ -223,6 +223,13 @@ def main [ # no other stores % CHECK_EQ(trace_count_prefix("mem", "storing"), 7); +:(before "End variant_type Special-cases") +if (contains_type_ingredient(element)) { + if (!type->right) + raise << "illegal type " << to_string(type) << " seems to be missing a type ingredient or three while computing variant type of exclusive-container\n" << end(); + replace_type_ingredients(element.type, type->right, info); +} + :(scenario get_on_shape_shifting_container) container foo:_t [ x:_t @@ -295,15 +302,6 @@ replace_type_ingredients(element, full_type, exclusive_container_info, location_ replace_type_ingredients(element, type, info, location_for_error_messages); if (contains_type_ingredient(element)) return; // error raised elsewhere -:(code) -void replace_type_ingredients(reagent& element, const type_tree* caller_type, const type_info& info, const string& location_for_error_messages) { - if (contains_type_ingredient(element)) { - if (!caller_type->right) - raise << "illegal type " << names_to_string(caller_type) << " seems to be missing a type ingredient or three" << location_for_error_messages << '\n' << end(); - replace_type_ingredients(element.type, caller_type->right, info); - } -} - :(after "Compute size_of Container") assert(!contains_type_ingredient(type)); :(after "Compute size_of Exclusive Container") @@ -320,6 +318,14 @@ bool contains_type_ingredient(const type_tree* type) { return contains_type_ingredient(type->left) || contains_type_ingredient(type->right); } +void replace_type_ingredients(reagent& element, const type_tree* caller_type, const type_info& info, const string& location_for_error_messages) { + if (contains_type_ingredient(element)) { + if (!caller_type->right) + raise << "illegal type " << names_to_string(caller_type) << " seems to be missing a type ingredient or three" << location_for_error_messages << '\n' << end(); + replace_type_ingredients(element.type, caller_type->right, info); + } +} + // replace all type_ingredients in element_type with corresponding elements of callsite_type void replace_type_ingredients(type_tree* element_type, const type_tree* callsite_type, const type_info& container_info) { if (!callsite_type) return; // error but it's already been raised above @@ -681,10 +687,3 @@ def main [ 1:foo:bar <- merge 1/y, 23 ] +error: main: too few ingredients in '1:foo:bar <- merge 1/y, 23' - -:(before "End variant_type Special-cases") -if (contains_type_ingredient(element)) { - if (!type->right) - raise << "illegal type " << to_string(type) << " seems to be missing a type ingredient or three while computing variant type of exclusive-container\n" << end(); - replace_type_ingredients(element.type, type->right, info); -} |