summaryrefslogtreecommitdiff
path: root/editor/editor_dir_dialog.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'editor/editor_dir_dialog.cpp')
-rw-r--r--editor/editor_dir_dialog.cpp150
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;
}