Java Code Examples for org.antlr.runtime.tree.CommonTreeNodeStream#consume()
The following examples show how to use
org.antlr.runtime.tree.CommonTreeNodeStream#consume() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: GrammarAST.java From codebuff with BSD 2-Clause "Simplified" License | 6 votes |
public String toTokenString() { CharStream input = this.token.getInputStream(); GrammarASTAdaptor adaptor = new GrammarASTAdaptor(input); CommonTreeNodeStream nodes = new CommonTreeNodeStream(adaptor, this); StringBuilder buf = new StringBuilder(); GrammarAST o = (GrammarAST)nodes.LT(1); int type = adaptor.getType(o); while ( type!=Token.EOF ) { buf.append(" "); buf.append(o.getText()); nodes.consume(); o = (GrammarAST)nodes.LT(1); type = adaptor.getType(o); } return buf.toString(); }
Example 2
Source File: TestCommonTreeNodeStream.java From jFuzzyLogic with GNU Lesser General Public License v3.0 | 4 votes |
public void testPushPop() throws Exception { // ^(101 ^(102 103) ^(104 105) ^(106 107) 108 109) // stream has 9 real + 8 nav nodes // Sequence of types: 101 DN 102 DN 103 UP 104 DN 105 UP 106 DN 107 UP 108 109 UP Tree r0 = new CommonTree(new CommonToken(101)); Tree r1 = new CommonTree(new CommonToken(102)); r1.addChild(new CommonTree(new CommonToken(103))); r0.addChild(r1); Tree r2 = new CommonTree(new CommonToken(104)); r2.addChild(new CommonTree(new CommonToken(105))); r0.addChild(r2); Tree r3 = new CommonTree(new CommonToken(106)); r3.addChild(new CommonTree(new CommonToken(107))); r0.addChild(r3); r0.addChild(new CommonTree(new CommonToken(108))); r0.addChild(new CommonTree(new CommonToken(109))); CommonTreeNodeStream stream = new CommonTreeNodeStream(r0); String expecting = " 101 2 102 2 103 3 104 2 105 3 106 2 107 3 108 109 3"; String found = stream.toString(); assertEquals(expecting, found); // Assume we want to hit node 107 and then "call 102" then return int indexOf102 = 2; int indexOf107 = 12; for (int k=1; k<=indexOf107; k++) { // consume til 107 node stream.consume(); } // CALL 102 assertEquals(107, ((Tree)stream.LT(1)).getType()); stream.push(indexOf102); assertEquals(102, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 102 assertEquals(Token.DOWN, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume DN assertEquals(103, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 103 assertEquals(Token.UP, ((Tree)stream.LT(1)).getType()); // RETURN stream.pop(); assertEquals(107, ((Tree)stream.LT(1)).getType()); }
Example 3
Source File: TestCommonTreeNodeStream.java From jFuzzyLogic with GNU Lesser General Public License v3.0 | 4 votes |
public void testNestedPushPop() throws Exception { // ^(101 ^(102 103) ^(104 105) ^(106 107) 108 109) // stream has 9 real + 8 nav nodes // Sequence of types: 101 DN 102 DN 103 UP 104 DN 105 UP 106 DN 107 UP 108 109 UP Tree r0 = new CommonTree(new CommonToken(101)); Tree r1 = new CommonTree(new CommonToken(102)); r1.addChild(new CommonTree(new CommonToken(103))); r0.addChild(r1); Tree r2 = new CommonTree(new CommonToken(104)); r2.addChild(new CommonTree(new CommonToken(105))); r0.addChild(r2); Tree r3 = new CommonTree(new CommonToken(106)); r3.addChild(new CommonTree(new CommonToken(107))); r0.addChild(r3); r0.addChild(new CommonTree(new CommonToken(108))); r0.addChild(new CommonTree(new CommonToken(109))); CommonTreeNodeStream stream = new CommonTreeNodeStream(r0); // Assume we want to hit node 107 and then "call 102", which // calls 104, then return int indexOf102 = 2; int indexOf107 = 12; for (int k=1; k<=indexOf107; k++) { // consume til 107 node stream.consume(); } assertEquals(107, ((Tree)stream.LT(1)).getType()); // CALL 102 stream.push(indexOf102); assertEquals(102, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 102 assertEquals(Token.DOWN, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume DN assertEquals(103, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 103 // CALL 104 int indexOf104 = 6; stream.push(indexOf104); assertEquals(104, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 102 assertEquals(Token.DOWN, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume DN assertEquals(105, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 103 assertEquals(Token.UP, ((Tree)stream.LT(1)).getType()); // RETURN (to UP node in 102 subtree) stream.pop(); assertEquals(Token.UP, ((Tree)stream.LT(1)).getType()); // RETURN (to empty stack) stream.pop(); assertEquals(107, ((Tree)stream.LT(1)).getType()); }
Example 4
Source File: TestCommonTreeNodeStream.java From jFuzzyLogic with GNU Lesser General Public License v3.0 | 4 votes |
public void testPushPopFromEOF() throws Exception { // ^(101 ^(102 103) ^(104 105) ^(106 107) 108 109) // stream has 9 real + 8 nav nodes // Sequence of types: 101 DN 102 DN 103 UP 104 DN 105 UP 106 DN 107 UP 108 109 UP Tree r0 = new CommonTree(new CommonToken(101)); Tree r1 = new CommonTree(new CommonToken(102)); r1.addChild(new CommonTree(new CommonToken(103))); r0.addChild(r1); Tree r2 = new CommonTree(new CommonToken(104)); r2.addChild(new CommonTree(new CommonToken(105))); r0.addChild(r2); Tree r3 = new CommonTree(new CommonToken(106)); r3.addChild(new CommonTree(new CommonToken(107))); r0.addChild(r3); r0.addChild(new CommonTree(new CommonToken(108))); r0.addChild(new CommonTree(new CommonToken(109))); CommonTreeNodeStream stream = new CommonTreeNodeStream(r0); while ( stream.LA(1)!=Token.EOF ) { stream.consume(); } int indexOf102 = 2; int indexOf104 = 6; assertEquals(Token.EOF, ((Tree)stream.LT(1)).getType()); // CALL 102 stream.push(indexOf102); assertEquals(102, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 102 assertEquals(Token.DOWN, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume DN assertEquals(103, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 103 assertEquals(Token.UP, ((Tree)stream.LT(1)).getType()); // RETURN (to empty stack) stream.pop(); assertEquals(Token.EOF, ((Tree)stream.LT(1)).getType()); // CALL 104 stream.push(indexOf104); assertEquals(104, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 102 assertEquals(Token.DOWN, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume DN assertEquals(105, ((Tree)stream.LT(1)).getType()); stream.consume(); // consume 103 assertEquals(Token.UP, ((Tree)stream.LT(1)).getType()); // RETURN (to empty stack) stream.pop(); assertEquals(Token.EOF, ((Tree)stream.LT(1)).getType()); }