<?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>optP -- making a parser optional</title> <link rel="stylesheet" type="text/css" href="../../../../Macaulay2/Style/doc.css"/> </head> <body> <table class="buttons"> <tr> <td><div><a href="_or__P.html">next</a> | <a href="___Q__Q__Parser.html">previous</a> | <a href="_or__P.html">forward</a> | <a href="___Q__Q__Parser.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="_opt__P.html" title="making a parser optional">optP</a></div> <hr/> <div><h1>optP -- making a parser optional</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>optP p</tt></div> </dd></dl> </div> </li> <li><div class="single">Inputs:<ul><li><span><tt>p</tt>, <span>a <a href="___Parser.html">parser</a></span></span></li> </ul> </div> </li> <li><div class="single">Outputs:<ul><li><span><span>a <a href="___Parser.html">parser</a></span>, a parser that accepts tokens accepted by p and returns the value returned by p, or accepts the empty sequence of tokens and returns the symbol <tt>nil</tt>. It prefers to do the former.</span></li> </ul> </div> </li> </ul> </div> <div class="single"><h2>Description</h2> <div><p>After the first token, the parser is no slower than <tt>p</tt> would have been.</p> <table class="examples"><tr><td><pre>i1 : (optP constParser "abc" : charAnalyzer) "abc" o1 = abc</pre> </td></tr> <tr><td><pre>i2 : (optP constParser "abc" : charAnalyzer) "" o2 = nil o2 : Symbol</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="_char__Analyzer.html" title="a lexical analyzer that provides characters from a string one at a time">charAnalyzer</a> -- a lexical analyzer that provides characters from a string one 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> </body> </html>