當前位置: 首頁>>代碼示例>>Java>>正文


Java Tree.getType方法代碼示例

本文整理匯總了Java中org.antlr.runtime.tree.Tree.getType方法的典型用法代碼示例。如果您正苦於以下問題:Java Tree.getType方法的具體用法?Java Tree.getType怎麽用?Java Tree.getType使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.antlr.runtime.tree.Tree的用法示例。


在下文中一共展示了Tree.getType方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: hasImmediateRecursiveRuleRefs

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
/**
 * Match (RULE RULE_REF (BLOCK (ALT .*) (ALT RULE_REF[self] .*) (ALT .*)))
 * Match (RULE RULE_REF (BLOCK (ALT .*) (ALT (ASSIGN ID RULE_REF[self]) .*) (ALT .*)))
 */
public static boolean hasImmediateRecursiveRuleRefs(GrammarAST t, String ruleName) {
	if ( t==null ) return false;
	GrammarAST blk = (GrammarAST)t.getFirstChildWithType(BLOCK);
	if ( blk==null ) return false;
	int n = blk.getChildren().size();
	for (int i = 0; i < n; i++) {
		GrammarAST alt = (GrammarAST)blk.getChildren().get(i);
		Tree first = alt.getChild(0);
		if ( first==null ) continue;
		if (first.getType() == ELEMENT_OPTIONS) {
			first = alt.getChild(1);
			if (first == null) {
				continue;
			}
		}
		if ( first.getType()==RULE_REF && first.getText().equals(ruleName) ) return true;
		Tree rref = first.getChild(1);
		if ( rref!=null && rref.getType()==RULE_REF && rref.getText().equals(ruleName) ) return true;
	}
	return false;
}
 
開發者ID:antlr,項目名稱:codebuff,代碼行數:26,代碼來源:LeftRecursiveRuleAnalyzer.java

示例2: toPredicate

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
private Predicate<T> toPredicate(Tree r) throws QueryParseException, IllegalArgumentException {
  switch (r.getType()) {
    case AND:
      return and(children(r));
    case OR:
      return or(children(r));
    case NOT:
      return not(toPredicate(onlyChildOf(r)));

    case DEFAULT_FIELD:
      return defaultField(onlyChildOf(r));

    case FIELD_NAME:
      return operator(r.getText(), onlyChildOf(r));

    default:
      throw error("Unsupported operator: " + r);
  }
}
 
開發者ID:gerrit-review,項目名稱:gerrit,代碼行數:20,代碼來源:QueryBuilder.java

示例3: translateQuantifier

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public Expression<Boolean> translateQuantifier(Tree n) {
  Quantifier q;
  switch(n.getType()) {
  case EXISTS:
    q = Quantifier.EXISTS;
    break;
  case FORALL:
    q = Quantifier.FORALL;
    break;
  default:
    throw new UnexpectedTokenException(n, FORALL, EXISTS);
  }
  List<? extends Variable<?>> vars = translateTypedVarList(n.getChild(0));
  pushContext(vars);
  Expression<Boolean> body = translateBoolExpression(n.getChild(1));
  popContext();
  return new QuantifierExpression(q, vars, body);
}
 
開發者ID:psycopaths,項目名稱:jconstraints,代碼行數:19,代碼來源:ASTTranslator.java

