EditorNode: enhance quit dialog
This commit is contained in:
parent
14fa4190b3
commit
1453d67145
@ -961,6 +961,23 @@ void EditorNode::_save_scene(String p_file, int idx) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EditorNode::_save_all_scenes() {
|
||||||
|
|
||||||
|
for (int i = 0; i < editor_data.get_edited_scene_count(); i++) {
|
||||||
|
Node *scene = editor_data.get_edited_scene_root(i);
|
||||||
|
if (scene && scene->get_filename() != "") {
|
||||||
|
// save in background if in the script editor
|
||||||
|
if (i != editor_data.get_edited_scene() || _get_current_main_editor() == EDITOR_SCRIPT) {
|
||||||
|
_save_scene(scene->get_filename(), i);
|
||||||
|
} else {
|
||||||
|
_save_scene_with_preview(scene->get_filename());
|
||||||
|
}
|
||||||
|
} // else: ignore new scenes
|
||||||
|
}
|
||||||
|
|
||||||
|
_save_default_environment();
|
||||||
|
}
|
||||||
|
|
||||||
void EditorNode::_import_action(const String &p_action) {
|
void EditorNode::_import_action(const String &p_action) {
|
||||||
#if 0
|
#if 0
|
||||||
import_confirmation->hide();
|
import_confirmation->hide();
|
||||||
@ -1900,6 +1917,8 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
|
|||||||
|
|
||||||
if (!p_confirmed && unsaved_cache) {
|
if (!p_confirmed && unsaved_cache) {
|
||||||
tab_closing = editor_data.get_edited_scene();
|
tab_closing = editor_data.get_edited_scene();
|
||||||
|
save_confirmation->get_ok()->set_text(TTR("Save & Close"));
|
||||||
|
save_confirmation->set_text(TTR("Save changes to the scene before closing?"));
|
||||||
save_confirmation->popup_centered_minsize();
|
save_confirmation->popup_centered_minsize();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1975,19 +1994,8 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
|
|||||||
} break;
|
} break;
|
||||||
|
|
||||||
case FILE_SAVE_ALL_SCENES: {
|
case FILE_SAVE_ALL_SCENES: {
|
||||||
for (int i = 0; i < editor_data.get_edited_scene_count(); i++) {
|
|
||||||
Node *scene = editor_data.get_edited_scene_root(i);
|
|
||||||
if (scene && scene->get_filename() != "") {
|
|
||||||
// save in background if in the script editor
|
|
||||||
if (i != editor_data.get_edited_scene() || _get_current_main_editor() == EDITOR_SCRIPT) {
|
|
||||||
_save_scene(scene->get_filename(), i);
|
|
||||||
} else {
|
|
||||||
_save_scene_with_preview(scene->get_filename());
|
|
||||||
}
|
|
||||||
} // else: ignore new scenes
|
|
||||||
}
|
|
||||||
|
|
||||||
_save_default_environment();
|
_save_all_scenes();
|
||||||
} break;
|
} break;
|
||||||
case FILE_SAVE_BEFORE_RUN: {
|
case FILE_SAVE_BEFORE_RUN: {
|
||||||
if (!p_confirmed) {
|
if (!p_confirmed) {
|
||||||
@ -2109,17 +2117,25 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
|
|||||||
case FILE_QUIT: {
|
case FILE_QUIT: {
|
||||||
|
|
||||||
if (!p_confirmed) {
|
if (!p_confirmed) {
|
||||||
|
if (_has_unsaved_scenes()) {
|
||||||
|
|
||||||
confirmation->get_ok()->set_text(TTR("Quit"));
|
save_confirmation->get_ok()->set_text(TTR("Save & Quit"));
|
||||||
//confirmation->get_cancel()->show();
|
save_confirmation->set_text(TTR("Save changes to the scene before quitting?"));
|
||||||
confirmation->set_text(TTR("Exit the editor?"));
|
save_confirmation->popup_centered_minsize();
|
||||||
confirmation->popup_centered(Size2(180, 70) * EDSCALE);
|
break;
|
||||||
break;
|
} else {
|
||||||
|
|
||||||
|
confirmation->get_ok()->set_text(TTR("Quit"));
|
||||||
|
//confirmation->get_cancel()->show();
|
||||||
|
confirmation->set_text(TTR("Exit the editor?"));
|
||||||
|
confirmation->popup_centered(Size2(180, 70) * EDSCALE);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_menu_option_confirm(RUN_STOP, true);
|
if (_has_unsaved_scenes())
|
||||||
exiting = true;
|
_save_all_scenes();
|
||||||
get_tree()->quit();
|
_discard_changes();
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
case FILE_EXTERNAL_OPEN_SCENE: {
|
case FILE_EXTERNAL_OPEN_SCENE: {
|
||||||
@ -2453,25 +2469,24 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
|
|||||||
case RUN_PROJECT_MANAGER: {
|
case RUN_PROJECT_MANAGER: {
|
||||||
|
|
||||||
if (!p_confirmed) {
|
if (!p_confirmed) {
|
||||||
confirmation->get_ok()->set_text(TTR("Yes"));
|
if (_has_unsaved_scenes()) {
|
||||||
confirmation->set_text(TTR("Open Project Manager? \n(Unsaved changes will be lost)"));
|
|
||||||
confirmation->popup_centered_minsize();
|
save_confirmation->get_ok()->set_text(TTR("Save & Quit"));
|
||||||
break;
|
save_confirmation->set_text(TTR("Save changes before opening Project Manager?"));
|
||||||
|
save_confirmation->popup_centered_minsize();
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
|
||||||
|
confirmation->get_ok()->set_text(TTR("Yes"));
|
||||||
|
confirmation->set_text(TTR("Open Project Manager?"));
|
||||||
|
confirmation->popup_centered_minsize();
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_menu_option_confirm(RUN_STOP, true);
|
if (_has_unsaved_scenes())
|
||||||
exiting = true;
|
_save_all_scenes();
|
||||||
get_tree()->quit();
|
_discard_changes();
|
||||||
String exec = OS::get_singleton()->get_executable_path();
|
|
||||||
|
|
||||||
List<String> args;
|
|
||||||
args.push_back("-path");
|
|
||||||
args.push_back(exec.get_base_dir());
|
|
||||||
args.push_back("-pm");
|
|
||||||
|
|
||||||
OS::ProcessID pid = 0;
|
|
||||||
Error err = OS::get_singleton()->execute(exec, args, false, &pid);
|
|
||||||
ERR_FAIL_COND(err);
|
|
||||||
} break;
|
} break;
|
||||||
case RUN_FILE_SERVER: {
|
case RUN_FILE_SERVER: {
|
||||||
|
|
||||||
@ -2697,6 +2712,19 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool EditorNode::_has_unsaved_scenes() {
|
||||||
|
|
||||||
|
for (int i = 0; i < editor_data.get_edited_scene_count(); i++) {
|
||||||
|
|
||||||
|
int current = editor_data.get_edited_scene();
|
||||||
|
bool unsaved = (i == current) ? saved_version != editor_data.get_undo_redo().get_version() : editor_data.get_scene_version(i) != 0;
|
||||||
|
if (unsaved)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void EditorNode::_discard_changes(const String &p_str) {
|
void EditorNode::_discard_changes(const String &p_str) {
|
||||||
|
|
||||||
save_confirmation->hide();
|
save_confirmation->hide();
|
||||||
@ -2710,6 +2738,28 @@ void EditorNode::_discard_changes(const String &p_str) {
|
|||||||
_update_scene_tabs();
|
_update_scene_tabs();
|
||||||
current_option = -1;
|
current_option = -1;
|
||||||
} break;
|
} break;
|
||||||
|
case FILE_QUIT: {
|
||||||
|
|
||||||
|
_menu_option_confirm(RUN_STOP, true);
|
||||||
|
exiting = true;
|
||||||
|
get_tree()->quit();
|
||||||
|
} break;
|
||||||
|
case RUN_PROJECT_MANAGER: {
|
||||||
|
|
||||||
|
_menu_option_confirm(RUN_STOP, true);
|
||||||
|
exiting = true;
|
||||||
|
get_tree()->quit();
|
||||||
|
String exec = OS::get_singleton()->get_executable_path();
|
||||||
|
|
||||||
|
List<String> args;
|
||||||
|
args.push_back("-path");
|
||||||
|
args.push_back(exec.get_base_dir());
|
||||||
|
args.push_back("-pm");
|
||||||
|
|
||||||
|
OS::ProcessID pid = 0;
|
||||||
|
Error err = OS::get_singleton()->execute(exec, args, false, &pid);
|
||||||
|
ERR_FAIL_COND(err);
|
||||||
|
} break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4289,6 +4339,8 @@ void EditorNode::_scene_tab_closed(int p_tab) {
|
|||||||
saved_version != editor_data.get_undo_redo().get_version() :
|
saved_version != editor_data.get_undo_redo().get_version() :
|
||||||
editor_data.get_scene_version(p_tab) != 0;
|
editor_data.get_scene_version(p_tab) != 0;
|
||||||
if (unsaved) {
|
if (unsaved) {
|
||||||
|
save_confirmation->get_ok()->set_text(TTR("Save & Close"));
|
||||||
|
save_confirmation->set_text(TTR("Save changes to the scene before closing?"));
|
||||||
save_confirmation->popup_centered_minsize();
|
save_confirmation->popup_centered_minsize();
|
||||||
} else {
|
} else {
|
||||||
_discard_changes();
|
_discard_changes();
|
||||||
@ -5909,9 +5961,7 @@ EditorNode::EditorNode() {
|
|||||||
confirmation->connect("confirmed", this, "_menu_confirm_current");
|
confirmation->connect("confirmed", this, "_menu_confirm_current");
|
||||||
|
|
||||||
save_confirmation = memnew(ConfirmationDialog);
|
save_confirmation = memnew(ConfirmationDialog);
|
||||||
save_confirmation->get_ok()->set_text(TTR("Save & Close"));
|
|
||||||
save_confirmation->add_button(TTR("Don't Save"), OS::get_singleton()->get_swap_ok_cancel(), "discard");
|
save_confirmation->add_button(TTR("Don't Save"), OS::get_singleton()->get_swap_ok_cancel(), "discard");
|
||||||
save_confirmation->set_text(TTR("Save changes to the scene before closing?"));
|
|
||||||
gui_base->add_child(save_confirmation);
|
gui_base->add_child(save_confirmation);
|
||||||
save_confirmation->connect("confirmed", this, "_menu_confirm_current");
|
save_confirmation->connect("confirmed", this, "_menu_confirm_current");
|
||||||
save_confirmation->connect("custom_action", this, "_discard_changes");
|
save_confirmation->connect("custom_action", this, "_discard_changes");
|
||||||
|
@ -466,6 +466,8 @@ private:
|
|||||||
void _vp_resized();
|
void _vp_resized();
|
||||||
|
|
||||||
void _save_scene(String p_file, int idx = -1);
|
void _save_scene(String p_file, int idx = -1);
|
||||||
|
void _save_all_scenes();
|
||||||
|
bool _has_unsaved_scenes();
|
||||||
void _discard_changes(const String &p_str = String());
|
void _discard_changes(const String &p_str = String());
|
||||||
|
|
||||||
void _instance_request(const Vector<String> &p_files);
|
void _instance_request(const Vector<String> &p_files);
|
||||||
|
Loading…
Reference in New Issue
Block a user