rustlr 0.4.0

LR Parser Generator with Advanced Options
Documentation
<!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>Error Recovery</title>
        <style>
/* From extension vscode.github */
/*---------------------------------------------------------------------------------------------
 *  Copyright (c) Microsoft Corporation. All rights reserved.
 *  Licensed under the MIT License. See License.txt in the project root for license information.
 *--------------------------------------------------------------------------------------------*/

.vscode-dark img[src$=\#gh-light-mode-only],
.vscode-light img[src$=\#gh-dark-mode-only] {
	display: none;
}

</style>
        
        <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/Microsoft/vscode/extensions/markdown-language-features/media/markdown.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/Microsoft/vscode/extensions/markdown-language-features/media/highlight.css">
<style>
            body {
                font-family: -apple-system, BlinkMacSystemFont, 'Segoe WPC', 'Segoe UI', system-ui, 'Ubuntu', 'Droid Sans', sans-serif;
                font-size: 14px;
                line-height: 1.6;
            }
        </style>
        <style>
.task-list-item {
    list-style-type: none;
}

.task-list-item-checkbox {
    margin-left: -20px;
    vertical-align: middle;
    pointer-events: none;
}
</style>
        
    </head>
    <body class="vscode-body vscode-light">
        <h2 id="error-recovery">Error Recovery</h2>
<p>Rustlr supports two methods of error recovery.  The first method
requires the designation of a special terminal symbol as an error
recovery symbol, using the directive &quot;errsym&quot; or &quot;errorsymbol&quot;.  This
symbol is assumed to not conflict with actual input tokens.  The error
symbol can appear at most once on the right-hand side of a production
rule.  When an error is encountered (a lookahead symbol with no
defined transition in the LR finite-state machine), the parser
looks down the parse stack for a state that has a transition defined
on the error symbol.  It truncates the stack and performs all possible
reductions until a state that can &quot;shift&quot; the error symbol
is found. It then simuluates the shifting of the next state
associated with the error symbol, with the default semantic value of its type,
onto the stack.  It then skips
lookheads until a valid transition is found for the new state.</p>
<p>The second method of error recovery is rather straightforward: the
grammar can define one or more &quot;resynchronization&quot; terminal symbols
using the &quot;resynch&quot; directive.  When an error is encountered, the
parser skips ahead past the first resynchronization symbol.  Then it
looks down the parse stack for a state that has a valid transition on
the next symbol.  For languages that ends statements with a ;
(semicolon), the ; is the natural choice as the resynch symbol.  The
parser will report an error message for the current statement, then
skip over to the next statement.</p>
<p>The second (resynch) method of error recovery is attempted if the
first method fails or if no error symbol is defined.</p>
<p>If both methods of error-recovery fail, the parser simply skips input
tokens until a suitable action is found.</p>
<p>The following grammar can be used to experiment with these error-recovery
methods.  It parses &quot;cout&quot; statements in &quot;C+-&quot;.    The grammar contains an injected <code>main</code> function and can replace the
&quot;<a href="http://main.rs">main.rs</a>&quot; of a crate.  One can test error recovery behavior with input
such as</p>
<pre><code>cout &lt;&lt; x; cout &lt;&lt; y x; cout z; cout &lt;&lt; y &lt;&lt; z ;
</code></pre>
<pre><code># Grammar for testing error-recovery
auto
grammarname cpm
nonterminals STAT STATLIST EXPR EXPRLIST
terminals x y z cin cout ; ( ) &gt;&gt; ERROR
lexterminal LLANGLE &lt;&lt;
topsym STATLIST
errsym ERROR
#resync ;

STATLIST --&gt; STAT+
STAT --&gt; cout LLANGLE EXPRLIST:s ; 

EXPR --&gt; x | y | z
EXPR --&gt; ( EXPR )
EXPRLIST --&gt; EXPR&lt;LLANGLE+&gt;

STAT:ErrorStat --&gt; ERROR ;
#STATLIST --&gt; ERROR STAT
EXPR:ErrorExpr --&gt; ( ERROR )
#EXPR --&gt; EXPR ERROR )

!//injected into parser:
!mod cpm_ast;
!use std::io::{Write};
!
!fn readln()-&gt; String {
!  let mut s = String::new();
!  let r = std::io::stdin().read_line(&amp;mut s);
!  s
!}
!
!fn main() {
!   print!(&quot;Write something in C+- : &quot;);
!   std::io::stdout().flush().unwrap();
!   let input = readln();
!   let mut lexer1 = cpmlexer::from_str(&amp;input);
!   let mut parser1 = make_parser();
!   let res = parse_with(&amp;mut parser1, &amp;mut lexer1);
!   //let res = parse_train_with(&amp;mut parser1, &amp;mut lexer1);
!   println!(&quot;parsing success: {}&quot;,!parser1.error_occurred());
!   println!(&quot;Result: {:?}&quot;,res);
!}//main
</code></pre>

        
        
    </body>
    </html>