2017-02-14 15:49:54 -08:00
|
|
|
options {
|
2017-02-14 14:31:07 -08:00
|
|
|
USER_CHAR_STREAM = true;
|
|
|
|
NODE_USES_PARSER=true;
|
|
|
|
UNICODE_INPUT=true;
|
2017-02-14 15:49:54 -08:00
|
|
|
FORCE_LA_CHECK = false;
|
|
|
|
IGNORE_CASE = true;
|
|
|
|
STATIC = false;
|
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
MULTI=true;
|
|
|
|
VISITOR=true;
|
|
|
|
TRACK_TOKENS = true;
|
2017-02-14 15:49:54 -08:00
|
|
|
}
|
2017-02-14 14:31:07 -08:00
|
|
|
|
|
|
|
PARSER_BEGIN(VfParser)
|
|
|
|
package net.sourceforge.pmd.lang.vf.ast;
|
|
|
|
|
|
|
|
import net.sourceforge.pmd.lang.ast.CharStream;
|
|
|
|
import net.sourceforge.pmd.lang.ast.TokenMgrError;
|
|
|
|
|
|
|
|
public class VfParser {
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Counter used to keep track of unclosed tags
|
|
|
|
*/
|
|
|
|
private OpenTagRegister tagRegister = new OpenTagRegister();
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
/**
|
|
|
|
* Return the contents of a quote.
|
|
|
|
* @param quote String - starting and ending with " or '
|
|
|
|
* @return String a substring of quote: quote without the first and list
|
|
|
|
* character.
|
|
|
|
*/
|
|
|
|
private static String quoteContent(String quote) {
|
|
|
|
return quote.substring(1, quote.length()-1);
|
|
|
|
}
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
/**
|
|
|
|
* Return the contents of a EL expression.
|
|
|
|
* @param expression String - starting with ${ or #{ and ending with }
|
|
|
|
* @return String a substring of expression: expression without the first two and list
|
|
|
|
* characters.
|
|
|
|
*/
|
|
|
|
private static String expressionContent(String expression) {
|
|
|
|
return expression.substring(2, expression.length()-1).trim();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
PARSER_END(VfParser)
|
|
|
|
|
2017-02-14 15:49:54 -08:00
|
|
|
/** ************************* VF LEXICON **************************** */
|
2017-02-14 14:31:07 -08:00
|
|
|
|
|
|
|
<*> TOKEN :
|
|
|
|
{
|
|
|
|
<#ALPHA_CHAR: [
|
|
|
|
"\u0024",
|
|
|
|
"\u0041"-"\u005a",
|
|
|
|
"\u005f",
|
|
|
|
"\u0061"-"\u007a",
|
|
|
|
"\u00c0"-"\u00d6",
|
|
|
|
"\u00d8"-"\u00f6",
|
|
|
|
"\u00f8"-"\u00ff"
|
|
|
|
] >
|
|
|
|
| <#NUM_CHAR: [
|
|
|
|
"\u0030"-"\u0039"
|
|
|
|
] >
|
|
|
|
| <#ALPHANUM_CHAR: ( <ALPHA_CHAR> | <NUM_CHAR> ) >
|
|
|
|
| <#IDENTIFIER_CHAR: ( <ALPHANUM_CHAR> | [ "_", "-", ".", ":" ] ) >
|
|
|
|
| <#IDENTIFIER: <ALPHA_CHAR> (<IDENTIFIER_CHAR>)* >
|
|
|
|
| <#XMLNAME: (<ALPHA_CHAR> | "_" | ":") (<IDENTIFIER_CHAR>)* >
|
2017-02-14 15:49:54 -08:00
|
|
|
| <#QUOTED_STRING_NO_BREAKS: ( "'" ( ~["'", "\r", "\n"] )* "'" )
|
2017-02-14 14:31:07 -08:00
|
|
|
| ( "\"" ( ~["\"", "\r", "\n"] )* "\"" ) >
|
|
|
|
| <#QUOTED_STRING: ( "'" ( ~["'"] )* "'" ) | ( "\"" ( ~["\""] )* "\"" ) >
|
|
|
|
| <#WHITESPACE: ( " " | "\t" | "\n" | "\r" ) >
|
|
|
|
| <#NEWLINE: ( "\r\n" | "\r" | "\n" ) >
|
|
|
|
| <#QUOTE: ( "'" | "\"" )>
|
|
|
|
| <#NO_WHITESPACE_OR_LT_OR_DOLLAR: (~[" ", "\t", "\n", "\r", "<", "$", "#"])>
|
|
|
|
| <#NO_BANG: (~["!"])>
|
|
|
|
| <#OPENBRACE: ("{") >
|
|
|
|
| <#NO_LT_OR_OPENBRACE: (~["<","{"])>
|
|
|
|
| <#NO_ENDTAG_START: (~["<"]~["/"]) >
|
|
|
|
| <#TEXT_IN_EL: (~["}", "'", "\""])+ >
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
<DEFAULT> SKIP :
|
|
|
|
{
|
|
|
|
< (<WHITESPACE>)+ >
|
|
|
|
}
|
|
|
|
|
|
|
|
<AfterTagState, InTagState, HtmlScriptContentState> SPECIAL_TOKEN :
|
|
|
|
{
|
|
|
|
< (<WHITESPACE>)+ >
|
|
|
|
}
|
|
|
|
|
2017-02-14 15:49:54 -08:00
|
|
|
<DEFAULT, AfterTagState> TOKEN :
|
2017-02-14 14:31:07 -08:00
|
|
|
{
|
|
|
|
<TAG_START: "<" > : StartTagState
|
|
|
|
| <ENDTAG_START: "</" > : StartTagState
|
|
|
|
| <COMMENT_START: "<!--" > : CommentState
|
|
|
|
| <DECL_START: "<?" > : StartTagState
|
|
|
|
| <DOCTYPE_DECL_START: "<!DOCTYPE" > : DocTypeState
|
|
|
|
| <CDATA_START: "<![CDATA[" > : CDataState
|
|
|
|
| <HTML_SCRIPT_START: "<script" > : InTagState
|
|
|
|
}
|
|
|
|
|
|
|
|
<AfterTagState> TOKEN :
|
2017-02-14 15:49:54 -08:00
|
|
|
{
|
2017-02-14 14:31:07 -08:00
|
|
|
<EL_EXPRESSION: ( "{!" (<QUOTED_STRING> | <TEXT_IN_EL>)* "}" ) >
|
|
|
|
| <UNPARSED_TEXT: ( <NO_LT_OR_OPENBRACE>|<OPENBRACE><NO_BANG>)+ >
|
|
|
|
}
|
|
|
|
|
2017-02-14 15:49:54 -08:00
|
|
|
<DocTypeState, DocTypeExternalIdState> TOKEN :
|
2017-02-14 14:31:07 -08:00
|
|
|
{
|
|
|
|
<WHITESPACES: (<WHITESPACE>)+ >
|
|
|
|
}
|
|
|
|
|
|
|
|
<DocTypeState> TOKEN:
|
|
|
|
{
|
|
|
|
<NAME: (<XMLNAME>) > : DocTypeExternalIdState
|
|
|
|
}
|
|
|
|
|
|
|
|
<DocTypeExternalIdState> TOKEN:
|
|
|
|
{
|
|
|
|
<PUBLIC: "PUBLIC">
|
|
|
|
| <SYSTEM: "SYSTEM">
|
|
|
|
| <DOCTYPE_DECL_END: ">" > : AfterTagState
|
|
|
|
| <QUOTED_LITERAL: (<QUOTED_STRING>) >
|
|
|
|
}
|
|
|
|
|
|
|
|
<CDataState> TOKEN :
|
|
|
|
{
|
|
|
|
<UNPARSED: (~[]) >
|
|
|
|
| <CDATA_END: ("]]>") > : AfterTagState
|
|
|
|
}
|
|
|
|
|
|
|
|
<StartTagState> TOKEN :
|
|
|
|
{
|
|
|
|
<TAG_NAME: <IDENTIFIER> > : InTagState
|
|
|
|
| <LST_ERROR: ~[]> : DEFAULT
|
|
|
|
}
|
|
|
|
|
|
|
|
<InTagState> TOKEN :
|
|
|
|
{
|
|
|
|
<ATTR_NAME: <IDENTIFIER> >
|
|
|
|
| <TAG_END: ">" > : AfterTagState
|
|
|
|
| <DECL_END: ("?>" | "!>") > : AfterTagState
|
|
|
|
| <TAG_SLASHEND: "/>" > : AfterTagState
|
|
|
|
| <ATTR_EQ: "=" > : AttrValueState
|
2017-02-15 11:48:08 -08:00
|
|
|
| <IN_TAG_ERROR: ~[] >
|
2017-02-14 14:31:07 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
<AttrValueState> TOKEN :
|
|
|
|
{
|
|
|
|
<SINGLE_QUOTE: "'"> : AttrValueBetweenSingleQuotesState
|
|
|
|
| <DOUBLE_QUOTE: "\""> : AttrValueBetweenDoubleQuotesState
|
|
|
|
| <NO_QUOTE_NO_WHITESPACE: ~["\"","'"," "] > { input_stream.backup(1);} : AttrValueNoQuotesState
|
|
|
|
| <IN_ATTR_WHITESPACE: [" "] > : InTagState //support for empty attributes
|
|
|
|
}
|
|
|
|
|
2017-02-15 11:48:08 -08:00
|
|
|
<AttrValueBetweenSingleQuotesState, AttrValueBetweenDoubleQuotesState, AttrValueNoQuotesState> TOKEN:
|
2017-02-14 14:31:07 -08:00
|
|
|
{
|
|
|
|
<EL_EXPRESSION_IN_ATTRIBUTE: "{!" (<QUOTED_STRING> | <TEXT_IN_EL>)* "}" >
|
|
|
|
}
|
|
|
|
|
|
|
|
<AttrValueNoQuotesState> TOKEN :
|
|
|
|
{
|
|
|
|
<ENDING_WHITESPACE: " " >: InTagState
|
|
|
|
| <UNPARSED_TEXT_NO_WHITESPACE: ( ~["$", "#", " "] |(["$", "#"] ~["{"]) )+ >
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
<AttrValueBetweenSingleQuotesState> TOKEN :
|
|
|
|
{
|
|
|
|
<ENDING_SINGLE_QUOTE: "'"> : InTagState
|
2017-02-14 15:49:54 -08:00
|
|
|
| <UNPARSED_TEXT_NO_SINGLE_QUOTES:
|
2017-02-15 11:53:31 -08:00
|
|
|
( (~["{", "'"]) | (["{"] ~["!", "'"]) )+ >
|
2017-02-14 14:31:07 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
<AttrValueBetweenDoubleQuotesState> TOKEN :
|
|
|
|
{
|
|
|
|
<ENDING_DOUBLE_QUOTE: "\""> : InTagState
|
2017-02-14 15:49:54 -08:00
|
|
|
| <UNPARSED_TEXT_NO_DOUBLE_QUOTES:
|
2017-02-15 11:53:31 -08:00
|
|
|
( (~["{", "\""]) | (["{"] ~["!", "\""]) )+ >
|
2017-02-14 14:31:07 -08:00
|
|
|
}
|
|
|
|
|
2017-02-14 15:49:54 -08:00
|
|
|
<CommentState> TOKEN :
|
2017-02-14 14:31:07 -08:00
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
< COMMENT_END: ("--" (" ")* ">" | "->") > : AfterTagState
|
2017-02-14 14:31:07 -08:00
|
|
|
| < COMMENT_TEXT: (~[]) >
|
|
|
|
}
|
|
|
|
|
|
|
|
<HtmlScriptContentState> TOKEN :
|
|
|
|
{
|
|
|
|
<HTML_SCRIPT_CONTENT: (~[]) >
|
2017-02-14 15:49:54 -08:00
|
|
|
| <HTML_SCRIPT_END_TAG : "</script>" | "</Script>" | "</SCRIPT>"> : AfterTagState
|
2017-02-14 14:31:07 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/** ************************* VF GRAMMAR **************************** */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The root of the AST of a VF.
|
|
|
|
*/
|
|
|
|
ASTCompilationUnit CompilationUnit() :
|
|
|
|
{}
|
|
|
|
{
|
|
|
|
Prolog()
|
2017-02-14 15:49:54 -08:00
|
|
|
|
|
|
|
Content() <EOF>
|
2017-02-14 14:31:07 -08:00
|
|
|
{ return jjtThis; }
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The optional prolog of a VF, including (xml) declarations and DTD.
|
|
|
|
*/
|
|
|
|
void Prolog() #void :
|
|
|
|
{}
|
|
|
|
{
|
|
|
|
(
|
|
|
|
LOOKAHEAD( ( CommentTag() )* Declaration() )
|
|
|
|
( CommentTag() )*
|
|
|
|
Declaration()
|
|
|
|
)?
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
(
|
|
|
|
LOOKAHEAD( ( CommentTag() )* DoctypeDeclaration() )
|
|
|
|
( CommentTag() )*
|
|
|
|
DoctypeDeclaration()
|
|
|
|
)?
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Everything between a start-tag and the corresponding end-tag of an element (if an end tag exists).
|
|
|
|
*/
|
2017-02-14 15:49:54 -08:00
|
|
|
void Content() #void :
|
2017-02-14 14:31:07 -08:00
|
|
|
{}
|
2017-02-14 15:49:54 -08:00
|
|
|
{
|
2017-02-14 14:31:07 -08:00
|
|
|
( Text() | ContentElement() )*
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A single (non-text) element that can occur between a start-tag and end-tag of an element.
|
2017-02-14 15:49:54 -08:00
|
|
|
*
|
2017-02-14 14:31:07 -08:00
|
|
|
*/
|
|
|
|
void ContentElement() #void :
|
|
|
|
{}
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
(
|
|
|
|
CommentTag()
|
|
|
|
| Element()
|
|
|
|
| CData()
|
|
|
|
| HtmlScript()
|
2017-02-14 14:31:07 -08:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This production groups all characters between two tags, where
|
|
|
|
* tag is an xml-tag "<...>" or CDATA "<![CDATA[...]]>".
|
|
|
|
* Text consists of unparsed text and/or Expression Language expressions.
|
|
|
|
*/
|
|
|
|
void Text() :
|
|
|
|
{
|
|
|
|
StringBuffer content = new StringBuffer();
|
|
|
|
String tmp;
|
|
|
|
}
|
2017-02-14 15:49:54 -08:00
|
|
|
{
|
|
|
|
(
|
2017-02-14 14:31:07 -08:00
|
|
|
tmp = UnparsedText() { content.append(tmp); }
|
|
|
|
| tmp = ElExpression() { content.append(tmp); }
|
|
|
|
)+
|
|
|
|
{jjtThis.setImage(content.toString());}
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
String UnparsedText() :
|
|
|
|
{ Token t; }
|
2017-02-14 15:49:54 -08:00
|
|
|
{
|
|
|
|
t = <UNPARSED_TEXT>
|
2017-02-14 14:31:07 -08:00
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
jjtThis.setImage(t.image);
|
2017-02-14 14:31:07 -08:00
|
|
|
return t.image;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
String UnparsedTextNoWhitespace() #UnparsedText :
|
|
|
|
{ Token t;}
|
|
|
|
{
|
|
|
|
(
|
|
|
|
t = <UNPARSED_TEXT_NO_WHITESPACE>
|
|
|
|
)
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
jjtThis.setImage(t.image);
|
2017-02-14 14:31:07 -08:00
|
|
|
return t.image;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Text that contains no single quotes, and that does not contain the start
|
|
|
|
* of a EL expression.
|
|
|
|
*/
|
2017-02-14 15:49:54 -08:00
|
|
|
String UnparsedTextNoSingleQuotes() #UnparsedText :
|
2017-02-14 14:31:07 -08:00
|
|
|
{ Token t; }
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
t = <UNPARSED_TEXT_NO_SINGLE_QUOTES>
|
|
|
|
{
|
|
|
|
jjtThis.setImage(t.image);
|
2017-02-14 14:31:07 -08:00
|
|
|
return t.image;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Text that contains no double quotes, and that does not contain the start
|
|
|
|
* of a EL expression.
|
|
|
|
*/
|
2017-02-14 15:49:54 -08:00
|
|
|
String UnparsedTextNoDoubleQuotes() #UnparsedText :
|
2017-02-14 14:31:07 -08:00
|
|
|
{ Token t; }
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
t = <UNPARSED_TEXT_NO_DOUBLE_QUOTES>
|
|
|
|
{
|
|
|
|
jjtThis.setImage(t.image);
|
2017-02-14 14:31:07 -08:00
|
|
|
return t.image;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An EL expression, not within an attribute value.
|
|
|
|
*/
|
|
|
|
String ElExpression() :
|
|
|
|
{ Token t; }
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
t = <EL_EXPRESSION>
|
|
|
|
{
|
|
|
|
jjtThis.setImage(expressionContent(t.image));
|
2017-02-14 14:31:07 -08:00
|
|
|
return t.image;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
String ElExpressionInAttribute() #ElExpression :
|
|
|
|
{ Token t; }
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
t = <EL_EXPRESSION_IN_ATTRIBUTE>
|
|
|
|
{
|
|
|
|
jjtThis.setImage(expressionContent(t.image));
|
2017-02-14 14:31:07 -08:00
|
|
|
return t.image;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CData() :
|
|
|
|
{
|
|
|
|
StringBuffer content = new StringBuffer();
|
|
|
|
Token t;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
<CDATA_START> ( t = <UNPARSED> { content.append(t.image); } )* <CDATA_END>
|
|
|
|
{
|
|
|
|
jjtThis.setImage(content.toString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A XML element, either with a single empty tag, or with a starting and closing tag
|
|
|
|
* with optional contained content.
|
|
|
|
*/
|
2017-02-14 15:49:54 -08:00
|
|
|
void Element() :
|
2017-02-14 14:31:07 -08:00
|
|
|
{
|
|
|
|
Token startTag;
|
|
|
|
Token endTag;
|
|
|
|
String tagName;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
(
|
|
|
|
(
|
2017-02-14 15:49:54 -08:00
|
|
|
<TAG_START>
|
2017-02-14 14:31:07 -08:00
|
|
|
startTag = <TAG_NAME> { tagName = startTag.image;
|
|
|
|
jjtThis.setName(tagName);
|
|
|
|
tagRegister.openTag(jjtThis);
|
|
|
|
}
|
|
|
|
)
|
|
|
|
(Attribute())*
|
2017-02-14 15:49:54 -08:00
|
|
|
(
|
2017-02-14 14:31:07 -08:00
|
|
|
(
|
|
|
|
<TAG_END>{ jjtThis.setEmpty(false);}
|
|
|
|
|
|
|
|
(Content())
|
2017-02-14 15:49:54 -08:00
|
|
|
|
|
|
|
(<ENDTAG_START>
|
2017-02-14 14:31:07 -08:00
|
|
|
endTag = <TAG_NAME> {tagRegister.closeTag(endTag.image);}
|
|
|
|
<TAG_END>)?
|
|
|
|
)
|
2017-02-14 15:49:54 -08:00
|
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
(<TAG_SLASHEND> { jjtThis.setEmpty(true);
|
|
|
|
jjtThis.setUnclosed(false);
|
|
|
|
}
|
2017-02-14 15:49:54 -08:00
|
|
|
)
|
2017-02-14 14:31:07 -08:00
|
|
|
)
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-02-14 15:49:54 -08:00
|
|
|
void Attribute() :
|
2017-02-14 14:31:07 -08:00
|
|
|
{ Token t; }
|
|
|
|
{
|
|
|
|
t = <ATTR_NAME> { jjtThis.setName(t.image); }
|
|
|
|
(
|
2017-02-14 15:49:54 -08:00
|
|
|
<ATTR_EQ>
|
2017-02-14 14:31:07 -08:00
|
|
|
AttributeValue()
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The value of an attribute of an element.
|
|
|
|
* EL expressions
|
|
|
|
* are parsed as sub-nodes of the AttributeValue node.
|
|
|
|
*/
|
2017-02-15 11:48:08 -08:00
|
|
|
void AttributeValue() :
|
|
|
|
{
|
|
|
|
StringBuffer content = new StringBuffer();
|
|
|
|
String tmp;
|
|
|
|
Token t = null ;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
(
|
|
|
|
( <DOUBLE_QUOTE>
|
|
|
|
( ( tmp = UnparsedTextNoDoubleQuotes()
|
|
|
|
| tmp = QuoteIndependentAttributeValueContent()
|
|
|
|
) { content.append(tmp); } )*
|
|
|
|
( <ENDING_DOUBLE_QUOTE> )
|
|
|
|
)
|
|
|
|
|
|
|
|
|
( <SINGLE_QUOTE>
|
|
|
|
( ( tmp = UnparsedTextNoSingleQuotes() | tmp = QuoteIndependentAttributeValueContent() )
|
|
|
|
{ content.append(tmp); } )*
|
|
|
|
( <ENDING_SINGLE_QUOTE> )
|
|
|
|
)
|
|
|
|
|
|
|
|
|
( <NO_QUOTE_NO_WHITESPACE>
|
|
|
|
( ( tmp = UnparsedTextNoWhitespace() | tmp = QuoteIndependentAttributeValueContent() )
|
|
|
|
{ content.append(tmp); }
|
|
|
|
)*
|
|
|
|
( <ENDING_WHITESPACE> )
|
|
|
|
)
|
|
|
|
| <IN_ATTR_WHITESPACE>
|
|
|
|
)
|
|
|
|
{ jjtThis.setImage( content.toString() );
|
|
|
|
}
|
|
|
|
}
|
2017-02-14 14:31:07 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Partial content of an attribute value that can contain all quotes.
|
|
|
|
* This groups EL expressions.
|
|
|
|
*/
|
|
|
|
String QuoteIndependentAttributeValueContent() #void :
|
|
|
|
{ String tmp; }
|
|
|
|
{
|
|
|
|
( tmp = ElExpressionInAttribute()
|
|
|
|
)
|
|
|
|
{ return tmp; }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CommentTag() :
|
|
|
|
{
|
|
|
|
StringBuffer content = new StringBuffer();
|
|
|
|
Token t;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
<COMMENT_START>
|
2017-02-14 15:49:54 -08:00
|
|
|
( t = <COMMENT_TEXT> { content.append(t.image); } )*
|
2017-02-14 14:31:07 -08:00
|
|
|
<COMMENT_END>
|
|
|
|
{
|
|
|
|
jjtThis.setImage(content.toString().trim());
|
|
|
|
}
|
|
|
|
}
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
void Declaration() :
|
|
|
|
{ Token t; }
|
|
|
|
{
|
2017-02-14 15:49:54 -08:00
|
|
|
<DECL_START>
|
2017-02-14 14:31:07 -08:00
|
|
|
t = <TAG_NAME> { jjtThis.setName(t.image); }
|
2017-02-14 15:49:54 -08:00
|
|
|
(Attribute())*
|
2017-02-14 14:31:07 -08:00
|
|
|
<DECL_END>
|
|
|
|
}
|
|
|
|
|
|
|
|
void DoctypeDeclaration() :
|
|
|
|
{ Token t; }
|
|
|
|
{
|
|
|
|
<DOCTYPE_DECL_START>
|
|
|
|
<WHITESPACES>
|
|
|
|
t = <NAME> { jjtThis.setName(t.image); }
|
|
|
|
(<WHITESPACES>)?
|
2017-02-14 15:49:54 -08:00
|
|
|
(DoctypeExternalId() (<WHITESPACES>)?)?
|
2017-02-14 14:31:07 -08:00
|
|
|
<DOCTYPE_DECL_END>
|
|
|
|
}
|
|
|
|
|
|
|
|
void DoctypeExternalId() :
|
|
|
|
{
|
|
|
|
Token systemLiteral;
|
|
|
|
Token pubIdLiteral;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
( <SYSTEM>
|
2017-02-14 15:49:54 -08:00
|
|
|
<WHITESPACES>
|
|
|
|
systemLiteral = <QUOTED_LITERAL>
|
2017-02-14 14:31:07 -08:00
|
|
|
{ jjtThis.setUri(quoteContent(systemLiteral.image)); }
|
|
|
|
)
|
2017-02-14 15:49:54 -08:00
|
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
( <PUBLIC>
|
2017-02-14 15:49:54 -08:00
|
|
|
<WHITESPACES>
|
|
|
|
pubIdLiteral = <QUOTED_LITERAL>
|
2017-02-14 14:31:07 -08:00
|
|
|
{ jjtThis.setPublicId(quoteContent(pubIdLiteral.image)); }
|
2017-02-14 15:49:54 -08:00
|
|
|
<WHITESPACES>
|
|
|
|
systemLiteral = <QUOTED_LITERAL>
|
2017-02-14 14:31:07 -08:00
|
|
|
{ jjtThis.setUri(quoteContent(systemLiteral.image)); }
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
void HtmlScript() :
|
|
|
|
{
|
|
|
|
StringBuffer content = new StringBuffer();
|
|
|
|
String tagName;
|
|
|
|
Token t;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
<HTML_SCRIPT_START> {}
|
|
|
|
(Attribute() )* {}
|
|
|
|
(
|
|
|
|
(
|
|
|
|
<TAG_END> {token_source.SwitchTo(HtmlScriptContentState);}
|
|
|
|
(t = <HTML_SCRIPT_CONTENT> { content.append(t.image); })*
|
|
|
|
<HTML_SCRIPT_END_TAG> { jjtThis.setImage(content.toString().trim());}
|
2017-02-14 15:49:54 -08:00
|
|
|
|
2017-02-14 14:31:07 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
(
|
|
|
|
<TAG_SLASHEND>
|
|
|
|
)
|
2017-02-14 15:49:54 -08:00
|
|
|
)
|
2017-02-14 14:31:07 -08:00
|
|
|
}
|