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


Java Tree類代碼示例

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


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

示例1: recursivelyFixWindowFucntion

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
public static void recursivelyFixWindowFucntion(
    CommonTree srcTree) {
    if (srcTree.getChildCount() == 0) { return; }

    // process node
 String text = srcTree.getText();
 System.out.println("Currently processed node==> " + text);
    if (text.equals(PARTITION_BY)) {
        return;
    } else if (text.equals(ORDER_BY)) {
		if (srcTree.getChildCount() == 0) {
			if (srcTree.getParent() != null) {
				// found a matching node
				srcTree.getParent().deleteChild(srcTree.getChildIndex());
				srcTree.getParent().freshenParentAndChildIndexes();
			}
		}
        return;
    }

    // process children
    for (Tree t : children(srcTree)) {
        recursivelyFixWindowFucntion((CommonTree)t);
    }
}
 
開發者ID:ajoabraham,項目名稱:hue,代碼行數:26,代碼來源:TreePatcher.java

示例2: findAggFuncRecursively

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
private static Boolean findAggFuncRecursively(
    CommonTree tree,
    List<String> aggregateFuncs) {
    Boolean ret = false;
    
    if (tree.getText().equals(FUNCTION_CALL)) {
        // function
        String funcName = tree.getChild(0).getChild(0).getText(); //FUNCTION_CALL->QNAME->xxx
        if (aggregateFuncs.contains(funcName.toLowerCase())) {
            return true;
        }
    }
    
    for (Tree t : children(tree)) {
        ret = findAggFuncRecursively((CommonTree)t, aggregateFuncs);
        if (ret == true) {
            return true;
        }
    }
    
    return false;
}
 
開發者ID:ajoabraham,項目名稱:hue,代碼行數:23,代碼來源:TreePatcher.java

示例3: patchTreeByTreesGroupBy

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
public static void patchTreeByTreesGroupBy(CommonTree srcTree, CommonTree targetTree)
{
    //System.out.println("Text = " + srcTree.getText() +  " ChildCount = " + srcTree.getChildCount() + " Type = " + srcTree.getType());
    if (srcTree.getChildCount() == 0) {
        return;
    }

    // process node
	if (srcTree.getText().equals(QUERY_SPEC_NODE)) {
		// patch
		targetTree.setParent(srcTree);
		srcTree.addChild(targetTree);
		return;
	}

    // process children
    for (Tree t : children(srcTree)) {
        patchTreeByTreesGroupBy((CommonTree)t, targetTree);
    }

    return;
}
 
開發者ID:ajoabraham,項目名稱:hue,代碼行數:23,代碼來源:TreePatcher.java

示例4: gatherTypes

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
private static void gatherTypes(CommonTree srcTree, Map<String, Integer> typesMap)
{
    if (srcTree.getChildCount() == 0) {
        return;
    }

    // process node
	if (!typesMap.containsKey(srcTree.getText())) {
		typesMap.put(srcTree.getText(), new Integer(srcTree.getType()));
	}

    // process children
    for (Tree subTree : children(srcTree)) {
        gatherTypes((CommonTree)subTree, typesMap);
    }

    return;
}
 
開發者ID:ajoabraham,項目名稱:hue,代碼行數:19,代碼來源:TreePatcher.java

示例5: updateTreeByString

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
public static void updateTreeByString(CommonTree tree, String target, String goal) {
    if (tree.getChildCount() == 0) {
        // leaf
		if (tree.getText().equals(target)) {
			//modifyText(tree, goal+'.'+target);
			modifyText(tree, goal);
			//System.out.println("Found 1!!!");
		}
		return;
    }

    // process node
	if (tree.getText().equals(target)) {
		modifyText(tree, goal+'.'+target);
		//System.out.println("Found 2!!!");
	}

    // process children
    for (Tree t : children(tree)) {
        updateTreeByString((CommonTree)t, target, goal);
    }

    return;
}
 
開發者ID:ajoabraham,項目名稱:hue,代碼行數:25,代碼來源:TreePatcher.java

示例6: treeToString

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
private static String treeToString(Tree tree, int depth)
{
    if (tree.getChildCount() == 0) {
        return quotedString(tree.toString());
    }
    StringBuilder sb = new StringBuilder();
    sb.append("(");
    sb.append(tree.toString());
    for (Tree t : children(tree)) {
        if (hasSubtree(t) && (leafCount(tree) > 2)) {
            sb.append("\n");
            sb.append(repeat("   ", depth));
        }
        else {
            sb.append(" ");
        }
        sb.append(treeToString(t, depth + 1));
    }
    sb.append(")");
    return sb.toString();
}
 
