Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > 7ebd25ac536d248d499a3ce2acda963a > files > 5546

Macaulay2-1.3.1-8.fc15.i686.rpm

<?xml version="1.0" encoding="utf-8" ?>  <!-- for emacs: -*- coding: utf-8 -*- -->
<!-- Apache may like this line in the file .htaccess: AddCharset utf-8 .html -->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0 plus SVG 1.1//EN"	 "http://www.w3.org/2002/04/xhtml-math-svg/xhtml-math-svg-flat.dtd" >
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head><title>andP -- parser conjunction</title>
<link rel="stylesheet" type="text/css" href="../../../../Macaulay2/Style/doc.css"/>
</head>
<body>
<table class="buttons">
  <tr>
    <td><div><a href="__st_sp__Parser.html">next</a> | <a href="_or__P.html">previous</a> | <a href="__st_sp__Parser.html">forward</a> | <a href="_or__P.html">backward</a> | <a href="___Parser.html">up</a> | <a href="index.html">top</a> | <a href="master.html">index</a> | <a href="toc.html">toc</a> | <a href="http://www.math.uiuc.edu/Macaulay2/">Macaulay2 web site</a></div>

    </td>
  </tr>
</table>
<div><a href="index.html" title="a framework for building parsers">Parsing</a> > <a href="___Parser.html" title="the class of all parsers">Parser</a> > <a href="_and__P.html" title="parser conjunction">andP</a></div>
<hr/>
<div><h1>andP -- parser conjunction</h1>
<div class="single"><h2>Synopsis</h2>
<ul><li><div class="list"><dl class="element"><dt class="heading">Usage: </dt><dd class="value"><div><tt>r = andP(p,q,...)</tt></div>
</dd></dl>
</div>
</li>
<li><div class="single">Inputs:<ul><li><span><tt>(p,q,...)</tt>, a sequence of parsers (of type <a href="___Parser.html" title="the class of all parsers">Parser</a>)</span></li>
</ul>
</div>
</li>
<li><div class="single">Outputs:<ul><li><span><tt>r</tt>, <span>a <a href="___Parser.html">parser</a></span>, a parser that accepts as many tokens as <tt>p</tt> will accept, then as many as <tt>q</tt> will accept, and so on.  The return value is the sequence of values returned by each of the input parsers.</span></li>
</ul>
</div>
</li>
</ul>
</div>
<div class="single"><h2>Description</h2>
<div><p>An abbreviation for <tt>andP(p,q)</tt> is <tt>p@q</tt>.</p>
<p>If one of the arguments is <span>a <a href="../../Macaulay2Doc/html/___String.html">string</a></span> then <a href="_const__Parser.html" title="produce a parser that accepts a fixed string, one character at a time">constParser</a> is used to convert it into a parser.</p>
<table class="examples"><tr><td><pre>i1 : (constParser "abc" @ constParser "def" : charAnalyzer) "abcdef"

o1 = (abc, def)

o1 : Sequence</pre>
</td></tr>
</table>
</div>
</div>
<div class="single"><h2>See also</h2>
<ul><li><span><a href="_const__Parser.html" title="produce a parser that accepts a fixed string, one character at a time">constParser</a> -- produce a parser that accepts a fixed string, one character at a time</span></li>
<li><span><a href="___Parser_sp_co_sp__Analyzer.html" title="combine a parser with a lexical analyzer to make a complete system">Parser : Analyzer</a> -- combine a parser with a lexical analyzer to make a complete system</span></li>
</ul>
</div>
<div class="waystouse"><div class="single"><h2>Code</h2>
<pre>../Parsing.m2:117:26-125:85: --source code:
Parser @ Parser := (p,q) -> new Parser from (
     c -> (
          if c =!= null then (
               if (p' := p c) =!= null 
               then p' @ q 
               else if (val1 := p null) =!= null then if (q' := q c) =!= null then (val2 -> (val1,val2)) % q'
               )
          else if (val1 = p null) =!= null and (val2 := q null) =!= null then (val1,val2)
          ))</pre>
</div>
</div>
</div>
</body>
</html>