A Unity package for zipping builds automatically, and on Windows, fix OSX builds by adding the executable bits in the process.
Install the package according to the installation instructions. Once installed, every OSX build you create, the post processing script will run, zip your build, and if necessary, fixes said build to be able to run on OSX devices.
This package comes with project specific settings, found at Edit > Project Settings... > OSX Zip Options.
| Setting | Description | 
|---|---|
| Zip Creation Method | Which method to use for creating the build zip file. (Windows Editor only). | 
| Zip Compression Level | The compression level to apply when generating the zip file. | 
| Original Build Option | Determines what happens to the original build directory that was used to create the zip file. | 
| WSL Process Timeout | The time (in seconds) until the wsl process times out. | 
| Verbose Logging | If checked, prints additional debugging information about the build process. | 
Windows Subsystem for Linux (WSL) lets developers run a GNU/Linux environment -- including most command-line tools, utilities, and applications -- directly on Windows, unmodified, without the overhead of a traditional virtual machine or dual-boot setup.
Warning
To use this option, WSL has to be installed (preferably an Ubuntu distribution, it's currently the only one we've tested), including the zip package on the standard Distribution of WSL on your device.
- For more information on how to install WSL: https://learn.microsoft.com/en-us/windows/wsl/install/
- For more information on how to install the zippackage on Linux (in this case, WSL): https://www.tecmint.com/install-zip-and-unzip-in-linux/#zipubuntu
Warning
To build on external or secondary drives, you have to make sure to mount those drives in WSL too: https://learn.microsoft.com/en-us/windows/wsl/wsl2-mount-disk/
A Windows-only solution, that zips the build, then edits very specific bytes of the newly created zip, in order to make it compatible with OSX.
| Compression Level | WSL | Zip Manipulation | 
|---|---|---|
| None | No compression ( 0in the zip command) | No compression | 
| Fastest | Fast compression ( 1out of 9 in the zip command) | Fast compression | 
| Optimal | Best compression ( 9out of 9 in the zip command) | Best compression | 
Open the Package Manager window, click on "Add Package from Git URL ...", then enter the following:
https://github.com/u-plus-one/unityosxbuild.git
Add the following line to your project's Packages/manifest.json:
"com.github.u-plus-one.unityosxbuild": "https://github.com/u-plus-one/unityosxbuild.git"You can also download this repository and extract the Editor directory file anywhere inside your project's Assets folder. (The folder must be named 'Editor' for it to work)
Any build for OSX (otherwise known as MacOS) built on Windows devices, do in general not work. Instead, you get presented with an error, saying The application "game-name" can't be opened, with no more information.
The reason why OSX builds built on Windows do not work on OSX, is the fact that Windows does not keep track of unix-specific file attributes (read/write/execute attributes), which are needed for OSX to run an executable. This executable attribute generally can only be added on Unix devices, which both Linux and OSX devices are. The only current solutions for creating an OSX build, are building on either Linux or OSX itself.
This package automatically creates a zip from the mac build and restores the executable bits, which get lost since Windows does not support them.
If you use the WSL Zip Creation Method, it utilises the Windows Subsystem for Linux to zip the build, so OSX knows how to read, unpack, and fix all files, hence adding the executable bit. It's possible to manually add the executable bit to a file on Linux too, with the chmod command. If WSL is already installed on the system, this is the recommended method.
The Zip Manipulation method, instead, is a Windows-only solution. Instead of relying on a Unix system, it zips the build first, then edits the zip itself and its entries (the files inside), to restore the missing file attributes. To make sure everything works as expected on OSX when unzipping this zip, it changes the zip's Host OS to Unix too, to ensure the required file attributes are applied.
Warning
The zip file should never be unzipped in a Windows environment, since it causes the file attributes to get lost, even when zipped again. Editing the zip's contents with an application (e.g. WinRAR) should be fine.
The zip creation process runs at the very end of the build process, meaning that all changes made during a IPostProcessBuild script are included in the build.
@lajawi - Unix attributes research, WSL zipper
@d3tonat0r - Package structure, Manual zip builder