FilesystemPanel: Handle root correctly in BuildFilePathFromSelection

This was unnecessary in the past but is necessary
for the next commit.
This commit is contained in:
JosJuice 2017-06-20 20:58:18 +02:00
parent 39ff203c1e
commit 2ca5f1dec8
1 changed files with 11 additions and 5 deletions

View File

@ -401,15 +401,21 @@ void FilesystemPanel::ExtractDirectories(const std::string& full_path,
std::pair<wxString, const DiscIO::FileSystem&> FilesystemPanel::BuildFilePathFromSelection() const std::pair<wxString, const DiscIO::FileSystem&> FilesystemPanel::BuildFilePathFromSelection() const
{ {
wxString file_path = m_tree_ctrl->GetItemText(m_tree_ctrl->GetSelection()); const wxTreeItemId root_node = m_tree_ctrl->GetRootItem();
wxTreeItemId node = m_tree_ctrl->GetSelection();
const auto root_node = m_tree_ctrl->GetRootItem(); wxString file_path;
auto node = m_tree_ctrl->GetItemParent(m_tree_ctrl->GetSelection());
while (node != root_node) if (node != root_node)
{ {
file_path = m_tree_ctrl->GetItemText(node) + DIR_SEP_CHR + file_path; file_path = m_tree_ctrl->GetItemText(node);
node = m_tree_ctrl->GetItemParent(node); node = m_tree_ctrl->GetItemParent(node);
while (node != root_node)
{
file_path = m_tree_ctrl->GetItemText(node) + DIR_SEP_CHR + file_path;
node = m_tree_ctrl->GetItemParent(node);
}
} }
if (m_has_partitions) if (m_has_partitions)