// Amplify Shader Editor - Visual Shader Editing Tool // Copyright (c) Amplify Creations, Lda //#define ASE_CONSOLE_WINDOW using UnityEngine; using UnityEditor; using System.Collections.Generic; namespace AmplifyShaderEditor { public sealed class DebugConsoleWindow : EditorWindow { private const float WindowSizeX = 250; private const float WindowSizeY = 250; private const float WindowPosX = 5; private const float WindowPosY = 5; private Rect m_availableArea; private bool m_wikiAreaFoldout = true; private bool m_miscAreaFoldout = true; private Vector2 m_currentScrollPos; private int m_minURLNode = 0; private int m_maxURLNode = -1; #if ASE_CONSOLE_WINDOW public readonly static bool DeveloperMode = true; public static bool UseShaderPanelsInfo = true; [MenuItem( "Window/Amplify Shader Editor/Open Debug Console" )] static void OpenMainShaderGraph() { OpenWindow(); } [MenuItem( "Window/Amplify Shader Editor/Create Template Menu Items" )] public static void CreateTemplateMenuItems() { UIUtils.CurrentWindow.TemplatesManagerInstance.CreateTemplateMenuItems(); } #else public readonly static bool DeveloperMode = false; public static bool UseShaderPanelsInfo = false; #endif public static DebugConsoleWindow OpenWindow() { if ( DeveloperMode ) { DebugConsoleWindow currentWindow = ( DebugConsoleWindow ) DebugConsoleWindow.GetWindow( typeof( DebugConsoleWindow ), false, "ASE Debug Console" ); currentWindow.titleContent.tooltip = "Debug Options for ASE. Intented only for ASE development team"; currentWindow.minSize = new Vector2( WindowSizeX, WindowSizeY ); currentWindow.maxSize = new Vector2( WindowSizeX, 2 * WindowSizeY ); ; currentWindow.wantsMouseMove = true; return currentWindow; } return null; } void OnGUI() { m_availableArea = new Rect( WindowPosX, WindowPosY, position.width - 2 * WindowPosX, position.height - 2 * WindowPosY ); GUILayout.BeginArea( m_availableArea ); { m_currentScrollPos = EditorGUILayout.BeginScrollView( m_currentScrollPos, GUILayout.Width( 0 ), GUILayout.Height( 0 ) ); { EditorGUILayout.BeginVertical(); { AmplifyShaderEditorWindow window = UIUtils.CurrentWindow; if ( window != null ) { EditorGUILayout.Separator(); NodeUtils.DrawPropertyGroup( ref m_wikiAreaFoldout, "Wiki Helper", ShowWikiHelperFunctions ); EditorGUILayout.Separator(); NodeUtils.DrawPropertyGroup( ref m_miscAreaFoldout, "Misc", ShowMiscFuntions ); EditorGUILayout.Separator(); } else { EditorGUILayout.LabelField( "Please open an ASE window to access debug options" ); } } EditorGUILayout.EndVertical(); } EditorGUILayout.EndScrollView(); } GUILayout.EndArea(); } void ShowWikiHelperFunctions() { AmplifyShaderEditorWindow window = UIUtils.CurrentWindow; EditorGUILayout.Separator(); if ( GUILayout.Button( "Nodes Screen Shots" ) ) { window.CurrentNodeExporterUtils.ActivateAutoScreenShot( Application.dataPath + "/../NodesInfo/Shots/",0,-1 ); } GUILayout.BeginHorizontal(); if( GUILayout.Button( "Nodes URLs" ) ) { window.CurrentNodeExporterUtils.ActivateNodesURL( m_minURLNode, m_maxURLNode ); } m_minURLNode = EditorGUILayout.IntField( m_minURLNode ); m_maxURLNode = EditorGUILayout.IntField( m_maxURLNode ); GUILayout.EndHorizontal(); EditorGUILayout.Separator(); if( GUILayout.Button( "Nodes Undo Test" ) ) { window.CurrentNodeExporterUtils.ActivateAutoUndo(); } EditorGUILayout.Separator(); if ( GUILayout.Button( "Nodes Info" ) ) { window.CurrentPaletteWindow.DumpAvailableNodes( false, Application.dataPath + "/../NodesInfo/" ); window.CurrentPaletteWindow.DumpAvailableNodes( true, Application.dataPath + "/../NodesInfo/" ); } EditorGUILayout.Separator(); if ( GUILayout.Button( "Shortcuts Info" ) ) { window.ShortcutManagerInstance.DumpShortcutsToDisk( Application.dataPath + "/../NodesInfo/" ); } } void ShowMiscFuntions() { AmplifyShaderEditorWindow window = UIUtils.CurrentWindow; if ( GUILayout.Button( "Force Example Shader Compilation" ) ) { UIUtils.ForceExampleShaderCompilation(); } EditorGUILayout.Separator(); if ( GUILayout.Button( "Refresh Available Nodes" ) ) { window.RefreshAvaibleNodes(); } EditorGUILayout.Separator(); if ( GUILayout.Button( "Dump Uniform Names" ) ) { //window.CurrentPaletteWindow.NewList() window.DuplicatePrevBufferInstance.DumpUniformNames(); } EditorGUILayout.Separator(); if ( GUILayout.Button( "Force Palette Update" ) ) { Debug.Log( UIUtils.CurrentWindow.IsShaderFunctionWindow ); window.CurrentPaletteWindow.ForceUpdate = true; } EditorGUILayout.Separator(); if( GUILayout.Button( "Detect Infinite Loops" ) ) { if( window.IsShaderFunctionWindow ) { Debug.Log( "Starting infinite loop detection over shader functions" ); List nodes = window.OutsideGraph.FunctionOutputNodes.NodesList; for( int i = 0; i < nodes.Count; i++ ) { UIUtils.DetectNodeLoopsFrom( nodes[ i ], new Dictionary() ); } } else { if( window.OutsideGraph.MultiPassMasterNodes.Count > 0 ) { Debug.Log( "Starting infinite loop detection over shader from template" ); List nodes = window.OutsideGraph.MultiPassMasterNodes.NodesList; for( int i = 0; i < nodes.Count; i++ ) { UIUtils.DetectNodeLoopsFrom( nodes[ i ], new Dictionary() ); } } else { Debug.Log( "Starting infinite loop detection over standard shader" ); UIUtils.DetectNodeLoopsFrom( window.OutsideGraph.CurrentMasterNode, new Dictionary() ); } } Debug.Log( "End infinite loop detection" ); } } } }