Mercurial > projects > dstep
diff dstep/foundation/NSXMLDocument.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/NSXMLDocument.d Mon Aug 03 15:31:48 2009 +0200 +++ b/dstep/foundation/NSXMLDocument.d Sun Jan 03 22:06:11 2010 +0100 @@ -6,11 +6,18 @@ */ module dstep.foundation.NSXMLDocument; +import dstep.foundation.NSArray; import dstep.foundation.NSData; +import dstep.foundation.NSDictionary; +import dstep.foundation.NSError; +import dstep.foundation.NSObjCRuntime; +import dstep.foundation.NSString; +import dstep.foundation.NSURL; import dstep.foundation.NSXMLDTD; +import dstep.foundation.NSXMLElement; import dstep.foundation.NSXMLNode; import dstep.objc.bridge.Bridge; -import dstep.objc.objc : id; +import dstep.objc.objc; alias NSUInteger NSXMLDocumentContentKind; @@ -24,54 +31,76 @@ class NSXMLDocument : NSXMLNode { - mixin ObjcWrap; - - Object initWithXMLString (NSString string, NSUInteger mask, NSError** error) + mixin (ObjcWrap); + + this () { - return invokeObjcSelf!(Object, "initWithXMLString:options:error:", NSString, NSUInteger, NSError**)(string, mask, error); + super(typeof(this).alloc.init.objcObject); + } + + typeof(this) init () + { + return invokeObjcSelf!(typeof(this), "init"); } - this (NSString string, NSUInteger mask, NSError** error) + Object initWithXMLString (NSString string, NSUInteger mask, ref NSError error) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithXMLString:options:error:", NSString, NSUInteger, NSError**)(objcObject, string, mask, error); - - if (result) - objcObject = ret; - - dObject = this; + id err; + + if (error) + err = new objc_object; + + Object result = invokeObjcSelf!(Object, "initWithXMLString:options:error:", NSString, NSUInteger, id*)(string, mask, &err); + + if (err) + error = new NSError(err); + + return result; } - Object initWithContentsOfURL (NSURL url, NSUInteger mask, NSError** error) + this (NSString string, NSUInteger mask, ref NSError error) { - return invokeObjcSelf!(Object, "initWithContentsOfURL:options:error:", NSURL, NSUInteger, NSError**)(url, mask, error); + typeof(this).alloc.initWithXMLString(string, mask, error); } - this (NSURL url, NSUInteger mask, NSError** error) + Object initWithContentsOfURL (NSURL url, NSUInteger mask, ref NSError error) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithContentsOfURL:options:error:", NSURL, NSUInteger, NSError**)(objcObject, url, mask, error); - - if (result) - objcObject = ret; - - dObject = this; + id err; + + if (error) + err = new objc_object; + + Object result = invokeObjcSelf!(Object, "initWithContentsOfURL:options:error:", NSURL, NSUInteger, id*)(url, mask, &err); + + if (err) + error = new NSError(err); + + return result; } - Object initWithData (NSData data, NSUInteger mask, NSError** error) + this (NSURL url, NSUInteger mask, ref NSError error) { - return invokeObjcSelf!(Object, "initWithData:options:error:", NSData, NSUInteger, NSError**)(data, mask, error); + typeof(this).alloc.initWithContentsOfURL(url, mask, error); } - this (NSData data, NSUInteger mask, NSError** error) + Object initWithData (NSData data, NSUInteger mask, ref NSError error) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithData:options:error:", NSData, NSUInteger, NSError**)(objcObject, data, mask, error); + id err; + + if (error) + err = new objc_object; + + Object result = invokeObjcSelf!(Object, "initWithData:options:error:", NSData, NSUInteger, id*)(data, mask, &err); + + if (err) + error = new NSError(err); + + return result; + } - if (result) - objcObject = ret; - - dObject = this; + this (NSData data, NSUInteger mask, ref NSError error) + { + typeof(this).alloc.initWithData(data, mask, error); } Object initWithRootElement (NSXMLElement element) @@ -81,18 +110,12 @@ this (NSXMLElement element) { - objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass); - id result = Bridge.invokeObjcMethod!(id, "initWithRootElement:", NSXMLElement)(objcObject, element); - - if (result) - objcObject = ret; - - dObject = this; + typeof(this).alloc.initWithRootElement(element); } static Class replacementClassForClass (Class cls) { - return invokeObjcSelfClass!(Class, "replacementClassForClass:", Class)(cls); + return invokeObjcSuperClass!(Class, "replacementClassForClass:", Class)(cls); } void setCharacterEncoding (NSString encoding) @@ -205,24 +228,64 @@ return invokeObjcSelf!(NSData, "XMLDataWithOptions:", NSUInteger)(options); } - Object objectByApplyingXSLT (NSData xslt, NSDictionary arguments, NSError** error) + Object objectByApplyingXSLT (NSData xslt, NSDictionary arguments, ref NSError error) { - return invokeObjcSelf!(Object, "objectByApplyingXSLT:arguments:error:", NSData, NSDictionary, NSError**)(xslt, arguments, error); + id err; + + if (error) + err = new objc_object; + + Object result = invokeObjcSelf!(Object, "objectByApplyingXSLT:arguments:error:", NSData, NSDictionary, id*)(xslt, arguments, &err); + + if (err) + error = new NSError(err); + + return result; } - Object objectByApplyingXSLTString (NSString xslt, NSDictionary arguments, NSError** error) + Object objectByApplyingXSLTString (NSString xslt, NSDictionary arguments, ref NSError error) { - return invokeObjcSelf!(Object, "objectByApplyingXSLTString:arguments:error:", NSString, NSDictionary, NSError**)(xslt, arguments, error); + id err; + + if (error) + err = new objc_object; + + Object result = invokeObjcSelf!(Object, "objectByApplyingXSLTString:arguments:error:", NSString, NSDictionary, id*)(xslt, arguments, &err); + + if (err) + error = new NSError(err); + + return result; } - Object objectByApplyingXSLTAtURL (NSURL xsltURL, NSDictionary argument, NSError** error) + Object objectByApplyingXSLTAtURL (NSURL xsltURL, NSDictionary argument, ref NSError error) { - return invokeObjcSelf!(Object, "objectByApplyingXSLTAtURL:arguments:error:", NSURL, NSDictionary, NSError**)(xsltURL, argument, error); + id err; + + if (error) + err = new objc_object; + + Object result = invokeObjcSelf!(Object, "objectByApplyingXSLTAtURL:arguments:error:", NSURL, NSDictionary, id*)(xsltURL, argument, &err); + + if (err) + error = new NSError(err); + + return result; } - bool validateAndReturnError (NSError** error) + bool validateAndReturnError (ref NSError error) { - return invokeObjcSelf!(bool, "validateAndReturnError:", NSError**)(error); + id err; + + if (error) + err = new objc_object; + + bool result = invokeObjcSelf!(bool, "validateAndReturnError:", id*)(&err); + + if (err) + error = new NSError(err); + + return result; } }