1*16467b97STreehugger Robot// 2*16467b97STreehugger Robot// ParseTree.m 3*16467b97STreehugger Robot// ANTLR 4*16467b97STreehugger Robot// 5*16467b97STreehugger Robot// Created by Alan Condit on 7/12/10. 6*16467b97STreehugger Robot// [The "BSD licence"] 7*16467b97STreehugger Robot// Copyright (c) 2010 Alan Condit 8*16467b97STreehugger Robot// All rights reserved. 9*16467b97STreehugger Robot// 10*16467b97STreehugger Robot// Redistribution and use in source and binary forms, with or without 11*16467b97STreehugger Robot// modification, are permitted provided that the following conditions 12*16467b97STreehugger Robot// are met: 13*16467b97STreehugger Robot// 1. Redistributions of source code must retain the above copyright 14*16467b97STreehugger Robot// notice, this list of conditions and the following disclaimer. 15*16467b97STreehugger Robot// 2. Redistributions in binary form must reproduce the above copyright 16*16467b97STreehugger Robot// notice, this list of conditions and the following disclaimer in the 17*16467b97STreehugger Robot// documentation and/or other materials provided with the distribution. 18*16467b97STreehugger Robot// 3. The name of the author may not be used to endorse or promote products 19*16467b97STreehugger Robot// derived from this software without specific prior written permission. 20*16467b97STreehugger Robot// 21*16467b97STreehugger Robot// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 22*16467b97STreehugger Robot// IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 23*16467b97STreehugger Robot// OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 24*16467b97STreehugger Robot// IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 25*16467b97STreehugger Robot// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 26*16467b97STreehugger Robot// NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 27*16467b97STreehugger Robot// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 28*16467b97STreehugger Robot// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 29*16467b97STreehugger Robot// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 30*16467b97STreehugger Robot// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31*16467b97STreehugger Robot 32*16467b97STreehugger Robot#import "ParseTree.h" 33*16467b97STreehugger Robot 34*16467b97STreehugger Robot/** A record of the rules used to match a token sequence. The tokens 35*16467b97STreehugger Robot * end up as the leaves of this tree and rule nodes are the interior nodes. 36*16467b97STreehugger Robot * This really adds no functionality, it is just an alias for CommonTree 37*16467b97STreehugger Robot * that is more meaningful (specific) and holds a String to display for a node. 38*16467b97STreehugger Robot */ 39*16467b97STreehugger Robot@implementation ParseTree 40*16467b97STreehugger Robot+ (ParseTree *)newParseTree:(id<Token>)label 41*16467b97STreehugger Robot{ 42*16467b97STreehugger Robot return [[ParseTree alloc] initWithLabel:label]; 43*16467b97STreehugger Robot} 44*16467b97STreehugger Robot 45*16467b97STreehugger Robot- (id)initWithLabel:(id<Token>)label 46*16467b97STreehugger Robot{ 47*16467b97STreehugger Robot self = [super init]; 48*16467b97STreehugger Robot if ( self != nil) { 49*16467b97STreehugger Robot payload = [label retain]; 50*16467b97STreehugger Robot } 51*16467b97STreehugger Robot return self; 52*16467b97STreehugger Robot} 53*16467b97STreehugger Robot 54*16467b97STreehugger Robot- (id<BaseTree>)dupNode 55*16467b97STreehugger Robot{ 56*16467b97STreehugger Robot return nil; 57*16467b97STreehugger Robot} 58*16467b97STreehugger Robot 59*16467b97STreehugger Robot- (NSInteger)type 60*16467b97STreehugger Robot{ 61*16467b97STreehugger Robot return 0; 62*16467b97STreehugger Robot} 63*16467b97STreehugger Robot 64*16467b97STreehugger Robot- (NSString *)text 65*16467b97STreehugger Robot{ 66*16467b97STreehugger Robot return [self toString]; 67*16467b97STreehugger Robot} 68*16467b97STreehugger Robot 69*16467b97STreehugger Robot- (NSInteger)getTokenStartIndex 70*16467b97STreehugger Robot{ 71*16467b97STreehugger Robot return 0; 72*16467b97STreehugger Robot} 73*16467b97STreehugger Robot 74*16467b97STreehugger Robot- (void)setTokenStartIndex:(NSInteger)anIndex 75*16467b97STreehugger Robot{ 76*16467b97STreehugger Robot} 77*16467b97STreehugger Robot 78*16467b97STreehugger Robot- (NSInteger)getTokenStopIndex 79*16467b97STreehugger Robot{ 80*16467b97STreehugger Robot return 0; 81*16467b97STreehugger Robot} 82*16467b97STreehugger Robot 83*16467b97STreehugger Robot- (void)setTokenStopIndex:(NSInteger)anIndex 84*16467b97STreehugger Robot{ 85*16467b97STreehugger Robot} 86*16467b97STreehugger Robot 87*16467b97STreehugger Robot- (NSString *)description 88*16467b97STreehugger Robot{ 89*16467b97STreehugger Robot if ( [payload isKindOfClass:[CommonToken class]] ) { 90*16467b97STreehugger Robot id<Token> t = (id<Token>)payload; 91*16467b97STreehugger Robot if ( t.type == TokenTypeEOF ) { 92*16467b97STreehugger Robot return @"<EOF>"; 93*16467b97STreehugger Robot } 94*16467b97STreehugger Robot return [t text]; 95*16467b97STreehugger Robot } 96*16467b97STreehugger Robot return [payload description]; 97*16467b97STreehugger Robot} 98*16467b97STreehugger Robot 99*16467b97STreehugger Robot- (NSString *)toString 100*16467b97STreehugger Robot{ 101*16467b97STreehugger Robot return [self description]; 102*16467b97STreehugger Robot} 103*16467b97STreehugger Robot 104*16467b97STreehugger Robot/** Emit a token and all hidden nodes before. EOF node holds all 105*16467b97STreehugger Robot * hidden tokens after last real token. 106*16467b97STreehugger Robot */ 107*16467b97STreehugger Robot- (NSString *)toStringWithHiddenTokens 108*16467b97STreehugger Robot{ 109*16467b97STreehugger Robot NSMutableString *buf = [NSMutableString stringWithCapacity:25]; 110*16467b97STreehugger Robot if ( hiddenTokens!=nil ) { 111*16467b97STreehugger Robot for (NSUInteger i = 0; i < [hiddenTokens count]; i++) { 112*16467b97STreehugger Robot id<Token> hidden = (id<Token> ) [hiddenTokens objectAtIndex:i]; 113*16467b97STreehugger Robot [buf appendString:[hidden text]]; 114*16467b97STreehugger Robot } 115*16467b97STreehugger Robot } 116*16467b97STreehugger Robot NSString *nodeText = [self toString]; 117*16467b97STreehugger Robot if ( ![nodeText isEqualTo:@"<EOF>"] ) 118*16467b97STreehugger Robot [buf appendString:nodeText]; 119*16467b97STreehugger Robot return buf; 120*16467b97STreehugger Robot} 121*16467b97STreehugger Robot 122*16467b97STreehugger Robot/** Print out the leaves of this tree, which means printing original 123*16467b97STreehugger Robot * input back out. 124*16467b97STreehugger Robot */ 125*16467b97STreehugger Robot- (NSString *)toInputString 126*16467b97STreehugger Robot{ 127*16467b97STreehugger Robot NSMutableString *buf = [NSMutableString stringWithCapacity:25]; 128*16467b97STreehugger Robot [self _toStringLeaves:buf]; 129*16467b97STreehugger Robot return buf; 130*16467b97STreehugger Robot} 131*16467b97STreehugger Robot 132*16467b97STreehugger Robot- (void)_toStringLeaves:(NSMutableString *)buf 133*16467b97STreehugger Robot{ 134*16467b97STreehugger Robot if ( [payload isKindOfClass:[CommonToken class]] ) { // leaf node token? 135*16467b97STreehugger Robot [buf appendString:[self toStringWithHiddenTokens]]; 136*16467b97STreehugger Robot return; 137*16467b97STreehugger Robot } 138*16467b97STreehugger Robot for (int i = 0; children!=nil && i < [children count]; i++) { 139*16467b97STreehugger Robot ParseTree *t = (ParseTree *) [children objectAtIndex:i]; 140*16467b97STreehugger Robot [t _toStringLeaves:buf]; 141*16467b97STreehugger Robot } 142*16467b97STreehugger Robot} 143*16467b97STreehugger Robot 144*16467b97STreehugger Robot@synthesize payload; 145*16467b97STreehugger Robot@synthesize hiddenTokens; 146*16467b97STreehugger Robot//@synthesize children; 147*16467b97STreehugger Robot//@synthesize anException; 148*16467b97STreehugger Robot 149*16467b97STreehugger Robot@end 150