Feeds

A better way to build OS X preferences

Behind the interface

3 Big data security analytics techniques

Mac Secrets Welcome to Dave Jewell’s new Mac Secrets column, focused at Apple Mac developers — particularly those using Cocoa. Here, on a regular basis, Dave will introduce you to unknown and undocumented aspects of the Foundation and AppKit class libraries that Apple has, er, neglected to tell you about…

In my opinion, there’s no sense in re-inventing the wheel if Apple has already done the job for you. Over the coming months you’ll find there are an amazing number of undocumented wheels within the Apple libraries that let you get on with writing great applications without having to reinvent what Apple have already done. They are just waiting for you to set ’em spinning!

At this point, a few folks will doubtless be sharpening their quill pens (or even wooden stakes!) and preparing to chastise me for using undocumented features. After all, it’s possible that the techniques I’m going to describe may not work in some future version of the operating system, right? That’s true, but I’d offer a couple of counter arguments in return.

First, Leopard (OS X 10.5) has only recently been released, and is likely to be good for several years — it’s very unlikely that minor system updates would impact what I’m describing here. And if they do, I’ll obviously make every effort to bring you a workaround.

Next, and more importantly, you can spend more time making your great Mac application even greater — and surely that’s what we’d all like to see, including Apple. Right, Apple?

Implementing preference dialogs

Let’s start by taking a look at preference dialogs. As you’ll know, the standard way of building a preference dialog is to create a window complete with toolbar buttons for each “page” of preferences. You can see an example of this in the advanced portion of the Safari preferences dialog box (below).

Mac preferences windows

A preference dialog box from Safari

In recent years, the mechanics of automatically saving and loading your application preferences have become easier, largely due to the introduction of Cocoa bindings. You can read more on this here. What I’m concerned with in this article, however, is the user interface rather than persistence issues.

There are really two undocumented classes we need to focus on here. These are NSPreferences and NSPreferencesModule. You can think of the former as a sort of supervisory class that handles the display of the preferences window. Most of the real work is done by this class, but — for our purposes — the interface is extremely simple. You will typically have one subclass of NSPreferences, and it will be instantiated by AppKit, not by you.

The other class, NSPreferencesModule, corresponds to one page of your tabbed preferences dialog. If you’ve got three preference categories (for example), then you’ll need three subclasses of NSPreferencesModule. Again, you don’t need to instantiate them.

SANS - Survey on application security programs

More from The Register

next story
Android engineer: We DIDN'T copy Apple OR follow Samsung's orders
Veep testifies for Samsung during Apple patent trial
This time it's 'Personal': new Office 365 sub covers just two devices
Redmond also brings Office into Google's back yard
Batten down the hatches, Ubuntu 14.04 LTS due in TWO DAYS
Admins dab straining server brows in advance of Trusty Tahr's long-term support landing
Microsoft lobs pre-release Windows Phone 8.1 at devs who dare
App makers can load it before anyone else, but if they do they're stuck with it
Half of Twitter's 'active users' are SILENT STALKERS
Nearly 50% have NEVER tweeted a word
Internet-of-stuff startup dumps NoSQL for ... SQL?
NoSQL taste great at first but lacks proper nutrients, says startup cloud whiz
Windows 8.1, which you probably haven't upgraded to yet, ALREADY OBSOLETE
Pre-Update versions of new Windows version will no longer support patches
Microsoft TIER SMEAR changes app prices whether devs ask or not
Some go up, some go down, Redmond goes silent
Red Hat to ship RHEL 7 release candidate with a taste of container tech
Grab 'near-final' version of next Enterprise Linux next week
Ditch the sync, paddle in the Streem: Upstart offers syncless sharing
Upload, delete and carry on sharing afterwards?
prev story

Whitepapers

Designing a defence for mobile apps
In this whitepaper learn the various considerations for defending mobile applications; from the mobile application architecture itself to the myriad testing technologies needed to properly assess mobile applications risk.
3 Big data security analytics techniques
Applying these Big Data security analytics techniques can help you make your business safer by detecting attacks early, before significant damage is done.
Five 3D headsets to be won!
We were so impressed by the Durovis Dive headset we’ve asked the company to give some away to Reg readers.
The benefits of software based PBX
Why you should break free from your proprietary PBX and how to leverage your existing server hardware.
Securing web applications made simple and scalable
In this whitepaper learn how automated security testing can provide a simple and scalable way to protect your web applications.