Package org.stringtemplate.v4

Examples of org.stringtemplate.v4.ST


    if (lexerAction != null) {
      return action(ID, lexerAction);
    }

    // fall back to standard action generation for the command
    ST cmdST = codegenTemplates.getInstanceOf("Lexer" +
                          CharSupport.capitalize(ID.getText())+
                          "Command");
    if (cmdST == null) {
      g.tool.errMgr.grammarError(ErrorType.INVALID_LEXER_COMMAND, g.fileName, ID.token, ID.getText());
      return epsilon(ID);
    }

    if (cmdST.impl.formalArguments == null || !cmdST.impl.formalArguments.containsKey("arg")) {
      g.tool.errMgr.grammarError(ErrorType.UNWANTED_LEXER_COMMAND_ARGUMENT, g.fileName, ID.token, ID.getText());
      return epsilon(ID);
    }

    cmdST.add("arg", arg.getText());
    return action(cmdST.render());
  }
View Full Code Here


    if (lexerAction != null) {
      return action(ID, lexerAction);
    }

    // fall back to standard action generation for the command
    ST cmdST = codegenTemplates.getInstanceOf("Lexer" +
                          CharSupport.capitalize(ID.getText())+
                          "Command");
    if (cmdST == null) {
      g.tool.errMgr.grammarError(ErrorType.INVALID_LEXER_COMMAND, g.fileName, ID.token, ID.getText());
      return epsilon(ID);
    }

    if (cmdST.impl.formalArguments != null && cmdST.impl.formalArguments.containsKey("arg")) {
      g.tool.errMgr.grammarError(ErrorType.MISSING_LEXER_COMMAND_ARGUMENT, g.fileName, ID.token, ID.getText());
      return epsilon(ID);
    }

    return action(cmdST.render());
  }
View Full Code Here

    // error information possible, but actually writing output files stops
    // after the first error is reported
    int errorCount = g.tool.errMgr.getNumErrors();

    if ( g.isLexer() ) {
      ST lexer = gen.generateLexer();
      if (g.tool.errMgr.getNumErrors() == errorCount) {
        writeRecognizer(lexer, gen);
      }
    }
    else {
      ST parser = gen.generateParser();
      if (g.tool.errMgr.getNumErrors() == errorCount) {
        writeRecognizer(parser, gen);
      }
      if ( g.tool.gen_listener ) {
        ST listener = gen.generateListener();
        if (g.tool.errMgr.getNumErrors() == errorCount) {
          gen.writeListener(listener);
        }
        if (gen.getTarget().wantsBaseListener()) {
          ST baseListener = gen.generateBaseListener();
          if (g.tool.errMgr.getNumErrors() == errorCount) {
            gen.writeBaseListener(baseListener);
          }
        }
      }
      if ( g.tool.gen_visitor ) {
        ST visitor = gen.generateVisitor();
        if (g.tool.errMgr.getNumErrors() == errorCount) {
          gen.writeVisitor(visitor);
        }
        if (gen.getTarget().wantsBaseVisitor()) {
          ST baseVisitor = gen.generateBaseVisitor();
          if (g.tool.errMgr.getNumErrors() == errorCount) {
            gen.writeBaseVisitor(baseVisitor);
          }
        }
      }
View Full Code Here

      column = offendingToken.getCharPositionInLine();
    }
    if ( g!=null ) {
      file = g.getFileName();
    }
    ST st = getMessageTemplate();
    if ( arg!=null ) {
      st.add("arg", arg);
    }
    if ( arg2!=null ) {
      st.add("arg2", arg2);
    }
    return super.toString(st);
  }
View Full Code Here

    String fileName = probe.dfa.nfa.grammar.getFileName();
    if ( fileName!=null ) {
      file = fileName;
    }

    ST st = getMessageTemplate();

    if ( probe.dfa.isTokensRuleDecision() ) {
      // alts are token rules, convert to the names instead of numbers
      for (int i = 0; i < alts.size(); i++) {
        Integer altI = alts.get(i);
        String tokenName =
          probe.getTokenNameForTokensRuleAlt(altI);
        // reset the line/col to the token definition
        NFAState ruleStart =
          probe.dfa.nfa.grammar.getRuleStartState(tokenName);
        line = ruleStart.associatedASTNode.getLine();
        column = ruleStart.associatedASTNode.getCharPositionInLine();
        st.add("tokens", tokenName);
      }
    }
    else {
      // regular alt numbers, show the alts
      st.add("alts", alts);
    }

    return super.toString(st);
  }
