1324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/*
2324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver [The "BSD license"]
3324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver Copyright (c) 2005-2006 Terence Parr
4324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver All rights reserved.
5324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
6324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver Redistribution and use in source and binary forms, with or without
7324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver modification, are permitted provided that the following conditions
8324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver are met:
9324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 1. Redistributions of source code must retain the above copyright
10324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    notice, this list of conditions and the following disclaimer.
11324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 2. Redistributions in binary form must reproduce the above copyright
12324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    notice, this list of conditions and the following disclaimer in the
13324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    documentation and/or other materials provided with the distribution.
14324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 3. The name of the author may not be used to endorse or promote products
15324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    derived from this software without specific prior written permission.
16324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
17324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver*/
28324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
29324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver@outputFile.imports() ::= <<
30324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<@super.imports()>
31324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(!TREE_PARSER)><! tree parser would already have imported !>
32324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverimport org.antlr.runtime.tree.*;<\n>
33324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
34324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
35324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
36324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver@genericParser.members() ::= <<
37324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<@super.members()>
38324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<parserMembers()>
39324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
40324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
41324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Add an adaptor property that knows how to build trees */
42324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverparserMembers() ::= <<
43324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverprotected TreeAdaptor adaptor = new CommonTreeAdaptor();<\n>
44324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverpublic void setTreeAdaptor(TreeAdaptor adaptor) {
45324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    this.adaptor = adaptor;
46324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    <grammar.directDelegates:{g|<g:delegateName()>.setTreeAdaptor(this.adaptor);}>
47324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
48324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverpublic TreeAdaptor getTreeAdaptor() {
49324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    return adaptor;
50324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
51324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
52324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
53324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver@returnScope.ruleReturnMembers() ::= <<
54324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ASTLabelType> tree;
55324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverpublic Object getTree() { return tree; }
56324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
57324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
58324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Add a variable to track rule's return AST */
59324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverruleDeclarations() ::= <<
60324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<super.ruleDeclarations()>
61324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ASTLabelType> root_0 = null;<\n>
62324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
63324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
64324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverruleLabelDefs() ::= <<
65324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<super.ruleLabelDefs()>
66324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<[ruleDescriptor.tokenLabels,ruleDescriptor.wildcardTreeLabels,
67324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver  ruleDescriptor.wildcardTreeListLabels]:{it | <ASTLabelType> <it.label.text>_tree=null;}; separator="\n">
68324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ruleDescriptor.tokenListLabels:{it | <ASTLabelType> <it.label.text>_tree=null;}; separator="\n">
69324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ruleDescriptor.allTokenRefsInAltsWithRewrites
70324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRule<rewriteElementType>Stream stream_<it>=new RewriteRule<rewriteElementType>Stream(adaptor,"token <it>");}; separator="\n">
71324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ruleDescriptor.allRuleRefsInAltsWithRewrites
72324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRuleSubtreeStream stream_<it>=new RewriteRuleSubtreeStream(adaptor,"rule <it>");}; separator="\n">
73324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
74324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
75324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** When doing auto AST construction, we must define some variables;
76324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  These should be turned off if doing rewrites.  This must be a "mode"
77324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  as a rule could have both rewrite and AST within the same alternative
78324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  block.
79324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver */
80324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver@alt.declarations() ::= <<
81324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(autoAST)>
82324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(outerAlt)>
83324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(!rewriteMode)>
84324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_0 = (<ASTLabelType>)adaptor.nil();<\n>
85324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
86324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
87324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
88324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
89324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
90324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// T r a c k i n g  R u l e  E l e m e n t s
91324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
92324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** ID and track it for use in a rewrite rule */
93324c4644fee44b9898524c09511bd33c3f12e2dfBen GruvertokenRefTrack(token,label,elementIndex,terminalOptions) ::= <<
94324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<tokenRefBang(...)> <! Track implies no auto AST construction!>
95324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(backtracking)>if ( <actions.(actionScope).synpredgate> ) <endif>stream_<token>.add(<label>);<\n>
96324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
97324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
98324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** ids+=ID and track it for use in a rewrite rule; adds to ids *and*
99324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  to the tracking list stream_ID for use in the rewrite.
100324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver */
101324c4644fee44b9898524c09511bd33c3f12e2dfBen GruvertokenRefTrackAndListLabel(token,label,elementIndex,terminalOptions) ::= <<
102324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<tokenRefTrack(...)>
103324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<listLabel(elem=label, ...)>
104324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
105324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
106324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** ^(ID ...) track for rewrite */
107324c4644fee44b9898524c09511bd33c3f12e2dfBen GruvertokenRefRuleRootTrack(token,label,elementIndex,terminalOptions) ::= <<
108324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<tokenRefBang(...)>
109324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(backtracking)>if ( <actions.(actionScope).synpredgate> ) <endif>stream_<token>.add(<label>);<\n>
110324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
111324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
112324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Match ^(label+=TOKEN ...) track for rewrite */
113324c4644fee44b9898524c09511bd33c3f12e2dfBen GruvertokenRefRuleRootTrackAndListLabel(token,label,elementIndex,terminalOptions) ::= <<
114324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<tokenRefRuleRootTrack(...)>
115324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<listLabel(elem=label, ...)>
116324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
117324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
118324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** rule when output=AST and tracking for rewrite */
119324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverruleRefTrack(rule,label,elementIndex,args,scope) ::= <<
120324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<super.ruleRef(...)>
121324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(backtracking)>if ( <actions.(actionScope).synpredgate> ) <endif>stream_<rule.name>.add(<label>.getTree());
122324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
123324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
124324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** x+=rule when output=AST and tracking for rewrite */
125324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverruleRefTrackAndListLabel(rule,label,elementIndex,args,scope) ::= <<
126324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ruleRefTrack(...)>
127324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<listLabel(label, {<label>.getTree()})>
128324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
129324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
130324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** ^(rule ...) rewrite */
131324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverruleRefRuleRootTrack(rule,label,elementIndex,args,scope) ::= <<
132324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ruleRefRuleRoot(...)>
133324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(backtracking)>if ( <actions.(actionScope).synpredgate> ) <endif>stream_<rule>.add(<label>.getTree());
134324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
135324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
136324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** ^(x+=rule ...) rewrite */
137324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverruleRefRuleRootTrackAndListLabel(rule,label,elementIndex,args,scope) ::= <<
138324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ruleRefRuleRootTrack(...)>
139324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<listLabel(label, {<label>.getTree()})>
140324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
141324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
142324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// R e w r i t e
143324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
144324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteCode(
145324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	alts, description,
146324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElementsDeep, // ALL referenced elements to right of ->
147324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedTokenLabels,
148324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedTokenListLabels,
149324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedRuleLabels,
150324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedRuleListLabels,
151324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedWildcardLabels,
152324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedWildcardListLabels,
153324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	rewriteBlockLevel, enclosingTreeLevel, treeLevel) ::=
154324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<<
155324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
156324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// AST REWRITE
157324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// elements: <referencedElementsDeep; separator=", ">
158324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// token labels: <referencedTokenLabels; separator=", ">
159324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// rule labels: <referencedRuleLabels; separator=", ">
160324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// token list labels: <referencedTokenListLabels; separator=", ">
161324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// rule list labels: <referencedRuleListLabels; separator=", ">
162324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// wildcard labels: <[referencedWildcardLabels,referencedWildcardListLabels]; separator=", ">
163324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(backtracking)>
164324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverif ( <actions.(actionScope).synpredgate> ) {<\n>
165324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
166324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<prevRuleRootRef()>.tree = root_0;
167324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<rewriteCodeLabels()>
168324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_0 = (<ASTLabelType>)adaptor.nil();
169324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<alts:rewriteAlt(); separator="else ">
170324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<! if tree parser and rewrite=true !>
171324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(TREE_PARSER)>
172324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(rewriteMode)>
173324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<prevRuleRootRef()>.tree = (<ASTLabelType>)adaptor.rulePostProcessing(root_0);
174324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverinput.replaceChildren(adaptor.getParent(retval.start),
175324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver                      adaptor.getChildIndex(retval.start),
176324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver                      adaptor.getChildIndex(_last),
177324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver                      retval.tree);
178324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
179324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
180324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<! if parser or tree-parser && rewrite!=true, we need to set result !>
181324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(!TREE_PARSER)>
182324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<prevRuleRootRef()>.tree = root_0;
183324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<else>
184324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(!rewriteMode)>
185324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<prevRuleRootRef()>.tree = root_0;
186324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
187324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
188324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(backtracking)>
189324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
190324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
191324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
192324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
193324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteCodeLabels() ::= <<
194324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedTokenLabels
195324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRule<rewriteElementType>Stream stream_<it>=new RewriteRule<rewriteElementType>Stream(adaptor,"token <it>",<it>);};
196324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    separator="\n"
197324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>
198324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedTokenListLabels
199324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRule<rewriteElementType>Stream stream_<it>=new RewriteRule<rewriteElementType>Stream(adaptor,"token <it>", list_<it>);};
200324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    separator="\n"
201324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>
202324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedWildcardLabels
203324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRuleSubtreeStream stream_<it>=new RewriteRuleSubtreeStream(adaptor,"wildcard <it>",<it>);};
204324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    separator="\n"
205324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>
206324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedWildcardListLabels
207324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRuleSubtreeStream stream_<it>=new RewriteRuleSubtreeStream(adaptor,"wildcard <it>",list_<it>);};
208324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    separator="\n"
209324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>
210324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedRuleLabels
211324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRuleSubtreeStream stream_<it>=new RewriteRuleSubtreeStream(adaptor,"rule <it>",<it>!=null?<it>.tree:null);};
212324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    separator="\n"
213324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>
214324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedRuleListLabels
215324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    :{it | RewriteRuleSubtreeStream stream_<it>=new RewriteRuleSubtreeStream(adaptor,"token <it>",list_<it>);};
216324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    separator="\n"
217324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>
218324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
219324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
220324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Generate code for an optional rewrite block; note it uses the deep ref'd element
221324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver  *  list rather shallow like other blocks.
222324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver  */
223324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteOptionalBlock(
224324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	alt,rewriteBlockLevel,
225324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElementsDeep, // all nested refs
226324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElements, // elements in immediately block; no nested blocks
227324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	description) ::=
228324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<<
229324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// <fileName>:<description>
230324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverif ( <referencedElementsDeep:{el | stream_<el>.hasNext()}; separator="||"> ) {
231324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    <alt>
232324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
233324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedElementsDeep:{el | stream_<el>.reset();<\n>}>
234324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
235324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
236324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteClosureBlock(
237324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	alt,rewriteBlockLevel,
238324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElementsDeep, // all nested refs
239324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElements, // elements in immediately block; no nested blocks
240324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	description) ::=
241324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<<
242324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// <fileName>:<description>
243324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverwhile ( <referencedElements:{el | stream_<el>.hasNext()}; separator="||"> ) {
244324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    <alt>
245324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
246324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedElements:{el | stream_<el>.reset();<\n>}>
247324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
248324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
249324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewritePositiveClosureBlock(
250324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	alt,rewriteBlockLevel,
251324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElementsDeep, // all nested refs
252324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	referencedElements, // elements in immediately block; no nested blocks
253324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	description) ::=
254324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<<
255324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverif ( !(<referencedElements:{el | stream_<el>.hasNext()}; separator="||">) ) {
256324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    throw new RewriteEarlyExitException();
257324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
258324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverwhile ( <referencedElements:{el | stream_<el>.hasNext()}; separator="||"> ) {
259324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    <alt>
260324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
261324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<referencedElements:{el | stream_<el>.reset();<\n>}>
262324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
263324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
264324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteAlt(a) ::= <<
265324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// <a.description>
266324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(a.pred)>
267324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverif (<a.pred>) {
268324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    <a.alt>
269324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}<\n>
270324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<else>
271324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver{
272324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    <a.alt>
273324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}<\n>
274324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
275324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
276324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
277324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** For empty rewrites: "r : ... -> ;" */
278324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteEmptyAlt() ::= "root_0 = null;"
279324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
280324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTree(root,children,description,enclosingTreeLevel,treeLevel) ::= <<
281324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver// <fileName>:<description>
282324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver{
283324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<ASTLabelType> root_<treeLevel> = (<ASTLabelType>)adaptor.nil();
284324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<root:rewriteElement()>
285324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<children:rewriteElement()>
286324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<enclosingTreeLevel>, root_<treeLevel>);
287324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}<\n>
288324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
289324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
290324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteElementList(elements) ::= "<elements:rewriteElement()>"
291324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
292324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteElement(e) ::= <<
293324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<@pregen()>
294324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<e.el>
295324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
296324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
297324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen ID or ID[args] */
298324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTokenRef(token,elementIndex,terminalOptions,args) ::= <<
299324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, <createRewriteNodeFromElement(...)>);<\n>
300324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
301324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
302324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen $label ... where defined via label=ID */
303324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTokenLabelRef(label,elementIndex) ::= <<
304324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, stream_<label>.nextNode());<\n>
305324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
306324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
307324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen $label ... where defined via label+=ID */
308324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTokenListLabelRef(label,elementIndex) ::= <<
309324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, stream_<label>.nextNode());<\n>
310324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
311324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
312324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen ^($label ...) */
313324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTokenLabelRefRoot(label,elementIndex) ::= <<
314324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(stream_<label>.nextNode(), root_<treeLevel>);<\n>
315324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
316324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
317324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen ^($label ...) where label+=... */
318324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTokenListLabelRefRoot ::= rewriteTokenLabelRefRoot
319324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
320324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen ^(ID ...) or ^(ID[args] ...) */
321324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteTokenRefRoot(token,elementIndex,terminalOptions,args) ::= <<
322324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(<createRewriteNodeFromElement(...)>, root_<treeLevel>);<\n>
323324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
324324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
325324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteImaginaryTokenRef(args,token,terminalOptions,elementIndex) ::= <<
326324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, <createImaginaryNode(token,terminalOptions,args)>);<\n>
327324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
328324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
329324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteImaginaryTokenRefRoot(args,token,terminalOptions,elementIndex) ::= <<
330324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(<createImaginaryNode(token,terminalOptions,args)>, root_<treeLevel>);<\n>
331324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
332324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
333324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** plain -> {foo} action */
334324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteAction(action) ::= <<
335324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_0 = <action>;<\n>
336324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
337324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
338324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** What is the name of the previous value of this rule's root tree?  This
339324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  let's us refer to $rule to mean previous value.  I am reusing the
340324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  variable 'tree' sitting in retval struct to hold the value of root_0 right
341324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *  before I set it during rewrites.  The assign will be to retval.tree.
342324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver */
343324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverprevRuleRootRef() ::= "retval"
344324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
345324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteRuleRef(rule) ::= <<
346324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, stream_<rule>.nextTree());<\n>
347324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
348324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
349324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteRuleRefRoot(rule) ::= <<
350324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(stream_<rule>.nextNode(), root_<treeLevel>);<\n>
351324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
352324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
353324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteNodeAction(action) ::= <<
354324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, <action>);<\n>
355324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
356324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
357324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteNodeActionRoot(action) ::= <<
358324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(<action>, root_<treeLevel>);<\n>
359324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
360324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
361324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen $ruleLabel ... where defined via ruleLabel=rule */
362324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteRuleLabelRef(label) ::= <<
363324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, stream_<label>.nextTree());<\n>
364324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
365324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
366324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen $ruleLabel ... where defined via ruleLabel+=rule */
367324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteRuleListLabelRef(label) ::= <<
368324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, stream_<label>.nextTree());<\n>
369324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
370324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
371324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen ^($ruleLabel ...) where ruleLabel=rule */
372324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteRuleLabelRefRoot(label) ::= <<
373324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(stream_<label>.nextNode(), root_<treeLevel>);<\n>
374324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
375324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
376324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/** Gen ^($ruleLabel ...) where ruleLabel+=rule */
377324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteRuleListLabelRefRoot(label) ::= <<
378324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverroot_<treeLevel> = (<ASTLabelType>)adaptor.becomeRoot(stream_<label>.nextNode(), root_<treeLevel>);<\n>
379324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
380324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
381324c4644fee44b9898524c09511bd33c3f12e2dfBen GruverrewriteWildcardLabelRef(label) ::= <<
382324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.addChild(root_<treeLevel>, stream_<label>.nextTree());<\n>
383324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
384324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
385324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
386324c4644fee44b9898524c09511bd33c3f12e2dfBen GruvercreateImaginaryNode(tokenType,terminalOptions,args) ::= <<
387324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(terminalOptions.node)>
388324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<! new MethodNode(IDLabel, args) !>
389324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruvernew <terminalOptions.node>(<tokenType><if(args)>, <args; separator=", "><endif>)
390324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<else>
391324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver(<ASTLabelType>)adaptor.create(<tokenType>, <args; separator=", "><if(!args)>"<tokenType>"<endif>)
392324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
393324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
394324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
395324c4644fee44b9898524c09511bd33c3f12e2dfBen GruvercreateRewriteNodeFromElement(token,terminalOptions,args) ::= <<
396324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(terminalOptions.node)>
397324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruvernew <terminalOptions.node>(stream_<token>.nextToken()<if(args)>, <args; separator=", "><endif>)
398324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<else>
399324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<if(args)> <! must create new node from old !>
400324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruveradaptor.create(<token>, <args; separator=", ">)
401324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<else>
402324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverstream_<token>.nextNode()
403324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
404324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver<endif>
405324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver>>
406