mirror of
				https://github.com/godotengine/godot.git
				synced 2025-10-25 10:44:26 +00:00 
			
		
		
		
	Merge pull request #53735 from Paulb23/text-file-drop-and-drag
Allow dragging TextFiles from the Filesystem dock
This commit is contained in:
		
						commit
						64ec08d70d
					
				
					 2 changed files with 35 additions and 16 deletions
				
			
		|  | @ -1084,7 +1084,6 @@ void ScriptEditor::_file_dialog_action(String p_file) { | |||
| 			memdelete(file); | ||||
| 
 | ||||
| 			if (EditorFileSystem::get_singleton()) { | ||||
| 				const Vector<String> textfile_extensions = ((String)(EditorSettings::get_singleton()->get("docks/filesystem/textfile_extensions"))).split(",", false); | ||||
| 				if (textfile_extensions.has(p_file.get_extension())) { | ||||
| 					EditorFileSystem::get_singleton()->update_file(p_file); | ||||
| 				} | ||||
|  | @ -1172,9 +1171,8 @@ void ScriptEditor::_menu_option(int p_option) { | |||
| 			file_dialog_option = FILE_NEW_TEXTFILE; | ||||
| 
 | ||||
| 			file_dialog->clear_filters(); | ||||
| 			const Vector<String> textfile_ext = ((String)(EditorSettings::get_singleton()->get("docks/filesystem/textfile_extensions"))).split(",", false); | ||||
| 			for (int i = 0; i < textfile_ext.size(); i++) { | ||||
| 				file_dialog->add_filter("*." + textfile_ext[i] + " ; " + textfile_ext[i].to_upper()); | ||||
| 			for (const String &E : textfile_extensions) { | ||||
| 				file_dialog->add_filter("*." + E + " ; " + E.to_upper()); | ||||
| 			} | ||||
| 			file_dialog->popup_file_dialog(); | ||||
| 			file_dialog->set_title(TTR("New Text File...")); | ||||
|  | @ -1192,9 +1190,8 @@ void ScriptEditor::_menu_option(int p_option) { | |||
| 				file_dialog->add_filter("*." + extensions[i] + " ; " + extensions[i].to_upper()); | ||||
| 			} | ||||
| 
 | ||||
| 			const Vector<String> textfile_ext = ((String)(EditorSettings::get_singleton()->get("docks/filesystem/textfile_extensions"))).split(",", false); | ||||
| 			for (int i = 0; i < textfile_ext.size(); i++) { | ||||
| 				file_dialog->add_filter("*." + textfile_ext[i] + " ; " + textfile_ext[i].to_upper()); | ||||
| 			for (const String &E : textfile_extensions) { | ||||
| 				file_dialog->add_filter("*." + E + " ; " + E.to_upper()); | ||||
| 			} | ||||
| 
 | ||||
| 			file_dialog->popup_file_dialog(); | ||||
|  | @ -1547,6 +1544,7 @@ void ScriptEditor::_notification(int p_what) { | |||
| 
 | ||||
| 			EditorSettings::get_singleton()->connect("settings_changed", callable_mp(this, &ScriptEditor::_editor_settings_changed)); | ||||
| 			EditorFileSystem::get_singleton()->connect("filesystem_changed", callable_mp(this, &ScriptEditor::_filesystem_changed)); | ||||
| 			_editor_settings_changed(); | ||||
| 			[[fallthrough]]; | ||||
| 		} | ||||
| 		case NOTIFICATION_TRANSLATION_CHANGED: | ||||
|  | @ -2122,7 +2120,7 @@ void ScriptEditor::_update_script_connections() { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| Ref<TextFile> ScriptEditor::_load_text_file(const String &p_path, Error *r_error) { | ||||
| Ref<TextFile> ScriptEditor::_load_text_file(const String &p_path, Error *r_error) const { | ||||
| 	if (r_error) { | ||||
| 		*r_error = ERR_FILE_CANT_OPEN; | ||||
| 	} | ||||
|  | @ -2606,6 +2604,12 @@ void ScriptEditor::_save_layout() { | |||
| } | ||||
| 
 | ||||
| void ScriptEditor::_editor_settings_changed() { | ||||
| 	textfile_extensions.clear(); | ||||
| 	const Vector<String> textfile_ext = ((String)(EditorSettings::get_singleton()->get("docks/filesystem/textfile_extensions"))).split(",", false); | ||||
| 	for (const String &E : textfile_ext) { | ||||
| 		textfile_extensions.insert(E); | ||||
| 	} | ||||
| 
 | ||||
| 	trim_trailing_whitespace_on_save = EditorSettings::get_singleton()->get("text_editor/behavior/files/trim_trailing_whitespace_on_save"); | ||||
| 	convert_indent_on_save = EditorSettings::get_singleton()->get("text_editor/behavior/files/convert_indent_on_save"); | ||||
| 	use_space_indentation = EditorSettings::get_singleton()->get("text_editor/behavior/indent/type"); | ||||
|  | @ -2812,12 +2816,22 @@ bool ScriptEditor::can_drop_data_fw(const Point2 &p_point, const Variant &p_data | |||
| 			if (file == "" || !FileAccess::exists(file)) { | ||||
| 				continue; | ||||
| 			} | ||||
| 			Ref<Script> scr = ResourceLoader::load(file); | ||||
| 			if (scr.is_valid()) { | ||||
| 				return true; | ||||
| 			if (ResourceLoader::exists(file, "Script")) { | ||||
| 				Ref<Script> scr = ResourceLoader::load(file); | ||||
| 				if (scr.is_valid()) { | ||||
| 					return true; | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			if (textfile_extensions.has(file.get_extension())) { | ||||
| 				Error err; | ||||
| 				Ref<TextFile> text_file = _load_text_file(file, &err); | ||||
| 				if (text_file.is_valid() && err == OK) { | ||||
| 					return true; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		return true; | ||||
| 		return false; | ||||
| 	} | ||||
| 
 | ||||
| 	return false; | ||||
|  | @ -2882,9 +2896,13 @@ void ScriptEditor::drop_data_fw(const Point2 &p_point, const Variant &p_data, Co | |||
| 			if (file == "" || !FileAccess::exists(file)) { | ||||
| 				continue; | ||||
| 			} | ||||
| 			Ref<Script> scr = ResourceLoader::load(file); | ||||
| 			if (scr.is_valid()) { | ||||
| 				edit(scr); | ||||
| 
 | ||||
| 			if (!ResourceLoader::exists(file, "Script") && !textfile_extensions.has(file.get_extension())) { | ||||
| 				continue; | ||||
| 			} | ||||
| 
 | ||||
| 			RES res = open_file(file); | ||||
| 			if (res.is_valid()) { | ||||
| 				if (tab_container->get_child_count() > num_tabs_before) { | ||||
| 					tab_container->move_child(tab_container->get_child(tab_container->get_child_count() - 1), new_index); | ||||
| 					num_tabs_before = tab_container->get_child_count(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Rémi Verschelde
						Rémi Verschelde