Introduce PartitionJob
This commit is contained in:
parent
4516213b0b
commit
d374d8bad8
@ -30,6 +30,7 @@ calamares_add_plugin( partition
|
|||||||
DeviceModel.cpp
|
DeviceModel.cpp
|
||||||
PartitionCoreModule.cpp
|
PartitionCoreModule.cpp
|
||||||
PartitionInfo.cpp
|
PartitionInfo.cpp
|
||||||
|
PartitionJob.cpp
|
||||||
PartitionModel.cpp
|
PartitionModel.cpp
|
||||||
PartitionPage.cpp
|
PartitionPage.cpp
|
||||||
PartitionViewStep.cpp
|
PartitionViewStep.cpp
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <CreatePartitionJob.h>
|
#include <CreatePartitionJob.h>
|
||||||
|
#include <PartitionInfo.h>
|
||||||
|
|
||||||
#include <utils/Logger.h>
|
#include <utils/Logger.h>
|
||||||
|
|
||||||
@ -36,8 +37,8 @@
|
|||||||
#include <QScopedPointer>
|
#include <QScopedPointer>
|
||||||
|
|
||||||
CreatePartitionJob::CreatePartitionJob( Device* device, Partition* partition )
|
CreatePartitionJob::CreatePartitionJob( Device* device, Partition* partition )
|
||||||
: m_device( device )
|
: PartitionJob( partition )
|
||||||
, m_partition( partition )
|
, m_device( device )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,13 +19,13 @@
|
|||||||
#ifndef CREATEPARTITIONJOB_H
|
#ifndef CREATEPARTITIONJOB_H
|
||||||
#define CREATEPARTITIONJOB_H
|
#define CREATEPARTITIONJOB_H
|
||||||
|
|
||||||
#include <Job.h>
|
#include <PartitionJob.h>
|
||||||
|
|
||||||
class Device;
|
class Device;
|
||||||
class Partition;
|
class Partition;
|
||||||
class FileSystem;
|
class FileSystem;
|
||||||
|
|
||||||
class CreatePartitionJob : public Calamares::Job
|
class CreatePartitionJob : public PartitionJob
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
@ -39,14 +39,8 @@ public:
|
|||||||
return m_device;
|
return m_device;
|
||||||
}
|
}
|
||||||
|
|
||||||
Partition* partition() const
|
|
||||||
{
|
|
||||||
return m_partition;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Device* m_device;
|
Device* m_device;
|
||||||
Partition* m_partition;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* CREATEPARTITIONJOB_H */
|
#endif /* CREATEPARTITIONJOB_H */
|
||||||
|
@ -30,8 +30,8 @@
|
|||||||
#include <util/report.h>
|
#include <util/report.h>
|
||||||
|
|
||||||
DeletePartitionJob::DeletePartitionJob( Device* device, Partition* partition )
|
DeletePartitionJob::DeletePartitionJob( Device* device, Partition* partition )
|
||||||
: m_device( device )
|
: PartitionJob( partition )
|
||||||
, m_partition( partition )
|
, m_device( device )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,13 +19,13 @@
|
|||||||
#ifndef DELETEPARTITIONJOB_H
|
#ifndef DELETEPARTITIONJOB_H
|
||||||
#define DELETEPARTITIONJOB_H
|
#define DELETEPARTITIONJOB_H
|
||||||
|
|
||||||
#include <Job.h>
|
#include <PartitionJob.h>
|
||||||
|
|
||||||
class Device;
|
class Device;
|
||||||
class Partition;
|
class Partition;
|
||||||
class FileSystem;
|
class FileSystem;
|
||||||
|
|
||||||
class DeletePartitionJob : public Calamares::Job
|
class DeletePartitionJob : public PartitionJob
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
@ -39,14 +39,8 @@ public:
|
|||||||
return m_device;
|
return m_device;
|
||||||
}
|
}
|
||||||
|
|
||||||
Partition* partition() const
|
|
||||||
{
|
|
||||||
return m_partition;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Device* m_device;
|
Device* m_device;
|
||||||
Partition* m_partition;
|
|
||||||
FileSystem* m_fs;
|
FileSystem* m_fs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -257,6 +257,15 @@ PartitionCoreModule::deletePartition( Device* device, Partition* partition )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// Remove any PartitionJob on this partition
|
||||||
|
for ( auto it = jobs.begin(); it != jobs.end(); )
|
||||||
|
{
|
||||||
|
PartitionJob* job = qobject_cast< PartitionJob* >( it->data() );
|
||||||
|
if ( job && job->partition() == partition )
|
||||||
|
it = jobs.erase( it );
|
||||||
|
else
|
||||||
|
++it;
|
||||||
|
}
|
||||||
DeletePartitionJob* job = new DeletePartitionJob( device, partition );
|
DeletePartitionJob* job = new DeletePartitionJob( device, partition );
|
||||||
job->updatePreview();
|
job->updatePreview();
|
||||||
jobs << Calamares::job_ptr( job );
|
jobs << Calamares::job_ptr( job );
|
||||||
|
23
src/modules/partition/PartitionJob.cpp
Normal file
23
src/modules/partition/PartitionJob.cpp
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares 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 Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <PartitionJob.h>
|
||||||
|
|
||||||
|
PartitionJob::PartitionJob( Partition* partition )
|
||||||
|
: m_partition( partition )
|
||||||
|
{}
|
44
src/modules/partition/PartitionJob.h
Normal file
44
src/modules/partition/PartitionJob.h
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares 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 Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PARTITIONJOB_H
|
||||||
|
#define PARTITIONJOB_H
|
||||||
|
|
||||||
|
#include <Job.h>
|
||||||
|
|
||||||
|
class Partition;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for jobs which affect a partition
|
||||||
|
*/
|
||||||
|
class PartitionJob : public Calamares::Job
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
PartitionJob( Partition* partition );
|
||||||
|
|
||||||
|
Partition* partition() const
|
||||||
|
{
|
||||||
|
return m_partition;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Partition* m_partition;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* PARTITIONJOB_H */
|
@ -5,6 +5,8 @@ set( jobtests_SRCS
|
|||||||
${PartitionModule_SOURCE_DIR}/CreatePartitionJob.cpp
|
${PartitionModule_SOURCE_DIR}/CreatePartitionJob.cpp
|
||||||
${PartitionModule_SOURCE_DIR}/CreatePartitionTableJob.cpp
|
${PartitionModule_SOURCE_DIR}/CreatePartitionTableJob.cpp
|
||||||
${PartitionModule_SOURCE_DIR}/DeletePartitionJob.cpp
|
${PartitionModule_SOURCE_DIR}/DeletePartitionJob.cpp
|
||||||
|
${PartitionModule_SOURCE_DIR}/PartitionInfo.cpp
|
||||||
|
${PartitionModule_SOURCE_DIR}/PartitionJob.cpp
|
||||||
${PartitionModule_SOURCE_DIR}/PMUtils.cpp
|
${PartitionModule_SOURCE_DIR}/PMUtils.cpp
|
||||||
JobTests.cpp
|
JobTests.cpp
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user