diff options
-rw-r--r-- | cpp/020run | 4 | ||||
-rw-r--r-- | cpp/035call | 11 |
2 files changed, 6 insertions, 9 deletions
diff --git a/cpp/020run b/cpp/020run index 738545ee..2f08b23c 100644 --- a/cpp/020run +++ b/cpp/020run @@ -86,10 +86,6 @@ inline const string& current_recipe_name() { return Recipe[Current_routine->running_recipe].name; } -inline vector<instruction>& steps() { - return Recipe[Current_routine->running_recipe].steps; -} - inline const instruction& current_instruction() { return Recipe[Current_routine->running_recipe].steps[Current_routine->running_step_index]; } diff --git a/cpp/035call b/cpp/035call index 9aee3db8..2f9b0f15 100644 --- a/cpp/035call +++ b/cpp/035call @@ -45,6 +45,7 @@ struct routine { // End routine Fields routine(recipe_number r); bool completed() const; + const vector<instruction>& steps() const; }; :(code) routine::routine(recipe_number r) { @@ -61,10 +62,6 @@ inline size_t& current_step_index() { inline const string& current_recipe_name() { return Recipe[Current_routine->calls.top().running_recipe].name; } -:(replace{} "inline vector<instruction>& steps()") -inline vector<instruction>& steps() { - return Recipe[Current_routine->calls.top().running_recipe].steps; -} :(replace{} "inline const instruction& current_instruction()") inline const instruction& current_instruction() { return Recipe[Current_routine->calls.top().running_recipe].steps[Current_routine->calls.top().running_step_index]; @@ -88,10 +85,14 @@ inline bool routine::completed() const { return calls.empty(); } +inline const vector<instruction>& routine::steps() const { + return Recipe[calls.top().running_recipe].steps; +} + :(before "Running One Instruction") // when we reach the end of one call, we may reach the end of the one below // it, and the one below that, and so on -while (current_step_index() >= steps().size()) { +while (current_step_index() >= Current_routine->steps().size()) { Current_routine->calls.pop(); if (Current_routine->calls.empty()) return; // todo: no results returned warning |