1
0
Fork 0
mirror of https://github.com/ganelson/inform.git synced 2024-07-08 18:14:21 +03:00
inform7/docs/building-module/3-pi.html
2019-09-01 11:50:12 +01:00

737 lines
135 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>2/eis</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Language" content="en-gb">
<link href="inweb.css" rel="stylesheet" rev="stylesheet" type="text/css">
</head>
<body>
<!--Weave of '3/pi' generated by 7-->
<ul class="crumbs"><li><a href="../webs.html">&#9733;</a></li><li><a href="index.html">building</a></li><li><a href="index.html#3">Chapter 3: Masonry</a></li><li><b>Producing Inter</b></li></ul><p class="inwebparagraph"><a id="SP1"></a><b>&#167;1. Definitions. </b></p>
<p class="inwebparagraph"><a id="SP2"></a><b>&#167;2. </b></p>
<pre class="display">
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">inter_error_message</span><span class="plain"> *</span><span class="identifier">ERR</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> ((</span><span class="identifier">ERR</span><span class="plain">) &amp;&amp; (</span><span class="identifier">problem_count</span><span class="plain"> == 0)) { </span><span class="identifier">Inter::Errors::issue</span><span class="plain">(</span><span class="identifier">ERR</span><span class="plain">); </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"inter error"</span><span class="plain">); }</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::new_symbol</span><span class="plain">(</span><span class="identifier">inter_symbols_table</span><span class="plain"> *</span><span class="identifier">T</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">name</span><span class="plain">) {</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">symb</span><span class="plain"> = </span><span class="identifier">Inter::SymbolsTables::symbol_from_name</span><span class="plain">(</span><span class="identifier">T</span><span class="plain">, </span><span class="identifier">name</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> ((</span><span class="identifier">symb</span><span class="plain">) &amp;&amp; (</span><span class="identifier">Inter::Symbols::read_annotation</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">HOLDING_IANN</span><span class="plain">) == 1)) {</span>
<span class="functiontext">Produce::annotate_symbol_i</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">DELENDA_EST_IANN</span><span class="plain">, 1);</span>
<span class="identifier">inter_tree_node</span><span class="plain"> *</span><span class="identifier">D</span><span class="plain"> = </span><span class="identifier">Inter::Symbols::definition</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">);</span>
<span class="identifier">Inter::Tree::remove_node</span><span class="plain">(</span><span class="identifier">D</span><span class="plain">);</span>
<span class="identifier">Inter::Symbols::undefine</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">symb</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::SymbolsTables::create_with_unique_name</span><span class="plain">(</span><span class="identifier">T</span><span class="plain">, </span><span class="identifier">name</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::define_symbol</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Inter::Symbols::is_predeclared</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">)) {</span>
<span class="identifier">Inter::Symbols::undefine</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="plain">}</span>
<span class="reserved">if</span><span class="plain"> ((</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">) &amp;&amp; (</span><span class="identifier">Inter::Symbols::read_annotation</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">, </span><span class="identifier">HOLDING_IANN</span><span class="plain">) == 1)) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Inter::Symbols::read_annotation</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">, </span><span class="identifier">DELENDA_EST_IANN</span><span class="plain">) != 1) {</span>
<span class="functiontext">Produce::annotate_symbol_i</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">, </span><span class="identifier">DELENDA_EST_IANN</span><span class="plain">, 1);</span>
<span class="identifier">Inter::Symbols::strike_definition</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">iname</span><span class="plain">-</span><span class="element">&gt;symbol</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="identifier">inter_symbols_table</span><span class="plain"> *</span><span class="functiontext">Produce::main_scope</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::Packages::scope</span><span class="plain">(</span><span class="functiontext">Site::main_package_if_it_exists</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="identifier">inter_symbols_table</span><span class="plain"> *</span><span class="functiontext">Produce::connectors_scope</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::Packages::scope</span><span class="plain">(</span><span class="functiontext">Site::connectors_package</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::opcode</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">bip</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="functiontext">Primitives::get</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">bip</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="identifier">IBM</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">IBM</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="reserved">return</span><span class="plain"> 0;</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">) == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="reserved">return</span><span class="plain"> 0;</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Inter::Packages::is_rootlike</span><span class="plain">(</span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">))) </span><span class="reserved">return</span><span class="plain"> 0;</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Inter::Packages::is_codelike</span><span class="plain">(</span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">)))</span>
<span class="reserved">return</span><span class="plain"> (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="identifier">Inter::Packages::baseline</span><span class="plain">(</span><span class="identifier">Inter::Packages::parent</span><span class="plain">(</span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">))) + 1;</span>
<span class="reserved">return</span><span class="plain"> (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="identifier">Inter::Packages::baseline</span><span class="plain">(</span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">)) + 1;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::nop</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Nop::new</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::nop_at</span><span class="plain">(</span><span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="identifier">IBM</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Nop::new</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">, </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">) + 2, </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::version</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">int</span><span class="plain"> </span><span class="identifier">N</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Version::new</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">N</span><span class="plain">, </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::metadata</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">package_request</span><span class="plain"> *</span><span class="identifier">P</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">key</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">value</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">Str::copy</span><span class="plain">(</span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">), </span><span class="identifier">value</span><span class="plain">);</span>
<span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain"> = </span><span class="functiontext">InterNames::explicitly_named</span><span class="plain">(</span><span class="identifier">key</span><span class="plain">, </span><span class="identifier">P</span><span class="plain">);</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">key_name</span><span class="plain"> = </span><span class="functiontext">Produce::define_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">);</span>
<span class="reserved">packaging_state</span><span class="plain"> </span><span class="identifier">save</span><span class="plain"> = </span><span class="functiontext">Packaging::enter_home_of</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Metadata::new</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::SymbolsTables::id_from_IRS_and_symbol</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">key_name</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">, </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="functiontext">Packaging::exit</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">save</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::comment</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">text</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">Str::copy</span><span class="plain">(</span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">), </span><span class="identifier">text</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Comment::new</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)), </span><span class="identifier">NULL</span><span class="plain">, </span><span class="identifier">ID</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="identifier">inter_package</span><span class="plain"> *</span><span class="functiontext">Produce::package</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">ptype</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">ptype</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"no package type"</span><span class="plain">);</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">B</span><span class="plain"> = </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="identifier">inter_package</span><span class="plain"> *</span><span class="identifier">IP</span><span class="plain"> = </span><span class="identifier">NULL</span><span class="plain">;</span>
<span class="identifier">TEMPORARY_TEXT</span><span class="plain">(</span><span class="identifier">hmm</span><span class="plain">);</span>
<span class="identifier">WRITE_TO</span><span class="plain">(</span><span class="identifier">hmm</span><span class="plain">, </span><span class="string">"%n"</span><span class="plain">, </span><span class="identifier">iname</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Package::new_package_named</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">hmm</span><span class="plain">, </span><span class="identifier">TRUE</span><span class="plain">, </span><span class="identifier">ptype</span><span class="plain">, </span><span class="identifier">B</span><span class="plain">, </span><span class="identifier">NULL</span><span class="plain">, &amp;</span><span class="identifier">IP</span><span class="plain">));</span>
<span class="identifier">DISCARD_TEXT</span><span class="plain">(</span><span class="identifier">hmm</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">IP</span><span class="plain">) </span><span class="identifier">Inter::Bookmarks::set_current_package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">IP</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">IP</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::annotate_symbol_t</span><span class="plain">(</span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">S</span><span class="plain">) {</span>
<span class="identifier">Inter::Symbols::annotate_t</span><span class="plain">(</span><span class="identifier">Inter::Packages::tree</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">-&gt;</span><span class="identifier">owning_table</span><span class="plain">-&gt;</span><span class="identifier">owning_package</span><span class="plain">), </span><span class="identifier">symb</span><span class="plain">-&gt;</span><span class="identifier">owning_table</span><span class="plain">-&gt;</span><span class="identifier">owning_package</span><span class="plain">, </span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">S</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::annotate_symbol_w</span><span class="plain">(</span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">wording</span><span class="plain"> </span><span class="identifier">W</span><span class="plain">) {</span>
<span class="identifier">TEMPORARY_TEXT</span><span class="plain">(</span><span class="identifier">temp</span><span class="plain">);</span>
<span class="identifier">WRITE_TO</span><span class="plain">(</span><span class="identifier">temp</span><span class="plain">, </span><span class="string">"%W"</span><span class="plain">, </span><span class="identifier">W</span><span class="plain">);</span>
<span class="identifier">Inter::Symbols::annotate_t</span><span class="plain">(</span><span class="identifier">Inter::Packages::tree</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">-&gt;</span><span class="identifier">owning_table</span><span class="plain">-&gt;</span><span class="identifier">owning_package</span><span class="plain">), </span><span class="identifier">symb</span><span class="plain">-&gt;</span><span class="identifier">owning_table</span><span class="plain">-&gt;</span><span class="identifier">owning_package</span><span class="plain">, </span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">temp</span><span class="plain">);</span>
<span class="identifier">DISCARD_TEXT</span><span class="plain">(</span><span class="identifier">temp</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::annotate_symbol_i</span><span class="plain">(</span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">V</span><span class="plain">) {</span>
<span class="identifier">Inter::Symbols::annotate_i</span><span class="plain">(</span><span class="identifier">symb</span><span class="plain">, </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">V</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::annotate_iname_i</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">N</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">V</span><span class="plain">) {</span>
<span class="identifier">Inter::Symbols::annotate_i</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">N</span><span class="plain">), </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">V</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::set_flag</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="reserved">int</span><span class="plain"> </span><span class="identifier">f</span><span class="plain">) {</span>
<span class="identifier">Inter::Symbols::set_flag</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">f</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::clear_flag</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="reserved">int</span><span class="plain"> </span><span class="identifier">f</span><span class="plain">) {</span>
<span class="identifier">Inter::Symbols::clear_flag</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">f</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::annotate_i</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">V</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">iname</span><span class="plain">) </span><span class="functiontext">Produce::annotate_symbol_i</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">V</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::annotate_w</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">wording</span><span class="plain"> </span><span class="identifier">W</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">iname</span><span class="plain">) </span><span class="functiontext">Produce::annotate_symbol_w</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">annot_ID</span><span class="plain">, </span><span class="identifier">W</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">int</span><span class="plain"> </span><span class="functiontext">Produce::read_annotation</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">annot</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::Symbols::read_annotation</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">annot</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::change_translation</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">new_text</span><span class="plain">) {</span>
<span class="identifier">Inter::Symbols::set_translate</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">new_text</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="functiontext">Produce::get_translation</span><span class="plain">(</span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::Symbols::get_translate</span><span class="plain">(</span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::code</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Code::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::evaluation</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Evaluation::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::reference</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Reference::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
</pre>
<p class="inwebparagraph"></p>
<p class="endnote">The function Produce::guard is used in <a href="#SP3">&#167;3</a>, 1/ip (<a href="1-ip.html#SP1">&#167;1</a>), 1/tv (<a href="1-tv.html#SP1">&#167;1</a>), 1/pt (<a href="1-pt.html#SP1">&#167;1</a>).</p>
<p class="endnote">The function Produce::new_symbol is used in 1/pt (<a href="1-pt.html#SP1">&#167;1</a>), 1/in (<a href="1-in.html#SP8">&#167;8</a>).</p>
<p class="endnote">The function Produce::define_symbol appears nowhere else.</p>
<p class="endnote">The function Produce::main_scope is used in 2/eis (<a href="2-eis.html#SP4">&#167;4</a>).</p>
<p class="endnote">The function Produce::connectors_scope is used in 2/eis (<a href="2-eis.html#SP4">&#167;4</a>).</p>
<p class="endnote">The function Produce::opcode appears nowhere else.</p>
<p class="endnote">The function Produce::baseline is used in <a href="#SP3">&#167;3</a>.</p>
<p class="endnote">The function Produce::nop is used in 1/pck (<a href="1-pck.html#SP10">&#167;10</a>).</p>
<p class="endnote">The function Produce::nop_at is used in 1/pck (<a href="1-pck.html#SP10">&#167;10</a>).</p>
<p class="endnote">The function Produce::version is used in 1/pck (<a href="1-pck.html#SP11">&#167;11</a>).</p>
<p class="endnote">The function Produce::metadata is used in 1/hl (<a href="1-hl.html#SP6">&#167;6</a>).</p>
<p class="endnote">The function Produce::comment is used in 1/pck (<a href="1-pck.html#SP11">&#167;11</a>).</p>
<p class="endnote">The function Produce::package is used in <a href="#SP3">&#167;3</a>, 1/pck (<a href="1-pck.html#SP13">&#167;13</a>).</p>
<p class="endnote">The function Produce::annotate_symbol_t appears nowhere else.</p>
<p class="endnote">The function Produce::annotate_symbol_w appears nowhere else.</p>
<p class="endnote">The function Produce::annotate_symbol_i is used in 1/pt (<a href="1-pt.html#SP1">&#167;1</a>).</p>
<p class="endnote">The function Produce::annotate_iname_i appears nowhere else.</p>
<p class="endnote">The function Produce::set_flag is used in <a href="#SP3">&#167;3</a>, 1/hl (<a href="1-hl.html#SP3">&#167;3</a>).</p>
<p class="endnote">The function Produce::clear_flag appears nowhere else.</p>
<p class="endnote">The function Produce::annotate_i appears nowhere else.</p>
<p class="endnote">The function Produce::annotate_w appears nowhere else.</p>
<p class="endnote">The function Produce::read_annotation appears nowhere else.</p>
<p class="endnote">The function Produce::change_translation is used in 1/hl (<a href="1-hl.html#SP3">&#167;3</a>, <a href="1-hl.html#SP3_1">&#167;3.1</a>), 1/pck (<a href="1-pck.html#SP19">&#167;19</a>).</p>
<p class="endnote">The function Produce::get_translation appears nowhere else.</p>
<p class="endnote">The function Produce::code is used in 2/eis (<a href="2-eis.html#SP3_2">&#167;3.2</a>).</p>
<p class="endnote">The function Produce::evaluation is used in 2/eis (<a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::reference is used in 2/eis (<a href="2-eis.html#SP3_8">&#167;3.8</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="inwebparagraph"><a id="SP3"></a><b>&#167;3. </b></p>
<pre class="definitions">
<span class="definitionkeyword">define</span> <span class="constant">MAX_NESTED_NOTEWORTHY_LEVELS</span><span class="plain"> 256</span>
</pre>
<pre class="display">
<span class="reserved">typedef</span><span class="plain"> </span><span class="reserved">struct</span><span class="plain"> </span><span class="reserved">code_insertion_point</span><span class="plain"> {</span>
<span class="reserved">int</span><span class="plain"> </span><span class="identifier">inter_level</span><span class="plain">;</span>
<span class="reserved">int</span><span class="plain"> </span><span class="identifier">noted_levels</span><span class="plain">[</span><span class="constant">MAX_NESTED_NOTEWORTHY_LEVELS</span><span class="plain">];</span>
<span class="reserved">int</span><span class="plain"> </span><span class="identifier">noted_sp</span><span class="plain">;</span>
<span class="reserved">int</span><span class="plain"> </span><span class="identifier">error_flag</span><span class="plain">;</span>
<span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="identifier">insertion_bm</span><span class="plain">;</span>
<span class="identifier">inter_bookmark</span><span class="plain"> </span><span class="identifier">saved_bm</span><span class="plain">;</span>
<span class="plain">} </span><span class="reserved">code_insertion_point</span><span class="plain">;</span>
<span class="reserved">code_insertion_point</span><span class="plain"> </span><span class="functiontext">Produce::new_cip</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="identifier">IBM</span><span class="plain">) {</span>
<span class="reserved">code_insertion_point</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain">;</span>
<span class="identifier">cip</span><span class="element">.inter_level</span><span class="plain"> = (</span><span class="reserved">int</span><span class="plain">) (</span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">) + 2);</span>
<span class="identifier">cip</span><span class="element">.noted_sp</span><span class="plain"> = 2;</span>
<span class="identifier">cip</span><span class="element">.error_flag</span><span class="plain"> = </span><span class="identifier">FALSE</span><span class="plain">;</span>
<span class="identifier">cip</span><span class="element">.insertion_bm</span><span class="plain"> = </span><span class="identifier">IBM</span><span class="plain">;</span>
<span class="identifier">cip</span><span class="element">.saved_bm</span><span class="plain"> = </span><span class="identifier">Inter::Bookmarks::snapshot</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="functiontext">Produce::locals_bookmark</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="functiontext">Site::locals</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">inter_package</span><span class="plain"> *</span><span class="functiontext">Produce::block</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">packaging_state</span><span class="plain"> *</span><span class="identifier">save</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">) == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"no inter repository"</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">save</span><span class="plain">) {</span>
<span class="plain">*</span><span class="identifier">save</span><span class="plain"> = </span><span class="functiontext">Packaging::enter_home_of</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">);</span>
<span class="reserved">package_request</span><span class="plain"> *</span><span class="identifier">R</span><span class="plain"> = </span><span class="functiontext">InterNames::location</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> ((</span><span class="identifier">R</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) || (</span><span class="identifier">R</span><span class="plain"> == </span><span class="functiontext">Site::main_request</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">))) {</span>
<span class="identifier">LOG</span><span class="plain">(</span><span class="string">"Routine outside of package: %n\</span><span class="plain">n</span><span class="string">"</span><span class="plain">, </span><span class="identifier">iname</span><span class="plain">);</span>
<span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"routine outside of package"</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="plain">}</span>
<span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">block_iname</span><span class="plain"> = </span><span class="identifier">NULL</span><span class="plain">;</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="functiontext">Packaging::housed_in_function</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">iname</span><span class="plain">))</span>
<span class="identifier">block_iname</span><span class="plain"> = </span><span class="functiontext">Packaging::make_iname_within</span><span class="plain">(</span><span class="functiontext">InterNames::location</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">), </span><span class="identifier">I</span><span class="string">"block"</span><span class="plain">);</span>
<span class="reserved">else</span><span class="plain"> </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"routine outside function package"</span><span class="plain">);</span>
<span class="identifier">inter_bookmark</span><span class="plain"> </span><span class="identifier">save_ib</span><span class="plain"> = </span><span class="identifier">Inter::Bookmarks::snapshot</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="functiontext">Site::set_cir</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="functiontext">Produce::package</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">block_iname</span><span class="plain">, </span><span class="functiontext">PackageTypes::get</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">I</span><span class="string">"_code"</span><span class="plain">)));</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Code::new</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">),</span>
<span class="plain">(</span><span class="reserved">int</span><span class="plain">) </span><span class="functiontext">Produce::baseline</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)) + 1, </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="functiontext">Site::set_begin</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">Inter::Bookmarks::snapshot</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">Inter::Bookmarks::set_placement</span><span class="plain">(</span><span class="functiontext">Site::begin</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">IMMEDIATELY_AFTER_ICPLACEMENT</span><span class="plain">);</span>
<span class="functiontext">Site::set_locals</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, *</span><span class="functiontext">Site::begin</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="identifier">Inter::Bookmarks::set_placement</span><span class="plain">(</span><span class="functiontext">Site::locals</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">BEFORE_ICPLACEMENT</span><span class="plain">);</span>
<span class="functiontext">Site::set_code</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">Inter::Bookmarks::snapshot</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="reserved">code_insertion_point</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain"> = </span><span class="functiontext">Produce::new_cip</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="functiontext">Site::code</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="functiontext">Produce::push_code_position</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">cip</span><span class="plain">, </span><span class="identifier">save_ib</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="functiontext">Site::get_cir</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">inter_name</span><span class="plain"> *</span><span class="functiontext">Produce::kernel</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">public_name</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="functiontext">Packaging::housed_in_function</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">public_name</span><span class="plain">) == </span><span class="identifier">FALSE</span><span class="plain">)</span>
<span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"routine not housed in function"</span><span class="plain">);</span>
<span class="reserved">package_request</span><span class="plain"> *</span><span class="identifier">P</span><span class="plain"> = </span><span class="functiontext">InterNames::location</span><span class="plain">(</span><span class="identifier">public_name</span><span class="plain">);</span>
<span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">kernel_name</span><span class="plain"> = </span><span class="functiontext">Packaging::make_iname_within</span><span class="plain">(</span><span class="identifier">P</span><span class="plain">, </span><span class="identifier">I</span><span class="string">"kernel"</span><span class="plain">);</span>
<span class="functiontext">Produce::set_flag</span><span class="plain">(</span><span class="identifier">kernel_name</span><span class="plain">, </span><span class="identifier">MAKE_NAME_UNIQUE</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">kernel_name</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::end_main_block</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">packaging_state</span><span class="plain"> </span><span class="identifier">save</span><span class="plain">) {</span>
<span class="functiontext">Packaging::exit</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">save</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::end_block</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Site::set_cir</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">NULL</span><span class="plain">);</span>
<span class="functiontext">Produce::pop_code_position</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">int</span><span class="plain"> </span><span class="functiontext">Produce::emitting_routine</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="functiontext">Site::get_cir</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)) </span><span class="reserved">return</span><span class="plain"> </span><span class="identifier">TRUE</span><span class="plain">;</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">FALSE</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">code_insertion_point</span><span class="plain"> </span><span class="functiontext">Produce::begin_position</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">code_insertion_point</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain"> = </span><span class="functiontext">Produce::new_cip</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="functiontext">Site::begin</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">));</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::push_code_position</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">code_insertion_point</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain">, </span><span class="identifier">inter_bookmark</span><span class="plain"> </span><span class="identifier">save_ib</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &gt;= </span><span class="constant">MAX_CIP_STACK_SIZE</span><span class="plain">) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP overflow"</span><span class="plain">);</span>
<span class="identifier">cip</span><span class="element">.saved_bm</span><span class="plain"> = </span><span class="identifier">save_ib</span><span class="plain">;</span>
<span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">++] = </span><span class="identifier">cip</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">int</span><span class="plain"> </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &lt;= 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP level accessed outside routine"</span><span class="plain">);</span>
<span class="reserved">code_insertion_point</span><span class="plain"> *</span><span class="identifier">cip</span><span class="plain"> = &amp;(</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;inter_level</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::set_level</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">int</span><span class="plain"> </span><span class="identifier">N</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &lt;= 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP level accessed outside routine"</span><span class="plain">);</span>
<span class="reserved">code_insertion_point</span><span class="plain"> *</span><span class="identifier">cip</span><span class="plain"> = &amp;(</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">N</span><span class="plain"> &lt; 2) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">problem_count</span><span class="plain"> == 0) </span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;error_flag</span><span class="plain"> = </span><span class="identifier">TRUE</span><span class="plain">;</span>
<span class="identifier">N</span><span class="plain"> = 2;</span>
<span class="plain">}</span>
<span class="reserved">while</span><span class="plain"> (</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain"> &gt; 0) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_levels</span><span class="plain">[</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain">-1] &lt; </span><span class="identifier">N</span><span class="plain">) </span><span class="reserved">break</span><span class="plain">;</span>
<span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain">--;</span>
<span class="plain">}</span>
<span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;inter_level</span><span class="plain"> = </span><span class="identifier">N</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::note_level</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">from</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &lt;= 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP level accessed outside routine"</span><span class="plain">);</span>
<span class="reserved">code_insertion_point</span><span class="plain"> *</span><span class="identifier">cip</span><span class="plain"> = &amp;(</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain"> &gt;= </span><span class="constant">MAX_NESTED_NOTEWORTHY_LEVELS</span><span class="plain">) </span><span class="reserved">return</span><span class="plain">;</span>
<span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_levels</span><span class="plain">[</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain">++] = </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::to_last_level</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">int</span><span class="plain"> </span><span class="identifier">delta</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &lt;= 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP level accessed outside routine"</span><span class="plain">);</span>
<span class="reserved">code_insertion_point</span><span class="plain"> *</span><span class="identifier">cip</span><span class="plain"> = &amp;(</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain"> &lt;= 0) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">problem_count</span><span class="plain"> == 0) </span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;error_flag</span><span class="plain"> = </span><span class="identifier">TRUE</span><span class="plain">;</span>
<span class="plain">} </span><span class="reserved">else</span><span class="plain"> {</span>
<span class="functiontext">Produce::set_level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_levels</span><span class="plain">[</span><span class="identifier">cip</span><span class="plain">-</span><span class="element">&gt;noted_sp</span><span class="plain">-1] + </span><span class="identifier">delta</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="plain">}</span>
<span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &lt;= 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP level accessed outside routine"</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]</span><span class="element">.insertion_bm</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::down</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::set_level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">) + 1);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::up</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::set_level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">) - 1);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::pop_code_position</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain"> &lt;= 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"CIP underflow"</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]</span><span class="element">.error_flag</span><span class="plain">) {</span>
<span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"bad inter hierarchy"</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="plain">*(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)) = </span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_stack</span><span class="plain">[</span><span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">-1]</span><span class="element">.saved_bm</span><span class="plain">;</span>
<span class="identifier">I</span><span class="plain">-&gt;</span><span class="identifier">site</span><span class="element">.cip_sp</span><span class="plain">--;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::inv_assembly</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">opcode</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">SID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob_storage</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">SID</span><span class="plain">);</span>
<span class="identifier">Str::copy</span><span class="plain">(</span><span class="identifier">glob_storage</span><span class="plain">, </span><span class="identifier">opcode</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Inv::new_assembly</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">SID</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">bip</span><span class="plain">) {</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">prim_symb</span><span class="plain"> = </span><span class="functiontext">Primitives::get</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">bip</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">prim_symb</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"undefined primitive"</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> ((</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">SWITCH_BIP</span><span class="plain">) ||</span>
<span class="plain">(</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">IF_BIP</span><span class="plain">) ||</span>
<span class="plain">(</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">IFELSE_BIP</span><span class="plain">) ||</span>
<span class="plain">(</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">FOR_BIP</span><span class="plain">) ||</span>
<span class="plain">(</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">WHILE_BIP</span><span class="plain">) ||</span>
<span class="plain">(</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">DO_BIP</span><span class="plain">) ||</span>
<span class="plain">(</span><span class="identifier">bip</span><span class="plain"> == </span><span class="constant">OBJECTLOOP_BIP</span><span class="plain">)) </span><span class="functiontext">Produce::note_level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">prim_symb</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Inv::new_primitive</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">prim_symb</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::inv_call</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">prim_symb</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Inv::new_call</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">prim_symb</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::inv_call_iname</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">prim_symb</span><span class="plain"> = </span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Inv::new_call</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">prim_symb</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::inv_indirect_call</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">int</span><span class="plain"> </span><span class="identifier">arity</span><span class="plain">) {</span>
<span class="reserved">switch</span><span class="plain"> (</span><span class="identifier">arity</span><span class="plain">) {</span>
<span class="reserved">case</span><span class="plain"> 0: </span><span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">INDIRECT0_BIP</span><span class="plain">); </span><span class="reserved">break</span><span class="plain">;</span>
<span class="reserved">case</span><span class="plain"> 1: </span><span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">INDIRECT1_BIP</span><span class="plain">); </span><span class="reserved">break</span><span class="plain">;</span>
<span class="reserved">case</span><span class="plain"> 2: </span><span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">INDIRECT2_BIP</span><span class="plain">); </span><span class="reserved">break</span><span class="plain">;</span>
<span class="reserved">case</span><span class="plain"> 3: </span><span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">INDIRECT3_BIP</span><span class="plain">); </span><span class="reserved">break</span><span class="plain">;</span>
<span class="reserved">case</span><span class="plain"> 4: </span><span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">INDIRECT4_BIP</span><span class="plain">); </span><span class="reserved">break</span><span class="plain">;</span>
<span class="reserved">default</span><span class="plain">: </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"indirect function call with too many arguments"</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::rtrue</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">RETURN_BIP</span><span class="plain">);</span>
<span class="functiontext">Produce::down</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">LITERAL_IVAL</span><span class="plain">, 1); </span> <span class="comment">that is, return "true"</span>
<span class="functiontext">Produce::up</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::rfalse</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">RETURN_BIP</span><span class="plain">);</span>
<span class="functiontext">Produce::down</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">LITERAL_IVAL</span><span class="plain">, 0); </span> <span class="comment">that is, return "false"</span>
<span class="functiontext">Produce::up</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::push</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">PUSH_BIP</span><span class="plain">);</span>
<span class="functiontext">Produce::down</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="functiontext">Produce::val_iname</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">iname</span><span class="plain">);</span>
<span class="functiontext">Produce::up</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::pull</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="functiontext">Produce::inv_primitive</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="constant">PULL_BIP</span><span class="plain">);</span>
<span class="functiontext">Produce::down</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="functiontext">Produce::ref_iname</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">iname</span><span class="plain">);</span>
<span class="functiontext">Produce::up</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">val1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">val2</span><span class="plain">) {</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">val_kind</span><span class="plain"> = </span><span class="functiontext">Produce::kind_to_symbol</span><span class="plain">(</span><span class="identifier">K</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">val_kind</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"no kind for val"</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Val::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">val_kind</span><span class="plain">, </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">val1</span><span class="plain">, </span><span class="identifier">val2</span><span class="plain">, </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_nothing</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">) {</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">LITERAL_IVAL</span><span class="plain">, 0);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::lab</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">L</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Lab::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">L</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::reserve_label</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">lname</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Str::get_first_char</span><span class="plain">(</span><span class="identifier">lname</span><span class="plain">) != </span><span class="character">'.'</span><span class="plain">) {</span>
<span class="identifier">TEMPORARY_TEXT</span><span class="plain">(</span><span class="identifier">dotted</span><span class="plain">);</span>
<span class="identifier">WRITE_TO</span><span class="plain">(</span><span class="identifier">dotted</span><span class="plain">, </span><span class="string">".%S"</span><span class="plain">, </span><span class="identifier">lname</span><span class="plain">);</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">lab_name</span><span class="plain"> = </span><span class="functiontext">Produce::reserve_label</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">dotted</span><span class="plain">);</span>
<span class="identifier">DISCARD_TEXT</span><span class="plain">(</span><span class="identifier">dotted</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">lab_name</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">lab_name</span><span class="plain"> = </span><span class="functiontext">Produce::local_exists</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">lname</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">lab_name</span><span class="plain">) </span><span class="reserved">return</span><span class="plain"> </span><span class="identifier">lab_name</span><span class="plain">;</span>
<span class="identifier">lab_name</span><span class="plain"> = </span><span class="functiontext">Produce::new_local_symbol</span><span class="plain">(</span><span class="functiontext">Site::get_cir</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">lname</span><span class="plain">);</span>
<span class="identifier">Inter::Symbols::label</span><span class="plain">(</span><span class="identifier">lab_name</span><span class="plain">);</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">lab_name</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::place_label</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">lab_name</span><span class="plain">) {</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Label::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">lab_name</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::local_exists</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">lname</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::SymbolsTables::symbol_from_name</span><span class="plain">(</span><span class="identifier">Inter::Packages::scope</span><span class="plain">(</span><span class="functiontext">Site::get_cir</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)), </span><span class="identifier">lname</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::seek_symbol</span><span class="plain">(</span><span class="identifier">inter_symbols_table</span><span class="plain"> *</span><span class="identifier">T</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">name</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::SymbolsTables::symbol_from_name</span><span class="plain">(</span><span class="identifier">T</span><span class="plain">, </span><span class="identifier">name</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::text_value</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">text</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">text_storage</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">);</span>
<span class="identifier">Str::copy</span><span class="plain">(</span><span class="identifier">text_storage</span><span class="plain">, </span><span class="identifier">text</span><span class="plain">);</span>
<span class="plain">*</span><span class="identifier">v1</span><span class="plain"> = </span><span class="identifier">LITERAL_TEXT_IVAL</span><span class="plain">;</span>
<span class="plain">*</span><span class="identifier">v2</span><span class="plain"> = </span><span class="identifier">ID</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::real_value</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v2</span><span class="plain">, </span><span class="reserved">double</span><span class="plain"> </span><span class="identifier">g</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob_storage</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">g</span><span class="plain"> &gt; 0) </span><span class="identifier">WRITE_TO</span><span class="plain">(</span><span class="identifier">glob_storage</span><span class="plain">, </span><span class="string">"+"</span><span class="plain">);</span>
<span class="identifier">WRITE_TO</span><span class="plain">(</span><span class="identifier">glob_storage</span><span class="plain">, </span><span class="string">"%g"</span><span class="plain">, </span><span class="identifier">g</span><span class="plain">);</span>
<span class="plain">*</span><span class="identifier">v1</span><span class="plain"> = </span><span class="identifier">REAL_IVAL</span><span class="plain">;</span>
<span class="plain">*</span><span class="identifier">v2</span><span class="plain"> = </span><span class="identifier">ID</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::real_value_from_text</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">S</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob_storage</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">);</span>
<span class="identifier">LOOP_THROUGH_TEXT</span><span class="plain">(</span><span class="identifier">pos</span><span class="plain">, </span><span class="identifier">S</span><span class="plain">)</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Str::get</span><span class="plain">(</span><span class="identifier">pos</span><span class="plain">) != </span><span class="character">'$'</span><span class="plain">)</span>
<span class="identifier">PUT_TO</span><span class="plain">(</span><span class="identifier">glob_storage</span><span class="plain">, </span><span class="identifier">Str::get</span><span class="plain">(</span><span class="identifier">pos</span><span class="plain">));</span>
<span class="plain">*</span><span class="identifier">v1</span><span class="plain"> = </span><span class="identifier">REAL_IVAL</span><span class="plain">;</span>
<span class="plain">*</span><span class="identifier">v2</span><span class="plain"> = </span><span class="identifier">ID</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::dword_value</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob_storage</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">);</span>
<span class="identifier">Str::copy</span><span class="plain">(</span><span class="identifier">glob_storage</span><span class="plain">, </span><span class="identifier">glob</span><span class="plain">);</span>
<span class="plain">*</span><span class="identifier">v1</span><span class="plain"> = </span><span class="identifier">DWORD_IVAL</span><span class="plain">;</span>
<span class="plain">*</span><span class="identifier">v2</span><span class="plain"> = </span><span class="identifier">ID</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::plural_dword_value</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> *</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">ID</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::create_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">)));</span>
<span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">glob_storage</span><span class="plain"> = </span><span class="identifier">Inter::Warehouse::get_text</span><span class="plain">(</span><span class="identifier">Inter::Tree::warehouse</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">ID</span><span class="plain">);</span>
<span class="identifier">Str::copy</span><span class="plain">(</span><span class="identifier">glob_storage</span><span class="plain">, </span><span class="identifier">glob</span><span class="plain">);</span>
<span class="plain">*</span><span class="identifier">v1</span><span class="plain"> = </span><span class="identifier">PDWORD_IVAL</span><span class="plain">;</span>
<span class="plain">*</span><span class="identifier">v2</span><span class="plain"> = </span><span class="identifier">ID</span><span class="plain">;</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_iname</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">iname</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">problem_count</span><span class="plain"> == 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"no iname"</span><span class="plain">);</span>
<span class="reserved">else</span><span class="plain"> </span><span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">LITERAL_IVAL</span><span class="plain">, 0);</span>
<span class="plain">} </span><span class="reserved">else</span><span class="plain"> {</span>
<span class="functiontext">Produce::val_symbol</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K</span><span class="plain">, </span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_symbol</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">s</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">val1</span><span class="plain"> = 0, </span><span class="identifier">val2</span><span class="plain"> = 0;</span>
<span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="identifier">IBM</span><span class="plain"> = </span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="identifier">Inter::Symbols::to_data</span><span class="plain">(</span><span class="identifier">Inter::Bookmarks::tree</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">), </span><span class="identifier">s</span><span class="plain">, &amp;</span><span class="identifier">val1</span><span class="plain">, &amp;</span><span class="identifier">val2</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K</span><span class="plain">, </span><span class="identifier">val1</span><span class="plain">, </span><span class="identifier">val2</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_text</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">S</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">v1</span><span class="plain"> = 0, </span><span class="identifier">v2</span><span class="plain"> = 0;</span>
<span class="functiontext">Produce::text_value</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, &amp;</span><span class="identifier">v1</span><span class="plain">, &amp;</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">S</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">v2</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_char</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">wchar_t</span><span class="plain"> </span><span class="identifier">c</span><span class="plain">) {</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">LITERAL_IVAL</span><span class="plain">, (</span><span class="identifier">inter_t</span><span class="plain">) </span><span class="identifier">c</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_real</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="reserved">double</span><span class="plain"> </span><span class="identifier">g</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">v1</span><span class="plain"> = 0, </span><span class="identifier">v2</span><span class="plain"> = 0;</span>
<span class="functiontext">Produce::real_value</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, &amp;</span><span class="identifier">v1</span><span class="plain">, &amp;</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">g</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">v2</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_real_from_text</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">S</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">v1</span><span class="plain"> = 0, </span><span class="identifier">v2</span><span class="plain"> = 0;</span>
<span class="functiontext">Produce::real_value_from_text</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, &amp;</span><span class="identifier">v1</span><span class="plain">, &amp;</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">S</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">v2</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::val_dword</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">S</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">v1</span><span class="plain"> = 0, </span><span class="identifier">v2</span><span class="plain"> = 0;</span>
<span class="functiontext">Produce::dword_value</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, &amp;</span><span class="identifier">v1</span><span class="plain">, &amp;</span><span class="identifier">v2</span><span class="plain">, </span><span class="identifier">S</span><span class="plain">);</span>
<span class="functiontext">Produce::val</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K_value</span><span class="plain">, </span><span class="identifier">v1</span><span class="plain">, </span><span class="identifier">v2</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::ref</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">val1</span><span class="plain">, </span><span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">val2</span><span class="plain">) {</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">val_kind</span><span class="plain"> = </span><span class="functiontext">Produce::kind_to_symbol</span><span class="plain">(</span><span class="identifier">K</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">val_kind</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"no kind for ref"</span><span class="plain">);</span>
<span class="functiontext">Produce::guard</span><span class="plain">(</span><span class="identifier">Inter::Ref::new</span><span class="plain">(</span><span class="functiontext">Produce::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">val_kind</span><span class="plain">, </span><span class="functiontext">Produce::level</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">), </span><span class="identifier">val1</span><span class="plain">, </span><span class="identifier">val2</span><span class="plain">, </span><span class="identifier">NULL</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::ref_iname</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">, </span><span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">iname</span><span class="plain">) {</span>
<span class="functiontext">Produce::ref_symbol</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K</span><span class="plain">, </span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">iname</span><span class="plain">));</span>
<span class="plain">}</span>
<span class="reserved">void</span><span class="plain"> </span><span class="functiontext">Produce::ref_symbol</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">, </span><span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="identifier">s</span><span class="plain">) {</span>
<span class="identifier">inter_t</span><span class="plain"> </span><span class="identifier">val1</span><span class="plain"> = 0, </span><span class="identifier">val2</span><span class="plain"> = 0;</span>
<span class="identifier">inter_bookmark</span><span class="plain"> *</span><span class="identifier">IBM</span><span class="plain"> = </span><span class="functiontext">Packaging::at</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">);</span>
<span class="identifier">Inter::Symbols::to_data</span><span class="plain">(</span><span class="identifier">Inter::Bookmarks::tree</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">), </span><span class="identifier">Inter::Bookmarks::package</span><span class="plain">(</span><span class="identifier">IBM</span><span class="plain">), </span><span class="identifier">s</span><span class="plain">, &amp;</span><span class="identifier">val1</span><span class="plain">, &amp;</span><span class="identifier">val2</span><span class="plain">);</span>
<span class="functiontext">Produce::ref</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">K</span><span class="plain">, </span><span class="identifier">val1</span><span class="plain">, </span><span class="identifier">val2</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::new_local_symbol</span><span class="plain">(</span><span class="identifier">inter_package</span><span class="plain"> *</span><span class="identifier">rpack</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">name</span><span class="plain">) {</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">Inter::SymbolsTables::create_with_unique_name</span><span class="plain">(</span><span class="identifier">Inter::Packages::scope</span><span class="plain">(</span><span class="identifier">rpack</span><span class="plain">), </span><span class="identifier">name</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="identifier">inter_symbol</span><span class="plain"> *</span><span class="functiontext">Produce::kind_to_symbol</span><span class="plain">(</span><span class="identifier">kind</span><span class="plain"> *</span><span class="identifier">K</span><span class="plain">) {</span>
<span class="plain">#</span><span class="identifier">ifdef</span><span class="plain"> </span><span class="identifier">CORE_MODULE</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">K</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) </span><span class="reserved">return</span><span class="plain"> </span><span class="identifier">unchecked_interk</span><span class="plain">;</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">K</span><span class="plain"> == </span><span class="identifier">K_value</span><span class="plain">) </span><span class="reserved">return</span><span class="plain"> </span><span class="identifier">unchecked_interk</span><span class="plain">; </span> <span class="comment">for error recovery</span>
<span class="reserved">return</span><span class="plain"> </span><span class="functiontext">InterNames::to_symbol</span><span class="plain">(</span><span class="identifier">Kinds::RunTime::iname</span><span class="plain">(</span><span class="identifier">K</span><span class="plain">));</span>
<span class="plain">#</span><span class="identifier">endif</span>
<span class="plain">#</span><span class="identifier">ifndef</span><span class="plain"> </span><span class="identifier">CORE_MODULE</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">CodeGen::Pipeline::uks</span><span class="plain">();</span>
<span class="plain">#</span><span class="identifier">endif</span>
<span class="plain">}</span>
<span class="reserved">inter_name</span><span class="plain"> *</span><span class="functiontext">Produce::find_by_name</span><span class="plain">(</span><span class="identifier">inter_tree</span><span class="plain"> *</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">text_stream</span><span class="plain"> *</span><span class="identifier">name</span><span class="plain">) {</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">Str::len</span><span class="plain">(</span><span class="identifier">name</span><span class="plain">) == 0) </span><span class="identifier">internal_error</span><span class="plain">(</span><span class="string">"empty extern"</span><span class="plain">);</span>
<span class="reserved">inter_name</span><span class="plain"> *</span><span class="identifier">try</span><span class="plain"> = </span><span class="functiontext">HierarchyLocations::find_by_name</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">name</span><span class="plain">);</span>
<span class="reserved">if</span><span class="plain"> (</span><span class="identifier">try</span><span class="plain"> == </span><span class="identifier">NULL</span><span class="plain">) {</span>
<span class="functiontext">HierarchyLocations::con</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, -1, </span><span class="identifier">name</span><span class="plain">, </span><span class="functiontext">Translation::same</span><span class="plain">(), </span><span class="functiontext">HierarchyLocations::plug</span><span class="plain">());</span>
<span class="identifier">try</span><span class="plain"> = </span><span class="functiontext">HierarchyLocations::find_by_name</span><span class="plain">(</span><span class="identifier">I</span><span class="plain">, </span><span class="identifier">name</span><span class="plain">);</span>
<span class="plain">}</span>
<span class="reserved">return</span><span class="plain"> </span><span class="identifier">try</span><span class="plain">;</span>
<span class="plain">}</span>
</pre>
<p class="inwebparagraph"></p>
<p class="endnote">The function Produce::new_cip appears nowhere else.</p>
<p class="endnote">The function Produce::locals_bookmark appears nowhere else.</p>
<p class="endnote">The function Produce::block appears nowhere else.</p>
<p class="endnote">The function Produce::kernel appears nowhere else.</p>
<p class="endnote">The function Produce::end_main_block appears nowhere else.</p>
<p class="endnote">The function Produce::end_block appears nowhere else.</p>
<p class="endnote">The function Produce::emitting_routine appears nowhere else.</p>
<p class="endnote">The function Produce::begin_position appears nowhere else.</p>
<p class="endnote">The function Produce::push_code_position appears nowhere else.</p>
<p class="endnote">The function Produce::level is used in <a href="#SP2">&#167;2</a>.</p>
<p class="endnote">The function Produce::set_level appears nowhere else.</p>
<p class="endnote">The function Produce::note_level appears nowhere else.</p>
<p class="endnote">The function Produce::to_last_level is used in 2/eis (<a href="2-eis.html#SP1">&#167;1</a>, <a href="2-eis.html#SP3_2">&#167;3.2</a>, <a href="2-eis.html#SP3_10">&#167;3.10</a>).</p>
<p class="endnote">The function Produce::at is used in <a href="#SP2">&#167;2</a>.</p>
<p class="endnote">The function Produce::down is used in 2/eis (<a href="2-eis.html#SP3_2">&#167;3.2</a>, <a href="2-eis.html#SP3_3">&#167;3.3</a>, <a href="2-eis.html#SP3_4">&#167;3.4</a>, <a href="2-eis.html#SP3_5">&#167;3.5</a>, <a href="2-eis.html#SP3_6">&#167;3.6</a>, <a href="2-eis.html#SP3_7">&#167;3.7</a>, <a href="2-eis.html#SP3_8">&#167;3.8</a>, <a href="2-eis.html#SP3_9">&#167;3.9</a>, <a href="2-eis.html#SP3_10">&#167;3.10</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::up is used in 2/eis (<a href="2-eis.html#SP3_2">&#167;3.2</a>, <a href="2-eis.html#SP3_3">&#167;3.3</a>, <a href="2-eis.html#SP3_4">&#167;3.4</a>, <a href="2-eis.html#SP3_5">&#167;3.5</a>, <a href="2-eis.html#SP3_6">&#167;3.6</a>, <a href="2-eis.html#SP3_7">&#167;3.7</a>, <a href="2-eis.html#SP3_8">&#167;3.8</a>, <a href="2-eis.html#SP3_9">&#167;3.9</a>, <a href="2-eis.html#SP3_10">&#167;3.10</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::pop_code_position appears nowhere else.</p>
<p class="endnote">The function Produce::inv_assembly is used in 2/eis (<a href="2-eis.html#SP3_3">&#167;3.3</a>).</p>
<p class="endnote">The function Produce::inv_primitive is used in 2/eis (<a href="2-eis.html#SP3_4">&#167;3.4</a>, <a href="2-eis.html#SP3_5">&#167;3.5</a>, <a href="2-eis.html#SP3_6">&#167;3.6</a>, <a href="2-eis.html#SP3_7">&#167;3.7</a>, <a href="2-eis.html#SP3_8">&#167;3.8</a>, <a href="2-eis.html#SP3_9">&#167;3.9</a>, <a href="2-eis.html#SP3_10">&#167;3.10</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::inv_call is used in 2/eis (<a href="2-eis.html#SP3_4">&#167;3.4</a>).</p>
<p class="endnote">The function Produce::inv_call_iname appears nowhere else.</p>
<p class="endnote">The function Produce::inv_indirect_call appears nowhere else.</p>
<p class="endnote">The function Produce::rtrue appears nowhere else.</p>
<p class="endnote">The function Produce::rfalse appears nowhere else.</p>
<p class="endnote">The function Produce::push appears nowhere else.</p>
<p class="endnote">The function Produce::pull appears nowhere else.</p>
<p class="endnote">The function Produce::val is used in 2/eis (<a href="2-eis.html#SP3_7">&#167;3.7</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>), 3/vh (<a href="3-vh.html#SP3">&#167;3</a>).</p>
<p class="endnote">The function Produce::val_nothing appears nowhere else.</p>
<p class="endnote">The function Produce::lab is used in 2/eis (<a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::reserve_label is used in 2/eis (<a href="2-eis.html#SP3_1">&#167;3.1</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::place_label is used in 2/eis (<a href="2-eis.html#SP3_1">&#167;3.1</a>).</p>
<p class="endnote">The function Produce::local_exists appears nowhere else.</p>
<p class="endnote">The function Produce::seek_symbol is used in 2/eis (<a href="2-eis.html#SP4">&#167;4</a>).</p>
<p class="endnote">The function Produce::text_value appears nowhere else.</p>
<p class="endnote">The function Produce::real_value appears nowhere else.</p>
<p class="endnote">The function Produce::real_value_from_text appears nowhere else.</p>
<p class="endnote">The function Produce::dword_value appears nowhere else.</p>
<p class="endnote">The function Produce::plural_dword_value appears nowhere else.</p>
<p class="endnote">The function Produce::val_iname is used in 2/eis (<a href="2-eis.html#SP3_10_1">&#167;3.10.1</a>).</p>
<p class="endnote">The function Produce::val_symbol is used in 2/eis (<a href="2-eis.html#SP3_10_1">&#167;3.10.1</a>, <a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::val_text is used in 2/eis (<a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::val_char is used in 2/eis (<a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::val_real appears nowhere else.</p>
<p class="endnote">The function Produce::val_real_from_text is used in 2/eis (<a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::val_dword is used in 2/eis (<a href="2-eis.html#SP3_11">&#167;3.11</a>).</p>
<p class="endnote">The function Produce::ref appears nowhere else.</p>
<p class="endnote">The function Produce::ref_iname appears nowhere else.</p>
<p class="endnote">The function Produce::ref_symbol appears nowhere else.</p>
<p class="endnote">The function Produce::new_local_symbol appears nowhere else.</p>
<p class="endnote">The function Produce::kind_to_symbol is used in 1/bs (<a href="1-bs.html#SP2">&#167;2</a>), 2/eis (<a href="2-eis.html#SP4">&#167;4</a>).</p>
<p class="endnote">The function Produce::find_by_name is used in 2/eis (<a href="2-eis.html#SP4">&#167;4</a>).</p>
<p class="endnote">The structure code_insertion_point is private to this section.</p>
<hr class="tocbar">
<ul class="toc"><li><i>(This section begins Chapter 3: Masonry.)</i></li><li><a href="3-vh.html">Continue with 'Value Holsters'</a></li></ul><hr class="tocbar">
<!--End of weave-->
</body>
</html>