about summary refs log tree commit diff stats
path: root/test/layout/inline-table.expected
Commit message (Collapse)AuthorAgeFilesLines
* layout: fix crash on inline tablesbptato2024-05-281-0/+2
h=hlt&id=a1b06887864811a3fa95a0caf4c95dd07321b52d'>^
b2e4056d ^
e6692482 ^

d8509b41 ^
795f5244 ^
82177734 ^

6c96a437 ^
82177734 ^
e6692482 ^
f3760b0f ^
9dcbec39 ^
83266c76 ^
e6692482 ^
795f5244 ^
82177734 ^
e6692482 ^


a0b9fa55 ^
e6692482 ^


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27


                                                                              
                                                
                                                                  

       
                                                            
                                                                                                               

                                                                                      
                                                              
                                               
                                
                                                   
                                                                                                  
               
     
                                                    
                                       


   
                                                                        


                        
//: Once all code is loaded, save operation ids of instructions and check that
//: nothing's undefined.

:(before "End Instruction Modifying Transforms")
Transform.push_back(update_instruction_operations);  // idempotent

:(code)
void update_instruction_operations(const recipe_ordinal r) {
  trace(9991, "transform") << "--- compute instruction operations for recipe " << get(Recipe, r).name << end();
  recipe& caller = get(Recipe, r);
//?   cerr << "--- compute instruction operations for recipe " << caller.name << '\n';
  for (int index = 0;  index < SIZE(caller.steps);  ++index) {
    instruction& inst = caller.steps.at(index);
    if (inst.is_label) continue;
    if (!contains_key(Recipe_ordinal, inst.name)) {
      raise << maybe(caller.name) << "instruction '" << inst.name << "' has no recipe\n" << end();
      continue;
    }
    inst.operation = get(Recipe_ordinal, inst.name);
    // End Instruction Operation Checks
  }
}

// hook to suppress inserting recipe name into errors (for later layers)
string maybe(string s) {
  return s + ": ";
}