Committed everything

This commit is contained in:
2021-06-30 21:39:19 +10:00
commit fcfa8e7213
525 changed files with 49440 additions and 0 deletions

View File

@@ -0,0 +1,60 @@
using UnityEngine;
using UnityEditor;
using System;
using System.Collections.Generic;
using System.Reflection;
namespace Ink.UnityIntegration {
[CustomEditor(typeof(DefaultAsset), true)]
public class DefaultAssetEditor : Editor {
private DefaultAssetInspector inspector;
private void OnEnable () {
inspector = FindObjectInspector ();
if(inspector != null) {
inspector.editor = this;
inspector.serializedObject = serializedObject;
inspector.target = target;
inspector.OnEnable();
}
}
private void OnDisable () {
if(inspector != null)
inspector.OnDisable();
}
protected override void OnHeaderGUI () {
if(inspector != null) {
inspector.OnHeaderGUI();
}
else
base.OnHeaderGUI();
}
public override void OnInspectorGUI () {
if(inspector != null) {
GUI.enabled = true;
inspector.OnInspectorGUI();
}
else
base.OnInspectorGUI();
}
private DefaultAssetInspector FindObjectInspector () {
var assembly = Assembly.GetExecutingAssembly();
var assetPath = AssetDatabase.GetAssetPath(target);
foreach(var type in assembly.GetTypes()) {
if(type.IsSubclassOf(typeof(DefaultAssetInspector))) {
DefaultAssetInspector objectInspector = (DefaultAssetInspector)Activator.CreateInstance(type);
if(objectInspector.IsValid(assetPath)) {
objectInspector.target = target;
return objectInspector;
}
}
}
return null;
}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: fe3507ae5d970447197e131c39ac31b6
timeCreated: 1464440328
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,19 @@
using UnityEngine;
using UnityEditor;
namespace Ink.UnityIntegration {
public abstract class DefaultAssetInspector {
// Reference to the actual editor we draw to
public Editor editor;
// Shortcut to the target object
public Object target;
// Shortcut to the serializedObject
public SerializedObject serializedObject;
public abstract bool IsValid(string assetPath);
public virtual void OnEnable () {}
public virtual void OnDisable () {}
public virtual void OnHeaderGUI () {}
public virtual void OnInspectorGUI() {}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: 7fa6f007190b6408c8aebb32050a3bbe
timeCreated: 1470299519
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,418 @@
using UnityEngine;
using UnityEditor;
using System;
using System.IO;
using System.Linq;
using System.Collections.Generic;
using UnityEditorInternal;
using Object = UnityEngine.Object;
namespace Ink.UnityIntegration {
public class InkInspector : DefaultAssetInspector {
private InkFile inkFile;
private ReorderableList includesFileList;
private ReorderableList mastersFileList;
private ReorderableList errorList;
private ReorderableList warningList;
private ReorderableList todosList;
private string cachedTrimmedFileContents;
private const int maxCharacters = 16000;
public override bool IsValid(string assetPath) {
return Path.GetExtension(assetPath) == InkEditorUtils.inkFileExtension;
}
public override void OnHeaderGUI () {
GUILayout.BeginHorizontal();
GUILayout.Space(38f);
GUILayout.BeginVertical();
GUILayout.Space(19f);
GUILayout.BeginHorizontal();
GUILayoutUtility.GetRect(10f, 10f, 16f, 16f, EditorStyles.layerMaskField);
GUILayout.FlexibleSpace();
EditorGUI.BeginDisabledGroup(inkFile == null);
if (GUILayout.Button("Open", EditorStyles.miniButton)) {
AssetDatabase.OpenAsset(inkFile.inkAsset, 3);
GUIUtility.ExitGUI();
}
EditorGUI.EndDisabledGroup();
GUILayout.EndHorizontal();
GUILayout.EndVertical();
GUILayout.EndHorizontal();
Rect lastRect = GUILayoutUtility.GetLastRect();
Rect rect = new Rect(lastRect.x, lastRect.y, lastRect.width, lastRect.height);
Rect iconRect = new Rect(rect.x + 6f, rect.y + 6f, 32f, 32f);
GUI.DrawTexture(iconRect, InkBrowserIcons.inkFileIconLarge);
Rect childIconRect = new Rect(iconRect.x, iconRect.y, 16f, 16f);
if(inkFile == null) {
GUI.DrawTexture(childIconRect, InkBrowserIcons.unknownFileIcon, ScaleMode.ScaleToFit);
} else if(!inkFile.isMaster) {
GUI.DrawTexture(childIconRect, InkBrowserIcons.childIconLarge, ScaleMode.ScaleToFit);
}
Rect titleRect = new Rect(rect.x + 44f, rect.y + 6f, rect.width - 44f - 38f - 4f, 16f);
titleRect.yMin -= 2f;
titleRect.yMax += 2f;
GUI.Label(titleRect, editor.target.name, EditorStyles.largeLabel);
}
public override void OnEnable () {
Rebuild();
InkCompiler.OnCompileInk += OnCompileInk;
}
public override void OnDisable () {
InkCompiler.OnCompileInk -= OnCompileInk;
}
void OnCompileInk (InkFile inkFile) {
Rebuild();
}
void Rebuild () {
cachedTrimmedFileContents = "";
string assetPath = AssetDatabase.GetAssetPath(target);
inkFile = InkLibrary.GetInkFileWithPath(assetPath);
if(inkFile == null)
return;
if (inkFile.includes.Count > 0) CreateIncludeList ();
else includesFileList = null;
if (inkFile.masterInkAssets.Count > 0) CreateMastersList ();
else mastersFileList = null;
CreateErrorList();
CreateWarningList();
CreateTodoList();
cachedTrimmedFileContents = inkFile.GetFileContents();
cachedTrimmedFileContents = cachedTrimmedFileContents.Substring(0, Mathf.Min(cachedTrimmedFileContents.Length, maxCharacters));
if(cachedTrimmedFileContents.Length >= maxCharacters)
cachedTrimmedFileContents += "...\n\n<...etc...>";
}
void CreateIncludeList () {
List<DefaultAsset> includeTextAssets = inkFile.includes;
includesFileList = new ReorderableList(includeTextAssets, typeof(DefaultAsset), false, false, false, false);
includesFileList.drawHeaderCallback = (Rect rect) => {
EditorGUI.LabelField(rect, "Included Files");
};
includesFileList.drawElementCallback = (Rect rect, int index, bool isActive, bool isFocused) => {
DefaultAsset childAssetFile = ((List<DefaultAsset>)includesFileList.list)[index];
if(childAssetFile == null) {
Debug.LogError("Ink file in include list is null. This should never occur. Use Assets > Recompile Ink to fix this issue.");
EditorGUI.LabelField(rect, new GUIContent("Warning: Ink File in include list is null. Use Assets > Recompile Ink to fix this issue."));
return;
}
InkFile childInkFile = InkLibrary.GetInkFileWithFile(childAssetFile);
if(childInkFile == null) {
Debug.LogError("Ink File for included file "+childAssetFile+" not found. This should never occur. Use Assets > Recompile Ink to fix this issue.");
EditorGUI.LabelField(rect, new GUIContent("Warning: Ink File for included file "+childAssetFile+" not found. Use Assets > Recompile Ink to fix this issue."));
return;
}
Rect iconRect = new Rect(rect.x, rect.y, 0, 16);
if(childInkFile.hasErrors || childInkFile.hasWarnings) {
iconRect.width = 20;
}
Rect objectFieldRect = new Rect(iconRect.xMax, rect.y, rect.width - iconRect.width - 80, 16);
Rect selectRect = new Rect(objectFieldRect.xMax, rect.y, 80, 16);
if(childInkFile.hasErrors) {
EditorGUI.LabelField(iconRect, new GUIContent(InkBrowserIcons.errorIcon));
} else if(childInkFile.hasWarnings) {
EditorGUI.LabelField(iconRect, new GUIContent(InkBrowserIcons.warningIcon));
}
EditorGUI.BeginDisabledGroup(true);
EditorGUI.ObjectField(objectFieldRect, childAssetFile, typeof(Object), false);
EditorGUI.EndDisabledGroup();
if(GUI.Button(selectRect, "Select")) {
Selection.activeObject = childAssetFile;
}
};
}
void CreateMastersList () {
List<DefaultAsset> mastersTextAssets = inkFile.masterInkAssets;
mastersFileList = new ReorderableList(mastersTextAssets, typeof(DefaultAsset), false, false, false, false);
mastersFileList.drawHeaderCallback = (Rect rect) => {
EditorGUI.LabelField(rect, "Master Files");
};
mastersFileList.drawElementCallback = (Rect rect, int index, bool isActive, bool isFocused) => {
DefaultAsset masterAssetFile = ((List<DefaultAsset>)mastersFileList.list)[index];
if(masterAssetFile == null) {
Debug.LogError("Ink file in masters list is null. This should never occur. Use Assets > Recompile Ink to fix this issue.");
EditorGUI.LabelField(rect, new GUIContent("Warning: Ink File in masters list is null. Use Assets > Recompile Ink to fix this issue."));
return;
}
InkFile masterInkFile = InkLibrary.GetInkFileWithFile(masterAssetFile);
if(masterInkFile == null) {
Debug.LogError("Ink File for master file "+masterAssetFile+" not found. This should never occur. Use Assets > Recompile Ink to fix this issue.");
EditorGUI.LabelField(rect, new GUIContent("Warning: Ink File for master file "+masterAssetFile+" not found. Use Assets > Recompile Ink to fix this issue."));
return;
}
Rect iconRect = new Rect(rect.x, rect.y, 0, 16);
if(masterInkFile.hasErrors || masterInkFile.hasWarnings) {
iconRect.width = 20;
}
Rect objectFieldRect = new Rect(iconRect.xMax, rect.y, rect.width - iconRect.width - 80, 16);
Rect selectRect = new Rect(objectFieldRect.xMax, rect.y, 80, 16);
if(masterInkFile.hasErrors) {
EditorGUI.LabelField(iconRect, new GUIContent(InkBrowserIcons.errorIcon));
} else if(masterInkFile.hasWarnings) {
EditorGUI.LabelField(iconRect, new GUIContent(InkBrowserIcons.warningIcon));
}
EditorGUI.BeginDisabledGroup(true);
EditorGUI.ObjectField(objectFieldRect, masterAssetFile, typeof(Object), false);
EditorGUI.EndDisabledGroup();
if(GUI.Button(selectRect, "Select")) {
Selection.activeObject = masterAssetFile;
}
// foreach(var masterInkFile in inkFile.masterInkFiles) {
// EditorGUILayout.BeginHorizontal();
// if(masterInkFile.hasErrors) {
// GUILayout.Label(new GUIContent(InkBrowserIcons.errorIcon), GUILayout.Width(20));
// } else if(masterInkFile.hasWarnings) {
// GUILayout.Label(new GUIContent(InkBrowserIcons.warningIcon), GUILayout.Width(20));
// }
// EditorGUI.BeginDisabledGroup(true);
// EditorGUILayout.ObjectField("Master Ink File", masterInkFile.inkAsset, typeof(Object), false);
// EditorGUI.EndDisabledGroup();
// if(GUILayout.Button("Select", GUILayout.Width(80))) {
// Selection.activeObject = masterInkFile.inkAsset;
// }
// EditorGUILayout.EndHorizontal();
// }
};
}
void CreateErrorList () {
errorList = new ReorderableList(inkFile.errors, typeof(string), false, false, false, false);
errorList.elementHeight = 18;
errorList.drawHeaderCallback = (Rect rect) => {
EditorGUI.LabelField(rect, new GUIContent(InkBrowserIcons.errorIcon), new GUIContent("Errors"));
};
errorList.drawElementCallback = (Rect rect, int index, bool isActive, bool isFocused) => {
Rect labelRect = new Rect(rect.x, rect.y, rect.width - 80, rect.height);
Rect buttonRect = new Rect(labelRect.xMax, rect.y, 80, rect.height-2);
InkCompilerLog log = ((List<InkCompilerLog>)errorList.list)[index];
string label = log.content;
GUI.Label(labelRect, label);
string openLabel = "Open"+ (log.lineNumber == -1 ? "" : " ("+log.lineNumber+")");
if(GUI.Button(buttonRect, openLabel)) {
OpenInEditor(inkFile.filePath, log.lineNumber);
}
};
}
void CreateWarningList () {
warningList = new ReorderableList(inkFile.warnings, typeof(string), false, false, false, false);
warningList.elementHeight = 18;
warningList.drawHeaderCallback = (Rect rect) => {
EditorGUI.LabelField(rect, new GUIContent(InkBrowserIcons.warningIcon), new GUIContent("Warnings"));
};
warningList.drawElementCallback = (Rect rect, int index, bool isActive, bool isFocused) => {
Rect labelRect = new Rect(rect.x, rect.y, rect.width - 80, rect.height);
Rect buttonRect = new Rect(labelRect.xMax, rect.y, 80, rect.height-2);
InkCompilerLog log = ((List<InkCompilerLog>)warningList.list)[index];
string label = log.content;
GUI.Label(labelRect, label);
string openLabel = "Open"+ (log.lineNumber == -1 ? "" : " ("+log.lineNumber+")");
if(GUI.Button(buttonRect, openLabel)) {
OpenInEditor(inkFile.filePath, log.lineNumber);
}
};
}
void CreateTodoList () {
todosList = new ReorderableList(inkFile.todos, typeof(string), false, false, false, false);
todosList.elementHeight = 18;
todosList.drawHeaderCallback = (Rect rect) => {
EditorGUI.LabelField(rect, "To do");
};
todosList.drawElementCallback = (Rect rect, int index, bool isActive, bool isFocused) => {
Rect labelRect = new Rect(rect.x, rect.y, rect.width - 80, rect.height);
Rect buttonRect = new Rect(labelRect.xMax, rect.y, 80, rect.height-2);
InkCompilerLog log = ((List<InkCompilerLog>)todosList.list)[index];
string label = log.content;
GUI.Label(labelRect, label);
string openLabel = "Open"+ (log.lineNumber == -1 ? "" : " ("+log.lineNumber+")");
if(GUI.Button(buttonRect, openLabel)) {
OpenInEditor(inkFile.filePath, log.lineNumber);
}
};
}
static void OpenInEditor (string filePath, int lineNumber) {
#if UNITY_2019_1_OR_NEWER
// This function replaces OpenFileAtLineExternal, but I guess it's totally internal and can't be accessed.
// CodeEditorUtility.Editor.Current.OpenProject(filePath, lineNumber);
#pragma warning disable
UnityEditorInternal.InternalEditorUtility.OpenFileAtLineExternal(filePath, lineNumber);
#pragma warning restore
#else
UnityEditorInternal.InternalEditorUtility.OpenFileAtLineExternal(filePath, lineNumber);
#endif
}
public override void OnInspectorGUI () {
editor.Repaint();
serializedObject.Update();
if(inkFile == null) {
EditorGUILayout.HelpBox("Ink File is not in library.", MessageType.Warning);
if(GUILayout.Button("Rebuild Library")) {
InkLibrary.Rebuild();
Rebuild();
}
return;
}
if(InkCompiler.GetCompilationStackItem(inkFile) != null) {
EditorGUILayout.HelpBox("File is compiling...", MessageType.Info);
return;
}
if(inkFile.isMaster) {
DrawMasterFileHeader();
DrawEditAndCompileDates(inkFile);
if(inkFile.hasUnhandledCompileErrors) {
EditorGUILayout.HelpBox("Last compiled failed", MessageType.Error);
} if(inkFile.hasErrors) {
EditorGUILayout.HelpBox("Last compiled had errors", MessageType.Error);
} else if(inkFile.hasWarnings) {
EditorGUILayout.HelpBox("Last compile had warnings", MessageType.Warning);
} else if(inkFile.jsonAsset == null) {
EditorGUILayout.HelpBox("Ink file has not been compiled", MessageType.Warning);
}
if(inkFile.requiresCompile && GUILayout.Button("Compile")) {
InkCompiler.CompileInk(inkFile);
}
DrawIncludedFiles();
DrawCompileErrors();
DrawErrors();
DrawWarnings();
DrawTODOList();
} else {
DrawSubFileHeader();
}
DrawFileContents ();
serializedObject.ApplyModifiedProperties();
}
void DrawMasterFileHeader () {
EditorGUILayout.LabelField("Master File", EditorStyles.boldLabel);
if(!InkSettings.instance.compileAutomatically) {
inkFile.compileAutomatically = EditorGUILayout.Toggle("Compile Automatially", inkFile.compileAutomatically);
EditorApplication.RepaintProjectWindow();
}
EditorGUI.BeginDisabledGroup(true);
EditorGUILayout.ObjectField("JSON Asset", inkFile.jsonAsset, typeof(TextAsset), false);
EditorGUI.EndDisabledGroup();
if(inkFile.jsonAsset != null && inkFile.errors.Count == 0 && GUILayout.Button("Play")) {
InkPlayerWindow.LoadAndPlay(inkFile.jsonAsset);
}
// if(!checkedStoryForErrors) {
// if(GUILayout.Button("Check for errors")) {
// GetStoryErrors();
// }
// } else {
// if(exception != null) {
// EditorGUILayout.HelpBox("Story is invalid\n"+exception.ToString(), MessageType.Error);
// } else {
// EditorGUILayout.HelpBox("Story is valid", MessageType.Info);
// }
// }
}
void DrawSubFileHeader() {
EditorGUILayout.LabelField("Include File", EditorStyles.boldLabel);
if(mastersFileList != null && mastersFileList.count > 0) {
mastersFileList.DoLayoutList();
}
}
void DrawEditAndCompileDates (InkFile masterInkFile) {
string editAndCompileDateString = "";
DateTime lastEditDate = inkFile.lastEditDate;
editAndCompileDateString += "Last edit date "+lastEditDate.ToString();
if(masterInkFile.jsonAsset != null) {
DateTime lastCompileDate = masterInkFile.lastCompileDate;
editAndCompileDateString += "\nLast compile date "+lastCompileDate.ToString();
if(lastEditDate > lastCompileDate) {
if(EditorApplication.isPlaying && InkSettings.instance.delayInPlayMode) {
editAndCompileDateString += "\nWill compile on exiting play mode";
EditorGUILayout.HelpBox(editAndCompileDateString, MessageType.Info);
} else {
EditorGUILayout.HelpBox(editAndCompileDateString, MessageType.Warning);
}
} else {
EditorGUILayout.HelpBox(editAndCompileDateString, MessageType.None);
}
} else {
EditorGUILayout.HelpBox(editAndCompileDateString, MessageType.None);
}
}
void DrawIncludedFiles () {
if(includesFileList != null && includesFileList.count > 0) {
includesFileList.DoLayoutList();
}
}
void DrawCompileErrors () {
if(inkFile.unhandledCompileErrors.Count == 0)
return;
EditorGUILayout.BeginVertical(GUI.skin.box);
EditorGUILayout.HelpBox("Compiler bug prevented compilation of JSON file. Please help us fix it by reporting this as a bug.", MessageType.Error);
EditorGUILayout.BeginHorizontal();
if(GUILayout.Button("Report via Github")) {
Application.OpenURL("https://github.com/inkle/ink-unity-integration/issues/new");
}
if(GUILayout.Button("Report via Email")) {
Application.OpenURL("mailto:info@inklestudios.com");
}
EditorGUILayout.EndHorizontal();
foreach(string compileError in inkFile.unhandledCompileErrors) {
GUILayout.TextArea(compileError);
}
EditorGUILayout.EndVertical();
}
void DrawErrors () {
if(errorList != null && errorList.count > 0) {
errorList.DoLayoutList();
}
}
void DrawWarnings () {
if(warningList != null && warningList.count > 0) {
warningList.DoLayoutList();
}
}
void DrawTODOList () {
if(todosList != null && todosList.count > 0) {
todosList.DoLayoutList();
}
}
void DrawFileContents () {
float width = EditorGUIUtility.currentViewWidth-50;
float height = EditorStyles.wordWrappedLabel.CalcHeight(new GUIContent(cachedTrimmedFileContents), width);
EditorGUILayout.BeginVertical(EditorStyles.textArea);
EditorGUILayout.SelectableLabel(cachedTrimmedFileContents, EditorStyles.wordWrappedLabel, GUILayout.ExpandHeight(true), GUILayout.Width(width), GUILayout.Height(height));
EditorGUILayout.EndVertical();
}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: 6905e53703af64a70aa6eb42f98b047c
timeCreated: 1460011343
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant: