86 lines
2.1 KiB
Objective-C
Vendored
86 lines
2.1 KiB
Objective-C
Vendored
//
|
|
// HFByteSlice.m
|
|
// HexFiend_2
|
|
//
|
|
// Copyright 2007 ridiculous_fish. All rights reserved.
|
|
//
|
|
|
|
#import <HexFiend/HFByteSlice.h>
|
|
|
|
|
|
@implementation HFByteSlice
|
|
|
|
- (instancetype)init {
|
|
if ([self class] == [HFByteSlice class]) {
|
|
[NSException raise:NSInvalidArgumentException format:@"init sent to HFByteArray, but HFByteArray is an abstract class. Instantiate one of its subclasses instead."];
|
|
}
|
|
return [super init];
|
|
}
|
|
|
|
- (unsigned long long)length { UNIMPLEMENTED(); }
|
|
|
|
- (void)copyBytes:(unsigned char*)dst range:(HFRange)range { USE(dst); USE(range); UNIMPLEMENTED_VOID(); }
|
|
|
|
- (HFByteSlice *)subsliceWithRange:(HFRange)range { USE(range); UNIMPLEMENTED(); }
|
|
|
|
- (void)constructNewByteSlicesAboutRange:(HFRange)range first:(HFByteSlice **)first second:(HFByteSlice **)second {
|
|
const unsigned long long length = [self length];
|
|
|
|
//clip the range to our extent
|
|
range.location = llmin(range.location, length);
|
|
range.length = llmin(range.length, length - range.location);
|
|
|
|
HFRange firstRange = {0, range.location};
|
|
HFRange secondRange = {range.location + range.length, [self length] - (range.location + range.length)};
|
|
|
|
if (first) {
|
|
if (firstRange.length > 0)
|
|
*first = [self subsliceWithRange:firstRange];
|
|
else
|
|
*first = nil;
|
|
}
|
|
|
|
if (second) {
|
|
if (secondRange.length > 0)
|
|
*second = [self subsliceWithRange:secondRange];
|
|
else
|
|
*second = nil;
|
|
}
|
|
}
|
|
|
|
- (HFByteSlice *)byteSliceByAppendingSlice:(HFByteSlice *)slice {
|
|
USE(slice);
|
|
return nil;
|
|
}
|
|
|
|
- (HFByteRangeAttributeArray *)attributesForBytesInRange:(HFRange)range {
|
|
USE(range);
|
|
return nil;
|
|
}
|
|
|
|
- (BOOL)isSourcedFromFile {
|
|
return NO;
|
|
}
|
|
|
|
- (HFRange)sourceRangeForFile:(HFFileReference *)reference {
|
|
USE(reference);
|
|
return HFRangeMake(ULLONG_MAX, ULLONG_MAX);
|
|
}
|
|
|
|
- (id)retain {
|
|
HFAtomicIncrement(&retainCount, NO);
|
|
return self;
|
|
}
|
|
|
|
- (oneway void)release {
|
|
if (HFAtomicDecrement(&retainCount, NO) == (NSUInteger)(-1)) {
|
|
[self dealloc];
|
|
}
|
|
}
|
|
|
|
- (NSUInteger)retainCount {
|
|
return 1 + retainCount;
|
|
}
|
|
|
|
@end
|