Find missing scripts in your components and ScriptableObjects more easily by knowing their type.
Once you have the OpenUPM cli, run the following command:
openupm install com.solidalloy.missing-script-type
Or if you don't have it, add the scoped registry to manifest.json with the desired dependency semantic version:
"scopedRegistries": [
{
"name": "package.openupm.com",
"url": "https://package.openupm.com",
"scopes": [
"com.solidalloy",
"com.openupm"
]
}
],
"dependencies": {
"com.solidalloy.missing-script-type": "1.0.1"
},
Project supports Unity Package Manager. To install the project as a Git package do the following:
- In Unity, open Project Settings -> Package Manager.
- Add a new scoped registry with the following details:
- Name: package.openupm.com
- URL: https://package.openupm.com
- Scope(s):
- com.openupm
- com.solidalloy
- Hit Apply.
- Go to Window -> Package Manager.
- Press the + button, Add package from git URL.
- Enter com.solidalloy.missing-script-type, press Add.
When you stumble upon a MonoBehaviour or ScriptableObject with a missing script, it will now look like this:
You will see the type name of the script that had been assigned to this object before it went missing. Note that it will only for the objects where the script had been lost before the package was installed. If the package is installed after the object missed its script, the type field will be empty.
The plugin also searches for a script that contains this type. If the script is found, it will appear on the next line, and you will be able to restore the object in one button press:
You can customize how the type name is shown in Project Settings/Packages/Missing Script Type:
Short - TestBehaviour
Full (default) - DefaultNamespace.TestBehaviour
Full And Assembly - DefaultNamespace.TestBehaviour, Assembly-CSharp
The plugin works with Odin Inspector. When the object script is loaded, you will see the normal Odin interface. When the script is missing, you will be able to see its type.
There is also integration with GenericUnityObjects:
The plugin works through the custom editor called MissingScriptTypeEditor
which is enabled for all MonoBehaviours and ScriptableObjects that don't have their own custom editor.
If you have a custom editor in which you want to implement the "Last Known Type" feature, you can inherit from MissingScriptTypeEditor
:
[CustomEditor(typeof(MyClass))]
public class MyCustomEditor : MissingScriptTypeEditor
{
protected override OnEnable()
{
base.OnEnable();
// your custom enable code
}
public override void OnInspectorGUI()
{
if (_missingScriptUtility.IsScriptLoaded())
{
// your custom inspector UI
}
else
{
_missingScriptUtility.Draw();
}
}
}
Or use MissingScriptTypeUtility
:
[CustomEditor(typeof(MyClass))]
public class MyCustomEditor : Editor
{
private MissingScriptTypeUtility _missingScriptUtility;
protected override OnEnable()
{
_missingScriptUtility = new MissingScriptTypeUtility(serializedObject);
}
public override void OnInspectorGUI()
{
if (_missingScriptUtility.IsScriptLoaded())
{
// your custom inspector UI
}
else
{
_missingScriptUtility.Draw();
}
}
}
If you have another custom editor that you want to use on general MonoBehaviours and ScriptableObjects, you can disable MissingScriptTypeEditor
by adding DISABLE_MISSING_SCRIPT_EDITOR
to Player/Scripting Define Symbols.