diff options
author | Kartik K. Agaram <vc@akkartik.com> | 2016-04-27 15:40:46 -0700 |
---|---|---|
committer | Kartik K. Agaram <vc@akkartik.com> | 2016-04-27 15:40:46 -0700 |
commit | dea902172dd62d14eebc5fed9e11542ebcdc88e6 (patch) | |
tree | a7ac5d97cb87eec2997a024fffa9ee41b6dab045 /html/052tangle.cc.html | |
parent | 5109e78fab2e94059763eefaec93bd6649d22c1f (diff) | |
download | mu-dea902172dd62d14eebc5fed9e11542ebcdc88e6.tar.gz |
2875
Diffstat (limited to 'html/052tangle.cc.html')
-rw-r--r-- | html/052tangle.cc.html | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/html/052tangle.cc.html b/html/052tangle.cc.html index 4ffcaebf..6356cd68 100644 --- a/html/052tangle.cc.html +++ b/html/052tangle.cc.html @@ -168,14 +168,15 @@ tangle_done = <span class="Constant">false</span><span class="Delimiter">;</span <span class="Delimiter">}</span> <span class="Comment">//: complain about unapplied fragments</span> -<span class="Delimiter">:(before "End Globals")</span> -<span class="Normal">bool</span> Transform_check_insert_fragments_Ran = <span class="Constant">false</span><span class="Delimiter">;</span> -<span class="Delimiter">:(after "Transform.push_back(insert_fragments)")</span> -Transform<span class="Delimiter">.</span>push_back<span class="Delimiter">(</span>check_insert_fragments<span class="Delimiter">);</span> <span class="Comment">// idempotent</span> +<span class="Comment">//: This can't run during transform because later (shape-shifting recipes)</span> +<span class="Comment">//: we'll encounter situations where fragments might get used long after</span> +<span class="Comment">//: they're loaded, and we might run transform_all in between. To avoid</span> +<span class="Comment">//: spurious errors, run this check right at the end, after all code is</span> +<span class="Comment">//: loaded, right before we run main.</span> +<span class="Delimiter">:(before "End Commandline Parsing")</span> +check_insert_fragments<span class="Delimiter">();</span> <span class="Delimiter">:(code)</span> -<span class="Normal">void</span> check_insert_fragments<span class="Delimiter">(</span>unused recipe_ordinal<span class="Delimiter">)</span> <span class="Delimiter">{</span> - <span class="Normal">if</span> <span class="Delimiter">(</span>Transform_check_insert_fragments_Ran<span class="Delimiter">)</span> <span class="Identifier">return</span><span class="Delimiter">;</span> - Transform_check_insert_fragments_Ran = <span class="Constant">true</span><span class="Delimiter">;</span> +<span class="Normal">void</span> check_insert_fragments<span class="Delimiter">()</span> <span class="Delimiter">{</span> <span class="Normal">for</span> <span class="Delimiter">(</span>map<string<span class="Delimiter">,</span> recipe>::iterator p = Before_fragments<span class="Delimiter">.</span>begin<span class="Delimiter">();</span> p != Before_fragments<span class="Delimiter">.</span>end<span class="Delimiter">();</span> ++p<span class="Delimiter">)</span> <span class="Delimiter">{</span> <span class="Normal">if</span> <span class="Delimiter">(</span>!contains_key<span class="Delimiter">(</span>Fragments_used<span class="Delimiter">,</span> p<span class="Delimiter">-></span>first<span class="Delimiter">))</span> raise << <span class="Constant">"could not locate insert before "</span> << p<span class="Delimiter">-></span>first << <span class="cSpecial">'\n'</span> << end<span class="Delimiter">();</span> |