開發者ID:ajoabraham,項目名稱:hue,代碼行數:22,代碼來源:TreePrinter.java

示例7: getChildren

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
/**
 * Gets the children as a List
 * @param tree Tree
 * @return either emptyList or the children.
 */
public static List<Tree> getChildren(Tree tree)
{
    if (tree!=null && tree.getChildCount() > 0)
    {
        List<Tree> children = new ArrayList<Tree>(tree.getChildCount());
        for (int i = 0; i < tree.getChildCount(); i++) {
            Tree child = tree.getChild(i);
            children.add(child);
        }
        return children;
    }

    //Default
    return Collections.emptyList();
}
 
開發者ID:Alfresco,項目名稱:alfresco-remote-api,代碼行數:21,代碼來源:QueryHelper.java

示例8: getAltLabel

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
/** Walk ancestors of this node until we find ALT with
 *  alt!=null or leftRecursiveAltInfo!=null. Then grab label if any.
 *  If not a rule element, just returns null.
 */
public String getAltLabel() {
	List<? extends Tree> ancestors = this.getAncestors();
	if ( ancestors==null ) return null;
	for (int i=ancestors.size()-1; i>=0; i--) {
		GrammarAST p = (GrammarAST)ancestors.get(i);
		if ( p.getType()== ANTLRParser.ALT ) {
			AltAST a = (AltAST)p;
			if ( a.altLabel!=null ) return a.altLabel.getText();
			if ( a.leftRecursiveAltInfo!=null ) {
				return a.leftRecursiveAltInfo.altLabel;
			}
		}
	}
	return null;
}
 
開發者ID:antlr,項目名稱:codebuff,代碼行數:20,代碼來源:GrammarAST.java

示例9: 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

示例10: A

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
/**
 Make sure that action is last element in outer alt; here action,
 a2, z, and zz are bad, but a3 is ok:
 (RULE A (BLOCK (ALT {action} 'a')))
 (RULE B (BLOCK (ALT (BLOCK (ALT {a2} 'x') (ALT 'y')) {a3})))
 (RULE C (BLOCK (ALT 'd' {z}) (ALT 'e' {zz})))
 */
protected void checkElementIsOuterMostInSingleAlt(GrammarAST tree) {
	CommonTree alt = tree.parent;
	CommonTree blk = alt.parent;
	boolean outerMostAlt = blk.parent.getType() == RULE;
	Tree rule = tree.getAncestor(RULE);
	String fileName = tree.getToken().getInputStream().getSourceName();
	if ( !outerMostAlt || blk.getChildCount()>1 )
	{
		ErrorType e = ErrorType.LEXER_COMMAND_PLACEMENT_ISSUE;
		g.tool.errMgr.grammarError(e,
								   fileName,
								   tree.getToken(),
								   rule.getChild(0).getText());

	}
}
 
開發者ID:antlr,項目名稱:codebuff,代碼行數:24,代碼來源:BasicSemanticChecks.java

示例11: replaceWithCount

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
public void replaceWithCount(EntityReference entityRef) {
    Tree selectedItems = tree.getFirstChildWithType(JPA2Lexer.T_SELECTED_ITEMS);
    boolean isDistinct = "DISTINCT".equalsIgnoreCase(selectedItems.getChild(0).getText());
    if (!(isDistinct && selectedItems.getChildCount() == 2 ||
            selectedItems.getChildCount() == 1))
        throw new IllegalStateException("Cannot replace with count if multiple fields selected");

    SelectedItemNode selectedItemNode;
    if (isDistinct)
        selectedItems.deleteChild(0);

    selectedItemNode = (SelectedItemNode) selectedItems.getChild(0);
    AggregateExpressionNode countNode = createCountNode(entityRef, isDistinct);
    selectedItemNode.deleteChild(0);
    selectedItemNode.addChild(countNode);

    Tree orderBy = tree.getFirstChildWithType(JPA2Lexer.T_ORDER_BY);
    if (orderBy != null) {
        tree.deleteChild(orderBy.getChildIndex());
    }
    tree.freshenParentAndChildIndexes();
}
 
