///////////////////////////////////////////////////////////////////////////////
// LameXP - Audio Encoder Front-End
-// Copyright (C) 2004-2011 LoRd_MuldeR <MuldeR2@GMX.de>
+// Copyright (C) 2004-2012 LoRd_MuldeR <MuldeR2@GMX.de>
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
#include "Thread_DiskObserver.h"
#include "Global.h"
+#include "Model_Progress.h"
#include <QDir>
-#define MIN_DISKSPACE 104857600LL //100 MB
+#define MIN_DISKSPACE 104857600ui64 //100 MB
////////////////////////////////////////////////////////////
// Constructor & Destructor
:
m_path(makeRootDir(path))
{
- m_terminated = false;
}
DiskObserverThread::~DiskObserverThread(void)
FatalAppExit(0, L"Unhandeled exception error, application will exit!");
TerminateProcess(GetCurrentProcess(), -1);
}
+
+ while(m_semaphore.available()) m_semaphore.tryAcquire();
}
void DiskObserverThread::observe(void)
{
- __int64 freeSpace, minimumSpace = MIN_DISKSPACE;
+ unsigned __int64 minimumSpace = MIN_DISKSPACE;
+ unsigned __int64 freeSpace, previousSpace = 0ui64;
+ bool ok = false;
- while(!m_terminated)
+ forever
{
- freeSpace = lamexp_free_diskspace(m_path);
- if(freeSpace < minimumSpace)
+ freeSpace = lamexp_free_diskspace(m_path, &ok);
+ if(ok)
{
- qWarning("Free diskspace on '%s' dropped below %s MB, only %s MB free!", m_path.toUtf8().constData(), QString::number(minimumSpace / 1048576ui64).toUtf8().constData(), QString::number(freeSpace / 1048576ui64).toUtf8().constData());
- emit messageLogged(tr("Low diskspace on drive '%1' detected (only %2 MB are free), problems can occur!").arg(QDir::toNativeSeparators(m_path), QString::number(freeSpace / 1048576ui64)), true);
- minimumSpace = min(freeSpace, (minimumSpace >> 1));
+ if(freeSpace < minimumSpace)
+ {
+ qWarning("Free diskspace on '%s' dropped below %s MB, only %s MB free!", m_path.toUtf8().constData(), QString::number(minimumSpace / 1048576ui64).toUtf8().constData(), QString::number(freeSpace / 1048576ui64).toUtf8().constData());
+ emit messageLogged(tr("Low diskspace on drive '%1' detected (only %2 MB are free), problems can occur!").arg(QDir::toNativeSeparators(m_path), QString::number(freeSpace / 1048576ui64)), ProgressModel::SysMsg_Warning);
+ minimumSpace = qMin(freeSpace, (minimumSpace >> 1));
+ }
+ if(freeSpace != previousSpace)
+ {
+ emit freeSpaceChanged(freeSpace);
+ previousSpace = freeSpace;
+ }
}
- Sleep(1000);
+ if(m_semaphore.tryAcquire(1, 2000)) break;
}
}