BuildReport
class in
UnityEditor.Build.Reporting
/
Inherits from:Object
Suggest a change
Success!
Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.
Close
Submission failed
For some reason your suggested change could not be submitted. Please <a>try again</a> in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.
Close
Description
The BuildReport API gives you information about the Unity build process.
A BuildReport object is returned by BuildPipeline.BuildPlayer and can be used to discover information about the files output, the build steps taken, and other platform-specific information such as native code stripping.
For AssetBundle builds the BuildReport is available by calling GetLatestReport immediately after calling BuildPipeline.BuildAssetBundles.
using System.IO;
using System.Linq;
using System.Text;
using UnityEditor;
using UnityEditor.Build;
using UnityEditor.Build.Reporting;
using UnityEngine;
public class BuildReportExample
{
[MenuItem("Example/Build AssetBundle")]
static public void BuildBundles()
{
string buildOutputDirectory = "BuildOutput";
if (!Directory.Exists(buildOutputDirectory))
Directory.CreateDirectory(buildOutputDirectory);
var bundleDefinitions = new AssetBundleBuild[]
{
new AssetBundleBuild()
{
assetBundleName = "MyBundle",
assetNames = new string[] { "Assets/Scenes/SampleScene.unity" }
}
};
BuildPipeline.BuildAssetBundles(
buildOutputDirectory,
bundleDefinitions,
BuildAssetBundleOptions.ForceRebuildAssetBundle,
EditorUserBuildSettings.activeBuildTarget);
BuildReport report = BuildReport.GetLatestReport();
if (report != null)
{
var sb = new StringBuilder();
sb.AppendLine("Build result : " + report.summary.result);
sb.AppendLine("Build size : " + report.summary.totalSize + " bytes");
sb.AppendLine("Build time : " + report.summary.totalTime);
sb.AppendLine("Error summary : " + report.SummarizeErrors());
sb.Append(LogBuildReportSteps(report));
sb.AppendLine(LogBuildMessages(report));
Debug.Log(sb.ToString());
}
else
{
// Certain errors like invalid input can fail the build immediately, with no BuildReport written
Debug.Log("AssetBundle build failed");
}
}
public static string LogBuildReportSteps(BuildReport buildReport)
{
var sb = new StringBuilder();
sb.AppendLine($"Build steps: {buildReport.steps.Length}");
int maxWidth = buildReport.steps.Max(s => s.name.Length + s.depth) + 3;
foreach (var step in buildReport.steps)
{
string rawStepOutput = new string('-', step.depth + 1) + ' ' + step.name;
sb.AppendLine($"{rawStepOutput.PadRight(maxWidth)}: {step.duration:g}");
}
return sb.ToString();
}
public static string LogBuildMessages(BuildReport buildReport)
{
var sb = new StringBuilder();
foreach (var step in buildReport.steps)
{
foreach (var message in step.messages)
// If desired, this logic could ignore any Info or Warning messages to focus on more serious messages
sb.AppendLine($"[{message.type}] {message.content}");
}
string messages = sb.ToString();
if (messages.Length > 0)
return "Messages logged during Build:\n" + messages;
else
return "";
}
}
Properties
packedAssets | An array of all the PackedAssets generated by the build process. |
scenesUsingAssets | An optional array of ScenesUsingAssets generated by the build process if BuildOptions.DetailedBuildReport was used during the build. |
steps | An array of all the BuildSteps that took place during the build process. |
strippingInfo | The StrippingInfo object for the build. |
summary | A BuildSummary containing overall statistics and data about the build process. |
Public Methods
GetFiles | Returns an array of all the files output by the build process. |
SummarizeErrors | Returns a string summarizing any errors that occurred during the build |
Static Methods
GetLatestReport | Return the build report generated by the most recent Player or AssetBundle build |
Inherited Members
Properties
hideFlags | Should the object be hidden, saved with the Scene or modifiable by the user? |
name | The name of the object. |
Operators
bool | Does the object exist? |
operator != | Compares if two objects refer to a different object. |
operator == | Compares two object references to see if they refer to the same object. |