Class JavaScriptTarget


  • public class JavaScriptTarget
    extends Target
    • 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: Target
        ANTLR 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:
        getVersion in class Target
      • 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: Target
        Assume 16-bit char
        Overrides:
        encodeIntAsCharEscape in class Target
      • getSerializedATNSegmentLimit

        public int getSerializedATNSegmentLimit()
        Description copied from class: Target
        Gets the maximum number of 16-bit unsigned integers that can be encoded in a single segment of the serialized ATN.
        Overrides:
        getSerializedATNSegmentLimit in class Target
        Returns:
        the serialized ATN segment limit
        See Also:
        SerializedATN.getSegments()
      • getInlineTestSetWordSize

        public int getInlineTestSetWordSize()
        Description copied from class: Target
        How 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:
        getInlineTestSetWordSize in class Target
      • loadTemplates

        protected org.stringtemplate.v4.STGroup loadTemplates()
        Overrides:
        loadTemplates in class Target
      • appendUnicodeEscapedCodePoint

        protected void appendUnicodeEscapedCodePoint​(int codePoint,
                                                     java.lang.StringBuilder sb)
        Description copied from class: Target
        Escape the Unicode code point appropriately for this language and append the escaped value to sb.
        Specified by:
        appendUnicodeEscapedCodePoint in class Target