Mercurial > projects > dstep
diff dstep/foundation/NSArchiver.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/NSArchiver.d Mon Aug 03 15:31:48 2009 +0200 +++ b/dstep/foundation/NSArchiver.d Sun Jan 03 22:06:11 2010 +0100 @@ -6,27 +6,58 @@ */ module dstep.foundation.NSArchiver; +import dstep.foundation.NSArray; import dstep.foundation.NSCoder; import dstep.foundation.NSData; -import dstep.foundation.NSMutableArray; -import dstep.foundation.NSMutableData; -import dstep.foundation.NSMutableDictionary; +import dstep.foundation.NSDictionary; import dstep.foundation.NSString; +import dstep.foundation.NSZone; import dstep.objc.bridge.Bridge; -import dstep.objc.objc : id; +import dstep.objc.objc; + + import bindings = dstep.foundation.NSArchiver_bindings; -const NSString NSInconsistentArchiveException; +private NSString NSInconsistentArchiveException_; + +NSString NSInconsistentArchiveException () +{ + if (NSInconsistentArchiveException_) + return NSInconsistentArchiveException_; + + return NSInconsistentArchiveException_ = new NSString(bindings.NSInconsistentArchiveException); +} + +const TNSArchiverCallback = ` -static this () -{ - NSInconsistentArchiveException = new NSString(bindings.NSInconsistentArchiveException); -} + Class classForArchiver () + { + return invokeObjcSelf!(Class, "classForArchiver"); + } + + Object replacementObjectForArchiver (NSArchiver archiver) + { + return invokeObjcSelf!(Object, "replacementObjectForArchiver:", NSArchiver)(archiver); + } + + //mixin ObjcBindMethod!(classForArchiver, "classForArchiver"); + //mixin ObjcBindMethod!(replacementObjectForArchiver, "replacementObjectForArchiver:"); +`; class NSArchiver : NSCoder { - mixin ObjcWrap; + mixin (ObjcWrap); + + this () + { + super(typeof(this).alloc.init.objcObject); + } + + typeof(this) init () + { + return invokeObjcSelf!(typeof(this), "init"); + } Object initForWritingWithMutableData (NSMutableData mdata) { @@ -35,13 +66,7 @@ this (NSMutableData mdata) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initForWritingWithMutableData:", NSMutableData)(objcObject, mdata); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initForWritingWithMutableData(mdata); } NSMutableData archiverData () @@ -61,12 +86,12 @@ static NSData archivedDataWithRootObject (Object rootObject) { - return invokeObjcSelfClass!(NSData, "archivedDataWithRootObject:", Object)(rootObject); + return invokeObjcSuperClass!(NSData, "archivedDataWithRootObject:", Object)(rootObject); } static bool archiveRootObject (Object rootObject, NSString path) { - return invokeObjcSelfClass!(bool, "archiveRootObject:toFile:", Object, NSString)(rootObject, path); + return invokeObjcSuperClass!(bool, "archiveRootObject:toFile:", Object, NSString)(rootObject, path); } void encodeClassName (NSString trueName, NSString inArchiveName) @@ -87,7 +112,17 @@ class NSUnarchiver : NSCoder { - mixin ObjcWrap; + mixin (ObjcWrap); + + this () + { + super(typeof(this).alloc.init.objcObject); + } + + typeof(this) init () + { + return invokeObjcSelf!(typeof(this), "init"); + } Object initForReadingWithData (NSData data) { @@ -96,13 +131,7 @@ this (NSData data) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initForReadingWithData:", NSData)(objcObject, data); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initForReadingWithData(data); } void setObjectZone (NSZone* zone) @@ -127,17 +156,17 @@ static Object unarchiveObjectWithData (NSData data) { - return invokeObjcSelfClass!(Object, "unarchiveObjectWithData:", NSData)(data); + return invokeObjcSuperClass!(Object, "unarchiveObjectWithData:", NSData)(data); } static Object unarchiveObjectWithFile (NSString path) { - return invokeObjcSelfClass!(Object, "unarchiveObjectWithFile:", NSString)(path); + return invokeObjcSuperClass!(Object, "unarchiveObjectWithFile:", NSString)(path); } static void decodeClassName (NSString inArchiveName, NSString trueName) { - return invokeObjcSelfClass!(void, "decodeClassName:asClassName:", NSString, NSString)(inArchiveName, trueName); + return invokeObjcSuperClass!(void, "decodeClassName:asClassName:", NSString, NSString)(inArchiveName, trueName); } void decodeClassName (NSString inArchiveName, NSString trueName) @@ -147,7 +176,7 @@ static NSString classNameDecodedForArchiveClassName (NSString inArchiveName) { - return invokeObjcSelfClass!(NSString, "classNameDecodedForArchiveClassName:", NSString)(inArchiveName); + return invokeObjcSuperClass!(NSString, "classNameDecodedForArchiveClassName:", NSString)(inArchiveName); } NSString classNameDecodedForArchiveClassName (NSString inArchiveName) @@ -159,11 +188,4 @@ { return invokeObjcSelf!(void, "replaceObject:withObject:", Object, Object)(object, newObject); } -} - -template TNSArchiverCallback () -{ - Class classForArchiver (); - Object replacementObjectForArchiver (NSArchiver archiver); -} - +} \ No newline at end of file