CVirtualDirectoryModel: Return std::optional from GetProposedIndex()

Same behavior, minus out parameters.
This commit is contained in:
Lioncash 2020-07-05 10:19:49 -04:00
parent dcfb34ca1c
commit 97fa0c7f2d
2 changed files with 28 additions and 25 deletions

View File

@ -241,7 +241,7 @@ void CVirtualDirectoryModel::SetRoot(CVirtualDirectory *pDir)
endResetModel();
}
bool CVirtualDirectoryModel::GetProposedIndex(const QString& Path, QModelIndex& rOutParent, int& rOutRow)
std::optional<std::pair<QModelIndex, int>> CVirtualDirectoryModel::GetProposedIndex(const QString& Path)
{
// Get parent path
TString FullPath = TO_TSTRING(Path);
@ -249,43 +249,43 @@ bool CVirtualDirectoryModel::GetProposedIndex(const QString& Path, QModelIndex&
if (FullPath.EndsWith('/') || FullPath.EndsWith('\\'))
FullPath = FullPath.ChopBack(1);
uint32 LastSlash = FullPath.LastIndexOf("\\/");
TString ParentPath = FullPath.ChopBack( FullPath.Size() - LastSlash );
const uint32 LastSlash = FullPath.LastIndexOf("\\/");
const TString ParentPath = FullPath.ChopBack( FullPath.Size() - LastSlash );
// Find parent index
CVirtualDirectory* pParent = (ParentPath.IsEmpty() ? mpRoot : mpRoot->FindChildDirectory(ParentPath, false));
if (!pParent) return false;
if (pParent == nullptr)
return std::nullopt;
QModelIndex ParentIndex = GetIndexForDirectory(pParent);
if (!ParentIndex.isValid()) return false;
const QModelIndex ParentIndex = GetIndexForDirectory(pParent);
if (!ParentIndex.isValid())
return std::nullopt;
// Determine the row number that the new directory will be inserted at
QString DirName = TO_QSTRING(FullPath.ChopFront( LastSlash + 1 ));
int NumRows = rowCount(ParentIndex);
const QString DirName = TO_QSTRING(FullPath.ChopFront( LastSlash + 1 ));
const int NumRows = rowCount(ParentIndex);
int RowIdx = 0;
for (; RowIdx < NumRows; RowIdx++)
{
QModelIndex Index = index(RowIdx, 0, ParentIndex);
QString OtherName = data(Index, Qt::DisplayRole).toString();
const QModelIndex Index = index(RowIdx, 0, ParentIndex);
const QString OtherName = data(Index, Qt::DisplayRole).toString();
if (QString::compare(DirName, OtherName, Qt::CaseInsensitive) < 0)
break;
}
rOutParent = ParentIndex;
rOutRow = RowIdx;
return true;
return std::make_pair(ParentIndex, RowIdx);
}
void CVirtualDirectoryModel::OnDirectoryAboutToBeMoved(CVirtualDirectory *pDir, const QString& NewPath)
{
QModelIndex Parent;
int Row;
const auto indexOptional = GetProposedIndex(NewPath);
if (!GetProposedIndex(NewPath, Parent, Row))
if (!indexOptional)
return;
const auto [Parent, Row] = *indexOptional;
const QModelIndex OldIndex = GetIndexForDirectory(pDir);
const QModelIndex OldParent = OldIndex.parent();
const int OldRow = OldIndex.row();
@ -304,15 +304,15 @@ void CVirtualDirectoryModel::OnDirectoryAboutToBeMoved(CVirtualDirectory *pDir,
void CVirtualDirectoryModel::OnDirectoryAboutToBeCreated(const QString& DirPath)
{
QModelIndex Parent;
int Row;
const auto indexOptional = GetProposedIndex(DirPath);
if (GetProposedIndex(DirPath, Parent, Row))
{
if (!indexOptional)
return;
const auto [Parent, Row] = *indexOptional;
beginInsertRows(Parent, Row, Row);
mInsertingRows = true;
}
}
void CVirtualDirectoryModel::OnDirectoryAboutToBeDeleted(CVirtualDirectory *pDir)
{

View File

@ -6,6 +6,9 @@
#include <QAbstractItemModel>
#include <QIcon>
#include <optional>
#include <utility>
class CVirtualDirectoryModel : public QAbstractItemModel
{
Q_OBJECT
@ -37,7 +40,7 @@ public:
void SetRoot(CVirtualDirectory *pDir);
protected:
bool GetProposedIndex(const QString& Path, QModelIndex& rOutParent, int& rOutRow);
std::optional<std::pair<QModelIndex, int>> GetProposedIndex(const QString& Path);
public slots:
void OnDirectoryAboutToBeMoved(CVirtualDirectory *pDir, const QString& NewPath);