2014-06-30 13:37:46 +02:00
|
|
|
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
|
|
|
*
|
|
|
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
2015-02-27 19:07:17 +01:00
|
|
|
* Copyright 2014-2015, Teo Mrnjavac <teo@kde.org>
|
2014-06-30 13:37:46 +02:00
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2014-08-08 13:25:56 +02:00
|
|
|
#include <core/PartitionCoreModule.h>
|
|
|
|
|
|
|
|
#include <core/BootLoaderModel.h>
|
|
|
|
#include <core/DeviceModel.h>
|
|
|
|
#include <core/PartitionInfo.h>
|
|
|
|
#include <core/PartitionIterator.h>
|
|
|
|
#include <core/PartitionModel.h>
|
|
|
|
#include <core/PMUtils.h>
|
2014-11-28 15:51:59 +01:00
|
|
|
#include <jobs/ClearMountsJob.h>
|
2015-02-27 19:07:17 +01:00
|
|
|
#include <jobs/ClearTempMountsJob.h>
|
2014-08-08 13:25:56 +02:00
|
|
|
#include <jobs/CreatePartitionJob.h>
|
|
|
|
#include <jobs/CreatePartitionTableJob.h>
|
|
|
|
#include <jobs/DeletePartitionJob.h>
|
|
|
|
#include <jobs/FillGlobalStorageJob.h>
|
|
|
|
#include <jobs/FormatPartitionJob.h>
|
|
|
|
#include <jobs/ResizePartitionJob.h>
|
2014-06-30 13:37:46 +02:00
|
|
|
|
2014-06-30 18:08:13 +02:00
|
|
|
#include <Typedefs.h>
|
2014-07-02 15:49:35 +02:00
|
|
|
#include <utils/Logger.h>
|
2014-06-30 13:48:40 +02:00
|
|
|
|
2014-06-30 13:37:46 +02:00
|
|
|
// CalaPM
|
|
|
|
#include <CalaPM.h>
|
2014-07-02 15:49:35 +02:00
|
|
|
#include <core/device.h>
|
|
|
|
#include <core/partition.h>
|
2014-06-30 13:37:46 +02:00
|
|
|
#include <backend/corebackend.h>
|
|
|
|
#include <backend/corebackendmanager.h>
|
2014-08-06 16:15:34 +02:00
|
|
|
#include <fs/filesystemfactory.h>
|
2014-06-30 13:37:46 +02:00
|
|
|
|
2014-07-22 10:42:50 +02:00
|
|
|
// Qt
|
|
|
|
#include <QStandardItemModel>
|
|
|
|
|
2014-07-30 23:21:06 +02:00
|
|
|
static bool
|
|
|
|
hasRootPartition( Device* device )
|
|
|
|
{
|
|
|
|
for ( auto it = PartitionIterator::begin( device ); it != PartitionIterator::end( device ); ++it )
|
2014-08-05 09:54:30 +02:00
|
|
|
if ( ( *it )->mountPoint() == "/" )
|
2014-07-30 23:21:06 +02:00
|
|
|
return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
//- DeviceInfo ---------------------------------------------
|
|
|
|
PartitionCoreModule::DeviceInfo::DeviceInfo( Device* _device )
|
|
|
|
: device( _device )
|
|
|
|
, partitionModel( new PartitionModel )
|
|
|
|
{}
|
|
|
|
|
2014-07-11 16:55:21 +02:00
|
|
|
PartitionCoreModule::DeviceInfo::~DeviceInfo()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-07-11 17:08:56 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::DeviceInfo::forgetChanges()
|
|
|
|
{
|
|
|
|
jobs.clear();
|
2014-07-17 09:49:24 +02:00
|
|
|
for ( auto it = PartitionIterator::begin( device.data() ); it != PartitionIterator::end( device.data() ); ++it )
|
2014-07-16 16:20:58 +02:00
|
|
|
PartitionInfo::reset( *it );
|
2014-07-11 17:08:56 +02:00
|
|
|
}
|
|
|
|
|
2014-07-24 19:28:53 +02:00
|
|
|
|
|
|
|
bool
|
|
|
|
PartitionCoreModule::DeviceInfo::isDirty() const
|
|
|
|
{
|
|
|
|
if ( !jobs.isEmpty() )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
for ( auto it = PartitionIterator::begin( device.data() ); it != PartitionIterator::end( device.data() ); ++it )
|
|
|
|
if ( PartitionInfo::isDirty( *it ) )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
//- PartitionCoreModule ------------------------------------
|
2014-06-30 13:37:46 +02:00
|
|
|
PartitionCoreModule::PartitionCoreModule( QObject* parent )
|
|
|
|
: QObject( parent )
|
2014-06-30 13:48:40 +02:00
|
|
|
, m_deviceModel( new DeviceModel( this ) )
|
2014-07-23 18:14:27 +02:00
|
|
|
, m_bootLoaderModel( new BootLoaderModel( this ) )
|
2014-06-30 13:37:46 +02:00
|
|
|
{
|
|
|
|
if ( !CalaPM::init() )
|
|
|
|
qFatal( "Failed to init CalaPM" );
|
2014-08-06 16:15:34 +02:00
|
|
|
FileSystemFactory::init();
|
2014-07-24 19:28:53 +02:00
|
|
|
init();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
PartitionCoreModule::init()
|
|
|
|
{
|
2014-06-30 13:37:46 +02:00
|
|
|
CoreBackend* backend = CoreBackendManager::self()->backend();
|
2014-07-11 15:58:12 +02:00
|
|
|
auto devices = backend->scanDevices();
|
2014-07-30 23:21:06 +02:00
|
|
|
|
|
|
|
// Remove the device which contains / from the list
|
|
|
|
for ( auto it = devices.begin(); it != devices.end(); )
|
|
|
|
if ( hasRootPartition( *it ) )
|
|
|
|
it = devices.erase( it );
|
|
|
|
else
|
|
|
|
++it;
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
for ( auto device : devices )
|
2014-06-30 14:12:23 +02:00
|
|
|
{
|
2014-07-11 15:58:12 +02:00
|
|
|
auto deviceInfo = new DeviceInfo( device );
|
|
|
|
m_deviceInfos << deviceInfo;
|
|
|
|
|
2014-07-16 16:20:58 +02:00
|
|
|
deviceInfo->partitionModel->init( device );
|
2014-06-30 14:12:23 +02:00
|
|
|
}
|
2014-07-11 15:58:12 +02:00
|
|
|
m_deviceModel->init( devices );
|
2014-06-30 13:48:40 +02:00
|
|
|
|
2014-07-23 18:14:27 +02:00
|
|
|
m_bootLoaderModel->init( devices );
|
2014-06-30 13:37:46 +02:00
|
|
|
}
|
|
|
|
|
2014-06-30 14:12:23 +02:00
|
|
|
PartitionCoreModule::~PartitionCoreModule()
|
2014-06-30 13:37:46 +02:00
|
|
|
{
|
2014-07-11 15:58:12 +02:00
|
|
|
qDeleteAll( m_deviceInfos );
|
2014-06-30 13:37:46 +02:00
|
|
|
}
|
2014-06-30 13:48:40 +02:00
|
|
|
|
|
|
|
DeviceModel*
|
|
|
|
PartitionCoreModule::deviceModel() const
|
|
|
|
{
|
|
|
|
return m_deviceModel;
|
|
|
|
}
|
2014-06-30 14:12:23 +02:00
|
|
|
|
2014-07-22 10:42:50 +02:00
|
|
|
QAbstractItemModel*
|
|
|
|
PartitionCoreModule::bootLoaderModel() const
|
|
|
|
{
|
|
|
|
return m_bootLoaderModel;
|
|
|
|
}
|
|
|
|
|
2014-06-30 14:12:23 +02:00
|
|
|
PartitionModel*
|
|
|
|
PartitionCoreModule::partitionModelForDevice( Device* device ) const
|
|
|
|
{
|
2014-07-11 15:58:12 +02:00
|
|
|
DeviceInfo* info = infoForDevice( device );
|
|
|
|
Q_ASSERT( info );
|
|
|
|
return info->partitionModel.data();
|
2014-06-30 14:12:23 +02:00
|
|
|
}
|
2014-06-30 16:17:28 +02:00
|
|
|
|
2015-04-28 17:40:49 +02:00
|
|
|
|
|
|
|
Device*
|
|
|
|
PartitionCoreModule::createImmutableDeviceCopy( Device* device ) const
|
|
|
|
{
|
|
|
|
CoreBackend* backend = CoreBackendManager::self()->backend();
|
|
|
|
|
|
|
|
Device* deviceBefore = backend->scanDevice( device->deviceNode() );
|
|
|
|
return deviceBefore;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-07-10 19:55:16 +02:00
|
|
|
void
|
2014-07-15 14:40:08 +02:00
|
|
|
PartitionCoreModule::createPartitionTable( Device* device, PartitionTable::TableType type )
|
2014-07-10 19:55:16 +02:00
|
|
|
{
|
2014-07-11 17:08:56 +02:00
|
|
|
DeviceInfo* info = infoForDevice( device );
|
|
|
|
// Creating a partition table wipes all the disk, so there is no need to
|
|
|
|
// keep previous changes
|
|
|
|
info->forgetChanges();
|
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
PartitionModel::ResetHelper helper( partitionModelForDevice( device ) );
|
2014-07-15 14:40:08 +02:00
|
|
|
CreatePartitionTableJob* job = new CreatePartitionTableJob( device, type );
|
2014-07-10 19:55:16 +02:00
|
|
|
job->updatePreview();
|
2014-07-11 17:08:56 +02:00
|
|
|
info->jobs << Calamares::job_ptr( job );
|
2014-07-10 19:55:16 +02:00
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
refresh();
|
2014-07-10 19:55:16 +02:00
|
|
|
}
|
|
|
|
|
2014-06-30 16:17:28 +02:00
|
|
|
void
|
2014-07-16 16:20:58 +02:00
|
|
|
PartitionCoreModule::createPartition( Device* device, Partition* partition )
|
2014-06-30 16:17:28 +02:00
|
|
|
{
|
2014-07-11 15:58:12 +02:00
|
|
|
auto deviceInfo = infoForDevice( device );
|
|
|
|
Q_ASSERT( deviceInfo );
|
2014-07-04 17:58:32 +02:00
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
PartitionModel::ResetHelper helper( partitionModelForDevice( device ) );
|
2014-07-04 17:58:32 +02:00
|
|
|
CreatePartitionJob* job = new CreatePartitionJob( device, partition );
|
2014-07-01 17:09:39 +02:00
|
|
|
job->updatePreview();
|
2014-07-04 17:58:32 +02:00
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
deviceInfo->jobs << Calamares::job_ptr( job );
|
2014-07-02 15:49:35 +02:00
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
refresh();
|
2014-06-30 16:17:28 +02:00
|
|
|
}
|
|
|
|
|
2014-07-02 15:49:35 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::deletePartition( Device* device, Partition* partition )
|
|
|
|
{
|
2014-07-11 15:58:12 +02:00
|
|
|
auto deviceInfo = infoForDevice( device );
|
|
|
|
Q_ASSERT( deviceInfo );
|
2014-07-04 17:59:03 +02:00
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
PartitionModel::ResetHelper helper( partitionModelForDevice( device ) );
|
|
|
|
|
2014-07-17 15:01:45 +02:00
|
|
|
if ( partition->roles().has( PartitionRole::Extended ) )
|
|
|
|
{
|
|
|
|
// Delete all logical partitions first
|
|
|
|
// I am not sure if we can iterate on Partition::children() while
|
|
|
|
// deleting them, so let's play it safe and keep our own list.
|
|
|
|
QList< Partition* > lst;
|
|
|
|
for ( auto childPartition : partition->children() )
|
|
|
|
if ( !PMUtils::isPartitionFreeSpace( childPartition ) )
|
|
|
|
lst << childPartition;
|
|
|
|
|
|
|
|
for ( auto partition : lst )
|
|
|
|
deletePartition( device, partition );
|
|
|
|
}
|
2014-07-11 15:58:12 +02:00
|
|
|
|
2014-07-17 15:01:45 +02:00
|
|
|
QList< Calamares::job_ptr >& jobs = deviceInfo->jobs;
|
2014-07-02 15:49:35 +02:00
|
|
|
if ( partition->state() == Partition::StateNew )
|
|
|
|
{
|
|
|
|
// Find matching CreatePartitionJob
|
2014-07-11 15:58:12 +02:00
|
|
|
auto it = std::find_if( jobs.begin(), jobs.end(), [ partition ]( Calamares::job_ptr job )
|
2014-07-02 15:49:35 +02:00
|
|
|
{
|
|
|
|
CreatePartitionJob* createJob = qobject_cast< CreatePartitionJob* >( job.data() );
|
|
|
|
return createJob && createJob->partition() == partition;
|
|
|
|
} );
|
2014-07-11 15:58:12 +02:00
|
|
|
if ( it == jobs.end() )
|
2014-07-02 15:49:35 +02:00
|
|
|
{
|
|
|
|
cDebug() << "Failed to find a CreatePartitionJob matching the partition to remove";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Remove it
|
|
|
|
if ( ! partition->parent()->remove( partition ) )
|
|
|
|
{
|
|
|
|
cDebug() << "Failed to remove partition from preview";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
device->partitionTable()->updateUnallocated( *device );
|
2014-07-11 15:58:12 +02:00
|
|
|
jobs.erase( it );
|
2014-07-02 15:49:35 +02:00
|
|
|
// The partition is no longer referenced by either a job or the device
|
|
|
|
// partition list, so we have to delete it
|
|
|
|
delete partition;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-07-18 14:29:27 +02:00
|
|
|
// 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;
|
|
|
|
}
|
2014-07-02 15:49:35 +02:00
|
|
|
DeletePartitionJob* job = new DeletePartitionJob( device, partition );
|
|
|
|
job->updatePreview();
|
2014-07-11 15:58:12 +02:00
|
|
|
jobs << Calamares::job_ptr( job );
|
2014-07-02 15:49:35 +02:00
|
|
|
}
|
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
refresh();
|
2014-07-02 15:49:35 +02:00
|
|
|
}
|
|
|
|
|
2014-07-17 14:59:59 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::formatPartition( Device* device, Partition* partition )
|
|
|
|
{
|
2014-07-18 15:06:56 +02:00
|
|
|
auto deviceInfo = infoForDevice( device );
|
|
|
|
Q_ASSERT( deviceInfo );
|
2014-07-29 10:57:10 +02:00
|
|
|
PartitionModel::ResetHelper helper( partitionModelForDevice( device ) );
|
2014-07-18 15:06:56 +02:00
|
|
|
|
|
|
|
FormatPartitionJob* job = new FormatPartitionJob( device, partition );
|
|
|
|
deviceInfo->jobs << Calamares::job_ptr( job );
|
|
|
|
|
2014-07-29 10:57:10 +02:00
|
|
|
refresh();
|
2014-07-17 14:59:59 +02:00
|
|
|
}
|
|
|
|
|
2014-08-05 14:57:00 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::resizePartition( Device* device, Partition* partition, qint64 first, qint64 last )
|
|
|
|
{
|
|
|
|
auto deviceInfo = infoForDevice( device );
|
|
|
|
Q_ASSERT( deviceInfo );
|
|
|
|
PartitionModel::ResetHelper helper( partitionModelForDevice( device ) );
|
|
|
|
|
|
|
|
ResizePartitionJob* job = new ResizePartitionJob( device, partition, first, last );
|
|
|
|
job->updatePreview();
|
|
|
|
deviceInfo->jobs << Calamares::job_ptr( job );
|
|
|
|
|
|
|
|
refresh();
|
|
|
|
}
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
QList< Calamares::job_ptr >
|
|
|
|
PartitionCoreModule::jobs() const
|
|
|
|
{
|
|
|
|
QList< Calamares::job_ptr > lst;
|
2014-07-22 17:32:26 +02:00
|
|
|
QList< Device* > devices;
|
2014-11-28 15:51:59 +01:00
|
|
|
|
2015-02-27 19:07:17 +01:00
|
|
|
lst << Calamares::job_ptr( new ClearTempMountsJob() );
|
|
|
|
|
2014-11-28 15:51:59 +01:00
|
|
|
for ( auto info : m_deviceInfos )
|
|
|
|
{
|
2015-02-18 17:41:01 +01:00
|
|
|
if ( info->isDirty() )
|
|
|
|
lst << Calamares::job_ptr( new ClearMountsJob( info->device.data() ) );
|
2014-11-28 15:51:59 +01:00
|
|
|
}
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
for ( auto info : m_deviceInfos )
|
2014-07-22 17:32:26 +02:00
|
|
|
{
|
2014-07-11 15:58:12 +02:00
|
|
|
lst << info->jobs;
|
2014-07-22 17:32:26 +02:00
|
|
|
devices << info->device.data();
|
|
|
|
}
|
2014-07-23 18:16:55 +02:00
|
|
|
lst << Calamares::job_ptr( new FillGlobalStorageJob( devices, m_bootLoaderInstallPath ) );
|
2014-11-28 15:51:59 +01:00
|
|
|
|
2015-02-13 11:56:10 +01:00
|
|
|
|
|
|
|
QStringList jobsDebug;
|
|
|
|
foreach ( auto job, lst )
|
|
|
|
{
|
|
|
|
jobsDebug.append( job->prettyName() );
|
|
|
|
}
|
|
|
|
|
|
|
|
cDebug() << "PartitionCodeModule has been asked for jobs. About to return:"
|
|
|
|
<< jobsDebug.join( "\n" );
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
return lst;
|
|
|
|
}
|
|
|
|
|
2014-07-02 15:49:35 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::dumpQueue() const
|
|
|
|
{
|
2014-07-16 11:15:22 +02:00
|
|
|
cDebug() << "# Queue:";
|
2014-07-11 15:58:12 +02:00
|
|
|
for ( auto info : m_deviceInfos )
|
2014-07-02 15:49:35 +02:00
|
|
|
{
|
2014-07-16 11:15:22 +02:00
|
|
|
cDebug() << "## Device:" << info->device->name();
|
2014-07-11 15:58:12 +02:00
|
|
|
for ( auto job : info->jobs )
|
2014-07-16 11:15:22 +02:00
|
|
|
cDebug() << "-" << job->prettyName();
|
2014-07-02 15:49:35 +02:00
|
|
|
}
|
|
|
|
}
|
2014-07-10 18:55:19 +02:00
|
|
|
|
|
|
|
void
|
2014-07-29 10:57:10 +02:00
|
|
|
PartitionCoreModule::refreshPartition( Device* device, Partition* partition )
|
2014-07-10 18:55:19 +02:00
|
|
|
{
|
2014-07-29 10:57:10 +02:00
|
|
|
// Keep it simple for now: reset the model. This can be improved to cause
|
|
|
|
// the model to emit dataChanged() for the affected row instead, avoiding
|
|
|
|
// the loss of the current selection.
|
2014-07-11 15:58:12 +02:00
|
|
|
auto model = partitionModelForDevice( device );
|
2014-07-10 18:55:19 +02:00
|
|
|
Q_ASSERT( model );
|
2014-07-29 10:57:10 +02:00
|
|
|
PartitionModel::ResetHelper helper( model );
|
|
|
|
|
|
|
|
refresh();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
PartitionCoreModule::refresh()
|
|
|
|
{
|
2014-07-17 14:26:40 +02:00
|
|
|
updateHasRootMountPoint();
|
2014-07-24 19:28:53 +02:00
|
|
|
updateIsDirty();
|
2014-07-23 18:14:27 +02:00
|
|
|
m_bootLoaderModel->update();
|
2014-07-10 18:55:19 +02:00
|
|
|
}
|
2014-07-10 19:01:55 +02:00
|
|
|
|
|
|
|
void PartitionCoreModule::updateHasRootMountPoint()
|
|
|
|
{
|
|
|
|
bool oldValue = m_hasRootMountPoint;
|
2014-07-22 10:50:08 +02:00
|
|
|
m_hasRootMountPoint = findPartitionByMountPoint( "/" );
|
2014-07-10 19:01:55 +02:00
|
|
|
|
|
|
|
if ( oldValue != m_hasRootMountPoint )
|
|
|
|
hasRootMountPointChanged( m_hasRootMountPoint );
|
|
|
|
}
|
2014-07-11 15:58:12 +02:00
|
|
|
|
2014-07-24 19:28:53 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::updateIsDirty()
|
|
|
|
{
|
|
|
|
bool oldValue = m_isDirty;
|
|
|
|
m_isDirty = false;
|
|
|
|
for ( auto info : m_deviceInfos )
|
|
|
|
if ( info->isDirty() )
|
|
|
|
{
|
|
|
|
m_isDirty = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if ( oldValue != m_isDirty )
|
|
|
|
isDirtyChanged( m_isDirty );
|
|
|
|
}
|
|
|
|
|
2014-07-11 15:58:12 +02:00
|
|
|
PartitionCoreModule::DeviceInfo*
|
|
|
|
PartitionCoreModule::infoForDevice( Device* device ) const
|
|
|
|
{
|
|
|
|
for ( auto deviceInfo : m_deviceInfos )
|
|
|
|
{
|
|
|
|
if ( deviceInfo->device.data() == device )
|
|
|
|
return deviceInfo;
|
|
|
|
}
|
|
|
|
return nullptr;
|
|
|
|
}
|
2014-07-22 10:42:50 +02:00
|
|
|
|
|
|
|
Partition*
|
|
|
|
PartitionCoreModule::findPartitionByMountPoint( const QString& mountPoint ) const
|
|
|
|
{
|
|
|
|
for ( auto deviceInfo : m_deviceInfos )
|
|
|
|
{
|
|
|
|
Device* device = deviceInfo->device.data();
|
|
|
|
for ( auto it = PartitionIterator::begin( device ); it != PartitionIterator::end( device ); ++it )
|
|
|
|
if ( PartitionInfo::mountPoint( *it ) == mountPoint )
|
|
|
|
return *it;
|
|
|
|
}
|
|
|
|
return nullptr;
|
|
|
|
}
|
2014-07-23 18:15:46 +02:00
|
|
|
|
|
|
|
void
|
|
|
|
PartitionCoreModule::setBootLoaderInstallPath( const QString& path )
|
|
|
|
{
|
|
|
|
m_bootLoaderInstallPath = path;
|
|
|
|
}
|
2014-07-24 19:28:53 +02:00
|
|
|
|
|
|
|
void
|
|
|
|
PartitionCoreModule::revert()
|
|
|
|
{
|
|
|
|
qDeleteAll( m_deviceInfos );
|
|
|
|
m_deviceInfos.clear();
|
|
|
|
init();
|
|
|
|
updateIsDirty();
|
|
|
|
}
|
2014-07-30 14:15:29 +02:00
|
|
|
|
2014-09-04 19:35:44 +02:00
|
|
|
|
2014-09-16 18:11:19 +02:00
|
|
|
void
|
|
|
|
PartitionCoreModule::clearJobs()
|
|
|
|
{
|
|
|
|
foreach ( DeviceInfo* deviceInfo, m_deviceInfos )
|
|
|
|
{
|
|
|
|
deviceInfo->forgetChanges();
|
|
|
|
}
|
|
|
|
updateIsDirty();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-09-04 19:35:44 +02:00
|
|
|
bool
|
|
|
|
PartitionCoreModule::isDirty()
|
|
|
|
{
|
|
|
|
return m_isDirty;
|
|
|
|
}
|
|
|
|
|
2014-07-30 14:15:29 +02:00
|
|
|
QList< PartitionCoreModule::SummaryInfo >
|
|
|
|
PartitionCoreModule::createSummaryInfo() const
|
|
|
|
{
|
|
|
|
QList< SummaryInfo > lst;
|
|
|
|
CoreBackend* backend = CoreBackendManager::self()->backend();
|
|
|
|
for ( auto deviceInfo : m_deviceInfos )
|
|
|
|
{
|
|
|
|
if ( !deviceInfo->isDirty() )
|
|
|
|
continue;
|
|
|
|
SummaryInfo summaryInfo;
|
|
|
|
summaryInfo.deviceName = deviceInfo->device->name();
|
2015-04-09 17:47:23 +02:00
|
|
|
summaryInfo.deviceNode = deviceInfo->device->deviceNode();
|
2014-07-30 14:15:29 +02:00
|
|
|
|
|
|
|
Device* deviceBefore = backend->scanDevice( deviceInfo->device->deviceNode() );
|
|
|
|
summaryInfo.partitionModelBefore = new PartitionModel;
|
|
|
|
summaryInfo.partitionModelBefore->init( deviceBefore );
|
|
|
|
// Make deviceBefore a child of partitionModelBefore so that it is not
|
|
|
|
// leaked (as long as partitionModelBefore is deleted)
|
|
|
|
deviceBefore->setParent( summaryInfo.partitionModelBefore );
|
|
|
|
|
|
|
|
summaryInfo.partitionModelAfter = new PartitionModel;
|
|
|
|
summaryInfo.partitionModelAfter->init( deviceInfo->device.data() );
|
|
|
|
|
|
|
|
lst << summaryInfo;
|
|
|
|
}
|
|
|
|
return lst;
|
|
|
|
}
|