Package org.antlr.v4.codegen.target
Class JavaScriptTarget
- java.lang.Object
-
- org.antlr.v4.codegen.Target
-
- org.antlr.v4.codegen.target.JavaScriptTarget
-
public class JavaScriptTarget extends Target
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description protected static classJavaScriptTarget.JavaStringRenderer
-
Field Summary
Fields Modifier and Type Field Description protected java.util.Set<java.lang.String>badWordsAvoid grammar symbols in this set to prevent conflicts in gen'd code.protected static java.lang.String[]javaScriptKeywordsSource: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar-
Fields inherited from class org.antlr.v4.codegen.Target
gen, targetCharValueEscape
-
-
Constructor Summary
Constructors Constructor Description JavaScriptTarget(CodeGenerator gen)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidaddBadWords()protected voidappendUnicodeEscapedCodePoint(int codePoint, java.lang.StringBuilder sb)Escape the Unicode code point appropriately for this language and append the escaped value tosb.java.lang.StringencodeIntAsCharEscape(int v)Assume 16-bit charjava.util.Set<java.lang.String>getBadWords()intgetInlineTestSetWordSize()How many bits should be used to do inline token type tests? Java assumes a 64-bit word for bitsets.intgetSerializedATNSegmentLimit()Gets the maximum number of 16-bit unsigned integers that can be encoded in a single segment of the serialized ATN.java.lang.StringgetVersion()ANTLR tool should check output templates / target are compatible with tool code generation.protected org.stringtemplate.v4.STGrouploadTemplates()booleansupportsOverloadedMethods()protected booleanvisibleGrammarSymbolCausesIssueInGeneratedCode(GrammarAST idNode)booleanwantsBaseListener()booleanwantsBaseVisitor()-
Methods inherited from class org.antlr.v4.codegen.Target
genFile, getAltLabelContextStructName, getBaseListenerFileName, getBaseVisitorFileName, getCodeGenerator, getElementListName, getElementName, getImplicitRuleLabel, getImplicitSetLabel, getImplicitTokenLabel, getLanguage, getListenerFileName, getListLabel, getLoopCounter, getLoopLabel, getRecognizerFileName, getRuleFunctionContextStructName, getRuleFunctionContextStructName, getTargetStringLiteralFromANTLRStringLiteral, getTargetStringLiteralFromString, getTargetStringLiteralFromString, getTemplates, getTokenTypeAsTargetLabel, getTokenTypesAsTargetLabels, getVisitorFileName, grammarSymbolCausesIssueInGeneratedCode, needsHeader, shouldUseUnicodeEscapeForCodePointInDoubleQuotedString, templatesExist
-
-
-
-
Field Detail
-
javaScriptKeywords
protected static final java.lang.String[] javaScriptKeywords
Source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar
-
badWords
protected final java.util.Set<java.lang.String> badWords
Avoid grammar symbols in this set to prevent conflicts in gen'd code.
-
-
Constructor Detail
-
JavaScriptTarget
public JavaScriptTarget(CodeGenerator gen)
-
-
Method Detail
-
getVersion
public java.lang.String getVersion()
Description copied from class:TargetANTLR tool should check output templates / target are compatible with tool code generation. For now, a simple string match used on x.y of x.y.z scheme. We use a method to avoid mismatches between a template called VERSION. This value is checked against Tool.VERSION during load of templates. This additional method forces all targets 4.3 and beyond to add this method.- Specified by:
getVersionin classTarget
-
getBadWords
public java.util.Set<java.lang.String> getBadWords()
-
addBadWords
protected void addBadWords()
-
encodeIntAsCharEscape
public java.lang.String encodeIntAsCharEscape(int v)
Description copied from class:TargetAssume 16-bit char- Overrides:
encodeIntAsCharEscapein classTarget
-
getSerializedATNSegmentLimit
public int getSerializedATNSegmentLimit()
Description copied from class:TargetGets the maximum number of 16-bit unsigned integers that can be encoded in a single segment of the serialized ATN.- Overrides:
getSerializedATNSegmentLimitin classTarget- Returns:
- the serialized ATN segment limit
- See Also:
SerializedATN.getSegments()
-
getInlineTestSetWordSize
public int getInlineTestSetWordSize()
Description copied from class:TargetHow many bits should be used to do inline token type tests? Java assumes a 64-bit word for bitsets. Must be a valid wordsize for your target like 8, 16, 32, 64, etc...- Overrides:
getInlineTestSetWordSizein classTarget
-
visibleGrammarSymbolCausesIssueInGeneratedCode
protected boolean visibleGrammarSymbolCausesIssueInGeneratedCode(GrammarAST idNode)
- Specified by:
visibleGrammarSymbolCausesIssueInGeneratedCodein classTarget
-
loadTemplates
protected org.stringtemplate.v4.STGroup loadTemplates()
- Overrides:
loadTemplatesin classTarget
-
wantsBaseListener
public boolean wantsBaseListener()
- Overrides:
wantsBaseListenerin classTarget
-
wantsBaseVisitor
public boolean wantsBaseVisitor()
- Overrides:
wantsBaseVisitorin classTarget
-
supportsOverloadedMethods
public boolean supportsOverloadedMethods()
- Overrides:
supportsOverloadedMethodsin classTarget
-
appendUnicodeEscapedCodePoint
protected void appendUnicodeEscapedCodePoint(int codePoint, java.lang.StringBuilder sb)Description copied from class:TargetEscape the Unicode code point appropriately for this language and append the escaped value tosb.- Specified by:
appendUnicodeEscapedCodePointin classTarget
-
-