Home | History | Annotate | Download | only in Headers
      1 //
      2 //  ANTLRSymbolStack.m
      3 //  ANTLR
      4 //
      5 //  Created by Alan Condit on 6/9/10.
      6 // [The "BSD licence"]
      7 // Copyright (c) 2010 Alan Condit
      8 // All rights reserved.
      9 //
     10 // Redistribution and use in source and binary forms, with or without
     11 // modification, are permitted provided that the following conditions
     12 // are met:
     13 // 1. Redistributions of source code must retain the above copyright
     14 //    notice, this list of conditions and the following disclaimer.
     15 // 2. Redistributions in binary form must reproduce the above copyright
     16 //    notice, this list of conditions and the following disclaimer in the
     17 //    documentation and/or other materials provided with the distribution.
     18 // 3. The name of the author may not be used to endorse or promote products
     19 //    derived from this software without specific prior written permission.
     20 //
     21 // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     22 // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     23 // OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     24 // IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     25 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     26 // NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     27 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     28 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     29 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     30 // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     31 
     32 #define SUCCESS (0)
     33 #define FAILURE (-1)
     34 
     35 #import "ANTLRSymbolStack.h"
     36 #import "ANTLRTree.h"
     37 
     38 
     39 @implementation ANTLRSymbolsScope
     40 
     41 + (ANTLRSymbolsScope *)newANTLRSymbolsScope
     42 {
     43     return( [[ANTLRSymbolsScope alloc] init] );
     44 }
     45 
     46 - (id)init
     47 {
     48     if ((self = [super init]) != nil) {
     49     }
     50     return (self);
     51 }
     52 
     53 @end
     54 
     55 /*
     56  * Start of ANTLRSymbolStack
     57  */
     58 @implementation ANTLRSymbolStack
     59 
     60 +(ANTLRSymbolStack *)newANTLRSymbolStack
     61 {
     62     return [[ANTLRSymbolStack alloc] init];
     63 }
     64 
     65 +(ANTLRSymbolStack *)newANTLRSymbolStackWithLen:(NSInteger)cnt
     66 {
     67     return [[ANTLRSymbolStack alloc] initWithLen:cnt];
     68 }
     69 
     70 -(id)init
     71 {
     72 	if ((self = [super init]) != nil) {
     73 	}
     74     return( self );
     75 }
     76 
     77 -(id)initWithLen:(NSInteger)cnt
     78 {
     79 	if ((self = [super initWithLen:cnt]) != nil) {
     80 	}
     81     return( self );
     82 }
     83 
     84 -(void)dealloc
     85 {
     86 	[super dealloc];
     87 }
     88 
     89 - (id) copyWithZone:(NSZone *)aZone
     90 {
     91     return [super copyWithZone:aZone];
     92 }
     93 
     94 -(ANTLRSymbolsScope *)getHashMapEntry:(NSInteger)idx
     95 {
     96 	return( (ANTLRSymbolsScope *)[super objectAtIndex:idx] );
     97 }
     98 
     99 -(ANTLRSymbolsScope **)getHashMap
    100 {
    101 	return( (ANTLRSymbolsScope **)ptrBuffer );
    102 }
    103 
    104 -(ANTLRSymbolsScope *) pop
    105 {
    106     return (ANTLRSymbolsScope *)[super pop];
    107 }
    108 
    109 - (void) insertObject:(ANTLRSymbolsScope *)aRule atIndex:(NSInteger)idx
    110 {
    111     if (aRule != ptrBuffer[idx]) {
    112         if (ptrBuffer[idx] != nil) [ptrBuffer[idx] release];
    113         [aRule retain];
    114     }
    115     ptrBuffer[idx] = aRule;
    116 }
    117 
    118 - (ANTLRSymbolsScope *)objectAtIndex:(NSInteger)idx
    119 {
    120     return (ANTLRSymbolsScope *)[super objectAtIndex:idx];
    121 }
    122 
    123 @end
    124