Parameter-Mode.html 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd">
  2. <html>
  3. <!-- Created on December 10, 2012 by texi2html 1.82
  4. texi2html was written by:
  5. Lionel Cons <[email protected]> (original author)
  6. Karl Berry <[email protected]>
  7. Olaf Bachmann <[email protected]>
  8. and many others.
  9. Maintained by: Many creative people.
  10. Send bugs and suggestions to <[email protected]>
  11. -->
  12. <head>
  13. <title>avram - a virtual machine code interpreter: 1.2.2 Parameter Mode</title>
  14. <meta name="description" content="avram - a virtual machine code interpreter: 1.2.2 Parameter Mode">
  15. <meta name="keywords" content="avram - a virtual machine code interpreter: 1.2.2 Parameter Mode">
  16. <meta name="resource-type" content="document">
  17. <meta name="distribution" content="global">
  18. <meta name="Generator" content="texi2html 1.82">
  19. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  20. <style type="text/css">
  21. <!--
  22. a.summary-letter {text-decoration: none}
  23. blockquote.smallquotation {font-size: smaller}
  24. pre.display {font-family: serif}
  25. pre.format {font-family: serif}
  26. pre.menu-comment {font-family: serif}
  27. pre.menu-preformatted {font-family: serif}
  28. pre.smalldisplay {font-family: serif; font-size: smaller}
  29. pre.smallexample {font-size: smaller}
  30. pre.smallformat {font-family: serif; font-size: smaller}
  31. pre.smalllisp {font-size: smaller}
  32. span.roman {font-family:serif; font-weight:normal;}
  33. span.sansserif {font-family:sans-serif; font-weight:normal;}
  34. ul.toc {list-style: none}
  35. -->
  36. </style>
  37. </head>
  38. <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
  39. <a name="Parameter-Mode"></a>
  40. <table cellpadding="1" cellspacing="1" border="0">
  41. <tr><td valign="middle" align="left">[<a href="Filter-Mode.html#Filter-Mode" title="Previous section in reading order"> &lt; </a>]</td>
  42. <td valign="middle" align="left">[<a href="Filter-Mode-Options.html#Filter-Mode-Options" title="Next section in reading order"> &gt; </a>]</td>
  43. <td valign="middle" align="left"> &nbsp; </td>
  44. <td valign="middle" align="left">[<a href="User-Manual.html#User-Manual" title="Beginning of this chapter or previous chapter"> &lt;&lt; </a>]</td>
  45. <td valign="middle" align="left">[<a href="Modes-of-Operation.html#Modes-of-Operation" title="Up section"> Up </a>]</td>
  46. <td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Next chapter"> &gt;&gt; </a>]</td>
  47. <td valign="middle" align="left"> &nbsp; </td>
  48. <td valign="middle" align="left"> &nbsp; </td>
  49. <td valign="middle" align="left"> &nbsp; </td>
  50. <td valign="middle" align="left"> &nbsp; </td>
  51. <td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td>
  52. <td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td>
  53. <td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td>
  54. <td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td>
  55. </tr></table>
  56. <hr size="1">
  57. <a name="Parameter-Mode-1"></a>
  58. <h3 class="subsection">1.2.2 Parameter Mode</h3>
  59. <a name="index-parameter-mode"></a>
  60. <p>In parameter mode, the argument to the function given by the virtual
  61. code is a data structure containing environment variables and command
  62. line parameters including files, application specific options, and
  63. possibly standard input. The result obtained by evaluating the
  64. function is either a data structure representing a set of files to be
  65. written, which may include standard output, or a sequence of shell
  66. commands to be executed, or a combination of both. Parameter mode is
  67. indicated whenever either of these conditions is met.
  68. </p>
  69. <ul>
  70. <li>
  71. Any of the parameter mode options appears on the
  72. command line preceding the first filename parameter.
  73. <br>
  74. See section <a href="Parameter-Mode-Options.html#Parameter-Mode-Options">Parameter Mode Options</a>.
  75. </li><li>
  76. At least one additional filename parameter or option follows the first
  77. filename parameter, and the option &lsquo;<samp>--unparameterized</samp>&rsquo; does not
  78. precede it.
  79. </li></ul>
  80. <p>Examples:
  81. </p>
  82. <dl compact="compact">
  83. <dt> <kbd>avram --map-to-each-file prettyprinter.avm *.c *.h --extra-pretty</kbd></dt>
  84. <dd><p>In this example, parameter mode is indicated both by the parameter
  85. mode option &lsquo;<samp>--map-to-each-file</samp>&rsquo; and by the presence of input
  86. file names and the &lsquo;<samp>--extra-pretty</samp>&rsquo; option. The latter is
  87. specific to the hypothetical <code>prettyprinter.avm</code> virtual code
  88. application, as indicated by its position on the command line, and is
  89. therefore passed to it by <code>avram</code>.
  90. </p></dd>
  91. <dt> <kbd>cat ~/specfile | avram reportgenerator -v - /var/log/syslog</kbd></dt>
  92. <dd><p>In this example, a hypothetical parameter mode application
  93. <code>reportgenerator</code> is able to read &lsquo;<tt>~/specfile</tt>&rsquo; from standard
  94. input because of the <code>-</code> used as a parameter.
  95. </p></dd>
  96. <dt> <kbd>avram --parameterized grepenv</kbd></dt>
  97. <dd><p>In this example, a hypothetical application that searches shell
  98. variables is invoked in parameter mode even with no input files or
  99. application specific options, because of the &lsquo;<samp>--parameterized</samp>&rsquo;
  100. option. Parameter mode invocation is required by the application to give
  101. it access to the environment.
  102. </p></dd>
  103. <dt> <kbd>avram grepenv --search-targets=PATH,MANPATH</kbd></dt>
  104. <dd><p>This example shows an application specific option with both a keyword
  105. and a parameter list. They suffice to indicate parameter mode without
  106. an explicit &lsquo;<samp>--parameterized</samp>&rsquo; option.
  107. </p></dd>
  108. </dl>
  109. <hr size="1">
  110. <table cellpadding="1" cellspacing="1" border="0">
  111. <tr><td valign="middle" align="left">[<a href="Filter-Mode.html#Filter-Mode" title="Previous section in reading order"> &lt; </a>]</td>
  112. <td valign="middle" align="left">[<a href="Filter-Mode-Options.html#Filter-Mode-Options" title="Next section in reading order"> &gt; </a>]</td>
  113. <td valign="middle" align="left"> &nbsp; </td>
  114. <td valign="middle" align="left">[<a href="User-Manual.html#User-Manual" title="Beginning of this chapter or previous chapter"> &lt;&lt; </a>]</td>
  115. <td valign="middle" align="left">[<a href="Modes-of-Operation.html#Modes-of-Operation" title="Up section"> Up </a>]</td>
  116. <td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Next chapter"> &gt;&gt; </a>]</td>
  117. <td valign="middle" align="left"> &nbsp; </td>
  118. <td valign="middle" align="left"> &nbsp; </td>
  119. <td valign="middle" align="left"> &nbsp; </td>
  120. <td valign="middle" align="left"> &nbsp; </td>
  121. <td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td>
  122. <td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td>
  123. <td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td>
  124. <td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td>
  125. </tr></table>
  126. <p>
  127. <font size="-1">
  128. This document was generated on <i>December 10, 2012</i> using <a href="http://www.nongnu.org/texi2html/"><i>texi2html 1.82</i></a>.
  129. </font>
  130. <br>
  131. </p>
  132. </body>
  133. </html>