diff options
author | RĂ©mi Verschelde <remi@verschelde.fr> | 2022-01-28 11:03:23 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-01-28 11:03:23 +0100 |
commit | 9686d680b754337a4f399449a7e95fa2d2eb2324 (patch) | |
tree | 3f0d404b1764d5ca63219d8636c6b6a95d9c2ee5 /scene/gui/file_dialog.cpp | |
parent | 26672df72e8aa09a9a7ec85cb442c50ebf87e251 (diff) | |
parent | cba82805156ada29993d18b4ceb0721636a3db80 (diff) |
Merge pull request #57116 from bruvzg/win_net_share
Diffstat (limited to 'scene/gui/file_dialog.cpp')
-rw-r--r-- | scene/gui/file_dialog.cpp | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/scene/gui/file_dialog.cpp b/scene/gui/file_dialog.cpp index e5bd6f4882..dad84461f4 100644 --- a/scene/gui/file_dialog.cpp +++ b/scene/gui/file_dialog.cpp @@ -169,7 +169,14 @@ void FileDialog::update_dir() { dir->set_text(dir_access->get_current_dir(false)); if (drives->is_visible()) { - drives->select(dir_access->get_current_drive()); + if (dir_access->get_current_dir().is_network_share_path()) { + _update_drives(false); + drives->add_item(RTR("Network")); + drives->set_item_disabled(drives->get_item_count() - 1, true); + drives->select(drives->get_item_count() - 1); + } else { + drives->select(dir_access->get_current_drive()); + } } // Deselect any item, to make "Select Current Folder" button text by default. @@ -846,7 +853,7 @@ void FileDialog::_select_drive(int p_idx) { _push_history(); } -void FileDialog::_update_drives() { +void FileDialog::_update_drives(bool p_select) { int dc = dir_access->get_drive_count(); if (dc == 0 || access != ACCESS_FILESYSTEM) { drives->hide(); @@ -864,7 +871,9 @@ void FileDialog::_update_drives() { drives->add_item(dir_access->get_drive(i)); } - drives->select(dir_access->get_current_drive()); + if (p_select) { + drives->select(dir_access->get_current_drive()); + } } } |