diff options
Diffstat (limited to 'editor/editor_dir_dialog.cpp')
-rw-r--r-- | editor/editor_dir_dialog.cpp | 150 |
1 files changed, 67 insertions, 83 deletions
diff --git a/editor/editor_dir_dialog.cpp b/editor/editor_dir_dialog.cpp index 235d1f06ba..5cd277e218 100644 --- a/editor/editor_dir_dialog.cpp +++ b/editor/editor_dir_dialog.cpp @@ -28,28 +28,27 @@ /*************************************************************************/ #include "editor_dir_dialog.h" -#include "os/os.h" -#include "os/keyboard.h" -#include "editor/editor_settings.h" #include "editor/editor_file_system.h" +#include "editor/editor_settings.h" +#include "os/keyboard.h" +#include "os/os.h" +void EditorDirDialog::_update_dir(TreeItem *p_item) { -void EditorDirDialog::_update_dir(TreeItem* p_item) { - - updating=true; + updating = true; p_item->clear_children(); DirAccess *da = DirAccess::create(DirAccess::ACCESS_RESOURCES); String cdir = p_item->get_metadata(0); da->change_dir(cdir); da->list_dir_begin(); - String p=da->get_next(); + String p = da->get_next(); List<String> dirs; bool ishidden; bool show_hidden = EditorSettings::get_singleton()->get("filesystem/file_dialog/show_hidden_files"); - while(p!="") { + while (p != "") { ishidden = da->current_is_hidden(); @@ -58,153 +57,144 @@ void EditorDirDialog::_update_dir(TreeItem* p_item) { dirs.push_back(p); } } - p=da->get_next(); + p = da->get_next(); } dirs.sort(); - for(List<String>::Element *E=dirs.front();E;E=E->next()) { + for (List<String>::Element *E = dirs.front(); E; E = E->next()) { TreeItem *ti = tree->create_item(p_item); - ti->set_text(0,E->get()); - ti->set_icon(0,get_icon("Folder","EditorIcons")); + ti->set_text(0, E->get()); + ti->set_icon(0, get_icon("Folder", "EditorIcons")); ti->set_collapsed(true); - } memdelete(da); - updating=false; - + updating = false; } - void EditorDirDialog::reload() { if (!is_visible_in_tree()) { - must_reload=true; + must_reload = true; return; } tree->clear(); TreeItem *root = tree->create_item(); - root->set_metadata(0,"res://"); - root->set_icon(0,get_icon("Folder","EditorIcons")); - root->set_text(0,"/"); + root->set_metadata(0, "res://"); + root->set_icon(0, get_icon("Folder", "EditorIcons")); + root->set_text(0, "/"); _update_dir(root); _item_collapsed(root); - must_reload=false; - + must_reload = false; } - void EditorDirDialog::_notification(int p_what) { - if (p_what==NOTIFICATION_ENTER_TREE) { + if (p_what == NOTIFICATION_ENTER_TREE) { reload(); - if (!tree->is_connected("item_collapsed",this,"_item_collapsed")) { - tree->connect("item_collapsed",this,"_item_collapsed",varray(),CONNECT_DEFERRED); + if (!tree->is_connected("item_collapsed", this, "_item_collapsed")) { + tree->connect("item_collapsed", this, "_item_collapsed", varray(), CONNECT_DEFERRED); } - if (!EditorFileSystem::get_singleton()->is_connected("filesystem_changed",this,"reload")) { - EditorFileSystem::get_singleton()->connect("filesystem_changed",this,"reload"); + if (!EditorFileSystem::get_singleton()->is_connected("filesystem_changed", this, "reload")) { + EditorFileSystem::get_singleton()->connect("filesystem_changed", this, "reload"); } - } - if (p_what==NOTIFICATION_VISIBILITY_CHANGED) { + if (p_what == NOTIFICATION_VISIBILITY_CHANGED) { if (must_reload && is_visible_in_tree()) { reload(); } } } -void EditorDirDialog::_item_collapsed(Object* _p_item){ +void EditorDirDialog::_item_collapsed(Object *_p_item) { - TreeItem *p_item=_p_item->cast_to<TreeItem>(); + TreeItem *p_item = _p_item->cast_to<TreeItem>(); if (updating || p_item->is_collapsed()) return; TreeItem *ci = p_item->get_children(); - while(ci) { + while (ci) { - String p =ci->get_metadata(0); - if (p=="") { + String p = ci->get_metadata(0); + if (p == "") { String pp = p_item->get_metadata(0); - ci->set_metadata(0,pp.plus_file(ci->get_text(0))); + ci->set_metadata(0, pp.plus_file(ci->get_text(0))); _update_dir(ci); } - ci=ci->get_next(); + ci = ci->get_next(); } - } -void EditorDirDialog::set_current_path(const String& p_path) { +void EditorDirDialog::set_current_path(const String &p_path) { reload(); String p = p_path; if (p.begins_with("res://")) - p = p.replace_first("res://",""); + p = p.replace_first("res://", ""); - Vector<String> dirs = p.split("/",false); + Vector<String> dirs = p.split("/", false); - TreeItem *r=tree->get_root(); - for(int i=0;i<dirs.size();i++) { + TreeItem *r = tree->get_root(); + for (int i = 0; i < dirs.size(); i++) { String d = dirs[i]; TreeItem *p = r->get_children(); - while(p) { + while (p) { - if (p->get_text(0)==d) + if (p->get_text(0) == d) break; - p=p->get_next(); + p = p->get_next(); } ERR_FAIL_COND(!p); String pp = p->get_metadata(0); - if (pp=="") { - p->set_metadata(0,String(r->get_metadata(0)).plus_file(d)); + if (pp == "") { + p->set_metadata(0, String(r->get_metadata(0)).plus_file(d)); _update_dir(p); } - updating=true; + updating = true; p->set_collapsed(false); - updating=false; + updating = false; _item_collapsed(p); - r=p; + r = p; } r->select(0); - } void EditorDirDialog::ok_pressed() { - TreeItem *ti=tree->get_selected(); + TreeItem *ti = tree->get_selected(); if (!ti) return; String dir = ti->get_metadata(0); - emit_signal("dir_selected",dir); + emit_signal("dir_selected", dir); hide(); } - void EditorDirDialog::_make_dir() { - TreeItem *ti=tree->get_selected(); + TreeItem *ti = tree->get_selected(); if (!ti) { mkdirerr->set_text("Please select a base directory first"); mkdirerr->popup_centered_minsize(); return; } - makedialog->popup_centered_minsize(Size2(250,80)); + makedialog->popup_centered_minsize(Size2(250, 80)); makedirname->grab_focus(); } void EditorDirDialog::_make_dir_confirm() { - TreeItem *ti=tree->get_selected(); + TreeItem *ti = tree->get_selected(); if (!ti) return; @@ -214,63 +204,57 @@ void EditorDirDialog::_make_dir_confirm() { ERR_FAIL_COND(!d); Error err = d->make_dir(makedirname->get_text()); - if (err!=OK) { - mkdirerr->popup_centered_minsize(Size2(250,80)); + if (err != OK) { + mkdirerr->popup_centered_minsize(Size2(250, 80)); } else { set_current_path(dir.plus_file(makedirname->get_text())); } makedirname->set_text(""); // reset label } - void EditorDirDialog::_bind_methods() { - ClassDB::bind_method(D_METHOD("_item_collapsed"),&EditorDirDialog::_item_collapsed); - ClassDB::bind_method(D_METHOD("_make_dir"),&EditorDirDialog::_make_dir); - ClassDB::bind_method(D_METHOD("_make_dir_confirm"),&EditorDirDialog::_make_dir_confirm); - ClassDB::bind_method(D_METHOD("reload"),&EditorDirDialog::reload); + ClassDB::bind_method(D_METHOD("_item_collapsed"), &EditorDirDialog::_item_collapsed); + ClassDB::bind_method(D_METHOD("_make_dir"), &EditorDirDialog::_make_dir); + ClassDB::bind_method(D_METHOD("_make_dir_confirm"), &EditorDirDialog::_make_dir_confirm); + ClassDB::bind_method(D_METHOD("reload"), &EditorDirDialog::reload); - ADD_SIGNAL(MethodInfo("dir_selected",PropertyInfo(Variant::STRING,"dir"))); + ADD_SIGNAL(MethodInfo("dir_selected", PropertyInfo(Variant::STRING, "dir"))); } - - EditorDirDialog::EditorDirDialog() { - updating=false; + updating = false; set_title(TTR("Choose a Directory")); set_hide_on_ok(false); - tree = memnew( Tree ); + tree = memnew(Tree); add_child(tree); - tree->connect("item_activated",this,"_ok"); + tree->connect("item_activated", this, "_ok"); - makedir = add_button(TTR("Create Folder"),OS::get_singleton()->get_swap_ok_cancel()?true:false,"makedir"); - makedir->connect("pressed",this,"_make_dir"); + makedir = add_button(TTR("Create Folder"), OS::get_singleton()->get_swap_ok_cancel() ? true : false, "makedir"); + makedir->connect("pressed", this, "_make_dir"); - makedialog = memnew( ConfirmationDialog ); + makedialog = memnew(ConfirmationDialog); makedialog->set_title(TTR("Create Folder")); add_child(makedialog); - VBoxContainer *makevb= memnew( VBoxContainer ); + VBoxContainer *makevb = memnew(VBoxContainer); makedialog->add_child(makevb); //makedialog->set_child_rect(makevb); - makedirname = memnew( LineEdit ); - makevb->add_margin_child(TTR("Name:"),makedirname); + makedirname = memnew(LineEdit); + makevb->add_margin_child(TTR("Name:"), makedirname); makedialog->register_text_enter(makedirname); - makedialog->connect("confirmed",this,"_make_dir_confirm"); + makedialog->connect("confirmed", this, "_make_dir_confirm"); - mkdirerr = memnew( AcceptDialog ); + mkdirerr = memnew(AcceptDialog); mkdirerr->set_text(TTR("Could not create folder.")); add_child(mkdirerr); get_ok()->set_text(TTR("Choose")); - must_reload=false; - - - + must_reload = false; } |