kpmcore/src/jobs/deletefilesystemjob.cpp

95 lines
3.2 KiB
C++
Raw Permalink Normal View History

/*
SPDX-FileCopyrightText: 2008-2010 Volker Lanz <vl@fidra.de>
SPDX-FileCopyrightText: 2012-2018 Andrius Štikonas <andrius@stikonas.eu>
SPDX-FileCopyrightText: 2016 Chantara Tith <tith.chantara@gmail.com>
SPDX-License-Identifier: GPL-3.0-or-later
*/
#include "jobs/deletefilesystemjob.h"
#include "backend/corebackend.h"
#include "backend/corebackendmanager.h"
#include "backend/corebackenddevice.h"
#include "backend/corebackendpartitiontable.h"
#include "core/partition.h"
#include "core/device.h"
#include "util/helpers.h"
#include "util/report.h"
#include <QDebug>
#include <KLocalizedString>
/** Creates a new DeleteFileSystemJob
2015-07-13 15:16:36 +01:00
@param d the Device the FileSystem to delete is on
@param p the Partition the FileSystem to delete is on
*/
DeleteFileSystemJob::DeleteFileSystemJob(Device& d, Partition& p) :
2015-07-13 15:16:36 +01:00
Job(),
m_Device(d),
m_Partition(p)
{
}
bool DeleteFileSystemJob::run(Report& parent)
{
2015-07-13 15:16:36 +01:00
Q_ASSERT(device().deviceNode() == partition().devicePath());
2015-07-13 15:16:36 +01:00
if (device().deviceNode() != partition().devicePath()) {
qWarning() << "deviceNode: " << device().deviceNode() << ", partition path: " << partition().devicePath();
return false;
}
2015-07-13 15:16:36 +01:00
bool rval = false;
2015-07-13 15:16:36 +01:00
Report* report = jobStarted(parent);
if (isMounted(partition().partitionPath())) {
report->line() << xi18nc("@info:progress", "Could not delete file system: file system on <filename>%1</filename> is mounted.", partition().deviceNode());
jobFinished(*report, rval);
return false;
}
2016-06-18 21:58:40 +01:00
if (partition().roles().has(PartitionRole::Extended)) {
2015-07-13 15:16:36 +01:00
rval = true;
} else if (device().type() == Device::Type::LVM_Device) {
2016-06-18 21:58:40 +01:00
rval = true;
}
2015-07-13 15:16:36 +01:00
else {
if (!partition().fileSystem().remove(*report, partition().deviceNode())) {
jobFinished(*report, rval);
return false;
}
std::unique_ptr<CoreBackendDevice> backendDevice = CoreBackendManager::self()->backend()->openDevice(device());
2015-07-13 15:16:36 +01:00
if (backendDevice) {
std::unique_ptr<CoreBackendPartitionTable> backendPartitionTable = backendDevice->openPartitionTable();
2015-07-13 15:16:36 +01:00
if (backendPartitionTable) {
rval = backendPartitionTable->clobberFileSystem(*report, partition());
2015-07-13 15:16:36 +01:00
if (!rval)
report->line() << xi18nc("@info:progress", "Could not delete file system on <filename>%1</filename>.", partition().deviceNode());
2015-07-13 15:16:36 +01:00
else
backendPartitionTable->commit();
} else
report->line() << xi18nc("@info:progress", "Could not open partition table on device <filename>%1</filename> to delete file system on <filename>%2</filename>.", device().deviceNode(), partition().deviceNode());
2015-07-13 15:16:36 +01:00
} else
report->line() << xi18nc("@info:progress", "Could not delete file system signature for partition <filename>%1</filename>: Failed to open device <filename>%2</filename>.", partition().deviceNode(), device().deviceNode());
2015-07-13 15:16:36 +01:00
}
2015-07-13 15:16:36 +01:00
jobFinished(*report, rval);
2015-07-13 15:16:36 +01:00
return rval;
}
QString DeleteFileSystemJob::description() const
{
return xi18nc("@info:progress", "Delete file system on <filename>%1</filename>", partition().deviceNode());
}