mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2025-01-18 04:10:06 +08:00
104 lines
3.1 KiB
C#
104 lines
3.1 KiB
C#
|
using System;
|
|||
|
using nadena.dev.modular_avatar.core.editor;
|
|||
|
using UnityEditor;
|
|||
|
using UnityEngine;
|
|||
|
using UnityEngine.SceneManagement;
|
|||
|
using UnityEngine.UIElements;
|
|||
|
|
|||
|
namespace nadena.dev.modular_avatar.editor.ErrorReporting
|
|||
|
{
|
|||
|
internal class ErrorElement : Box
|
|||
|
{
|
|||
|
private readonly ErrorLog log;
|
|||
|
|
|||
|
Texture2D GetIcon()
|
|||
|
{
|
|||
|
switch (log.reportLevel)
|
|||
|
{
|
|||
|
case ReportLevel.Info:
|
|||
|
return EditorGUIUtility.FindTexture("d_console.infoicon");
|
|||
|
case ReportLevel.Warning:
|
|||
|
return EditorGUIUtility.FindTexture("d_console.warnicon");
|
|||
|
default:
|
|||
|
return EditorGUIUtility.FindTexture("d_console.erroricon");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
public ErrorElement(ErrorLog log, ObjectRefLookupCache cache)
|
|||
|
{
|
|||
|
this.log = log;
|
|||
|
|
|||
|
AddToClassList("ErrorElement");
|
|||
|
var tex = GetIcon();
|
|||
|
if (tex != null)
|
|||
|
{
|
|||
|
var image = new Image();
|
|||
|
image.image = tex;
|
|||
|
Add(image);
|
|||
|
}
|
|||
|
|
|||
|
var inner = new Box();
|
|||
|
Add(inner);
|
|||
|
|
|||
|
var label = new Label(GetLabelText());
|
|||
|
inner.Add(label);
|
|||
|
|
|||
|
foreach (var obj in log.referencedObjects)
|
|||
|
{
|
|||
|
var referenced = obj.Lookup(cache);
|
|||
|
if (referenced != null)
|
|||
|
{
|
|||
|
inner.Add(new SelectionButton(obj.typeName, referenced));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (!string.IsNullOrWhiteSpace(log.stacktrace))
|
|||
|
{
|
|||
|
var foldout = new Foldout();
|
|||
|
foldout.text = Localization.S("error.stack_trace");
|
|||
|
var field = new TextField();
|
|||
|
field.value = log.stacktrace;
|
|||
|
field.isReadOnly = true;
|
|||
|
field.multiline = true;
|
|||
|
foldout.Add(field);
|
|||
|
foldout.value = false;
|
|||
|
inner.Add(foldout);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
private static GameObject FindObject(string path)
|
|||
|
{
|
|||
|
var scene = SceneManager.GetActiveScene();
|
|||
|
foreach (var root in scene.GetRootGameObjects())
|
|||
|
{
|
|||
|
if (root.name == path) return root;
|
|||
|
if (path.StartsWith(root.name + "/"))
|
|||
|
{
|
|||
|
return root.transform.Find(path.Substring(root.name.Length + 1))?.gameObject;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return null;
|
|||
|
}
|
|||
|
|
|||
|
private string GetLabelText()
|
|||
|
{
|
|||
|
var objArray = new object[log.substitutions.Length];
|
|||
|
for (int i = 0; i < log.substitutions.Length; i++)
|
|||
|
{
|
|||
|
objArray[i] = log.substitutions[i];
|
|||
|
}
|
|||
|
|
|||
|
try
|
|||
|
{
|
|||
|
return string.Format(Localization.S(log.messageCode), objArray);
|
|||
|
}
|
|||
|
catch (FormatException e)
|
|||
|
{
|
|||
|
Debug.LogError("Error formatting message code: " + log.messageCode);
|
|||
|
Debug.LogException(e);
|
|||
|
return log.messageCode + "\n" + string.Join("\n", objArray);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|