1*16467b97STreehugger Robot// 2*16467b97STreehugger Robot// TreeException.m 3*16467b97STreehugger Robot// ANTLR 4*16467b97STreehugger Robot// 5*16467b97STreehugger Robot// Created by Kay Röpke on 24.10.2006. 6*16467b97STreehugger Robot// [The "BSD licence"] 7*16467b97STreehugger Robot// Copyright (c) 2006-2007 Kay Roepke 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 33*16467b97STreehugger Robot#import "TreeException.h" 34*16467b97STreehugger Robot 35*16467b97STreehugger Robot 36*16467b97STreehugger Robot@implementation TreeException 37*16467b97STreehugger Robot 38*16467b97STreehugger Robot+ (id) newException:(id<BaseTree>)theOldRoot newRoot:(id<BaseTree>)theNewRoot stream:(id<IntStream>)aStream; 39*16467b97STreehugger Robot{ 40*16467b97STreehugger Robot return [[TreeException alloc] initWithOldRoot:theOldRoot newRoot:theNewRoot stream:aStream]; 41*16467b97STreehugger Robot} 42*16467b97STreehugger Robot 43*16467b97STreehugger Robot- (id) initWithOldRoot:(id<BaseTree>)theOldRoot newRoot:(id<BaseTree>)theNewRoot stream:(id<IntStream>)aStream; 44*16467b97STreehugger Robot{ 45*16467b97STreehugger Robot if ((self = [super initWithStream:aStream reason:@"The new root has more than one child. Cannot make it the root node."]) != nil ) { 46*16467b97STreehugger Robot [self setOldRoot:theOldRoot]; 47*16467b97STreehugger Robot [self setNewRoot:theNewRoot]; 48*16467b97STreehugger Robot } 49*16467b97STreehugger Robot return self; 50*16467b97STreehugger Robot} 51*16467b97STreehugger Robot 52*16467b97STreehugger Robot- (void) dealloc 53*16467b97STreehugger Robot{ 54*16467b97STreehugger Robot#ifdef DEBUG_DEALLOC 55*16467b97STreehugger Robot NSLog( @"called dealloc in TreeException" ); 56*16467b97STreehugger Robot#endif 57*16467b97STreehugger Robot [self setOldRoot:nil]; 58*16467b97STreehugger Robot [self setNewRoot:nil]; 59*16467b97STreehugger Robot [super dealloc]; 60*16467b97STreehugger Robot} 61*16467b97STreehugger Robot 62*16467b97STreehugger Robot- (void) setNewRoot:(id<BaseTree>)aTree 63*16467b97STreehugger Robot{ 64*16467b97STreehugger Robot if (newRoot != aTree) { 65*16467b97STreehugger Robot [aTree retain]; 66*16467b97STreehugger Robot if ( newRoot ) [newRoot release]; 67*16467b97STreehugger Robot newRoot = aTree; 68*16467b97STreehugger Robot } 69*16467b97STreehugger Robot} 70*16467b97STreehugger Robot 71*16467b97STreehugger Robot- (void) setOldRoot:(id<BaseTree>)aTree 72*16467b97STreehugger Robot{ 73*16467b97STreehugger Robot if (oldRoot != aTree) { 74*16467b97STreehugger Robot [aTree retain]; 75*16467b97STreehugger Robot if ( oldRoot ) [oldRoot release]; 76*16467b97STreehugger Robot oldRoot = aTree; 77*16467b97STreehugger Robot } 78*16467b97STreehugger Robot} 79*16467b97STreehugger Robot 80*16467b97STreehugger Robot- (NSString *) description 81*16467b97STreehugger Robot{ 82*16467b97STreehugger Robot return [NSMutableString stringWithFormat:@"%@ old root: <%@> new root: <%@>", [super description], [oldRoot treeDescription], [newRoot treeDescription]]; 83*16467b97STreehugger Robot} 84*16467b97STreehugger Robot 85*16467b97STreehugger Robot@end 86