1*16467b97STreehugger Robot// 2*16467b97STreehugger Robot// RuleStack.m 3*16467b97STreehugger Robot// ANTLR 4*16467b97STreehugger Robot// 5*16467b97STreehugger Robot// Created by Alan Condit on 6/9/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#define SUCCESS (0) 33*16467b97STreehugger Robot#define FAILURE (-1) 34*16467b97STreehugger Robot 35*16467b97STreehugger Robotextern NSInteger debug; 36*16467b97STreehugger Robot 37*16467b97STreehugger Robot#import "RuleStack.h" 38*16467b97STreehugger Robot#import "Tree.h" 39*16467b97STreehugger Robot 40*16467b97STreehugger Robot/* 41*16467b97STreehugger Robot * Start of RuleStack 42*16467b97STreehugger Robot */ 43*16467b97STreehugger Robot@implementation RuleStack 44*16467b97STreehugger Robot 45*16467b97STreehugger Robot+ (RuleStack *)newRuleStack 46*16467b97STreehugger Robot{ 47*16467b97STreehugger Robot return [[RuleStack alloc] init]; 48*16467b97STreehugger Robot} 49*16467b97STreehugger Robot 50*16467b97STreehugger Robot+ (RuleStack *)newRuleStack:(NSInteger)cnt 51*16467b97STreehugger Robot{ 52*16467b97STreehugger Robot return [[RuleStack alloc] initWithLen:cnt]; 53*16467b97STreehugger Robot} 54*16467b97STreehugger Robot 55*16467b97STreehugger Robot- (id)init 56*16467b97STreehugger Robot{ 57*16467b97STreehugger Robot if ((self = [super init]) != nil) { 58*16467b97STreehugger Robot } 59*16467b97STreehugger Robot return( self ); 60*16467b97STreehugger Robot} 61*16467b97STreehugger Robot 62*16467b97STreehugger Robot- (id)initWithLen:(NSInteger)cnt 63*16467b97STreehugger Robot{ 64*16467b97STreehugger Robot if ((self = [super initWithLen:cnt]) != nil) { 65*16467b97STreehugger Robot } 66*16467b97STreehugger Robot return( self ); 67*16467b97STreehugger Robot} 68*16467b97STreehugger Robot 69*16467b97STreehugger Robot- (void)dealloc 70*16467b97STreehugger Robot{ 71*16467b97STreehugger Robot#ifdef DEBUG_DEALLOC 72*16467b97STreehugger Robot NSLog( @"called dealloc in RuleStack" ); 73*16467b97STreehugger Robot#endif 74*16467b97STreehugger Robot [super dealloc]; 75*16467b97STreehugger Robot} 76*16467b97STreehugger Robot 77*16467b97STreehugger Robot- (id) copyWithZone:(NSZone *)aZone 78*16467b97STreehugger Robot{ 79*16467b97STreehugger Robot return [super copyWithZone:aZone]; 80*16467b97STreehugger Robot} 81*16467b97STreehugger Robot 82*16467b97STreehugger Robot- (NSInteger)count 83*16467b97STreehugger Robot{ 84*16467b97STreehugger Robot RuleMemo *anElement; 85*16467b97STreehugger Robot NSInteger aCnt = 0; 86*16467b97STreehugger Robot for( int i = 0; i < BuffSize; i++ ) { 87*16467b97STreehugger Robot if ((anElement = ptrBuffer[i]) != nil) 88*16467b97STreehugger Robot aCnt++; 89*16467b97STreehugger Robot } 90*16467b97STreehugger Robot return aCnt; 91*16467b97STreehugger Robot} 92*16467b97STreehugger Robot 93*16467b97STreehugger Robot- (NSInteger)size 94*16467b97STreehugger Robot{ 95*16467b97STreehugger Robot RuleMemo *anElement; 96*16467b97STreehugger Robot NSInteger aSize = 0; 97*16467b97STreehugger Robot for( int i = 0; i < BuffSize; i++ ) { 98*16467b97STreehugger Robot if ((anElement = ptrBuffer[i]) != nil) { 99*16467b97STreehugger Robot aSize++; 100*16467b97STreehugger Robot } 101*16467b97STreehugger Robot } 102*16467b97STreehugger Robot return aSize; 103*16467b97STreehugger Robot} 104*16467b97STreehugger Robot 105*16467b97STreehugger Robot- (HashRule *)pop 106*16467b97STreehugger Robot{ 107*16467b97STreehugger Robot return (HashRule *)[super pop]; 108*16467b97STreehugger Robot} 109*16467b97STreehugger Robot 110*16467b97STreehugger Robot- (void) insertObject:(HashRule *)aRule atIndex:(NSInteger)idx 111*16467b97STreehugger Robot{ 112*16467b97STreehugger Robot if ( idx >= BuffSize ) { 113*16467b97STreehugger Robot if ( debug > 2 ) NSLog( @"In RuleStack attempting to insert aRule at Index %d, but Buffer is only %d long\n", idx, BuffSize ); 114*16467b97STreehugger Robot [self ensureCapacity:idx]; 115*16467b97STreehugger Robot } 116*16467b97STreehugger Robot if ( aRule != ptrBuffer[idx] ) { 117*16467b97STreehugger Robot if ( ptrBuffer[idx] ) [ptrBuffer[idx] release]; 118*16467b97STreehugger Robot [aRule retain]; 119*16467b97STreehugger Robot } 120*16467b97STreehugger Robot ptrBuffer[idx] = aRule; 121*16467b97STreehugger Robot} 122*16467b97STreehugger Robot 123*16467b97STreehugger Robot- (HashRule *)objectAtIndex:(NSInteger)idx 124*16467b97STreehugger Robot{ 125*16467b97STreehugger Robot if (idx < BuffSize) { 126*16467b97STreehugger Robot return ptrBuffer[idx]; 127*16467b97STreehugger Robot } 128*16467b97STreehugger Robot return nil; 129*16467b97STreehugger Robot} 130*16467b97STreehugger Robot 131*16467b97STreehugger Robot- (void)putHashRuleAtRuleIndex:(NSInteger)aRuleIndex StartIndex:(NSInteger)aStartIndex StopIndex:(NSInteger)aStopIndex 132*16467b97STreehugger Robot{ 133*16467b97STreehugger Robot HashRule *aHashRule; 134*16467b97STreehugger Robot RuleMemo *aRuleMemo; 135*16467b97STreehugger Robot 136*16467b97STreehugger Robot if (aRuleIndex >= BuffSize) { 137*16467b97STreehugger Robot if ( debug) NSLog( @"putHashRuleAtRuleIndex attempting to insert aRule at Index %d, but Buffer is only %d long\n", aRuleIndex, BuffSize ); 138*16467b97STreehugger Robot [self ensureCapacity:aRuleIndex]; 139*16467b97STreehugger Robot } 140*16467b97STreehugger Robot if ((aHashRule = ptrBuffer[aRuleIndex]) == nil) { 141*16467b97STreehugger Robot aHashRule = [[HashRule newHashRuleWithLen:17] retain]; 142*16467b97STreehugger Robot ptrBuffer[aRuleIndex] = aHashRule; 143*16467b97STreehugger Robot } 144*16467b97STreehugger Robot if (( aRuleMemo = [aHashRule objectAtIndex:aStartIndex] ) == nil ) { 145*16467b97STreehugger Robot aRuleMemo = [[RuleMemo newRuleMemo] retain]; 146*16467b97STreehugger Robot [aHashRule insertObject:aRuleMemo atIndex:aStartIndex]; 147*16467b97STreehugger Robot } 148*16467b97STreehugger Robot [aRuleMemo setStartIndex:[ACNumber numberWithInteger:aStartIndex]]; 149*16467b97STreehugger Robot [aRuleMemo setStopIndex:[ACNumber numberWithInteger:aStopIndex]]; 150*16467b97STreehugger Robot} 151*16467b97STreehugger Robot 152*16467b97STreehugger Robot@end 153