View Full Code Here

    if ( fileName!=null ) {
      file = fileName;
    }
    List<Label> labels = probe.getSampleNonDeterministicInputSequence(problemState);
    String input = probe.getInputSequenceDisplay(labels);
    ST st = getMessageTemplate();
    List<Integer> alts = new ArrayList<Integer>();
    alts.addAll(problemState.getAltSet());
    Collections.sort(alts);
    st.add("danglingAlts", alts);
    st.add("input", input);

    return super.toString(st);
  }
View Full Code Here

    column = decisionASTNode.getCharPositionInLine();
    String fileName = probe.dfa.nfa.grammar.getFileName();
    if ( fileName!=null ) {
      file = fileName;
    }
    ST st = getMessageTemplate();
    // convert to string key to avoid 3.1 ST bug
    Map<String, Set<Token>> altToLocationsWithStringKey = new LinkedHashMap<String, Set<Token>>();
    List<Integer> alts = new ArrayList<Integer>();
    alts.addAll(altToLocations.keySet());
    Collections.sort(alts);
    for (Integer altI : alts) {
      altToLocationsWithStringKey.put(altI.toString(), altToLocations.get(altI));
      /*
      List<String> tokens = new ArrayList<String>();
      for (Token t : altToLocations.get(altI)) {
        tokens.add(t.toString());
      }
      Collections.sort(tokens);
      System.out.println("tokens=\n"+tokens);
      */
    }
    st.add("altToLocations", altToLocationsWithStringKey);

    List<Label> sampleInputLabels = problemState.dfa.probe.getSampleNonDeterministicInputSequence(problemState);
    String input = problemState.dfa.probe.getInputSequenceDisplay(sampleInputLabels);
    st.add("upon", input);

    st.add("hasPredicateBlockedByAction", problemState.dfa.hasPredicateBlockedByAction);

    return super.toString(st);
  }
View Full Code Here

   'for'=8
   *
   *  This is independent of the target language; used by antlr internally
   */
  ST getTokenVocabOutput() {
    ST vocabFileST = new ST(vocabFilePattern);
    Map<String,Integer> tokens = new LinkedHashMap<String,Integer>();
    // make constants for the token names
    for (String t : g.tokenNameToTypeMap.keySet()) {
      int tokenType = g.tokenNameToTypeMap.get(t);
      if ( tokenType>=Token.MIN_USER_TOKEN_TYPE) {
        tokens.put(t, tokenType);
      }
    }
    vocabFileST.add("tokens", tokens);

    // now dump the strings
    Map<String,Integer> literals = new LinkedHashMap<String,Integer>();
    for (String literal : g.stringLiteralToTypeMap.keySet()) {
      int tokenType = g.stringLiteralToTypeMap.get(literal);
      if ( tokenType>=Token.MIN_USER_TOKEN_TYPE) {
        literals.put(literal, tokenType);
      }
    }
    vocabFileST.add("literals", literals);

    return vocabFileST;
  }
View Full Code Here

  public void writeHeaderFile() {
    String fileName = getHeaderFileName();
    if ( fileName==null ) return;
    if ( getTemplates().isDefined("headerFile") ) {
      ST extST = getTemplates().getInstanceOf("headerFileExtension");
      ST headerFileST = null;
      // TODO:  don't hide this header file generation here!
      getTarget().genRecognizerHeaderFile(g, headerFileST, extST.render(lineWidth));
    }
  }
View Full Code Here

  }

  public void writeVocabFile() {
    // write out the vocab interchange file; used by antlr,
    // does not change per target
    ST tokenVocabSerialization = getTokenVocabOutput();
    String fileName = getVocabFileName();
    if ( fileName!=null ) {
      getTarget().genFile(g, tokenVocabSerialization, fileName);
    }
  }
View Full Code Here

TOP

Related Classes of org.stringtemplate.v4.ST

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.