• Open Menu Close Menu
  • Apple
  • Shopping Bag
  • Apple
  • Mac
  • iPad
  • iPhone
  • Watch
  • TV
  • Music
  • Support
  • Search apple.com
  • Shopping Bag

Lists

Open Menu Close Menu
  • Terms and Conditions
  • Lists hosted on this site
  • Email the Postmaster
  • Tips for posting to public mailing lists
Re: Hierarchical defaults in NSUserDefaults?
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Hierarchical defaults in NSUserDefaults?


  • Subject: Re: Hierarchical defaults in NSUserDefaults?
  • From: Christopher Hickman <email@hidden>
  • Date: Sat, 10 Nov 2007 14:25:54 -0500

I had a similar issue and never came up with your solution. That's why I was excited to see NSDictionaryController in Leopard. :)

I think it helps in this regard, though I haven't had an opportunity to try it out yet.

Topher

On Jul 29, 2007, at 7:36 AM, Greg Best wrote:

I never got a response on this, but I think I've found a solution:

I've added an additional NSObjectController to the NIB, binding it's contentObject binding to SharedDefaults, controller key "values", model key path "testPath". I rewired my text box to point to the NSObjectController, controller key "selection", model key path "blah.pi". Having done this, the text box comes up as 3.14.

The next problem was that changing the value didn't cause the plist to be written to Preferences, but it appears that checking "Handles Content as Compound Value" does the trick. Now the plist is written and remembered when the application is relaunched.

The downside of this is I'll need to instantiate a separate controller for each group of preferences I create, but that should be manageable as my Preferences window has its own NIB file.

Hopefully this will help someone else searching the archives. If anyone has any comments on my approach, I'd be interested in hearing them.

Cheers--
 Greg


On Jul 25, 2007, at 12:21 AM, Greg Best wrote:

I've been searching the web for an answer to this, and maybe I'm just not using the right search terms...

I'd prefer not to put all of my defaults into the root level of my preferences file-- it saves me encoding namespaces into the default's key, and hopefully will allow me to pull a dictionary from the defaults database to hand to an initializer in one chunk. I can't get it to bind properly though.

Stripping it down to a basic example, I've got my app delegate with the following code:
#import "appDel.h"


@implementation appDel

+(void)initialize
{
  NSUserDefaults* appDefaults=[NSUserDefaults standardUserDefaults];
  NSMutableDictionary* myDefaults=[NSMutableDictionary dictionary];

[myDefaults setValue:[NSMutableDictionary dictionary] forKey:@"testPath"];
[myDefaults setValue:[NSMutableDictionary dictionary] forKeyPath:@"testPath.blah"];
[myDefaults setValue:@"3.14" forKeyPath:@"testPath.blah.pi"];


[appDefaults registerDefaults:myDefaults];
//check dictionary structure
[myDefaults writeToFile:[@"~/test.plist" stringByExpandingTildeInPath] atomically:true];
}


@end

In the main window in the nib file, I have a single text box bound to Shared User Defaults, controller key is "values", and model key path is "testPath.blah.pi".

When I run, the test.plist file I create in the initialize method is what I'd expect-- it's a plist file containing a dictionary called "testPath", containing a dictionary called "blah" containing a string called "pi" equal to "3.14".

Problem is my text box comes up blank. When I enter a value, that value is retained, but my "com.yourcompany.defaultsTest.plist" preferences file contains only a string called "testPath.blah.pi" which is equal to whatever I put in that text box.

Why isn't my Model Key Path being parsed into it's component elements, and how do I convince the controller to do so?

Thanks--
 Greg

_______________________________________________

Cocoa-dev mailing list (email@hidden)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden

_______________________________________________

Cocoa-dev mailing list (email@hidden)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden

_______________________________________________

Cocoa-dev mailing list (email@hidden)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden


  • Prev by Date: Re: Where are the books?
  • Next by Date: Re: Where are the books?
  • Previous by thread: Re: Where are the books?
  • Next by thread: [Leopard] CoreData fails to save, fails to report error
  • Index(es):
    • Date
    • Thread