org.antlr.codegen.templates.CSharp3.CSharp3.stg Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of antlr-complete Show documentation
Show all versions of antlr-complete Show documentation
Complete distribution for ANTLR 3
/*
* [The "BSD license"]
* Copyright (c) 2011 Terence Parr
* All rights reserved.
*
* Conversion to C#:
* Copyright (c) 2011 Sam Harwell, Pixel Mine, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
csharpVisibilityMap ::= [
"private":"private",
"protected":"protected",
"public":"public",
"fragment":"private",
default:"private"
]
/** The overall file structure of a recognizer; stores methods for rules
* and cyclic DFAs plus support code.
*/
outputFile( LEXER,PARSER,TREE_PARSER, actionScope, actions,
docComment, recognizer,
name, tokens, tokenNames, rules, cyclicDFAs,
bitsets, buildTemplate, buildAST, rewriteMode, profile,
backtracking, synpreds, memoize, numRules,
fileName, ANTLRVersion, generatedTimestamp, trace,
scopes, superClass, literals) ::=
<<
//------------------------------------------------------------------------------
// \
// This code was generated by a tool.
// ANTLR Version:
//
// Changes to this file may cause incorrect behavior and will be lost if
// the code is regenerated.
// \
//------------------------------------------------------------------------------
// $ANTLR
// The variable 'variable' is assigned but its value is never used.
#pragma warning disable 219
// Unreachable code detected.
#pragma warning disable 162
// Missing XML comment for publicly visible type or member 'Type_or_Member'
#pragma warning disable 1591
// CLS compliance checking will not be performed on 'type' because it is not visible from outside this assembly.
#pragma warning disable 3019
<@imports>
using System.Collections.Generic;
using Antlr.Runtime;
using Antlr.Runtime.Misc;
using Antlr.Runtime.Tree;
using RewriteRuleITokenStream = Antlr.Runtime.Tree.RewriteRuleTokenStream;
<@end>
namespace
{
} // namespace
>>
lexerInputStreamType() ::= <<
>>
lexer(grammar, name, tokens, scopes, rules, numRules, filterMode, labelType="CommonToken",
superClass={Antlr.Runtime.Lexer},
rewriteElementType={}, ASTLabelType={}) ::= <<
[System.CodeDom.Compiler.GeneratedCode("ANTLR", "")]
[System.CLSCompliant(false)]
partial class : <@superClassName><@end>
{
=;}; separator="\n">
}>
// delegates
;}; separator="\n">
// delegators
;}; separator="\n">
gParent;}>
()
{
OnCreated();
}
( input }> )
: this(input, new RecognizerSharedState()}>)
{
}
( input, RecognizerSharedState state }>)
: base(input, state)
{
state.ruleMemo = new System.Collections.Generic.Dictionary\[+1];<\n>
= new (input, this.state}>, this);}; separator="\n">
= ;}; separator="\n">
;}>
OnCreated();
}
public override string GrammarFileName { get { return ""; } }
public override CharStream
{
get
{
return base.CharStream;
}
set
{
base.CharStream = value;
= new (input, state}>, this);}; separator="\n">
= ;}; separator="\n">
;}>
}
}
public override void SetState(RecognizerSharedState state)
{
base.SetState(state);
.SetState(state);}; separator="\n">
}
partial void OnCreated();
partial void EnterRule(string ruleName, int ruleIndex);
partial void LeaveRule(string ruleName, int ruleIndex);
#region DFA
dfa;}; separator="\n">
protected override void InitDFAs()
{
base.InitDFAs();
= new DFA(this, SpecialStateTransition);}; separator="\n">
}
#endregion
}
>>
/** A override of Lexer.nextToken() that backtracks over mTokens() looking
* for matches. No error can be generated upon error; just rewind, consume
* a token and then try again. backtracking needs to be set as well.
* Make rule memoization happen only at levels above 1 as we start mTokens
* at backtracking==1.
*/
filteringNextToken() ::= <<
public override IToken NextToken()
{
while (true)
{
if (input.LA(1) == CharStreamConstants.EndOfFile)
{
IToken eof = new CommonToken((ICharStream)input, CharStreamConstants.EndOfFile, TokenChannels.Default, input.Index, input.Index);
eof.Line = Line;
eof.CharPositionInLine = CharPositionInLine;
return eof;
}
state.token = null;
state.channel = TokenChannels.Default;
state.tokenStartCharIndex = input.Index;
state.tokenStartCharPositionInLine = input.CharPositionInLine;
state.tokenStartLine = input.Line;
state.text = null;
try
{
int m = input.Mark();
state.backtracking=1;
state.failed=false;
mTokens();
state.backtracking=0;
if (state.failed)
{
input.Rewind(m);
input.Consume();
}
else
{
Emit();
return state.token;
}
}
catch (RecognitionException re)
{
// shouldn't happen in backtracking mode, but...
ReportError(re);
Recover(re);
}
}
}
public override void Memoize(IIntStream input, int ruleIndex, int ruleStartIndex)
{
if (state.backtracking > 1)
base.Memoize(input, ruleIndex, ruleStartIndex);
}
public override bool AlreadyParsedRule(IIntStream input, int ruleIndex)
{
if (state.backtracking > 1)
return base.AlreadyParsedRule(input, ruleIndex);
return false;
}
>>
actionGate() ::= "state.backtracking == 0"
filteringActionGate() ::= "state.backtracking == 1"
/** How to generate a parser */
genericParser(grammar, name, scopes, tokens, tokenNames, rules, numRules,
bitsets, inputStreamType, superClass,
labelType, members, rewriteElementType,
filterMode, ASTLabelType="object") ::= <<
[System.CodeDom.Compiler.GeneratedCode("ANTLR", "")]
[System.CLSCompliant(false)]
partial class : <@superClassName><@end>
{
internal static readonly string[] tokenNames = new string[] {
"\", "\", "\", "\",
};
=;}; separator="\n">
// delegates
;}; separator="\n">
// delegators
;}; separator="\n">
gParent;}>
public override void SetState(RecognizerSharedState state)
{
base.SetState(state);
.SetState(state);}; separator="\n">
}
public override void SetTreeNodeStream(ITreeNodeStream input)
{
base.SetTreeNodeStream(input);
.SetTreeNodeStream(input);}; separator="\n">
}
}>
<@members()>
public override string[] TokenNames { get { return .tokenNames; } }
public override string GrammarFileName { get { return ""; } }
partial void OnCreated();
partial void EnterRule(string ruleName, int ruleIndex);
partial void LeaveRule(string ruleName, int ruleIndex);
#region Rules
#endregion Rules
#region Delegated rules
(){ return .(}; separator=", ">); \}}; separator="\n">
#endregion Delegated rules
#region DFA
dfa;}; separator="\n">
protected override void InitDFAs()
{
base.InitDFAs();
= new DFA( this, SpecialStateTransition );}; separator="\n">
}
#endregion DFA
#region Follow sets
private static class Follow
{
_in_}, words64=it.bits)>}; separator="\n">
}
#endregion Follow sets
}
>>
@genericParser.members() ::= <<
( input }>)
: this(input, new RecognizerSharedState()}>)
{
}
( input, RecognizerSharedState state }>)
: base(input, state)
{
= new (input, state}>, this);}; separator="\n">
= .;}; separator="\n">
;}>
OnCreated();
}
>>
// imported grammars are 'public' (can't be internal because their return scope classes must be accessible)
parserModifier(grammar, actions) ::= <<
public
>>
parserCtorBody() ::= <<
this.state.ruleMemo = new System.Collections.Generic.Dictionary\[+1];<\n>
= ;}; separator="\n">
>>
parser(grammar, name, scopes, tokens, tokenNames, rules, numRules, bitsets,
ASTLabelType="object", superClass={Antlr.Runtime.Parser}, labelType="IToken",
members={}) ::= <<
>>
/** How to generate a tree parser; same as parser except the input
* stream is a different type.
*/
treeParser(grammar, name, scopes, tokens, tokenNames, globalAction, rules,
numRules, bitsets, filterMode, labelType={}, ASTLabelType="object",
superClass={Antlr.Runtime.Tree.TreeRewriterTreeFilterTreeParser},
members={}) ::= <<
>>
/** A simpler version of a rule template that is specific to the imaginary
* rules created for syntactic predicates. As they never have return values
* nor parameters etc..., just give simplest possible method. Don't do
* any of the normal memoization stuff in here either; it's a waste.
* As predicates cannot be inlined into the invoking rule, they need to
* be in a rule by themselves.
*/
synpredRule(ruleName, ruleDescriptor, block, description, nakedBlock) ::=
<<
partial void EnterRule__fragment();
partial void LeaveRule__fragment();
// $ANTLR start
void _fragment()
{
EnterRule__fragment();
EnterRule("_fragment", );
TraceIn("_fragment", );
try
{
}
finally
{
TraceOut("_fragment", );
LeaveRule("_fragment", );
LeaveRule__fragment();
}
}
// $ANTLR end
>>
insertLexerSynpreds(synpreds) ::= <<
>>
insertSynpreds(synpreds) ::= <<
#region Synpreds
private bool EvaluatePredicate(System.Action fragment)
{
bool success = false;
state.backtracking++;
<@start()>
try { DebugBeginBacktrack(state.backtracking);
int start = input.Mark();
try
{
fragment();
}
catch ( RecognitionException re )
{
System.Console.Error.WriteLine("impossible: "+re);
}
success = !state.failed;
input.Rewind(start);
} finally { DebugEndBacktrack(state.backtracking, success); }
<@stop()>
state.backtracking--;
state.failed=false;
return success;
}
#endregion Synpreds
>>
ruleMemoization(name) ::= <<
if (state.backtracking > 0 && AlreadyParsedRule(input, )) { }
>>
/** How to test for failure and return from rule */
checkRuleBacktrackFailure() ::= <<
if (state.failed)
>>
/** This rule has failed, exit indicating failure during backtrack */
ruleBacktrackFailure() ::= <<
if (state.backtracking>0) {state.failed=true; }
>>
ruleWrapperMap ::= [
"bottomup":{},
"topdown":{},
default:""
]
ruleWrapperBottomup() ::= <<
protected override IAstRuleReturnScopevoid Bottomup() { return bottomup(); }
>>
ruleWrapperTopdown() ::= <<
protected override IAstRuleReturnScopevoid Topdown() {