about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--059shape_shifting_recipe.cc15
-rw-r--r--edit/010-warnings.mu4
2 files changed, 13 insertions, 6 deletions
diff --git a/059shape_shifting_recipe.cc b/059shape_shifting_recipe.cc
index d3596ea9..4f6bf447 100644
--- a/059shape_shifting_recipe.cc
+++ b/059shape_shifting_recipe.cc
@@ -59,6 +59,13 @@ recently_added_types.clear();
 //? cerr << "clearing recently-added shape-shifting recipes\n";
 recently_added_shape_shifting_recipes.clear();
 
+//: save original name of specialized recipes
+:(before "End recipe Fields")
+string original_name;
+//: original name is only set during load
+:(before "End recipe Refinements")
+result.original_name = result.name;
+
 :(before "End Instruction Dispatch(inst, best_score)")
 if (best_score == -1) {
   trace(9992, "transform") << "no variant found; searching for variant with suitable type ingredients" << end();
@@ -189,6 +196,7 @@ recipe_ordinal new_variant(recipe_ordinal exemplar, const instruction& inst, con
   recently_added_shape_shifting_recipes.push_back(new_recipe_ordinal);
   put(Recipe, new_recipe_ordinal, get(Recipe, exemplar));
   recipe& new_recipe = get(Recipe, new_recipe_ordinal);
+  new_recipe.name = new_name;
   // Since the exemplar never ran any transforms, we have to redo some of the
   // work of the check_types_by_name transform while supporting type-ingredients.
   compute_type_names(new_recipe);
@@ -203,8 +211,6 @@ recipe_ordinal new_variant(recipe_ordinal exemplar, const instruction& inst, con
     if (error) return exemplar;
   }
   ensure_all_concrete_types(new_recipe, get(Recipe, exemplar));
-  // update the name after specialization is complete (so earlier error messages look better)
-  new_recipe.name = new_name;
   return new_recipe_ordinal;
 }
 
@@ -233,7 +239,7 @@ void save_or_deduce_type_name(reagent& x, map<string, string_tree*>& type_name,
     return;
   }
   if (!x.properties.at(0).second) {
-    raise_error << maybe(variant.name) << "unknown type for " << x.original_string << " (check the name for typos)\n" << end();
+    raise_error << maybe(variant.original_name) << "unknown type for " << x.original_string << " (check the name for typos)\n" << end();
     return;
   }
   if (contains_key(type_name, x.name)) return;
@@ -337,7 +343,7 @@ void replace_type_ingredients(reagent& x, const map<string, const string_tree*>&
   trace(9993, "transform") << "replacing in ingredient " << x.original_string << end();
   // replace properties
   if (!x.properties.at(0).second) {
-    raise_error << "specializing " << caller.name << ": missing type for " << x.original_string << '\n' << end();
+    raise_error << "specializing " << caller.original_name << ": missing type for " << x.original_string << '\n' << end();
     return;
   }
   replace_type_ingredients(x.properties.at(0).second, mappings);
@@ -710,4 +716,5 @@ recipe foo x:_elem -> y:number [
   }
   reply y
 ]
++transform: new specialization: foo_2
 # transform terminates
diff --git a/edit/010-warnings.mu b/edit/010-warnings.mu
index 4a04d73d..5e41cf12 100644
--- a/edit/010-warnings.mu
+++ b/edit/010-warnings.mu
@@ -173,7 +173,7 @@ z <- add x, [a]
     .local-scope                                       ┊━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━.
     .load-ingredients                                  ┊                                                x.
     .z <- add x, [a]                                   ┊foo 2                                            .
-    .]                                                 ┊foo_3: 'add' requires number ingredients, but go↩.
+    .]                                                 ┊foo_2: 'add' requires number ingredients, but go↩.
     .┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┊t [a]                                            .
     .                                                  ┊━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━.
     .                                                  ┊                                                 .
@@ -192,7 +192,7 @@ z <- add x, [a]
     .local-scope                                       ┊━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━.
     .load-ingredients                                  ┊                                                x.
     .z <- add x, [a]                                   ┊foo 2                                            .
-    .]                                                 ┊foo_3: 'add' requires number ingredients, but go↩.
+    .]                                                 ┊foo_2: 'add' requires number ingredients, but go↩.
     .┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┊t [a]                                            .
     .                                                  ┊━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━.
     .                                                  ┊                                                 .