Implement this interface to execute code at the start of the Player build or AssetBundle build process.
At the start of a Player build or AssetBundle build, Unity uses the IOrderedCallback.callbackOrder property on each implementation to determine the order in which to invoke the callbacks.
This callback can be useful for automated tasks and ensuring your build environment is correctly configured.
You can't invoke an additional build from inside this callback. To invoke an AssetBundle build at the start of a Player build you should use BuildPlayerProcessor.PrepareForBuild instead.
Example usages include:
Note: Build callbacks are a powerful feature, but it is strongly recommended that their implementations maintain deterministic build outputs.
The result of a build should be predictable and reproducible, based on the project’s content, the Unity version, and installed packages.
Introducing environment-specific behavior, external dependencies, randomness, or other non-deterministic elements can lead to outcomes
that are challenging to debug or reproduce. This unpredictability might compromise the efficiency and accuracy of incremental builds or incremental upgrades.
The main difference between this interface and IPreprocessBuildWithReport or IPreprocessBuild is that this callback gets called on AssetBundle builds and Player builds.
For more information about build callbacks, refer to [Use build callbacks](xref:build-callbacks)
Additional resources: BuildPlayerProcessor.PrepareForBuild, IPostprocessBuildWithContext, BuildPlayerProcessor, BuildPipeline.BuildPlayer, BuildPipeline.BuildAssetBundles
using System; using UnityEditor.Build;
class BuildScheduleEnforcer : IPreprocessBuildWithContext { public int callbackOrder { get { return 100; } } public void OnPreprocessBuild(BuildCallbackContext ctx) { if (DateTime.Now.DayOfWeek == DayOfWeek.Thursday) // Force the build to fail. This message will appear in the console and Editor log. throw new BuildFailedException("No builds are allowed on Thursdays"); } }
| Method | Description |
|---|---|
| OnPreprocessBuild | Implement this method to receive a callback before the build is started. |