mirror of
https://github.com/parchlinux/calamares.git
synced 2025-07-17 11:45:37 -04:00
In order to be able to parse partition size strings using the same functions across the partition module, the parseSizeString() function is exported to the PartUtils namespace. Signed-off-by: Arnaud Ferraris <arnaud.ferraris@collabora.com>
77 lines
2.5 KiB
C++
77 lines
2.5 KiB
C++
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
|
*
|
|
* Copyright 2018, Collabora Ltd
|
|
* Copyright 2019, Adriaan de Groot <groot@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 PARTITIONLAYOUT_H
|
|
#define PARTITIONLAYOUT_H
|
|
|
|
#include "core/PartUtils.h"
|
|
|
|
#include "Typedefs.h"
|
|
|
|
// KPMcore
|
|
#include <kpmcore/core/partitiontable.h>
|
|
#include <kpmcore/fs/filesystem.h>
|
|
|
|
// Qt
|
|
#include <QList>
|
|
#include <QObject>
|
|
|
|
class Partition;
|
|
|
|
class PartitionLayout
|
|
{
|
|
public:
|
|
|
|
struct PartitionEntry
|
|
{
|
|
QString partLabel;
|
|
QString partMountPoint;
|
|
FileSystem::Type partFileSystem = FileSystem::Unknown;
|
|
double partSize = 0.0L;
|
|
PartUtils::SizeUnit partSizeUnit = PartUtils::SizeUnit::Percent;
|
|
double partMinSize = 0.0L;
|
|
PartUtils::SizeUnit partMinSizeUnit = PartUtils::SizeUnit::Percent;
|
|
|
|
/// @brief All-zeroes PartitionEntry
|
|
PartitionEntry() {};
|
|
/// @brief Parse @p size and @p min to their respective member variables
|
|
PartitionEntry( const QString& size, const QString& min );
|
|
};
|
|
|
|
PartitionLayout();
|
|
PartitionLayout( PartitionEntry entry );
|
|
PartitionLayout( const PartitionLayout& layout );
|
|
~PartitionLayout();
|
|
|
|
void addEntry( PartitionEntry entry );
|
|
void addEntry( const QString& mountPoint, const QString& size, const QString& min = QString() );
|
|
void addEntry( const QString& label, const QString& mountPoint, const QString& fs, const QString& size, const QString& min = QString() );
|
|
|
|
/**
|
|
* @brief Apply the current partition layout to the selected drive space.
|
|
* @return A list of Partition objects.
|
|
*/
|
|
QList< Partition* > execute( Device *dev, qint64 firstSector, qint64 lastSector, QString luksPassphrase, PartitionNode* parent, const PartitionRole& role );
|
|
|
|
private:
|
|
FileSystem::Type m_defaultFsType;
|
|
QList< PartitionEntry > m_partLayout;
|
|
};
|
|
|
|
#endif /* PARTITIONLAYOUT_H */
|