Export: Properly reload preset when opening dialog

Fixes #20119 where newly installed templates were not detected.

Also fix a bug with preset deletion where it would attempt to
edit an already removed preset. For this I made it so that
ItemList::deselect_all() also resets `current` to -1, as a manual
ItemList::deselect(idx) already does.
This commit is contained in:
Rémi Verschelde 2018-07-18 13:46:02 +02:00
parent d603a74c53
commit 13239cd4cc
5 changed files with 5 additions and 12 deletions

View file

@ -1856,10 +1856,6 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
} break; } break;
case SETTINGS_EXPORT_PREFERENCES: {
//project_export_settings->popup_centered_ratio();
} break;
case FILE_IMPORT_SUBSCENE: { case FILE_IMPORT_SUBSCENE: {
if (!editor_data.get_edited_scene_root()) { if (!editor_data.get_edited_scene_root()) {

View file

@ -164,7 +164,6 @@ private:
SETTINGS_UPDATE_ALWAYS, SETTINGS_UPDATE_ALWAYS,
SETTINGS_UPDATE_CHANGES, SETTINGS_UPDATE_CHANGES,
SETTINGS_UPDATE_SPINNER_HIDE, SETTINGS_UPDATE_SPINNER_HIDE,
SETTINGS_EXPORT_PREFERENCES,
SETTINGS_PREFERENCES, SETTINGS_PREFERENCES,
SETTINGS_LAYOUT_SAVE, SETTINGS_LAYOUT_SAVE,
SETTINGS_LAYOUT_DELETE, SETTINGS_LAYOUT_DELETE,

View file

@ -123,7 +123,6 @@ void ExportTemplateManager::_update_template_list() {
void ExportTemplateManager::_download_template(const String &p_version) { void ExportTemplateManager::_download_template(const String &p_version) {
print_line("download " + p_version);
while (template_list->get_child_count()) { while (template_list->get_child_count()) {
memdelete(template_list->get_child(0)); memdelete(template_list->get_child(0));
} }
@ -352,7 +351,6 @@ void ExportTemplateManager::_http_download_mirror_completed(int p_status, int p_
bool mirrors_found = false; bool mirrors_found = false;
Dictionary d = r; Dictionary d = r;
print_line(r);
if (d.has("mirrors")) { if (d.has("mirrors")) {
Array mirrors = d["mirrors"]; Array mirrors = d["mirrors"];
for (int i = 0; i < mirrors.size(); i++) { for (int i = 0; i < mirrors.size(); i++) {
@ -507,7 +505,6 @@ void ExportTemplateManager::_notification(int p_what) {
if (p_what == NOTIFICATION_VISIBILITY_CHANGED) { if (p_what == NOTIFICATION_VISIBILITY_CHANGED) {
if (!is_visible_in_tree()) { if (!is_visible_in_tree()) {
print_line("closed");
set_process(false); set_process(false);
} }
} }

View file

@ -76,6 +76,9 @@ void ProjectExportDialog::popup_export() {
} }
_update_presets(); _update_presets();
if (presets->get_current() >= 0) {
_edit_preset(presets->get_current()); // triggers rescan for templates if newly installed
}
// Restore valid window bounds or pop up at default size. // Restore valid window bounds or pop up at default size.
if (EditorSettings::get_singleton()->has_setting("interface/dialogs/export_bounds")) { if (EditorSettings::get_singleton()->has_setting("interface/dialogs/export_bounds")) {
@ -154,7 +157,6 @@ void ProjectExportDialog::_update_presets() {
if (current_idx != -1) { if (current_idx != -1) {
presets->select(current_idx); presets->select(current_idx);
//_edit_preset(current_idx);
} }
updating = false; updating = false;
@ -167,6 +169,7 @@ void ProjectExportDialog::_edit_preset(int p_index) {
name->set_editable(false); name->set_editable(false);
runnable->set_disabled(true); runnable->set_disabled(true);
parameters->edit(NULL); parameters->edit(NULL);
presets->unselect_all();
delete_preset->set_disabled(true); delete_preset->set_disabled(true);
sections->hide(); sections->hide();
patches->clear(); patches->clear();
@ -438,11 +441,9 @@ void ProjectExportDialog::_delete_preset() {
void ProjectExportDialog::_delete_preset_confirm() { void ProjectExportDialog::_delete_preset_confirm() {
int idx = presets->get_current(); int idx = presets->get_current();
parameters->edit(NULL); //to avoid crash
_edit_preset(-1); _edit_preset(-1);
EditorExport::get_singleton()->remove_export_preset(idx); EditorExport::get_singleton()->remove_export_preset(idx);
_update_presets(); _update_presets();
_edit_preset(presets->get_current());
} }
Variant ProjectExportDialog::get_drag_data_fw(const Point2 &p_point, Control *p_from) { Variant ProjectExportDialog::get_drag_data_fw(const Point2 &p_point, Control *p_from) {

View file

@ -285,7 +285,7 @@ void ItemList::unselect_all() {
items[i].selected = false; items[i].selected = false;
} }
current = -1;
update(); update();
} }