calamares/src/modules/partition/PartitionCoreModule.cpp

162 lines
4.6 KiB
C++
Raw Normal View History

/* === 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 <PartitionCoreModule.h>
#include <CreatePartitionJob.h>
2014-07-02 15:49:35 +02:00
#include <DeletePartitionJob.h>
#include <DeviceModel.h>
#include <PartitionModel.h>
#include <Typedefs.h>
2014-07-02 15:49:35 +02:00
#include <utils/Logger.h>
// CalaPM
#include <CalaPM.h>
2014-07-02 15:49:35 +02:00
#include <core/device.h>
#include <core/partition.h>
#include <backend/corebackend.h>
#include <backend/corebackendmanager.h>
PartitionCoreModule::PartitionCoreModule( QObject* parent )
: QObject( parent )
, m_deviceModel( new DeviceModel( this ) )
{
// FIXME: Should be done at startup
if ( !CalaPM::init() )
{
qFatal( "Failed to init CalaPM" );
}
CoreBackend* backend = CoreBackendManager::self()->backend();
2014-07-04 17:40:55 +02:00
m_devices = backend->scanDevices();
for ( auto device : m_devices )
{
2014-07-04 17:40:55 +02:00
PartitionModel* model = new PartitionModel;
model->init( device, &m_infoForPartitionHash );
m_partitionModelForDeviceHash[ device ] = model;
}
2014-07-04 17:40:55 +02:00
m_deviceModel->init( m_devices );
}
PartitionCoreModule::~PartitionCoreModule()
{
qDeleteAll( m_infoForPartitionHash );
qDeleteAll( m_devices );
}
DeviceModel*
PartitionCoreModule::deviceModel() const
{
return m_deviceModel;
}
PartitionModel*
PartitionCoreModule::partitionModelForDevice( Device* device ) const
{
2014-07-04 17:40:55 +02:00
return m_partitionModelForDeviceHash[ device ];
}
void
PartitionCoreModule::createPartition( Device* device, PartitionInfo* partitionInfo )
{
auto partition = partitionInfo->partition;
Q_ASSERT( !m_infoForPartitionHash.contains( partition ) );
m_infoForPartitionHash[ partition ] = partitionInfo;
CreatePartitionJob* job = new CreatePartitionJob( device, partition );
job->updatePreview();
2014-07-04 17:40:55 +02:00
auto partitionModel = m_partitionModelForDeviceHash.value( job->device() );
Q_ASSERT( partitionModel );
partitionModel->reload();
2014-07-02 15:49:35 +02:00
m_jobs << Calamares::job_ptr( job );
if ( partitionInfo->mountPoint == "/" && !m_hasRootMountPoint )
{
m_hasRootMountPoint = true;
hasRootMountPointChanged( m_hasRootMountPoint );
}
2014-07-02 15:49:35 +02:00
dumpQueue();
}
2014-07-02 15:49:35 +02:00
void
PartitionCoreModule::deletePartition( Device* device, Partition* partition )
{
auto it = m_infoForPartitionHash.find( partition );
if ( it != m_infoForPartitionHash.end() )
{
if ( it.value()->mountPoint == "/" )
{
m_hasRootMountPoint = false;
hasRootMountPointChanged( m_hasRootMountPoint );
}
m_infoForPartitionHash.erase( it );
}
2014-07-02 15:49:35 +02:00
if ( partition->state() == Partition::StateNew )
{
// Find matching CreatePartitionJob
auto it = std::find_if( m_jobs.begin(), m_jobs.end(), [ partition ]( Calamares::job_ptr job )
{
CreatePartitionJob* createJob = qobject_cast< CreatePartitionJob* >( job.data() );
return createJob && createJob->partition() == partition;
} );
if ( it == m_jobs.end() )
{
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 );
m_jobs.erase( it );
// The partition is no longer referenced by either a job or the device
// partition list, so we have to delete it
delete partition;
}
else
{
DeletePartitionJob* job = new DeletePartitionJob( device, partition );
job->updatePreview();
m_jobs << Calamares::job_ptr( job );
}
2014-07-04 17:40:55 +02:00
auto partitionModel = m_partitionModelForDeviceHash.value( device );
Q_ASSERT( partitionModel );
partitionModel->reload();
2014-07-02 15:49:35 +02:00
dumpQueue();
}
void
PartitionCoreModule::dumpQueue() const
{
cDebug() << "Queue:";
for ( auto job : m_jobs )
{
cDebug() << job->prettyName();
}
}