mirror of
				https://github.com/godotengine/godot.git
				synced 2025-10-26 11:14:17 +00:00 
			
		
		
		
	Implemented advanced features of DAP
Respect client "supportsVariableType" capability Implement "breakpointLocations" request Implement "restart" request Implement "evaluate" request Fix error messages not being shown, and improved wrong path message Removed thread option and behavior Implemented detailed inspection of complex variables Fix "const"ness of functions Added a configurable timeout for requests Implement Godot custom data request/event Implement syncing of breakpoints Added support for debugging native platforms
This commit is contained in:
		
							parent
							
								
									d8a8d32f2e
								
							
						
					
					
						commit
						292ed61c18
					
				
					 20 changed files with 845 additions and 67 deletions
				
			
		|  | @ -37,6 +37,7 @@ | |||
| #include "core/os/keyboard.h" | ||||
| #include "core/os/os.h" | ||||
| #include "editor/debugger/editor_debugger_node.h" | ||||
| #include "editor/debugger/script_editor_debugger.h" | ||||
| #include "editor/editor_node.h" | ||||
| #include "editor/editor_run_script.h" | ||||
| #include "editor/editor_scale.h" | ||||
|  | @ -486,6 +487,29 @@ void ScriptEditor::_clear_execution(REF p_script) { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| void ScriptEditor::_set_breakpoint(REF p_script, int p_line, bool p_enabled) { | ||||
| 	Ref<Script> script = Object::cast_to<Script>(*p_script); | ||||
| 	if (script.is_valid() && (script->has_source_code() || script->get_path().is_resource_file())) { | ||||
| 		if (edit(p_script, p_line, 0, false)) { | ||||
| 			editor->push_item(p_script.ptr()); | ||||
| 
 | ||||
| 			ScriptEditorBase *se = _get_current_editor(); | ||||
| 			if (se) { | ||||
| 				se->set_breakpoint(p_line, p_enabled); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void ScriptEditor::_clear_breakpoints() { | ||||
| 	for (int i = 0; i < tab_container->get_child_count(); i++) { | ||||
| 		ScriptEditorBase *se = Object::cast_to<ScriptEditorBase>(tab_container->get_child(i)); | ||||
| 		if (se) { | ||||
| 			se->clear_breakpoints(); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| ScriptEditorBase *ScriptEditor::_get_current_editor() const { | ||||
| 	int selected = tab_container->get_current_tab(); | ||||
| 	if (selected < 0 || selected >= tab_container->get_child_count()) { | ||||
|  | @ -3488,6 +3512,8 @@ ScriptEditor::ScriptEditor(EditorNode *p_editor) { | |||
| 	debugger->connect("set_execution", callable_mp(this, &ScriptEditor::_set_execution)); | ||||
| 	debugger->connect("clear_execution", callable_mp(this, &ScriptEditor::_clear_execution)); | ||||
| 	debugger->connect("breaked", callable_mp(this, &ScriptEditor::_breaked)); | ||||
| 	debugger->get_default_debugger()->connect("set_breakpoint", callable_mp(this, &ScriptEditor::_set_breakpoint)); | ||||
| 	debugger->get_default_debugger()->connect("clear_breakpoints", callable_mp(this, &ScriptEditor::_clear_breakpoints)); | ||||
| 
 | ||||
| 	menu_hb->add_spacer(); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ev1lbl0w
						Ev1lbl0w