00001 /* 00002 [The "BSD license"] 00003 Copyright (c) 2005-2009 Terence Parr 00004 All rights reserved. 00005 00006 Redistribution and use in source and binary forms, with or without 00007 modification, are permitted provided that the following conditions 00008 are met: 00009 1. Redistributions of source code must retain the above copyright 00010 notice, this list of conditions and the following disclaimer. 00011 2. Redistributions in binary form must reproduce the above copyright 00012 notice, this list of conditions and the following disclaimer in the 00013 documentation and/or other materials provided with the distribution. 00014 3. The name of the author may not be used to endorse or promote products 00015 derived from this software without specific prior written permission. 00016 00017 THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 00018 IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00019 OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 00020 IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 00021 INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 00022 NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 00023 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 00024 THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00025 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 00026 THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 package org.antlr.runtime.tree; 00029 00030 import java.util.List; 00031 00032 public class RewriteRuleSubtreeStream extends RewriteRuleElementStream { 00033 00034 public RewriteRuleSubtreeStream(TreeAdaptor adaptor, String elementDescription) { 00035 super(adaptor, elementDescription); 00036 } 00037 00039 public RewriteRuleSubtreeStream(TreeAdaptor adaptor, 00040 String elementDescription, 00041 Object oneElement) 00042 { 00043 super(adaptor, elementDescription, oneElement); 00044 } 00045 00047 public RewriteRuleSubtreeStream(TreeAdaptor adaptor, 00048 String elementDescription, 00049 List elements) 00050 { 00051 super(adaptor, elementDescription, elements); 00052 } 00053 00067 public Object nextNode() { 00068 //System.out.println("nextNode: elements="+elements+", singleElement="+((Tree)singleElement).toStringTree()); 00069 int n = size(); 00070 if ( dirty || (cursor>=n && n==1) ) { 00071 // if out of elements and size is 1, dup (at most a single node 00072 // since this is for making root nodes). 00073 Object el = _next(); 00074 return adaptor.dupNode(el); 00075 } 00076 // test size above then fetch 00077 Object tree = _next(); 00078 while (adaptor.isNil(tree) && adaptor.getChildCount(tree) == 1) 00079 tree = adaptor.getChild(tree, 0); 00080 //System.out.println("_next="+((Tree)tree).toStringTree()); 00081 Object el = adaptor.dupNode(tree); // dup just the root (want node here) 00082 return el; 00083 } 00084 00085 protected Object dup(Object el) { 00086 return adaptor.dupTree(el); 00087 } 00088 }
1.5.5