2011-03-28 04:26:47 +02:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// LameXP - Audio Encoder Front-End
|
2021-02-17 00:52:18 +01:00
|
|
|
// Copyright (C) 2004-2021 LoRd_MuldeR <MuldeR2@GMX.de>
|
2011-03-28 04:26:47 +02:00
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or modify
|
2020-03-28 15:31:01 +01:00
|
|
|
// it under the terms of the GNU GENERAL PUBLIC LICENSE as published by
|
2011-03-28 04:26:47 +02:00
|
|
|
// the Free Software Foundation; either version 2 of the License, or
|
2020-03-28 15:31:01 +01:00
|
|
|
// (at your option) any later version; always including the non-optional
|
|
|
|
// LAMEXP GNU GENERAL PUBLIC LICENSE ADDENDUM. See "License.txt" file!
|
2011-03-28 04:26:47 +02:00
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
|
|
// with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
//
|
|
|
|
// http://www.gnu.org/licenses/gpl-2.0.txt
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "Thread_DiskObserver.h"
|
|
|
|
|
2014-11-25 02:14:42 +01:00
|
|
|
//Internal
|
2011-03-28 04:26:47 +02:00
|
|
|
#include "Global.h"
|
2011-11-28 00:35:43 +01:00
|
|
|
#include "Model_Progress.h"
|
2011-03-28 04:26:47 +02:00
|
|
|
|
2014-11-25 02:14:42 +01:00
|
|
|
//MUtils
|
|
|
|
#include <MUtils/Global.h>
|
2014-11-25 18:23:03 +01:00
|
|
|
#include <MUtils/OSSupport.h>
|
2014-11-30 21:32:23 +01:00
|
|
|
#include <MUtils/Exception.h>
|
2014-11-25 02:14:42 +01:00
|
|
|
|
|
|
|
//Qt
|
2011-03-28 04:26:47 +02:00
|
|
|
#include <QDir>
|
|
|
|
|
2011-10-29 16:26:09 +02:00
|
|
|
#define MIN_DISKSPACE 104857600ui64 //100 MB
|
2011-03-28 04:26:47 +02:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Constructor & Destructor
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
DiskObserverThread::DiskObserverThread(const QString &path)
|
|
|
|
:
|
|
|
|
m_path(makeRootDir(path))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
DiskObserverThread::~DiskObserverThread(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Protected functions
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
void DiskObserverThread::run(void)
|
|
|
|
{
|
|
|
|
qDebug("DiskSpace observer started!");
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
observe();
|
|
|
|
}
|
2013-10-18 21:37:40 +02:00
|
|
|
catch(const std::exception &error)
|
|
|
|
{
|
2014-11-30 21:32:23 +01:00
|
|
|
MUTILS_PRINT_ERROR("\nGURU MEDITATION !!!\n\nException error:\n%s\n", error.what());
|
2014-11-25 18:23:03 +01:00
|
|
|
MUtils::OS::fatal_exit(L"Unhandeled C++ exception error, application will exit!");
|
2013-10-18 21:37:40 +02:00
|
|
|
}
|
2011-03-28 04:26:47 +02:00
|
|
|
catch(...)
|
|
|
|
{
|
2014-11-30 21:32:23 +01:00
|
|
|
MUTILS_PRINT_ERROR("\nGURU MEDITATION !!!\n\nUnknown exception error!\n");
|
2014-11-25 18:23:03 +01:00
|
|
|
MUtils::OS::fatal_exit(L"Unhandeled C++ exception error, application will exit!");
|
2011-03-28 04:26:47 +02:00
|
|
|
}
|
2011-11-25 01:01:30 +01:00
|
|
|
|
|
|
|
while(m_semaphore.available()) m_semaphore.tryAcquire();
|
2011-03-28 04:26:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void DiskObserverThread::observe(void)
|
|
|
|
{
|
2014-12-04 00:02:42 +01:00
|
|
|
quint64 minimumSpace = MIN_DISKSPACE;
|
|
|
|
quint64 previousSpace = quint64(-1);
|
2011-03-28 04:26:47 +02:00
|
|
|
|
2011-11-25 01:01:30 +01:00
|
|
|
forever
|
2011-03-28 04:26:47 +02:00
|
|
|
{
|
2014-12-04 00:02:42 +01:00
|
|
|
quint64 freeSpace = 0ui64;
|
|
|
|
if(MUtils::OS::free_diskspace(m_path, freeSpace))
|
2011-03-28 04:26:47 +02:00
|
|
|
{
|
2011-10-29 16:26:09 +02:00
|
|
|
if(freeSpace < minimumSpace)
|
|
|
|
{
|
2014-11-25 02:14:42 +01:00
|
|
|
qWarning("Free diskspace on '%s' dropped below %s MB, only %s MB free!", MUTILS_UTF8(m_path), MUTILS_UTF8(QString::number(minimumSpace / 1048576ui64)), MUTILS_UTF8(QString::number(freeSpace / 1048576ui64)));
|
2011-11-28 00:35:43 +01:00
|
|
|
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);
|
2011-11-08 15:12:31 +01:00
|
|
|
minimumSpace = qMin(freeSpace, (minimumSpace >> 1));
|
2011-10-29 16:26:09 +02:00
|
|
|
}
|
|
|
|
if(freeSpace != previousSpace)
|
|
|
|
{
|
|
|
|
emit freeSpaceChanged(freeSpace);
|
|
|
|
previousSpace = freeSpace;
|
|
|
|
}
|
2011-03-28 04:26:47 +02:00
|
|
|
}
|
2011-11-25 01:01:30 +01:00
|
|
|
if(m_semaphore.tryAcquire(1, 2000)) break;
|
2011-03-28 04:26:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QString DiskObserverThread::makeRootDir(const QString &baseDir)
|
|
|
|
{
|
|
|
|
QDir dir(baseDir);
|
|
|
|
|
|
|
|
if(!dir.exists())
|
|
|
|
{
|
|
|
|
return baseDir;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool success = true;
|
|
|
|
|
|
|
|
while(success)
|
|
|
|
{
|
|
|
|
success = dir.cdUp();
|
|
|
|
}
|
|
|
|
|
|
|
|
return dir.canonicalPath();
|
|
|
|
}
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// SLOTS
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/*NONE*/
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// EVENTS
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/*NONE*/
|