| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd"><html><!-- Created on December 10, 2012 by texi2html 1.82texi2html was written by:             Lionel Cons <[email protected]> (original author)            Karl Berry  <[email protected]>            Olaf Bachmann <[email protected]>            and many others.Maintained by: Many creative people.Send bugs and suggestions to <[email protected]>--><head><title>avram - a virtual machine code interpreter: 2.6.4.1 Line Oriented Interaction</title><meta name="description" content="avram - a virtual machine code interpreter: 2.6.4.1 Line Oriented Interaction"><meta name="keywords" content="avram - a virtual machine code interpreter: 2.6.4.1 Line Oriented Interaction"><meta name="resource-type" content="document"><meta name="distribution" content="global"><meta name="Generator" content="texi2html 1.82"><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><style type="text/css"><!--a.summary-letter {text-decoration: none}blockquote.smallquotation {font-size: smaller}pre.display {font-family: serif}pre.format {font-family: serif}pre.menu-comment {font-family: serif}pre.menu-preformatted {font-family: serif}pre.smalldisplay {font-family: serif; font-size: smaller}pre.smallexample {font-size: smaller}pre.smallformat {font-family: serif; font-size: smaller}pre.smalllisp {font-size: smaller}span.roman {font-family:serif; font-weight:normal;}span.sansserif {font-family:sans-serif; font-weight:normal;}ul.toc {list-style: none}--></style></head><body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000"><a name="Line-Oriented-Interaction"></a><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Output-From-Interactive-Applications.html#Output-From-Interactive-Applications" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Character-Oriented-Interaction.html#Character-Oriented-Interaction" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="Output-From-Interactive-Applications.html#Output-From-Interactive-Applications" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Library-Reference.html#Library-Reference" title="Next chapter"> >> </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td><td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td><td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td><td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td></tr></table><hr size="1"><a name="Line-Oriented-Interaction-1"></a><h4 class="subsubsection">2.6.4.1 Line Oriented Interaction</h4><p>Within this general pattern, more specific styles of interaction arepossible. In the simplest one to explain first, the result returned bythe function is always a data structure of the form<a name="index-command-line-4"></a><code>(<var>state</var>,(<var>command lines</var>,<var>prompts</var>))</code>, wherein thefields have these interpretations.</p><dl compact="compact"><dt> <var>state</var></dt><dd><p>is a tree incorporating any data in any format that the applicationneeds to remember from one invocation to the next.</p></dd><dt> <var>command lines</var></dt><dd><p>is a list of character strings that are piped to the standard inputstream of a separately spawned process. The process may persist from oneinvocation of the function to the next, or may be spawned each time.</p></dd><dt> <var>prompts</var></dt><dd><p>is a non-empty list of character strings containing a suffix of the textexpected from the standard output stream of the process as a result ofsending the command lines to it.</p></dd></dl><p>On each iteration, <code>avram</code> sends the command line character strings<a name="index-spawning-processes-1"></a>to a separately spawned process, with line breaks between them if thereare more than one command. If a process remains from the previous iteration thathas not terminated itself, the list of command lines is sent to the sameprocess. If no such process already exists, the first string in the listof command lines is treated as a shell command and used to spawn the<a name="index-exp_005fpopen-1"></a>process (using the <code>exp_popen</code> library function), and the remainingstrings are sent to the newly spawned process.</p><p>Normally processes spawned with commands that invoke interactive commandline interpreters of their own, such as <code>bash</code>, <code>ftp</code> or<code>bc</code>, will persist indefinitely unless the command causing themto exit is issued or some other event kills them. Processes spawned withnon-interactive commands, such as <code>ls</code> or <code>pwd</code>, willterminate when the last of their initial output has been received.</p><p>In the case of processes that persist after being spawned, <code>avram</code>needs some way of knowing when to stop waiting for more output from themso that it doesn’t get stuck waiting forever. This purpose is served bythe <var>prompts</var> field. This field could contain a single stringholding the last thing the process will send before becoming quiescent,such as the strings <code>bash$ </code> or <code>ftp> </code> in the aboveexamples. Alternatively, a sequence of more than one prompt string canbe used to indicate that the corresponding sequence of lines must bedetected. An empty string followed by <code>ftp> </code> would indicate thatthe <code>ftp> </code> prompt is expected to be immediately preceded by a line<a name="index-prompts"></a>break. There is also the option of using prompt strings to indicate apattern that does not necessarily imply quiescence, but is a moreconvenient point at which to stop reading the output from the process.</p><p>For processes spawned with commands that do not start their owninteractive command line interpreters, such as <code>ls</code> or<code>pwd</code>, it may be preferable to read all the output from themuntil they terminate. To achieve this effect, the list of prompt stringsshould contain only the single string containing only the single<code>EOF</code> character (usually code 4) or any other character that iscertain not to occur in the output of the process. This technique isbased on the assumption that the process was spawned originally with thecommand in question, not that such a command is sent to an existingshell process.</p><p>In any case, when enough output has been received from the process, itis collected into a list of received strings including the promptstrings at the end (if they were received), and the function is appliedto the pair <code>(<var>state</var>,<var>received strings</var>)</code>. If the cycle isto continue, the result returned by the function will include a newstate, a new list of command lines, and a new list of prompt strings. Aresult of <code>nil</code> will cause the computation to terminate.</p><p>There are some unusual situations that could occur in the course of lineoriented interaction, and are summarized as follows.</p><ul><li> If the process terminates before any pattern matching the promptstrings is received from it, all of the output from the process up tothe point where it terminated is collected into the <var>receivedstrings</var> list and passed to the function. This situation includes caseswhere the process terminates immediately upon being spawned, but notabnormal completion of the <code>exp_popen</code> library function, which isa fatal error. This feature of the interface is what allows <code>EOF</code>to be used for collecting all the output at once from a non-interactivecommand.</li><li> If the list of <var>command lines</var> is empty, and no processcurrently exists due to a previous iteration, the effect is the same asif the process terminates unexpectedly before outputting anything. I.e.,the function is applied to a pair containing an empty list of receivedstrings. There is no good reason for an application to get into thissituation.</li><li> If the list of <var>command lines</var> is empty but a process persistsfrom a previous iteration, no output is sent to it, but receiving fromit proceeds normally. This feature of the interface could be usedeffectively by applications intended to process the received data in<a name="index-deadlock"></a>parts, but will cause deadlock if the process is already quiescent.</li><li> All character strings have to consist of lists of validrepresentations of non-null characters according to <a href="Character-Table.html#Character-Table">Character Table</a>, or else there will be some fatal error messages.</li><li> If the list of <var>prompt strings</var> contains only the emptystring, <code>avram</code> will not wait to receive anything from the process,but will proceed with the next iteration immediately. If this effect isintended, care must be taken not to confuse the empty listof <var>prompt strings</var> with the list containing the empty string. The formerindicates character oriented interaction, which is explained next.</li></ul><hr size="1"><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Output-From-Interactive-Applications.html#Output-From-Interactive-Applications" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Character-Oriented-Interaction.html#Character-Oriented-Interaction" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="Output-From-Interactive-Applications.html#Output-From-Interactive-Applications" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Library-Reference.html#Library-Reference" title="Next chapter"> >> </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td><td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td><td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td><td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td></tr></table><p> <font size="-1">  This document was generated on <i>December 10, 2012</i> using <a href="http://www.nongnu.org/texi2html/"><i>texi2html 1.82</i></a>. </font> <br></p></body></html>
 |