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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
|
/*
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.
*/
#ifndef _PSortedArray_h_
#define _PSortedArray_h_
/* PSortedArray.h created by benhur on Mon 07-Apr-1997 */
#include <Foundation/Foundation.h>
#include "Comparing.h"
@interface PSortedArray : NSObject <NSCoding, NSCopying>
{
NSMutableArray *array;
SEL valueSelector;
}
+ (PSortedArray *)sortedArrayWithSelector:(SEL)sel;
- (id)initWithSelector:(SEL)sel;
- (void)setSelector:(SEL)sel;
- (NSUInteger)count;
- (id)objectAtIndex:(NSUInteger)index;
- (void)addObject:(id)obj
withValue:(id<Comparing>)objValue
left:(int)left
right:(int)right
pivot:(int)pivot;
- (void)addObject:(id)obj;
- (id)lastObject;
- (void)removeObjectAtIndex:(NSUInteger)index;
- (void)removeObjectsInRange:(NSRange)aRange;
- (void)removeObject:(id)obj;
- (void)removeObjectIdenticalTo:(id)obj;
- (void)removeObjectsBeforeValue:(id<Comparing>)value;
- (void)removeAllObjects;
- (void)removeLastObject;
- (void)verifyPositionOfObjectIdenticalTo:(id)obj;
- (NSEnumerator *)objectEnumerator;
- (NSEnumerator *)objectEnumeratorAfterValue:(id<Comparing>)value;
- (NSEnumerator *)objectEnumeratorNotAfterValue:(id<Comparing>)value;
- (NSEnumerator *)objectEnumeratorNotBeforeValue:(id<Comparing>)value;
- (NSEnumerator *)objectEnumeratorNotBeforeValue:(id<Comparing>)value1
notAfterValue:(id<Comparing>)value2;
- (NSEnumerator *)objectEnumeratorAfterValue:(id<Comparing>)value1
notAfterValue:(id<Comparing>)value2;
- (NSEnumerator *)reverseObjectEnumerator;
- (NSEnumerator *)reverseObjectEnumeratorAfterValue:(id<Comparing>)value;
- (NSEnumerator *)reverseObjectEnumeratorNotBeforeValue:(id<Comparing>)value;
- (NSUInteger)indexOfFirstObjectNotBeforeValue:(id<Comparing>)value; // 0--count
- (NSUInteger)indexOfFirstObjectAfterValue:(id<Comparing>)value; // 0--count
- (NSUInteger)indexOfLastObjectNotAfterValue:(id<Comparing>)value; // 0--count-1 may return NSNotFound
- (NSUInteger)indexOfLastObjectBeforeValue:(id<Comparing>)value; // 0--count-1 may return NSNotFound
- (NSUInteger)indexOfObjectWithValue:(id<Comparing>)value; // 0--count-1 may return NSNotFound
- (NSUInteger)indexOfObject:(id)obj; // 0--count-1 may return NSNotFound
- (NSEnumerator *)reverseObjectEnumeratorWithRange:(NSRange)range;
// NSCoding Protocol
- (void)encodeWithCoder:(NSCoder *)coder;
- (id)initWithCoder:(NSCoder *)coder;
// NSCopying Protocol
- (id)copyWithZone:(NSZone *)zone;
@end
#endif
|