Changes to main()
Let’s have a look at the changes to the
main()
function, which still is the starting point for our app. The function now looks like this:main()
uses the new @autoreleasepool { }
syntax introduced with LLVM 3.0, but that change doesn’t concern the app’s launch sequence. More importantly, the call to UIApplicationMain()
changed from UIApplicationMain(argc, argv, nil, nil);
to the one shown above. Note the change in the fourth argument.
Looking at the documentation, we learn that the fourth argument to
UIApplicationMain()
specifiesThe name of the class from which the application delegate is instantiated. … Specifynil
if you load the delegate object from your application’s main nib file.
So apparently our app delegate, which was previously created with Interface Builder inside
MainWindow.xib
, is now created directly by the UIApplicationMain()
function.1 In fact, there isn’t even a MainWindow.xib
file anymore in our project!No MainWindow.xib
Before Xcode 4.2, all default project templates did create a
MainWindow.xib
file. Because this file was specified in the app’s Info.plist
as the main NIB file, the UIApplicationMain()
function would load it automatically right after it had created the UIApplication
instance for the app.
It was then inside the NIB file that both the application delegate object and the app’s main window were created and wired together via outlets. More often than not,
MainWindow.xib
would also include the app’s root view controller, already connected to a custom outlet in the application delegate class and the window’s rootViewController
outlet.
With so much work done inside the main NIB file, the default
application:didFinishLaunchingWithOptions:
method could be kept almost empty. All it had to do was bring the window on screen:
For Xcode 4.2 and later, Apple has decided to remove the main NIB file from the iOS project templates. The immediate reason for this change was most likely the introduction of storyboarding.
Storyboards are based around view controllers, not views or windows. Sticking to the concept of a main NIB file for a storyboard-based app would make no sense (and is impossible since the
Info.plist
keys NSMainNibFile
and UIMainStoryboardFile
are mutually exclusive). And abandoning the main NIB file only for storyboard-based apps but keeping it for others would lead to project templates differ from each other more than necessary.
More Work To Do in application:didFinishLaunchingWithOptions:
With the main NIB file gone, the tasks that were performed in the NIB file must now move elsewhere. We have already seen that
UIApplicationMain()
takes over one of them: the creation of our application delegate. Since the function now has control over both the UIApplication
instance and its delegate, we can also safely assume that it will assign the delegate to the application instance.
At this stage, the
application:didFinishLaunchingWithOptions:
message will be sent. Since nobody has created a window or view controller yet, the method now performs these tasks in code, at least for an app that is not storyboard-based:
If your app uses storyboarding (by specifying a
UIMainStoryboardFile
in Info.plist
), the app will automatically load the main storyboard file at launch, just like the main NIB file. It will also create a window and place the storyboard’s initial view controller inside it, and bring the window on screen. Therefore, there is nothing left to do for us in application:didFinishLaunchingWithOptions:
: