1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
/*
Copyright (c) 1998, 1999, 2000, 2001, 2003, 2004 Benhur Stein
This file is part of Paj.
Paj is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License as published by the
Free Software Foundation; either version 2 of the License, or (at your
option) any later version.
Paj is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
for more details.
You should have received a copy of the GNU Lesser General Public License
along with Paj; if not, write to the Free Software Foundation, Inc.,
59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
*/
/* FilteredEnumerator.m created by benhur on Sat 14-Jun-1997 */
#include "FilteredEnumerator.h"
@implementation FilteredEnumerator
+ (FilteredEnumerator *)enumeratorWithEnumerator:(NSEnumerator *)orgEnum
filter:(id)f
selector:(SEL)sel
context:(id)c;
{
return [[[self alloc] initWithEnumerator:orgEnum
filter:f
selector:sel
context:c] autorelease];
}
- (id)initWithEnumerator:(NSEnumerator *)orgEnum
filter:(id)f
selector:(SEL)sel
context:(id)c
{
self = [super init];
if (self) {
originalEnumerator = [orgEnum retain];
filter = [f retain];
selector = sel;
context = [c retain];
}
return self;
}
- (void)dealloc
{
[originalEnumerator release];
[filter release];
[context release];
[super dealloc];
}
- (id)nextObject
{
id obj;
while (YES) {
obj = [originalEnumerator nextObject];
if (obj == nil) break;
obj = [filter performSelector:selector
withObject:obj
withObject:context];
if (obj != nil) break;
}
return obj;
}
@end
|