xref: /aosp_15_r20/external/antlr/runtime/ObjC/Framework/ParseTree.m (revision 16467b971bd3e2009fad32dd79016f2c7e421deb)
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