mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-03-22 14:55:36 +08:00
67 lines
1.9 KiB
C++
67 lines
1.9 KiB
C++
// SPDX-FileCopyrightText: Copyright (C) 2015 swift Project Community / Contributors
|
|
// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-swift-pilot-client-1
|
|
|
|
//! \file
|
|
|
|
#ifndef SWIFT_MISC_ATOMICFILE_H
|
|
#define SWIFT_MISC_ATOMICFILE_H
|
|
|
|
#include <QFile>
|
|
#include <QFileDevice>
|
|
#include <QString>
|
|
|
|
#include "misc/swiftmiscexport.h"
|
|
|
|
namespace swift::misc
|
|
{
|
|
/*!
|
|
* A subclass of QFile which writes to a temporary file while it is open, then renames the file
|
|
* when it is closed, so that it overwrites the target file as a single, atomic transaction.
|
|
*
|
|
* If the application crashes while data is still being written, the original file is unchanged.
|
|
*
|
|
* \fixme Consider using QSaveFile.
|
|
*/
|
|
class SWIFT_MISC_EXPORT CAtomicFile : public QFile
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
//! \copydoc QFile::QFile(const QString &)
|
|
CAtomicFile(const QString &filename) : QFile(filename) {}
|
|
|
|
//! \copydoc QFile::~QFile
|
|
virtual ~CAtomicFile() override;
|
|
|
|
//! \copydoc QFile::open
|
|
//! Just before opening the file, the filename is changed so we actually write to a temporary file.
|
|
virtual bool open(OpenMode mode) override;
|
|
|
|
//! \copydoc QFileDevice::close
|
|
//! After closing the file, it is renamed so that it overwrites the target file.
|
|
virtual void close() override;
|
|
|
|
//! Calls close() and returns false if there was an error at any stage.
|
|
bool checkedClose();
|
|
|
|
//! Closes the file without renaming it.
|
|
void abandon();
|
|
|
|
//! \copydoc QFileDevice::error
|
|
FileError error() const;
|
|
|
|
//! \copydoc QFileDevice::unsetError
|
|
void unsetError();
|
|
|
|
private:
|
|
static QString randomSuffix();
|
|
void replaceOriginal();
|
|
|
|
QString m_originalFilename;
|
|
bool m_renameError = false;
|
|
bool m_permissionError = false;
|
|
};
|
|
} // namespace swift::misc
|
|
|
|
#endif
|