Added "shader" filter to "Find in Files"

This commit is contained in:
Michael Alexsander Silva Dias 2018-10-27 12:24:41 -03:00
parent d4028a3f50
commit f6d137d3d0
5 changed files with 28 additions and 16 deletions

View file

@ -44,8 +44,6 @@
#include "scene/gui/progress_bar.h" #include "scene/gui/progress_bar.h"
#include "scene/gui/tree.h" #include "scene/gui/tree.h"
#define ROOT_PREFIX "res://"
const char *FindInFiles::SIGNAL_RESULT_FOUND = "result_found"; const char *FindInFiles::SIGNAL_RESULT_FOUND = "result_found";
const char *FindInFiles::SIGNAL_FINISHED = "finished"; const char *FindInFiles::SIGNAL_FINISHED = "finished";
@ -89,7 +87,6 @@ static bool find_next(const String &line, String pattern, int from, bool match_c
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
FindInFiles::FindInFiles() { FindInFiles::FindInFiles() {
_root_prefix = ROOT_PREFIX;
_searching = false; _searching = false;
_whole_words = true; _whole_words = true;
_match_case = true; _match_case = true;
@ -182,7 +179,7 @@ void FindInFiles::_iterate() {
_current_dir = _current_dir.plus_file(folder_name); _current_dir = _current_dir.plus_file(folder_name);
PoolStringArray sub_dirs; PoolStringArray sub_dirs;
_scan_dir(_root_prefix + _current_dir, sub_dirs); _scan_dir("res://" + _current_dir, sub_dirs);
_folders_stack.push_back(sub_dirs); _folders_stack.push_back(sub_dirs);
@ -348,7 +345,7 @@ FindInFilesDialog::FindInFilesDialog() {
HBoxContainer *hbc = memnew(HBoxContainer); HBoxContainer *hbc = memnew(HBoxContainer);
Label *prefix_label = memnew(Label); Label *prefix_label = memnew(Label);
prefix_label->set_text(ROOT_PREFIX); prefix_label->set_text("res://");
hbc->add_child(prefix_label); hbc->add_child(prefix_label);
_folder_line_edit = memnew(LineEdit); _folder_line_edit = memnew(LineEdit);
@ -375,10 +372,12 @@ FindInFilesDialog::FindInFilesDialog() {
{ {
HBoxContainer *hbc = memnew(HBoxContainer); HBoxContainer *hbc = memnew(HBoxContainer);
// TODO: Unhardcode this.
Vector<String> exts; Vector<String> exts;
exts.push_back("gd"); exts.push_back("gd");
if (Engine::get_singleton()->has_singleton("GodotSharp")) if (Engine::get_singleton()->has_singleton("GodotSharp"))
exts.push_back("cs"); exts.push_back("cs");
exts.push_back("shader");
for (int i = 0; i < exts.size(); ++i) { for (int i = 0; i < exts.size(); ++i) {
CheckBox *cb = memnew(CheckBox); CheckBox *cb = memnew(CheckBox);

View file

@ -73,7 +73,6 @@ private:
// Config // Config
String _pattern; String _pattern;
Set<String> _extension_filter; Set<String> _extension_filter;
String _root_prefix;
String _root_dir; String _root_dir;
bool _whole_words; bool _whole_words;
bool _match_case; bool _match_case;

View file

@ -40,6 +40,7 @@
#include "editor/editor_settings.h" #include "editor/editor_settings.h"
#include "editor/find_in_files.h" #include "editor/find_in_files.h"
#include "editor/node_dock.h" #include "editor/node_dock.h"
#include "editor/plugins/shader_editor_plugin.h"
#include "editor/script_editor_debugger.h" #include "editor/script_editor_debugger.h"
#include "scene/main/viewport.h" #include "scene/main/viewport.h"
#include "script_text_editor.h" #include "script_text_editor.h"
@ -2788,15 +2789,20 @@ void ScriptEditor::_on_find_in_files_requested(String text) {
void ScriptEditor::_on_find_in_files_result_selected(String fpath, int line_number, int begin, int end) { void ScriptEditor::_on_find_in_files_result_selected(String fpath, int line_number, int begin, int end) {
RES res = ResourceLoader::load(fpath); RES res = ResourceLoader::load(fpath);
if (fpath.get_extension() == "shader") {
ShaderEditorPlugin *shader_editor = Object::cast_to<ShaderEditorPlugin>(EditorNode::get_singleton()->get_editor_data().get_editor("Shader"));
shader_editor->edit(res.ptr());
shader_editor->make_visible(true);
shader_editor->get_shader_editor()->goto_line_selection(line_number - 1, begin, end);
} else {
edit(res); edit(res);
ScriptEditorBase *seb = _get_current_editor(); ScriptTextEditor *ste = Object::cast_to<ScriptTextEditor>(_get_current_editor());
ScriptTextEditor *ste = Object::cast_to<ScriptTextEditor>(seb);
if (ste) { if (ste) {
ste->goto_line_selection(line_number - 1, begin, end); ste->goto_line_selection(line_number - 1, begin, end);
} }
} }
}
void ScriptEditor::_start_find_in_files(bool with_replace) { void ScriptEditor::_start_find_in_files(bool with_replace) {

View file

@ -349,9 +349,9 @@ void ShaderEditor::_menu_option(int p_option) {
void ShaderEditor::_notification(int p_what) { void ShaderEditor::_notification(int p_what) {
if (p_what == NOTIFICATION_ENTER_TREE) { if (p_what == NOTIFICATION_VISIBILITY_CHANGED) {
} if (is_visible_in_tree())
if (p_what == NOTIFICATION_DRAW) { shader_editor->get_text_edit()->grab_focus();
} }
} }
@ -388,7 +388,6 @@ void ShaderEditor::_bind_methods() {
ClassDB::bind_method("_menu_option", &ShaderEditor::_menu_option); ClassDB::bind_method("_menu_option", &ShaderEditor::_menu_option);
ClassDB::bind_method("_params_changed", &ShaderEditor::_params_changed); ClassDB::bind_method("_params_changed", &ShaderEditor::_params_changed);
ClassDB::bind_method("apply_shaders", &ShaderEditor::apply_shaders); ClassDB::bind_method("apply_shaders", &ShaderEditor::apply_shaders);
//ClassDB::bind_method("_close_current_tab",&ShaderEditor::_close_current_tab);
} }
void ShaderEditor::ensure_select_current() { void ShaderEditor::ensure_select_current() {
@ -404,6 +403,11 @@ void ShaderEditor::ensure_select_current() {
}*/ }*/
} }
void ShaderEditor::goto_line_selection(int p_line, int p_begin, int p_end) {
shader_editor->goto_line_selection(p_line, p_begin, p_end);
}
void ShaderEditor::edit(const Ref<Shader> &p_shader) { void ShaderEditor::edit(const Ref<Shader> &p_shader) {
if (p_shader.is_null() || !p_shader->is_text_shader()) if (p_shader.is_null() || !p_shader->is_text_shader())

View file

@ -120,6 +120,8 @@ public:
void ensure_select_current(); void ensure_select_current();
void edit(const Ref<Shader> &p_shader); void edit(const Ref<Shader> &p_shader);
void goto_line_selection(int p_line, int p_begin, int p_end);
virtual Size2 get_minimum_size() const { return Size2(0, 200); } virtual Size2 get_minimum_size() const { return Size2(0, 200); }
void save_external_data(); void save_external_data();
@ -143,6 +145,8 @@ public:
virtual void make_visible(bool p_visible); virtual void make_visible(bool p_visible);
virtual void selected_notify(); virtual void selected_notify();
ShaderEditor *get_shader_editor() const { return shader_editor; }
virtual void save_external_data(); virtual void save_external_data();
virtual void apply_changes(); virtual void apply_changes();