Merge pull request #2352 from xodene/patch-6/script-file-new
Add "New" script button to Script Editor Popup Menu
This commit is contained in:
commit
889d21e004
@ -211,7 +211,6 @@ void ScriptEditorQuickOpen::_bind_methods() {
|
||||
ObjectTypeDB::bind_method(_MD("_confirmed"),&ScriptEditorQuickOpen::_confirmed);
|
||||
ObjectTypeDB::bind_method(_MD("_sbox_input"),&ScriptEditorQuickOpen::_sbox_input);
|
||||
|
||||
|
||||
ADD_SIGNAL(MethodInfo("goto_line",PropertyInfo(Variant::INT,"line")));
|
||||
|
||||
}
|
||||
@ -547,6 +546,10 @@ void ScriptEditor::_show_debugger(bool p_show) {
|
||||
|
||||
}
|
||||
|
||||
void ScriptEditor::_script_created(Ref<Script> p_script) {
|
||||
editor->push_item(p_script.operator->());
|
||||
}
|
||||
|
||||
void ScriptEditor::_goto_script_line2(int p_line) {
|
||||
|
||||
int selected = tab_container->get_current_tab();
|
||||
@ -574,7 +577,7 @@ void ScriptEditor::_close_current_tab() {
|
||||
int selected = tab_container->get_current_tab();
|
||||
if (selected<0 || selected>=tab_container->get_child_count())
|
||||
return;
|
||||
|
||||
|
||||
ScriptTextEditor *current = tab_container->get_child(selected)->cast_to<ScriptTextEditor>();
|
||||
if (!current)
|
||||
return;
|
||||
@ -753,7 +756,6 @@ void ScriptEditor::_menu_option(int p_option) {
|
||||
|
||||
|
||||
if (p_option==FILE_OPEN) {
|
||||
|
||||
editor->open_resource("Script");
|
||||
return;
|
||||
}
|
||||
@ -766,8 +768,11 @@ void ScriptEditor::_menu_option(int p_option) {
|
||||
return;
|
||||
|
||||
switch(p_option) {
|
||||
case FILE_NEW: {
|
||||
script_create_dialog->config("Node", ".gd");
|
||||
script_create_dialog->popup_centered(Size2(300, 300));
|
||||
} break;
|
||||
case FILE_SAVE: {
|
||||
|
||||
if (!_test_script_times_on_disk())
|
||||
return;
|
||||
editor->save_resource( current->get_edited_script() );
|
||||
@ -1419,6 +1424,7 @@ void ScriptEditor::_bind_methods() {
|
||||
ObjectTypeDB::bind_method("_update_script_names",&ScriptEditor::_update_script_names);
|
||||
ObjectTypeDB::bind_method("_tree_changed",&ScriptEditor::_tree_changed);
|
||||
ObjectTypeDB::bind_method("_script_selected",&ScriptEditor::_script_selected);
|
||||
ObjectTypeDB::bind_method("_script_created",&ScriptEditor::_script_created);
|
||||
ObjectTypeDB::bind_method("_script_split_dragged",&ScriptEditor::_script_split_dragged);
|
||||
}
|
||||
|
||||
@ -1803,6 +1809,7 @@ ScriptEditor::ScriptEditor(EditorNode *p_editor) {
|
||||
file_menu = memnew( MenuButton );
|
||||
menu_hb->add_child(file_menu);
|
||||
file_menu->set_text("File");
|
||||
file_menu->get_popup()->add_item("New",FILE_NEW);
|
||||
file_menu->get_popup()->add_item("Open",FILE_OPEN);
|
||||
file_menu->get_popup()->add_separator();
|
||||
file_menu->get_popup()->add_item("Save",FILE_SAVE,KEY_MASK_ALT|KEY_MASK_CMD|KEY_S);
|
||||
@ -1899,6 +1906,10 @@ ScriptEditor::ScriptEditor(EditorNode *p_editor) {
|
||||
add_child(erase_tab_confirm);
|
||||
erase_tab_confirm->connect("confirmed", this,"_close_current_tab");
|
||||
|
||||
script_create_dialog = memnew(ScriptCreateDialog);
|
||||
script_create_dialog->set_title("Create Script");
|
||||
add_child(script_create_dialog);
|
||||
script_create_dialog->connect("script_created", this, "_script_created");
|
||||
|
||||
goto_line_dialog = memnew(GotoLineDialog);
|
||||
add_child(goto_line_dialog);
|
||||
|
@ -30,6 +30,7 @@
|
||||
#define SCRIPT_EDITOR_PLUGIN_H
|
||||
|
||||
#include "tools/editor/editor_plugin.h"
|
||||
#include "tools/editor/script_create_dialog.h"
|
||||
#include "scene/gui/tab_container.h"
|
||||
#include "scene/gui/text_edit.h"
|
||||
#include "scene/gui/menu_button.h"
|
||||
@ -115,7 +116,7 @@ class ScriptEditor : public VBoxContainer {
|
||||
|
||||
EditorNode *editor;
|
||||
enum {
|
||||
|
||||
FILE_NEW,
|
||||
FILE_OPEN,
|
||||
FILE_SAVE,
|
||||
FILE_SAVE_AS,
|
||||
@ -167,6 +168,7 @@ class ScriptEditor : public VBoxContainer {
|
||||
FindReplaceDialog *find_replace_dialog;
|
||||
GotoLineDialog *goto_line_dialog;
|
||||
ConfirmationDialog *erase_tab_confirm;
|
||||
ScriptCreateDialog *script_create_dialog;
|
||||
ScriptEditorDebugger* debugger;
|
||||
ToolButton *scripts_visible;
|
||||
|
||||
@ -207,6 +209,7 @@ class ScriptEditor : public VBoxContainer {
|
||||
void _breaked(bool p_breaked,bool p_can_debug);
|
||||
void _show_debugger(bool p_show);
|
||||
void _update_window_menu();
|
||||
void _script_created(Ref<Script> p_script);
|
||||
|
||||
void _editor_settings_changed();
|
||||
void _autosave_scripts();
|
||||
|
@ -74,17 +74,17 @@ bool ScriptCreateDialog::_validate(const String& p_string) {
|
||||
void ScriptCreateDialog::_class_name_changed(const String& p_name) {
|
||||
|
||||
if (!_validate(parent_name->get_text())) {
|
||||
error_label->set_text("INVALID PARENT CLASS NAME");
|
||||
error_label->set_text("Invaild parent class name");
|
||||
error_label->add_color_override("font_color",Color(1,0.4,0.0,0.8));
|
||||
} else if (class_name->is_editable()) {
|
||||
if (class_name->get_text()=="") {
|
||||
error_label->set_text("Valid Chars: a-z A-Z 0-9 _");
|
||||
error_label->add_color_override("font_color",Color(1,1,1,0.6));
|
||||
} else if (!_validate(class_name->get_text())) {
|
||||
error_label->set_text("INVALID CLASS NAME");
|
||||
error_label->set_text("Invalid class name");
|
||||
error_label->add_color_override("font_color",Color(1,0.2,0.2,0.8));
|
||||
} else {
|
||||
error_label->set_text("Name is Valid");
|
||||
error_label->set_text("Valid Name");
|
||||
error_label->add_color_override("font_color",Color(0,1.0,0.8,0.8));
|
||||
}
|
||||
} else {
|
||||
@ -363,7 +363,7 @@ ScriptCreateDialog::ScriptCreateDialog() {
|
||||
|
||||
set_size(Size2(200,150));
|
||||
set_hide_on_ok(false);
|
||||
set_title("Create Script for Node..");;
|
||||
set_title("Create Script for Node");
|
||||
|
||||
file_browse = memnew( EditorFileDialog );
|
||||
file_browse->connect("file_selected",this,"_file_selected");
|
||||
|
Loading…
Reference in New Issue
Block a user