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.
Note: it is not possible to 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 may also compromise the efficiency and accuracy of incremental builds or incremental upgrades.
The main difference between this interface and IPreprocessBuildWithReport or Build.IPreprocessBuild is that this callback gets called on AssetBundle builds as well as Player builds.
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. |