Version: Unity 6.1 Alpha (6000.1)
Language : English
Building and delivering for macOS
macOS build settings reference

Build a macOS application

Refer to the following instructions and considerations on building your Unity application for macOS.

Target architecture

Before you build an application for macOS, be aware of the chipset differences between Apple devices. Some Apple devices use Intel chipsets and others use Apple silicon. You can use Unity to create both architecture-specific builds and builds that target both Intel and Apple silicon. The available target architectures are:

Architecture Description
Intel 64-bit Use Intel 64-bit to build for Apple devices with Intel chipsets.
Apple silicon Select Apple silicon to build for Apple devices that use the silicon architecture.
Intel 64-bit + Apple silicon Use Intel 64-bit + Apple silicon to generate a macOS build that works on both Intel chipsets and Apple silicon.

Note: This results in a build that’s larger than the individual architecture-specific builds, impacting the application size.

You can set the target architecture for your application from the macOS build settings in the Build ProfilesA set of customizable configuration settings to use when creating a build for your target platform. More info
See in Glossary
window.

Build the application

To build your Unity application, use the following steps:

  1. Open the Build Profiles window from File > Build Profiles.
  2. Select Add Build Profile to open the Platform Browser window. The Platform Browser window presents a list of supported platforms that include desktop, mobile, web, and closed platformsIncludes platforms that require confidentiality and legal agreements with the platform provider for using their developer tools and hardware. These platforms aren’t open to development unless you have an established relationship with the provider. For example PlayStation®, Game Core for Xbox®, and Nintendo®.
    See in Glossary
    .
  3. Select macOS from the list of available platforms. If macOS isn’t an option, select Install with Unity Hub and follow the installation instructions. For information on how to install modules, refer to Add modules.
  4. Set Architecture to the architecture type you want Unity to build your application for.
  5. If you want to create an Xcode project for your application, enable Create Xcode Project.
  6. Select Switch Profile to set the new build profile as the active profile.
  7. Click Build.

Note: If building a macOS application on Windows, you must set the executable flag for the binary before opening the application on macOS.

Duplicate native source files

When building for macOS, using multiple native source files as plug-insA set of code created outside of Unity that creates functionality in Unity. There are two kinds of plug-ins you can use in Unity: Managed plug-ins (managed .NET assemblies created with tools like Visual Studio) and Native plug-ins (platform-specific native code libraries). More info
See in Glossary
with the same name that target the same build will cause a build failure.

For example, if two or more files with the same name target different architectures, such as macOS ARM64 and macOS x64, and you build a Universal app that includes both architectures, the build will fail. This is because both files are included in the build, causing build conflicts.

As Xcode doesn’t support the use of files targeting different architectures, you need to merge your files into one or rename them to ensure they’re compatible with both architectures.

Information property list file

macOS applications require an information property list file called Info.plist that has metadata and configuration information for the application. The file holds a list of key-value pairs.

When Unity builds your application, it creates the Info.plist file. Unity stores this file at ApplicationName.app > Contents > Info.plist. Unity displays required Info.plist configuration properties in the Player SettingsSettings that let you set various player-specific options for the final game built by Unity. More info
See in Glossary
window that you can set before building the application. These properties are in the Other Settings > Mac App Store Options section.

There are additional keys that you can add to your Info.plist file. To add them, build the application and use a text editor to edit the file. For information about the available keys, refer to About Info.plist Keys and Values.

Entitlements

macOS applications require entitlements to specify permissions and restrictions that control specific actions of your application. Your application must include entitlements that result in a Hardened Runtime. These entitlements protect your application from code injection, hijacking of dynamically linked libraries, and memory tampering.

To define entitlements, macOS applications use an XML file with the .entitlements file extension. macOS applications then use a process called code signing to bind the entitlements to an application.

If your application uses plug-ins that perform macOS platform-specific actions, you might need to add entitlements to enable those actions. For more information on what actions require entitlements, refer to Apple Developer Entitlements.

Code signing & notarization

Code signing is the process of creating a code signature for an application. This signature guarantees the integrity of applications and safeguards from any tampering. Apple devices use an application’s code signature to detect changes made after the developer created the code signature. If an application doesn’t have a code signature, the device warns the end user before they open the application. Unity automatically code signs any application it builds for macOS.

Notarization is the process Apple uses to check that Developer ID-signed applications don’t contain malicious content. Digital distribution services often require you to notarize your application before you can share it on their platform. The Mac App Store has a content validation system that’s similar to notarization, which means that applications distributed through the store don’t require prior notarization.

Additional resources

Building and delivering for macOS
macOS build settings reference