Mercurial > projects > dstep
diff dstep/foundation/NSArray.d @ 16:19885b43130e
Huge update, the bridge actually works now
author | Jacob Carlborg <doob@me.com> |
---|---|
date | Sun, 03 Jan 2010 22:06:11 +0100 |
parents | 89f3c3ef1fd2 |
children | b9de51448c6b |
line wrap: on
line diff
--- a/dstep/foundation/NSArray.d Mon Aug 03 15:31:48 2009 +0200 +++ b/dstep/foundation/NSArray.d Sun Jan 03 22:06:11 2010 +0100 @@ -6,128 +6,48 @@ */ module dstep.foundation.NSArray; +import dstep.foundation.NSCoder; import dstep.foundation.NSData; import dstep.foundation.NSEnumerator; import dstep.foundation.NSIndexSet; +import dstep.foundation.NSObjCRuntime; import dstep.foundation.NSObject; +import dstep.foundation.NSPathUtilities; import dstep.foundation.NSRange; +import dstep.foundation.NSSortDescriptor; import dstep.foundation.NSString; import dstep.foundation.NSURL; +import dstep.foundation.NSZone; import dstep.objc.bridge.Bridge; -import dstep.objc.objc : id; - -class NSMutableArray : NSArray -{ - mixin ObjcWrap; - mixin TNSExtendedMutableArray; - mixin TNSMutableArrayCreation; - - void addObject (Object anObject) - { - return invokeObjcSelf!(void, "addObject:", Object)(anObject); - } - - void insertObject (Object anObject, NSUInteger index) - { - return invokeObjcSelf!(void, "insertObject:atIndex:", Object, NSUInteger)(anObject, index); - } - - void removeLastObject () - { - return invokeObjcSelf!(void, "removeLastObject"); - } - - void removeObjectAtIndex (NSUInteger index) - { - return invokeObjcSelf!(void, "removeObjectAtIndex:", NSUInteger)(index); - } - - void replaceObjectAtIndex (NSUInteger index, Object anObject) - { - return invokeObjcSelf!(void, "replaceObjectAtIndex:withObject:", NSUInteger, Object)(index, anObject); - } -} - -class NSArray : NSObject, INSCopying, INSMutableCopying, INSCoding, INSFastEnumeration -{ - mixin ObjcWrap; - mixin TNSArrayCreation; - mixin TNSExtendedArray; - mixin TNSSortDescriptorSorting; - mixin TNSArrayPathExtensions; +import dstep.objc.objc; - NSUInteger count () - { - return invokeObjcSelf!(NSUInteger, "count"); - } - - Object objectAtIndex (NSUInteger index) - { - return invokeObjcSelf!(Object, "objectAtIndex:", NSUInteger)(index); - } - - Object copyWithZone (NSZone* zone) - { - return invokeObjcSelf!(Object, "copyWithZone:", NSZone*)(zone); - } - - Object mutableCopyWithZone (NSZone* zone) - { - return invokeObjcSelf!(Object, "mutableCopyWithZone:", NSZone*)(zone); - } - - void encodeWithCoder (NSCoder aCoder) - { - return invokeObjcSelf!(void, "encodeWithCoder:", NSCoder)(aCoder); - } +alias extern (C) NSInteger function (id, id, void*) CompareFunc; - Object initWithCoder (NSCoder aDecoder) - { - return invokeObjcSelf!(Object, "initWithCoder:", NSCoder)(aDecoder); - } - - this (NSCoder aDecoder) - { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithCoder:", NSCoder)(objcObject, aDecoder); +const TNSArrayCreation = ` - if (result) - objcObject = ret; - - dObject = this; - } - - NSUInteger countByEnumeratingWithState (NSFastEnumerationState* state, id* stackbuf, NSUInteger len) - { - return invokeObjcSelf!(NSUInteger, "countByEnumeratingWithState:objects:count:", NSFastEnumerationState*, id*, NSUInteger)(state, stackbuf, len); - } -} - -template TNSArrayCreation () -{ static Object array () { - return invokeObjcSelfClass!(Object, "array"); + return invokeObjcSuperClass!(Object, "array"); } static Object arrayWithObject (Object anObject) { - return invokeObjcSelfClass!(Object, "arrayWithObject:", Object)(anObject); + return invokeObjcSuperClass!(Object, "arrayWithObject:", Object)(anObject); } static Object arrayWithObjects (id* objects, NSUInteger cnt) { - return invokeObjcSelfClass!(Object, "arrayWithObjects:count:", id*, NSUInteger)(objects, cnt); + return invokeObjcSuperClass!(Object, "arrayWithObjects:count:", id*, NSUInteger)(objects, cnt); } static Object arrayWithObjects (Object arrayWithObjects, ...) { - return invokeObjcSelfClass!(Object, "arrayWithObjects:", Object)(arrayWithObjects); + return invokeObjcSuperClass!(Object, "arrayWithObjects:", Object)(arrayWithObjects); } static Object arrayWithArray (NSArray array) { - return invokeObjcSelfClass!(Object, "arrayWithArray:", NSArray)(array); + return invokeObjcSuperClass!(Object, "arrayWithArray:", NSArray)(array); } Object initWithObjects (id* objects, NSUInteger cnt) @@ -137,13 +57,7 @@ this (id* objects, NSUInteger cnt) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithObjects:count:", id*, NSUInteger)(objcObject, objects, cnt); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initWithObjects(objects, cnt); } Object initWithObjects (Object initWithObjects, ...) @@ -153,13 +67,7 @@ this (Object initWithObjects, ...) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithObjects:", Object)(objcObject, initWithObjects); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initWithObjects(initWithObjects); } Object initWithArray (NSArray array) @@ -169,13 +77,7 @@ this (NSArray array) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithArray:", NSArray)(objcObject, array); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initWithArray(array); } Object initWithArray (NSArray array, bool flag) @@ -185,23 +87,17 @@ this (NSArray array, bool flag) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithArray:copyItems:", NSArray, bool)(objcObject, array, flag); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initWithArray(array, flag); } static Object arrayWithContentsOfFile (NSString path) { - return invokeObjcSelfClass!(Object, "arrayWithContentsOfFile:", NSString)(path); + return invokeObjcSuperClass!(Object, "arrayWithContentsOfFile:", NSString)(path); } static Object arrayWithContentsOfURL (NSURL url) { - return invokeObjcSelfClass!(Object, "arrayWithContentsOfURL:", NSURL)(url); + return invokeObjcSuperClass!(Object, "arrayWithContentsOfURL:", NSURL)(url); } Object initWithContentsOfFile (NSString path) @@ -211,13 +107,7 @@ this (NSString path) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithContentsOfFile:", NSString)(objcObject, path); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initWithContentsOfFile(path); } Object initWithContentsOfURL (NSURL url) @@ -227,18 +117,12 @@ this (NSURL url) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithContentsOfURL:", NSURL)(objcObject, url); - - if (result) - objcObject = ret; + typeof(this).alloc.initWithContentsOfURL(url); + } +`; - dObject = this; - } -} +const TNSExtendedArray = ` -template TNSExtendedArray () -{ NSArray arrayByAddingObject (Object anObject) { return invokeObjcSelf!(NSArray, "arrayByAddingObject:", Object)(anObject); @@ -334,14 +218,14 @@ return invokeObjcSelf!(NSData, "sortedArrayHint"); } - NSArray sortedArrayUsingFunction (NSInteger *id, id, void* comparator, void* context) + NSArray sortedArrayUsingFunction (CompareFunc comparator, void* context) { - return invokeObjcSelf!(NSArray, "sortedArrayUsingFunction:context:", NSInteger *id, id, void*, void*)(comparator, context); + return invokeObjcSelf!(NSArray, "sortedArrayUsingFunction:context:", CompareFunc, void*)(comparator, context); } - NSArray sortedArrayUsingFunction (NSInteger *id, id, void* comparator, void* context, NSData hint) + NSArray sortedArrayUsingFunction (CompareFunc comparator, void* context, NSData hint) { - return invokeObjcSelf!(NSArray, "sortedArrayUsingFunction:context:hint:", NSInteger *id, id, void*, void*, NSData)(comparator, context, hint); + return invokeObjcSelf!(NSArray, "sortedArrayUsingFunction:context:hint:", CompareFunc, void*, NSData)(comparator, context, hint); } NSArray sortedArrayUsingSelector (SEL comparator) @@ -378,10 +262,10 @@ { return invokeObjcSelf!(NSArray, "objectsAtIndexes:", NSIndexSet)(indexes); } -} +`; -template TNSExtendedMutableArray () -{ +const TNSExtendedMutableArray = ` + void addObjectsFromArray (NSArray otherArray) { return invokeObjcSelf!(void, "addObjectsFromArray:", NSArray)(otherArray); @@ -447,9 +331,9 @@ return invokeObjcSelf!(void, "setArray:", NSArray)(otherArray); } - void sortUsingFunction (NSInteger *id, id, void* compare, void* context) + void sortUsingFunction (CompareFunc compare, void* context) { - return invokeObjcSelf!(void, "sortUsingFunction:context:", NSInteger *id, id, void*, void*)(compare, context); + return invokeObjcSelf!(void, "sortUsingFunction:context:", CompareFunc, void*)(compare, context); } void sortUsingSelector (SEL comparator) @@ -471,13 +355,13 @@ { return invokeObjcSelf!(void, "replaceObjectsAtIndexes:withObjects:", NSIndexSet, NSArray)(indexes, objects); } -} +`; -template TNSMutableArrayCreation () -{ +const TNSMutableArrayCreation = ` + static Object arrayWithCapacity (NSUInteger numItems) { - return invokeObjcSelfClass!(Object, "arrayWithCapacity:", NSUInteger)(numItems); + return invokeObjcSuperClass!(Object, "arrayWithCapacity:", NSUInteger)(numItems); } Object initWithCapacity (NSUInteger numItems) @@ -487,13 +371,458 @@ this (NSUInteger numItems) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithCapacity:", NSUInteger)(objcObject, numItems); + typeof(this).alloc.initWithCapacity(numItems); + } +`; + +class NSMutableArray : NSArray +{ + mixin (ObjcWrap); + + this () + { + super(typeof(this).alloc.init.objcObject); + } + + typeof(this) init () + { + return invokeObjcSelf!(typeof(this), "init"); + } + + void addObject (Object anObject) + { + return invokeObjcSelf!(void, "addObject:", Object)(anObject); + } + + void insertObject (Object anObject, NSUInteger index) + { + return invokeObjcSelf!(void, "insertObject:atIndex:", Object, NSUInteger)(anObject, index); + } + + void removeLastObject () + { + return invokeObjcSelf!(void, "removeLastObject"); + } + + void removeObjectAtIndex (NSUInteger index) + { + return invokeObjcSelf!(void, "removeObjectAtIndex:", NSUInteger)(index); + } - if (result) - objcObject = ret; - - dObject = this; + void replaceObjectAtIndex (NSUInteger index, Object anObject) + { + return invokeObjcSelf!(void, "replaceObjectAtIndex:withObject:", NSUInteger, Object)(index, anObject); + } + + // NSExtendedMutableArray + void addObjectsFromArray (NSArray otherArray) + { + return invokeObjcSelf!(void, "addObjectsFromArray:", NSArray)(otherArray); + } + + void exchangeObjectAtIndex (NSUInteger idx1, NSUInteger idx2) + { + return invokeObjcSelf!(void, "exchangeObjectAtIndex:withObjectAtIndex:", NSUInteger, NSUInteger)(idx1, idx2); + } + + void removeAllObjects () + { + return invokeObjcSelf!(void, "removeAllObjects"); + } + + void removeObject (Object anObject, NSRange range) + { + return invokeObjcSelf!(void, "removeObject:inRange:", Object, NSRange)(anObject, range); + } + + void removeObject (Object anObject) + { + return invokeObjcSelf!(void, "removeObject:", Object)(anObject); + } + + void removeObjectIdenticalTo (Object anObject, NSRange range) + { + return invokeObjcSelf!(void, "removeObjectIdenticalTo:inRange:", Object, NSRange)(anObject, range); + } + + void removeObjectIdenticalTo (Object anObject) + { + return invokeObjcSelf!(void, "removeObjectIdenticalTo:", Object)(anObject); + } + + void removeObjectsFromIndices (NSUInteger* indices, NSUInteger cnt) + { + return invokeObjcSelf!(void, "removeObjectsFromIndices:numIndices:", NSUInteger*, NSUInteger)(indices, cnt); + } + + void removeObjectsInArray (NSArray otherArray) + { + return invokeObjcSelf!(void, "removeObjectsInArray:", NSArray)(otherArray); + } + + void removeObjectsInRange (NSRange range) + { + return invokeObjcSelf!(void, "removeObjectsInRange:", NSRange)(range); + } + + void replaceObjectsInRange (NSRange range, NSArray otherArray, NSRange otherRange) + { + return invokeObjcSelf!(void, "replaceObjectsInRange:withObjectsFromArray:range:", NSRange, NSArray, NSRange)(range, otherArray, otherRange); + } + + void replaceObjectsInRange (NSRange range, NSArray otherArray) + { + return invokeObjcSelf!(void, "replaceObjectsInRange:withObjectsFromArray:", NSRange, NSArray)(range, otherArray); + } + + void setArray (NSArray otherArray) + { + return invokeObjcSelf!(void, "setArray:", NSArray)(otherArray); + } + + void sortUsingFunction (CompareFunc compare, void* context) + { + return invokeObjcSelf!(void, "sortUsingFunction:context:", CompareFunc, void*)(compare, context); + } + + void sortUsingSelector (SEL comparator) + { + return invokeObjcSelf!(void, "sortUsingSelector:", SEL)(comparator); + } + + void insertObjects (NSArray objects, NSIndexSet indexes) + { + return invokeObjcSelf!(void, "insertObjects:atIndexes:", NSArray, NSIndexSet)(objects, indexes); + } + + void removeObjectsAtIndexes (NSIndexSet indexes) + { + return invokeObjcSelf!(void, "removeObjectsAtIndexes:", NSIndexSet)(indexes); + } + + void replaceObjectsAtIndexes (NSIndexSet indexes, NSArray objects) + { + return invokeObjcSelf!(void, "replaceObjectsAtIndexes:withObjects:", NSIndexSet, NSArray)(indexes, objects); + } + + + // NSMutableArrayCreation + static Object arrayWithCapacity (NSUInteger numItems) + { + return invokeObjcSuperClass!(Object, "arrayWithCapacity:", NSUInteger)(numItems); + } + + Object initWithCapacity (NSUInteger numItems) + { + return invokeObjcSelf!(Object, "initWithCapacity:", NSUInteger)(numItems); + } + + this (NSUInteger numItems) + { + typeof(this).alloc.initWithCapacity(numItems); } } +class NSArray : NSObject, INSCopying, INSMutableCopying, INSCoding, INSFastEnumeration +{ + mixin (ObjcWrap); + + this () + { + super(typeof(this).alloc.init.objcObject); + } + + typeof(this) init () + { + return invokeObjcSelf!(typeof(this), "init"); + } + + NSUInteger count () + { + return invokeObjcSelf!(NSUInteger, "count"); + } + + Object objectAtIndex (NSUInteger index) + { + return invokeObjcSelf!(Object, "objectAtIndex:", NSUInteger)(index); + } + + Object copyWithZone (NSZone* zone) + { + return invokeObjcSelf!(Object, "copyWithZone:", NSZone*)(zone); + } + + Object mutableCopyWithZone (NSZone* zone) + { + return invokeObjcSelf!(Object, "mutableCopyWithZone:", NSZone*)(zone); + } + + void encodeWithCoder (NSCoder aCoder) + { + return invokeObjcSelf!(void, "encodeWithCoder:", NSCoder)(aCoder); + } + + Object initWithCoder (NSCoder aDecoder) + { + return invokeObjcSelf!(Object, "initWithCoder:", NSCoder)(aDecoder); + } + + this (NSCoder aDecoder) + { + typeof(this).alloc.initWithCoder(aDecoder); + } + + NSUInteger countByEnumeratingWithState (NSFastEnumerationState* state, id* stackbuf, NSUInteger len) + { + return invokeObjcSelf!(NSUInteger, "countByEnumeratingWithState:objects:count:", NSFastEnumerationState*, id*, NSUInteger)(state, stackbuf, len); + } + + // NSArrayCreation + static Object array () + { + return invokeObjcSuperClass!(Object, "array"); + } + + static Object arrayWithObject (Object anObject) + { + return invokeObjcSuperClass!(Object, "arrayWithObject:", Object)(anObject); + } + + static Object arrayWithObjects (id* objects, NSUInteger cnt) + { + return invokeObjcSuperClass!(Object, "arrayWithObjects:count:", id*, NSUInteger)(objects, cnt); + } + + static Object arrayWithObjects (Object arrayWithObjects, ...) + { + return invokeObjcSuperClass!(Object, "arrayWithObjects:", Object)(arrayWithObjects); + } + + static Object arrayWithArray (NSArray array) + { + return invokeObjcSuperClass!(Object, "arrayWithArray:", NSArray)(array); + } + + Object initWithObjects (id* objects, NSUInteger cnt) + { + return invokeObjcSelf!(Object, "initWithObjects:count:", id*, NSUInteger)(objects, cnt); + } + + this (id* objects, NSUInteger cnt) + { + typeof(this).alloc.initWithObjects(objects, cnt); + } + + Object initWithObjects (Object initWithObjects, ...) + { + return invokeObjcSelf!(Object, "initWithObjects:", Object)(initWithObjects); + } + + this (Object initWithObjects, ...) + { + typeof(this).alloc.initWithObjects(initWithObjects); + } + + Object initWithArray (NSArray array) + { + return invokeObjcSelf!(Object, "initWithArray:", NSArray)(array); + } + + this (NSArray array) + { + typeof(this).alloc.initWithArray(array); + } + + Object initWithArray (NSArray array, bool flag) + { + return invokeObjcSelf!(Object, "initWithArray:copyItems:", NSArray, bool)(array, flag); + } + + this (NSArray array, bool flag) + { + typeof(this).alloc.initWithArray(array, flag); + } + + static Object arrayWithContentsOfFile (NSString path) + { + return invokeObjcSuperClass!(Object, "arrayWithContentsOfFile:", NSString)(path); + } + + static Object arrayWithContentsOfURL (NSURL url) + { + return invokeObjcSuperClass!(Object, "arrayWithContentsOfURL:", NSURL)(url); + } + + Object initWithContentsOfFile (NSString path) + { + return invokeObjcSelf!(Object, "initWithContentsOfFile:", NSString)(path); + } + + this (NSString path) + { + typeof(this).alloc.initWithContentsOfFile(path); + } + + Object initWithContentsOfURL (NSURL url) + { + return invokeObjcSelf!(Object, "initWithContentsOfURL:", NSURL)(url); + } + + this (NSURL url) + { + typeof(this).alloc.initWithContentsOfURL(url); + } + + // NSExtendedArray + NSArray arrayByAddingObject (Object anObject) + { + return invokeObjcSelf!(NSArray, "arrayByAddingObject:", Object)(anObject); + } + + NSArray arrayByAddingObjectsFromArray (NSArray otherArray) + { + return invokeObjcSelf!(NSArray, "arrayByAddingObjectsFromArray:", NSArray)(otherArray); + } + + NSString componentsJoinedByString (NSString separator) + { + return invokeObjcSelf!(NSString, "componentsJoinedByString:", NSString)(separator); + } + + bool containsObject (Object anObject) + { + return invokeObjcSelf!(bool, "containsObject:", Object)(anObject); + } + + NSString description () + { + return invokeObjcSelf!(NSString, "description"); + } + + NSString descriptionWithLocale (Object locale) + { + return invokeObjcSelf!(NSString, "descriptionWithLocale:", Object)(locale); + } + + NSString descriptionWithLocale (Object locale, NSUInteger level) + { + return invokeObjcSelf!(NSString, "descriptionWithLocale:indent:", Object, NSUInteger)(locale, level); + } + + Object firstObjectCommonWithArray (NSArray otherArray) + { + return invokeObjcSelf!(Object, "firstObjectCommonWithArray:", NSArray)(otherArray); + } + + void getObjects (id* objects) + { + return invokeObjcSelf!(void, "getObjects:", id*)(objects); + } + + void getObjects (id* objects, NSRange range) + { + return invokeObjcSelf!(void, "getObjects:range:", id*, NSRange)(objects, range); + } + + NSUInteger indexOfObject (Object anObject) + { + return invokeObjcSelf!(NSUInteger, "indexOfObject:", Object)(anObject); + } + + NSUInteger indexOfObject (Object anObject, NSRange range) + { + return invokeObjcSelf!(NSUInteger, "indexOfObject:inRange:", Object, NSRange)(anObject, range); + } + + NSUInteger indexOfObjectIdenticalTo (Object anObject) + { + return invokeObjcSelf!(NSUInteger, "indexOfObjectIdenticalTo:", Object)(anObject); + } + + NSUInteger indexOfObjectIdenticalTo (Object anObject, NSRange range) + { + return invokeObjcSelf!(NSUInteger, "indexOfObjectIdenticalTo:inRange:", Object, NSRange)(anObject, range); + } + + bool isEqualToArray (NSArray otherArray) + { + return invokeObjcSelf!(bool, "isEqualToArray:", NSArray)(otherArray); + } + + Object lastObject () + { + return invokeObjcSelf!(Object, "lastObject"); + } + + NSEnumerator objectEnumerator () + { + return invokeObjcSelf!(NSEnumerator, "objectEnumerator"); + } + + NSEnumerator reverseObjectEnumerator () + { + return invokeObjcSelf!(NSEnumerator, "reverseObjectEnumerator"); + } + + NSData sortedArrayHint () + { + return invokeObjcSelf!(NSData, "sortedArrayHint"); + } + + NSArray sortedArrayUsingFunction (CompareFunc comparator, void* context) + { + return invokeObjcSelf!(NSArray, "sortedArrayUsingFunction:context:", CompareFunc, void*)(comparator, context); + } + + NSArray sortedArrayUsingFunction (CompareFunc comparator, void* context, NSData hint) + { + return invokeObjcSelf!(NSArray, "sortedArrayUsingFunction:context:hint:", CompareFunc, void*, NSData)(comparator, context, hint); + } + + NSArray sortedArrayUsingSelector (SEL comparator) + { + return invokeObjcSelf!(NSArray, "sortedArrayUsingSelector:", SEL)(comparator); + } + + NSArray subarrayWithRange (NSRange range) + { + return invokeObjcSelf!(NSArray, "subarrayWithRange:", NSRange)(range); + } + + bool writeToFile (NSString path, bool useAuxiliaryFile) + { + return invokeObjcSelf!(bool, "writeToFile:atomically:", NSString, bool)(path, useAuxiliaryFile); + } + + bool writeToURL (NSURL url, bool atomically) + { + return invokeObjcSelf!(bool, "writeToURL:atomically:", NSURL, bool)(url, atomically); + } + + void makeObjectsPerformSelector (SEL aSelector) + { + return invokeObjcSelf!(void, "makeObjectsPerformSelector:", SEL)(aSelector); + } + + void makeObjectsPerformSelector (SEL aSelector, Object argument) + { + return invokeObjcSelf!(void, "makeObjectsPerformSelector:withObject:", SEL, Object)(aSelector, argument); + } + + NSArray objectsAtIndexes (NSIndexSet indexes) + { + return invokeObjcSelf!(NSArray, "objectsAtIndexes:", NSIndexSet)(indexes); + } + + // NSSortDescriptorSorting + NSArray sortedArrayUsingDescriptors (NSArray sortDescriptors) + { + return invokeObjcSelf!(NSArray, "sortedArrayUsingDescriptors:", NSArray)(sortDescriptors); + } + + // NSArrayPathExtensions + NSArray pathsMatchingExtensions (NSArray filterTypes) + { + return invokeObjcSelf!(NSArray, "pathsMatchingExtensions:", NSArray)(filterTypes); + } +} \ No newline at end of file