Added ability to look up asset IDs with the search bar

This commit is contained in:
Aruki 2017-07-22 17:39:49 -06:00
parent 4f2828e0f8
commit 305fbbdeed
2 changed files with 63 additions and 4 deletions

View File

@ -598,6 +598,7 @@ void CResourceBrowser::FindAssetByID()
QString QStringAssetID = QInputDialog::getText(this, "Enter Asset ID", "Enter asset ID:"); QString QStringAssetID = QInputDialog::getText(this, "Enter Asset ID", "Enter asset ID:");
TString StringAssetID = TO_TSTRING(QStringAssetID); TString StringAssetID = TO_TSTRING(QStringAssetID);
StringAssetID.RemoveWhitespace();
if (!StringAssetID.IsEmpty()) if (!StringAssetID.IsEmpty())
{ {

View File

@ -21,6 +21,10 @@ private:
ESortMode mSortMode; ESortMode mSortMode;
QSet<CResTypeInfo*> mTypeFilter; QSet<CResTypeInfo*> mTypeFilter;
u64 mCompareID;
u64 mCompareMask;
u32 mCompareBitLength;
public: public:
explicit CResourceProxyModel(QObject *pParent = 0) explicit CResourceProxyModel(QObject *pParent = 0)
: QSortFilterProxyModel(pParent) : QSortFilterProxyModel(pParent)
@ -74,18 +78,49 @@ public:
bool filterAcceptsRow(int SourceRow, const QModelIndex& rkSourceParent) const bool filterAcceptsRow(int SourceRow, const QModelIndex& rkSourceParent) const
{ {
QModelIndex Index = mpModel->index(SourceRow, 0, rkSourceParent); QModelIndex Index = mpModel->index(SourceRow, 0, rkSourceParent);
CVirtualDirectory *pDir = mpModel->IndexDirectory(Index);
CResourceEntry *pEntry = mpModel->IndexEntry(Index); CResourceEntry *pEntry = mpModel->IndexEntry(Index);
if (pEntry && !IsTypeAccepted(pEntry->TypeInfo())) if (pEntry && !IsTypeAccepted(pEntry->TypeInfo()))
return false; return false;
// Compare search results
if (!mSearchString.IsEmpty()) if (!mSearchString.IsEmpty())
{ {
if (pDir) if (!pEntry)
return false; return false;
else
return pEntry->UppercaseName().Contains(mSearchString); bool HasNameMatch = pEntry->UppercaseName().Contains(mSearchString);
if (!HasNameMatch)
{
bool HasIDMatch = false;
if (mCompareBitLength > 0)
{
u32 IDBitLength = pEntry->ID().Length() * 8;
if (mCompareBitLength <= IDBitLength)
{
u64 ID = pEntry->ID().ToLongLong();
u32 MaxShift = IDBitLength - mCompareBitLength;
for (u32 Shift = 0; Shift <= MaxShift; Shift += 4)
{
u64 ShiftCompare = mCompareID << Shift;
u32 Mask = mCompareMask << Shift;
if ((ID & Mask) == ShiftCompare)
{
HasIDMatch = true;
break;
}
}
}
}
if (!HasIDMatch)
return false;
}
} }
return true; return true;
@ -127,6 +162,29 @@ public slots:
void SetSearchString(const TString& rkString) void SetSearchString(const TString& rkString)
{ {
mSearchString = rkString.ToUpper(); mSearchString = rkString.ToUpper();
// Check if this is an asset ID
TString IDString = rkString;
IDString.RemoveWhitespace();
if (IDString.StartsWith("0x"))
IDString = IDString.ChopFront(2);
if (IDString.Size() <= 16 && IDString.IsHexString())
{
mCompareBitLength = IDString.Size() * 4;
mCompareMask = ((u64) 1 << mCompareBitLength) - 1;
mCompareID = IDString.ToInt64(16);
if (mCompareMask == 0)
mCompareMask = -1;
}
else
{
mCompareID = -1;
mCompareMask = 0;
mCompareBitLength = 0;
}
} }
}; };