2017-12-20 14:39:09 +01:00
|
|
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
2014-06-30 15:03:29 +02:00
|
|
|
*
|
2016-03-04 19:11:31 +01:00
|
|
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
|
|
|
* Copyright 2015-2016, Teo Mrnjavac <teo@kde.org>
|
2014-06-30 15:03:29 +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/>.
|
|
|
|
*/
|
2015-09-18 15:41:07 +02:00
|
|
|
#ifndef KPMHELPERS_H
|
|
|
|
#define KPMHELPERS_H
|
2014-06-30 15:03:29 +02:00
|
|
|
|
2015-07-02 13:49:21 +02:00
|
|
|
// KPMcore
|
2016-03-04 19:11:31 +01:00
|
|
|
#include <kpmcore/core/partitiontable.h>
|
2015-07-02 13:49:21 +02:00
|
|
|
#include <kpmcore/fs/filesystem.h>
|
2014-08-04 18:16:05 +02:00
|
|
|
|
2014-07-23 18:14:27 +02:00
|
|
|
// Qt
|
|
|
|
#include <QList>
|
|
|
|
|
2015-05-22 18:14:53 +02:00
|
|
|
#include <functional>
|
|
|
|
|
2014-07-23 18:14:27 +02:00
|
|
|
class Device;
|
2014-06-30 15:03:29 +02:00
|
|
|
class Partition;
|
2014-08-04 18:16:05 +02:00
|
|
|
class PartitionNode;
|
|
|
|
class PartitionRole;
|
2014-06-30 15:03:29 +02:00
|
|
|
|
2014-08-08 11:46:43 +02:00
|
|
|
/**
|
|
|
|
* Helper functions to manipulate partitions
|
|
|
|
*/
|
2015-09-18 15:41:07 +02:00
|
|
|
namespace KPMHelpers
|
2014-06-30 15:03:29 +02:00
|
|
|
{
|
|
|
|
|
2015-07-03 17:03:33 +02:00
|
|
|
/**
|
|
|
|
* Thin wrapper on top of CoreBackendManager. Hides things like initializing the
|
|
|
|
* Config instance or instantiating the backend.
|
|
|
|
*
|
|
|
|
* Initialize PartitionManager Config object and load a PartitionManager
|
|
|
|
* backend. It loads the "libparted" plugin by default, but this can be
|
|
|
|
* overloaded by settings the environment variable KPMCORE_BACKEND. Setting it to
|
|
|
|
* "dummy" will load the dummy plugin instead.
|
|
|
|
*
|
|
|
|
* @return true if initialization was successful.
|
|
|
|
*/
|
|
|
|
bool initKPMcore();
|
|
|
|
|
2014-06-30 15:03:29 +02:00
|
|
|
bool isPartitionFreeSpace( Partition* );
|
|
|
|
|
2014-08-08 11:46:43 +02:00
|
|
|
/**
|
|
|
|
* Returns true if the partition is planned to be created by the installer as
|
|
|
|
* opposed to already existing on the disk.
|
|
|
|
*/
|
2014-07-15 17:32:55 +02:00
|
|
|
bool isPartitionNew( Partition* );
|
|
|
|
|
2014-08-08 11:46:43 +02:00
|
|
|
/**
|
|
|
|
* Iterates on all devices and return the first partition which is associated
|
|
|
|
* with mountPoint. This uses PartitionInfo::mountPoint(), not Partition::mountPoint()
|
|
|
|
*/
|
2014-07-23 18:14:27 +02:00
|
|
|
Partition* findPartitionByMountPoint( const QList< Device* >& devices, const QString& mountPoint );
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
/**
|
|
|
|
* Iterates on all devices and partitions and returns a pointer to the Partition object
|
|
|
|
* for the given path, or nullptr if a Partition for the given path cannot be found.
|
|
|
|
*/
|
|
|
|
Partition* findPartitionByPath( const QList< Device* >& devices, const QString& path );
|
|
|
|
|
2015-05-22 18:14:53 +02:00
|
|
|
/**
|
|
|
|
* Iterates on all devices and partitions and returns a list of pointers to the Partition
|
|
|
|
* objects that satisfy the conditions defined in the criterion function.
|
|
|
|
*/
|
|
|
|
QList< Partition* > findPartitions( const QList< Device* >& devices,
|
|
|
|
std::function< bool ( Partition* ) > criterionFunction );
|
|
|
|
|
2014-08-08 11:46:43 +02:00
|
|
|
/**
|
|
|
|
* Helper function to create a new Partition object (does not create anything
|
|
|
|
* on the disk) associated with a FileSystem.
|
|
|
|
*/
|
2016-03-04 19:11:31 +01:00
|
|
|
Partition* createNewPartition( PartitionNode* parent,
|
|
|
|
const Device& device,
|
|
|
|
const PartitionRole& role,
|
|
|
|
FileSystem::Type fsType,
|
|
|
|
qint64 firstSector,
|
|
|
|
qint64 lastSector,
|
2018-11-11 13:55:46 +01:00
|
|
|
PartitionTable::Flags flags );
|
2014-08-04 18:16:05 +02:00
|
|
|
|
2016-04-22 16:01:31 +02:00
|
|
|
Partition* createNewEncryptedPartition( PartitionNode* parent,
|
|
|
|
const Device& device,
|
|
|
|
const PartitionRole& role,
|
|
|
|
FileSystem::Type fsType,
|
|
|
|
qint64 firstSector,
|
|
|
|
qint64 lastSector,
|
|
|
|
const QString& passphrase,
|
2018-11-11 13:55:46 +01:00
|
|
|
PartitionTable::Flags flags );
|
2016-04-22 16:01:31 +02:00
|
|
|
|
2014-08-07 12:59:24 +02:00
|
|
|
Partition* clonePartition( Device* device, Partition* partition );
|
2015-12-16 15:46:32 +01:00
|
|
|
|
|
|
|
QString prettyNameForFileSystemType( FileSystem::Type t );
|
2014-06-30 15:03:29 +02:00
|
|
|
}
|
|
|
|
|
2015-09-18 15:41:07 +02:00
|
|
|
#endif /* KPMHELPERS_H */
|