What is an umbrella header?

What is basically an umbrella header? What is its use? I got a warning as shown below. What does this mean?

<module-includes>:1:1: warning: umbrella header for module 'XCTest' does not include header 'XCTextCase+AsynchronousTesting.h' [-Wincomplete-umbrella]
#import "/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/Frameworks/XCTest.framework/Headers/XCTest.h"

Solution 1:

The umbrella header is the 'master' header file for a framework. Its use is that you can write

#import <UIKit/UIKit.h>

instead of

#import <UIKit/UIViewController.h>
#import <UIKit/UILabel.h>
#import <UIKit/UIButton.h>
#import <UIKit/UIDatePicker.h>

and so on.

For me, <XCTest/XCTestCase+AsynchronousTesting.h> is included in <XCTest/XCTest.h>. Maybe it is not for you? In that case, add the

#import <XCTest/XCTestCase+AsynchronousTesting.h>

manually.

Solution 2:

umbrella header - iOS framework or library on Objective-C or Swift can have a header file that contains references to all the other headers in that project.

When you create a framework target Xcode will automatically generate <targer_name.h> file. It should has the same name as PRODUCT_NAME

For example <umbrella_name.h> looks like

#import "header_1.h"
#import "header_2.h"

or:

#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>

//! Project version number for SomeModule.
FOUNDATION_EXPORT double SomeModuleVersionNumber;

//! Project version string for SomeModule.
FOUNDATION_EXPORT const unsigned char SomeModuleVersionString[];

// In this header, you should import all the public headers of your framework using statements like #import <SomeModule/PublicHeader.h>

As a result you can use the next syntax

#import <umbrella_name.h>

instead of

#import <header_1.h>
#import <header_2.h>

On practice when you create a Framework on Objective-C[Example] or Swift[Example] this file will be created automatically with <product_name>

Using

1.umbrella header is required by [.modulemap] structure to use module(expose Objective-C headers) for Objective-C or Swift

2.umbrella header can be just used by Objective-C consumer for connivance

3.umbrella header helps to import every Objective-C header into Swift module that is why you can just skip import

Swift sees every header you expose publicly in your umbrella header. The contents of the Objective-C files in that framework are automatically available from any Swift file within that framework target, with no import statements. Use classes and other declarations from your Objective-C code with the same Swift syntax you use for system classes.

Importing Objective-C into Swift within a Framework Target