mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-05 01:05:34 +08:00
During #475 found issue with deleter
* changed / improved deleter * formatting in related class soundgenerator
This commit is contained in:
committed by
Mathew Sutcliffe
parent
84b06c51d9
commit
68d0b8cc98
@@ -7,28 +7,57 @@
|
||||
* contained in the LICENSE file.
|
||||
*/
|
||||
|
||||
#include <QFile>
|
||||
#include "filedeleter.h"
|
||||
#include <QFile>
|
||||
|
||||
namespace BlackMisc
|
||||
{
|
||||
void CFileDeleter::addFile(const QString &file)
|
||||
void CFileDeleter::addFileForDeletion(const QString &file)
|
||||
{
|
||||
if (file.isEmpty()) return;
|
||||
if (file.isEmpty()) { return; }
|
||||
if (!this->m_fileNames.contains(file)) this->m_fileNames.append(file);
|
||||
}
|
||||
|
||||
void CFileDeleter::addFileForDeletion(const QString &file)
|
||||
void CFileDeleter::addFilesForDeletion(const QStringList &files)
|
||||
{
|
||||
CFileDeleter::fileDeleter().addFile(file);
|
||||
if (files.isEmpty()) { return; }
|
||||
this->m_fileNames.append(files);
|
||||
}
|
||||
|
||||
CFileDeleter::~CFileDeleter()
|
||||
{
|
||||
foreach(const QString fn, this->m_fileNames)
|
||||
this->deleteFiles();
|
||||
}
|
||||
|
||||
void CFileDeleter::deleteFiles()
|
||||
{
|
||||
const QStringList files(m_fileNames);
|
||||
m_fileNames.clear();
|
||||
|
||||
for (const QString &fn : files)
|
||||
{
|
||||
if (fn.isEmpty()) { continue; }
|
||||
QFile f(fn);
|
||||
f.remove();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
CTimedFileDeleter::CTimedFileDeleter(const QString &file, int deleteAfterMs, QObject *parent) :
|
||||
QObject(parent)
|
||||
{
|
||||
Q_ASSERT_X(!file.isEmpty(), Q_FUNC_INFO, "No file name");
|
||||
if (deleteAfterMs < 100) { deleteAfterMs = 100; } // makes sure timer is started properly
|
||||
this->m_fileDeleter.addFileForDeletion(file);
|
||||
m_timerId = startTimer(deleteAfterMs);
|
||||
}
|
||||
|
||||
void CTimedFileDeleter::timerEvent(QTimerEvent *event)
|
||||
{
|
||||
Q_UNUSED(event);
|
||||
if (m_timerId > 0) { this->killTimer(m_timerId); }
|
||||
m_timerId = -1;
|
||||
m_fileDeleter.deleteFiles();
|
||||
this->deleteLater();
|
||||
}
|
||||
|
||||
} // ns
|
||||
|
||||
@@ -18,33 +18,49 @@
|
||||
|
||||
namespace BlackMisc
|
||||
{
|
||||
|
||||
/*!
|
||||
* Utility class, deleting files when it is destroyed
|
||||
*/
|
||||
class BLACKMISC_EXPORT CFileDeleter
|
||||
{
|
||||
|
||||
private:
|
||||
QStringList m_fileNames;
|
||||
|
||||
public:
|
||||
//! File deleter
|
||||
CFileDeleter() {}
|
||||
|
||||
//! add given file for deletion
|
||||
void addFile(const QString &file);
|
||||
|
||||
public:
|
||||
|
||||
//! file deleter
|
||||
static CFileDeleter &fileDeleter() { static CFileDeleter f; return f;}
|
||||
|
||||
//! add a file (name)
|
||||
static void addFileForDeletion(const QString &file);
|
||||
void addFileForDeletion(const QString &file);
|
||||
|
||||
//! Add files (names)
|
||||
void addFilesForDeletion(const QStringList &files);
|
||||
|
||||
//! Destructor
|
||||
~CFileDeleter();
|
||||
|
||||
//! Delete files
|
||||
void deleteFiles();
|
||||
|
||||
private:
|
||||
QStringList m_fileNames;
|
||||
};
|
||||
}
|
||||
|
||||
/*!
|
||||
* Utility class, deleting files after time
|
||||
*/
|
||||
class BLACKMISC_EXPORT CTimedFileDeleter : public QObject
|
||||
{
|
||||
public:
|
||||
//! Constructor
|
||||
CTimedFileDeleter(const QString &file, int deleteAfterMs, QObject *parent = nullptr);
|
||||
|
||||
protected:
|
||||
//! \copydoc QObject::timerEvent
|
||||
virtual void timerEvent(QTimerEvent *event) override;
|
||||
|
||||
private:
|
||||
CFileDeleter m_fileDeleter;
|
||||
int m_timerId = -1;
|
||||
};
|
||||
|
||||
} // ns
|
||||
|
||||
#endif // guard
|
||||
|
||||
Reference in New Issue
Block a user