Some improvements to LockedFile class.
This commit is contained in:
parent
4b5158c4ae
commit
593ef23a22
@ -34,8 +34,8 @@
|
|||||||
#define VER_LAMEXP_MINOR_HI 1
|
#define VER_LAMEXP_MINOR_HI 1
|
||||||
#define VER_LAMEXP_MINOR_LO 3
|
#define VER_LAMEXP_MINOR_LO 3
|
||||||
#define VER_LAMEXP_TYPE RC
|
#define VER_LAMEXP_TYPE RC
|
||||||
#define VER_LAMEXP_PATCH 3
|
#define VER_LAMEXP_PATCH 4
|
||||||
#define VER_LAMEXP_BUILD 1834
|
#define VER_LAMEXP_BUILD 1840
|
||||||
#define VER_LAMEXP_CONFG 1818
|
#define VER_LAMEXP_CONFG 1818
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -32,26 +32,27 @@ static const char *g_salt = "ee9f7bdabc170763d2200a7e3030045aafe380011aefc1730e5
|
|||||||
|
|
||||||
QByteArray FileHash::computeHash(QFile &file)
|
QByteArray FileHash::computeHash(QFile &file)
|
||||||
{
|
{
|
||||||
QByteArray hash = QByteArray::fromHex(g_blnk);
|
QByteArray hash = QByteArray::fromHex(g_blnk).toHex();
|
||||||
|
|
||||||
if(file.isOpen() && file.reset())
|
if(file.isOpen() && file.reset())
|
||||||
{
|
{
|
||||||
MUtils::Hash::Keccak keccak;
|
MUtils::Hash::Keccak keccak;
|
||||||
|
|
||||||
const QByteArray data = file.readAll();
|
const QByteArray data = file.readAll();
|
||||||
const QByteArray seed = QByteArray::fromHex(g_seed);
|
if (data.size() >= 16)
|
||||||
const QByteArray salt = QByteArray::fromHex(g_salt);
|
|
||||||
|
|
||||||
if(keccak.init(MUtils::Hash::Keccak::hb384))
|
|
||||||
{
|
{
|
||||||
bool ok = true;
|
const QByteArray seed = QByteArray::fromHex(g_seed);
|
||||||
ok = ok && keccak.addData(seed);
|
const QByteArray salt = QByteArray::fromHex(g_salt);
|
||||||
ok = ok && keccak.addData(data);
|
if (keccak.init(MUtils::Hash::Keccak::hb384))
|
||||||
ok = ok && keccak.addData(salt);
|
|
||||||
if(ok)
|
|
||||||
{
|
{
|
||||||
const QByteArray digest = keccak.finalize();
|
bool ok = true;
|
||||||
if(!digest.isEmpty()) hash = digest.toHex();
|
ok = ok && keccak.addData(seed);
|
||||||
|
ok = ok && keccak.addData(data);
|
||||||
|
ok = ok && keccak.addData(salt);
|
||||||
|
if (ok)
|
||||||
|
{
|
||||||
|
const QByteArray digest = keccak.finalize();
|
||||||
|
if (!digest.isEmpty()) hash = digest.toHex();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ class LockedFile;
|
|||||||
*/
|
*/
|
||||||
void lamexp_tools_register(const QString &toolName, LockedFile *const file, const quint32 &version, const QString &tag = QString());
|
void lamexp_tools_register(const QString &toolName, LockedFile *const file, const quint32 &version, const QString &tag = QString());
|
||||||
bool lamexp_tools_check (const QString &toolName);
|
bool lamexp_tools_check (const QString &toolName);
|
||||||
const QString& lamexp_tools_lookup (const QString &toolName);
|
const QString lamexp_tools_lookup (const QString &toolName);
|
||||||
const quint32& lamexp_tools_version (const QString &toolName, QString *const tagOut = NULL);
|
const quint32& lamexp_tools_version (const QString &toolName, QString *const tagOut = NULL);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -133,7 +133,7 @@ bool lamexp_tools_check(const QString &toolName)
|
|||||||
/*
|
/*
|
||||||
* Lookup tool path
|
* Lookup tool path
|
||||||
*/
|
*/
|
||||||
const QString &lamexp_tools_lookup(const QString &toolName)
|
const QString lamexp_tools_lookup(const QString &toolName)
|
||||||
{
|
{
|
||||||
QReadLocker readLock(&g_lamexp_tools_lock);
|
QReadLocker readLock(&g_lamexp_tools_lock);
|
||||||
|
|
||||||
|
@ -117,23 +117,52 @@ static __forceinline void doValidateFileExists(const QString &filePath)
|
|||||||
|
|
||||||
static __forceinline void doLockFile(HANDLE &fileHandle, const QString &filePath, QFile *const outFile)
|
static __forceinline void doLockFile(HANDLE &fileHandle, const QString &filePath, QFile *const outFile)
|
||||||
{
|
{
|
||||||
|
bool success = false;
|
||||||
|
fileHandle = INVALID_HANDLE_VALUE;
|
||||||
|
|
||||||
|
//Try to open the file!
|
||||||
for(int i = 0; i < 64; i++)
|
for(int i = 0; i < 64; i++)
|
||||||
{
|
{
|
||||||
fileHandle = CreateFileW(MUTILS_WCHR(QDir::toNativeSeparators(filePath)), GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, NULL, NULL);
|
const HANDLE hTemp = CreateFileW(MUTILS_WCHR(QDir::toNativeSeparators(filePath)), GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, NULL, NULL);
|
||||||
if(VALID_HANDLE(fileHandle))
|
if(VALID_HANDLE(hTemp))
|
||||||
{
|
{
|
||||||
break;
|
fileHandle = hTemp;
|
||||||
|
break; /*file opened successfully*/
|
||||||
}
|
}
|
||||||
if(i == 0)
|
if(i == 0)
|
||||||
{
|
{
|
||||||
qWarning("Failed to lock file on first attemp, retrying...");
|
qWarning("Failed to open file on first attemp, retrying...");
|
||||||
|
}
|
||||||
|
Sleep(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Now try to actually lock the file!
|
||||||
|
if (VALID_HANDLE(fileHandle))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < 64; i++)
|
||||||
|
{
|
||||||
|
LARGE_INTEGER fileSize;
|
||||||
|
if (GetFileSizeEx(fileHandle, &fileSize))
|
||||||
|
{
|
||||||
|
OVERLAPPED overlapped = { 0U, 0U, 0U, 0U, 0U };
|
||||||
|
if (LockFileEx(fileHandle, LOCKFILE_FAIL_IMMEDIATELY, 0, fileSize.LowPart, fileSize.HighPart, &overlapped))
|
||||||
|
{
|
||||||
|
success = true;
|
||||||
|
break; /*file locked successfully*/
|
||||||
|
}
|
||||||
|
Sleep(1);
|
||||||
|
}
|
||||||
|
if (i == 0)
|
||||||
|
{
|
||||||
|
qWarning("Failed to lock file on first attemp, retrying...");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Sleep(25);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Locked successfully?
|
//Locked successfully?
|
||||||
if(!VALID_HANDLE(fileHandle))
|
if(!success)
|
||||||
{
|
{
|
||||||
|
CLOSE_HANDLE(fileHandle);
|
||||||
if(outFile)
|
if(outFile)
|
||||||
{
|
{
|
||||||
QFile::remove(QFileInfo(*outFile).canonicalFilePath());
|
QFile::remove(QFileInfo(*outFile).canonicalFilePath());
|
||||||
@ -172,7 +201,7 @@ static __forceinline void doValidateHash(HANDLE &fileHandle, const int &fileDesc
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Opened successfully
|
//Opened successfully
|
||||||
if(!checkFile.isOpen())
|
if((!checkFile.isOpen()) || checkFile.peek(1).isEmpty())
|
||||||
{
|
{
|
||||||
QFile::remove(filePath);
|
QFile::remove(filePath);
|
||||||
MUTILS_THROW_FMT("File '%s' could not be read!", MUTILS_UTF8(QFileInfo(filePath).fileName()));
|
MUTILS_THROW_FMT("File '%s' could not be read!", MUTILS_UTF8(QFileInfo(filePath).fileName()));
|
||||||
@ -287,7 +316,16 @@ LockedFile::~LockedFile(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString &LockedFile::filePath()
|
const QString LockedFile::filePath(void)
|
||||||
{
|
{
|
||||||
|
if (m_fileDescriptor >= 0)
|
||||||
|
{
|
||||||
|
const QString path = MUtils::OS::get_file_path(m_fileDescriptor);
|
||||||
|
if (!path.isEmpty())
|
||||||
|
{
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
MUTILS_THROW_FMT("Failed to determine file path!");
|
||||||
|
}
|
||||||
return m_filePath;
|
return m_filePath;
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ public:
|
|||||||
LockedFile(const QString &filePath, const bool bOwnsFile = false);
|
LockedFile(const QString &filePath, const bool bOwnsFile = false);
|
||||||
~LockedFile(void);
|
~LockedFile(void);
|
||||||
|
|
||||||
const QString &filePath();
|
const QString filePath(void);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const bool m_bOwnsFile;
|
const bool m_bOwnsFile;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user