開發者ID:cuba-platform,項目名稱:cuba,代碼行數:23,代碼來源:QueryTreeTransformer.java

示例12: getSelectedPathNode

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
public PathNode getSelectedPathNode() {
    Tree selectedItems = tree.getFirstChildWithType(JPA2Lexer.T_SELECTED_ITEMS);
    boolean isDistinct = "DISTINCT".equalsIgnoreCase(selectedItems.getChild(0).getText());
    SelectedItemNode selectedItemNode;
    if (isDistinct) {
        if (selectedItems.getChildCount() != 2)
            throw new IllegalStateException("Cannot select path node if multiple fields selected");
        selectedItemNode = (SelectedItemNode) selectedItems.getChild(1);
    } else {
        if (selectedItems.getChildCount() != 1)
            throw new IllegalStateException("Cannot select path node if multiple fields selected");
        selectedItemNode = (SelectedItemNode) selectedItems.getChild(0);
    }

    if (!(selectedItemNode.getChild(0) instanceof PathNode)) {
        throw new IllegalStateException("An entity path is assumed to be selected");
    }
    return (PathNode) selectedItemNode.getChild(0);
}
 
開發者ID:cuba-platform,項目名稱:cuba,代碼行數:20,代碼來源:QueryTreeAnalyzer.java

示例13: executeHelp

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
private void executeHelp(Tree tree)
{
    if (tree.getChildCount() > 0)
    {
        String token = tree.getChild(0).getText();
        for (CliCommandHelp ch : getHelp().commands)
        {
            if (token.equals(ch.name))
            {
                sessionState.out.println(ch.help);
                break;
            }
        }
    }
    else
    {
        sessionState.out.println(getHelp().help);
    }
}
 
開發者ID:vcostet,項目名稱:cassandra-kmean,代碼行數:20,代碼來源:CliClient.java

示例14: executeConsistencyLevelStatement

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
/**
 * Command: CONSISTENCYLEVEL AS (ONE | QUORUM ...)
 * Tree: ^(NODE_CONSISTENCY_LEVEL AS (ONE | QUORUM ...))
 * @param statement - tree representing current statement
 */
private void executeConsistencyLevelStatement(Tree statement)
{
    if (!CliMain.isConnected())
        return;

    String userSuppliedLevel = statement.getChild(0).getText().toUpperCase();

    try
    {
        consistencyLevel = ConsistencyLevel.valueOf(userSuppliedLevel);
    }
    catch (IllegalArgumentException e)
    {
        String elements = "ONE, TWO, THREE, QUORUM, ALL, LOCAL_QUORUM, EACH_QUORUM, ANY";
        sessionState.out.println(String.format("'%s' is invalid. Available: %s", userSuppliedLevel, elements));
        return;
    }

    sessionState.out.println(String.format("Consistency level is set to '%s'.", consistencyLevel));
}
 
開發者ID:vcostet,項目名稱:cassandra-kmean,代碼行數:26,代碼來源:CliClient.java

示例15: executeAssumeStatement

import org.antlr.runtime.tree.Tree; //導入依賴的package包/類
/**
 * Command: ASSUME <columnFamily> (VALIDATOR | COMPARATOR | KEYS | SUB_COMPARATOR) AS <type>
 * Tree: ^(NODE_ASSUME <columnFamily> (VALIDATOR | COMPARATOR | KEYS | SUB_COMPARATOR) <type>))
 * @param statement - tree representing current statement
 */
private void executeAssumeStatement(Tree statement)
{
    if (!CliMain.isConnected() || !hasKeySpace())
        return;

    String cfName = CliCompiler.getColumnFamily(statement, currentCfDefs());

    // VALIDATOR | COMPARATOR | KEYS | SUB_COMPARATOR
    String assumptionElement = statement.getChild(1).getText().toUpperCase();


    // Could be UTF8Type, IntegerType, LexicalUUIDType etc.
    String defaultType = CliUtils.unescapeSQLString(statement.getChild(2).getText());

    if (applyAssumption(cfName, assumptionElement, defaultType))
    {
        assumptions.addAssumption(keySpace, cfName, assumptionElement, defaultType);
        sessionState.out.println(String.format("Assumption for column family '%s' added successfully.", cfName));
    }
}
 
開發者ID:vcostet,項目名稱:cassandra-kmean,代碼行數:26,代碼來源:CliClient.java


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