diff dstep/foundation/NSUserDefaults.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 7ff919f595d5
children b9de51448c6b
line wrap: on
line diff
--- a/dstep/foundation/NSUserDefaults.d	Mon Aug 03 15:31:48 2009 +0200
+++ b/dstep/foundation/NSUserDefaults.d	Sun Jan 03 22:06:11 2010 +0100
@@ -9,55 +9,78 @@
 import dstep.foundation.NSArray;
 import dstep.foundation.NSData;
 import dstep.foundation.NSDictionary;
-import dstep.foundation.NSMutableDictionary;
+import dstep.foundation.NSObjCRuntime;
 import dstep.foundation.NSObject;
 import dstep.foundation.NSString;
 import dstep.objc.bridge.Bridge;
-import dstep.objc.objc : id;
+import dstep.objc.objc;
+
+
 
 import bindings = dstep.foundation.NSUserDefaults_bindings;
 
-const NSString NSGlobalDomain;
-const NSString NSArgumentDomain;
-const NSString NSRegistrationDomain;
-const NSString NSUserDefaultsDidChangeNotification;
+private
+{
+	NSString NSGlobalDomain_;
+	NSString NSArgumentDomain_;
+	NSString NSRegistrationDomain_;
+	NSString NSUserDefaultsDidChangeNotification_;
+}
+
+NSString NSGlobalDomain ()
+{
+	if (NSGlobalDomain_)
+		return NSGlobalDomain_;
+		
+	return NSGlobalDomain_ = new NSString(bindings.NSGlobalDomain);
+}
 
-static this ()
+NSString NSArgumentDomain ()
+{
+	if (NSArgumentDomain_)
+		return NSArgumentDomain_;
+		
+	return NSArgumentDomain_ = new NSString(bindings.NSArgumentDomain);
+}
+
+NSString NSRegistrationDomain ()
 {
-	NSGlobalDomain = new NSString(bindings.NSGlobalDomain);
-	NSArgumentDomain = new NSString(bindings.NSArgumentDomain);
-	NSRegistrationDomain = new NSString(bindings.NSRegistrationDomain);
-	NSUserDefaultsDidChangeNotification = new NSString(bindings.NSUserDefaultsDidChangeNotification);
+	if (NSRegistrationDomain_)
+		return NSRegistrationDomain_;
+		
+	return NSRegistrationDomain_ = new NSString(bindings.NSRegistrationDomain);
+}
+
+NSString NSUserDefaultsDidChangeNotification ()
+{
+	if (NSUserDefaultsDidChangeNotification_)
+		return NSUserDefaultsDidChangeNotification_;
+		
+	return NSUserDefaultsDidChangeNotification_ = new NSString(bindings.NSUserDefaultsDidChangeNotification);
 }
 
 class NSUserDefaults : NSObject
 {
-	mixin ObjcWrap;
+	mixin (ObjcWrap);
+	
+	this ()
+	{
+		super(typeof(this).alloc.init.objcObject);
+	}
+	
+	typeof(this) init ()
+	{
+		return invokeObjcSelf!(typeof(this), "init");
+	}
 
 	static NSUserDefaults standardUserDefaults ()
 	{
-		return invokeObjcSelfClass!(NSUserDefaults, "standardUserDefaults");
+		return invokeObjcSuperClass!(NSUserDefaults, "standardUserDefaults");
 	}
 
 	static void resetStandardUserDefaults ()
 	{
-		return invokeObjcSelfClass!(void, "resetStandardUserDefaults");
-	}
-
-	Object init ()
-	{
-		return invokeObjcSelf!(Object, "init");
-	}
-
-	this ()
-	{
-		objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass);
-		id result = Bridge.invokeObjcMethod!(id, "init")(objcObject);
-
-		if (result)
-			objcObject = ret;
-
-		dObject = this;
+		return invokeObjcSuperClass!(void, "resetStandardUserDefaults");
 	}
 
 	Object initWithUser (NSString username)
@@ -67,13 +90,7 @@
 
 	this (NSString username)
 	{
-		objcObject = Bridge.invokeObjcClassMethod!(id, "alloc")(objcClass);
-		id result = Bridge.invokeObjcMethod!(id, "initWithUser:", NSString)(objcObject, username);
-
-		if (result)
-			objcObject = ret;
-
-		dObject = this;
+		typeof(this).alloc.initWithUser(username);
 	}
 
 	Object objectForKey (NSString defaultName)