示例4: getText

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
static private String getText(Tree node)
{
    String text = node.getText();
    int index;
    switch (node.getType())
    {
    case CMIS_FTSParser.FTSWORD:
        index = text.indexOf('\\');
        if (index == -1)
        {
            return text;
        }
        else
        {
            return unescape(text);
        }
    case CMIS_FTSParser.FTSPHRASE:
        String phrase = text.substring(1, text.length() - 1);
        index = phrase.indexOf('\\');
        if (index == -1)
        {
            return phrase;
        }
        else
        {
            return unescape(phrase);
        }
    default:
        return text;
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-data-model,代碼行數:32,代碼來源:CMISFTSQueryParser.java

示例5: getAllChildrenWithType

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public List<GrammarAST> getAllChildrenWithType(int type) {
	List<GrammarAST> nodes = new ArrayList<GrammarAST>();
	for (int i = 0; children!=null && i < children.size(); i++) {
		Tree t = (Tree) children.get(i);
		if ( t.getType()==type ) {
			nodes.add((GrammarAST)t);
		}
	}
	return nodes;
}
 
開發者ID:antlr,項目名稱:codebuff,代碼行數:11,代碼來源:GrammarAST.java

示例6: getLexerAction

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public ActionAST getLexerAction() {
	Tree blk = getFirstChildWithType(ANTLRParser.BLOCK);
	if ( blk.getChildCount()==1 ) {
		Tree onlyAlt = blk.getChild(0);
		Tree lastChild = onlyAlt.getChild(onlyAlt.getChildCount()-1);
		if ( lastChild.getType()==ANTLRParser.ACTION ) {
			return (ActionAST)lastChild;
		}
	}
	return null;
}
 
開發者ID:antlr,項目名稱:codebuff,代碼行數:12,代碼來源:RuleAST.java

示例7: blockHasWildcardAlt

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
/**
 * {@code (BLOCK (ALT .))} or {@code (BLOCK (ALT 'a') (ALT .))}.
 */
public static boolean blockHasWildcardAlt(GrammarAST block) {
	for (Object alt : block.getChildren()) {
		if ( !(alt instanceof AltAST) ) continue;
		AltAST altAST = (AltAST)alt;
		if ( altAST.getChildCount()==1 || (altAST.getChildCount() == 2 && altAST.getChild(0).getType() == ANTLRParser.ELEMENT_OPTIONS) ) {
			Tree e = altAST.getChild(altAST.getChildCount() - 1);
			if ( e.getType()==ANTLRParser.WILDCARD ) {
				return true;
			}
		}
	}
	return false;
}
 
開發者ID:antlr,項目名稱:codebuff,代碼行數:17,代碼來源:ParserATNFactory.java

示例8: executeCount

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
private void executeCount(Tree statement)
        throws TException, InvalidRequestException, UnavailableException, TimedOutException
{
    if (!CliMain.isConnected() || !hasKeySpace())
        return;

    Tree columnFamilySpec = statement.getChild(0);

    String columnFamily = CliCompiler.getColumnFamily(columnFamilySpec, currentCfDefs());
    int columnSpecCnt = CliCompiler.numColumnSpecifiers(columnFamilySpec);

    ColumnParent colParent = new ColumnParent(columnFamily).setSuper_column((ByteBuffer) null);

    if (columnSpecCnt != 0)
    {
        Tree columnTree = columnFamilySpec.getChild(2);

        byte[] superColumn = (columnTree.getType() == CliParser.FUNCTION_CALL)
                              ? convertValueByFunction(columnTree, null, null).array()
                              : columnNameAsByteArray(CliCompiler.getColumn(columnFamilySpec, 0), columnFamily);

        colParent = new ColumnParent(columnFamily).setSuper_column(superColumn);
    }

    SliceRange range = new SliceRange(ByteBufferUtil.EMPTY_BYTE_BUFFER, ByteBufferUtil.EMPTY_BYTE_BUFFER, false, Integer.MAX_VALUE);
    SlicePredicate predicate = new SlicePredicate().setColumn_names(null).setSlice_range(range);

    int count = thriftClient.get_count(getKeyAsBytes(columnFamily, columnFamilySpec.getChild(1)), colParent, predicate, consistencyLevel);
    sessionState.out.printf("%d cells%n", count);
}
 
開發者ID:vcostet,項目名稱:cassandra-kmean,代碼行數:31,代碼來源:CliClient.java

示例9: getKeyAsBytes

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public ByteBuffer getKeyAsBytes(String columnFamily, Tree keyTree)
{
    if (keyTree.getType() == CliParser.FUNCTION_CALL)
        return convertValueByFunction(keyTree, null, null);

    String key = CliUtils.unescapeSQLString(keyTree.getText());

    return getBytesAccordingToType(key, getKeyComparatorForCF(columnFamily));
}
 
開發者ID:vcostet,項目名稱:cassandra-kmean,代碼行數:10,代碼來源:CliClient.java

示例10: requireType

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
private static void requireType(Tree n, int ...expected) {
  int t = n.getType();
  for(int i = 0; i < expected.length; i++) {
    if(t == expected[i])
      return;
  }
  throw new UnexpectedTokenException(n, expected);
}
 
開發者ID:psycopaths,項目名稱:jconstraints,代碼行數:9,代碼來源:ASTTranslator.java

示例11: operator

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
private Predicate<T> operator(String name, Tree val) throws QueryParseException {
  switch (val.getType()) {
      // Expand multiple values, "foo:(a b c)", as though they were written
      // out with the longer form, "foo:a foo:b foo:c".
      //
    case AND:
    case OR:
      {
        List<Predicate<T>> p = new ArrayList<>(val.getChildCount());
        for (int i = 0; i < val.getChildCount(); i++) {
          final Tree c = val.getChild(i);
          if (c.getType() != DEFAULT_FIELD) {
            throw error("Nested operator not expected: " + c);
          }
          p.add(operator(name, onlyChildOf(c)));
        }
        return val.getType() == AND ? and(p) : or(p);
      }

    case SINGLE_WORD:
    case EXACT_PHRASE:
      if (val.getChildCount() != 0) {
        throw error("Expected no children under: " + val);
      }
      return operator(name, val.getText());

    default:
      throw error("Unsupported node in operator " + name + ": " + val);
  }
}
 
開發者ID:gerrit-review,項目名稱:gerrit,代碼行數:31,代碼來源:QueryBuilder.java

示例12: translateIdentifier

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public String translateIdentifier(Tree n) {
  switch(n.getType()) {
  case ExpressionParser.ID:
    return n.getText();
  case ExpressionParser.QID:
    String txt = n.getText();
    // TODO : unescape quotes
    return txt.substring(1, txt.length() - 1);
  }
  throw new UnexpectedTokenException(n, ExpressionParser.ID, ExpressionParser.QID);
}
 
開發者ID:psycopaths,項目名稱:jconstraints,代碼行數:12,代碼來源:ASTTranslator.java

示例13: translateBoolExpression

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public Expression<Boolean> translateBoolExpression(Tree n) {
  switch(n.getType()) {
  case FORALL:
  case EXISTS:
    return translateQuantifier(n);
  case LIMP:
  case LEQ:
  case LXOR:
  case LOR:
  case LAND:
    return translatePropositionalCompound(n);
  case EQ:
  case NE:
  case LT:
  case LE:
  case GT:
  case GE:
    return translateNumericComparison(n);
  case LNOT:
    return translateLogicalNegation(n);
  case TRUE:
    return ExpressionUtil.TRUE;
  case FALSE:
    return ExpressionUtil.FALSE;
  case QID:
  case ID:
    return (Expression<Boolean>) translateVariable(n);
  }
  throw new UnexpectedTokenException(n, FORALL, EXISTS, LIMP, LEQ, LXOR, LOR, LAND, EQ, NE, LT, LE, GT, GE, LNOT, TRUE, FALSE);
}
 
開發者ID:psycopaths,項目名稱:jconstraints,代碼行數:31,代碼來源:ASTTranslator.java

示例14: translateNumericComparison

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public Expression<Boolean> translateNumericComparison(Tree n) {
  NumericComparator cmp;
  switch(n.getType()) {
  case EQ:
    cmp = NumericComparator.EQ;
    break;
  case NE:
    cmp = NumericComparator.NE;
    break;
  case LT:
    cmp = NumericComparator.LT;
    break;
  case LE:
    cmp = NumericComparator.LE;
    break;
  case GT:
    cmp = NumericComparator.GT;
    break;
  case GE:
    cmp = NumericComparator.GE;
    break;
  default:
    throw new UnexpectedTokenException(n, EQ, NE, LT, LE, GT, GE);
  }
  
  Expression<?> left = translateArithmeticExpression(n.getChild(0));
  Expression<?> right = translateArithmeticExpression(n.getChild(1));
  
  return NumericBooleanExpression.create(left, cmp, right);
}
 
開發者ID:psycopaths,項目名稱:jconstraints,代碼行數:31,代碼來源:ASTTranslator.java

示例15: translateArithmeticExpression

import org.antlr.runtime.tree.Tree; //導入方法依賴的package包/類
public Expression<?> translateArithmeticExpression(Tree n) {
  switch(n.getType()) {
  case BVOR:
  case BVXOR:
  case BVAND:
  case BVSHL:
  case BVSHR:
  case BVSHUR:
    return translateBitvectorOperator(n);
  case BVNEG:
    return translateBitvectorNegation(n);
  case ADD:
  case SUB:
  case MUL:
  case DIV:
  case REM:
    return translateNumericCompound(n);
  case UNARY_PLUS:
    return translateArithmeticExpression(n.getChild(0));
  case UNARY_MINUS:
    return translateUnaryMinus(n);
  case TYPE_CAST:
    return translateTypeCast(n);
  case ID:
  case QID:
    return translateVariable(n);
  case BYTE_LITERAL:
  case SHORT_LITERAL:
  case INT_LITERAL:
  case LONG_LITERAL:
  case FLOAT_LITERAL:
  case DOUBLE_LITERAL:
  case BIGINT_LITERAL:
  case BIGDECIMAL_LITERAL:
    return translateLiteral(n);
  default:
    throw new UnexpectedTokenException(n, BVOR, BVXOR, BVAND, BVSHL, BVSHR, BVSHUR, BVNEG, ADD, SUB, MUL, DIV, REM, UNARY_PLUS, UNARY_MINUS, TYPE_CAST);
  }
}
 
開發者ID:psycopaths,項目名稱:jconstraints,代碼行數:40,代碼來源:ASTTranslator.java


注:本文中的org.antlr.runtime.tree.Tree.getType方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。