[partition] Add support for partition attributes
This commit is contained in:
parent
ac8de23c6e
commit
c1b5426c66
@ -85,6 +85,19 @@ getInteger( const QVariantMap& map, const QString& key, qint64 d )
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
quint64
|
||||||
|
getUnsignedInteger( const QVariantMap& map, const QString& key, quint64 u )
|
||||||
|
{
|
||||||
|
quint64 result = u;
|
||||||
|
if ( map.contains( key ) )
|
||||||
|
{
|
||||||
|
auto v = map.value( key );
|
||||||
|
result = v.toString().toULongLong(nullptr, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
double
|
double
|
||||||
getDouble( const QVariantMap& map, const QString& key, double d )
|
getDouble( const QVariantMap& map, const QString& key, double d )
|
||||||
{
|
{
|
||||||
|
@ -48,6 +48,11 @@ DLLEXPORT QString getString( const QVariantMap& map, const QString& key );
|
|||||||
*/
|
*/
|
||||||
DLLEXPORT qint64 getInteger( const QVariantMap& map, const QString& key, qint64 d );
|
DLLEXPORT qint64 getInteger( const QVariantMap& map, const QString& key, qint64 d );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get an unsigned integer value from a mapping; returns @p u if no value.
|
||||||
|
*/
|
||||||
|
DLLEXPORT quint64 getUnsignedInteger( const QVariantMap& map, const QString& key, quint64 u );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a double value from a mapping (integers are converted); returns @p d if no value.
|
* Get a double value from a mapping (integers are converted); returns @p d if no value.
|
||||||
*/
|
*/
|
||||||
|
@ -884,6 +884,7 @@ PartitionCoreModule::initLayout( const QVariantList& config )
|
|||||||
|
|
||||||
if ( !m_partLayout->addEntry( CalamaresUtils::getString( pentry, "name" ),
|
if ( !m_partLayout->addEntry( CalamaresUtils::getString( pentry, "name" ),
|
||||||
CalamaresUtils::getString( pentry, "type" ),
|
CalamaresUtils::getString( pentry, "type" ),
|
||||||
|
CalamaresUtils::getUnsignedInteger( pentry, "attributes", 0 ),
|
||||||
CalamaresUtils::getString( pentry, "mountPoint" ),
|
CalamaresUtils::getString( pentry, "mountPoint" ),
|
||||||
CalamaresUtils::getString( pentry, "filesystem" ),
|
CalamaresUtils::getString( pentry, "filesystem" ),
|
||||||
CalamaresUtils::getSubMap( pentry, "features", ok ),
|
CalamaresUtils::getSubMap( pentry, "features", ok ),
|
||||||
|
@ -119,6 +119,7 @@ PartitionLayout::addEntry( const QString& mountPoint, const QString& size, const
|
|||||||
bool
|
bool
|
||||||
PartitionLayout::addEntry( const QString& label,
|
PartitionLayout::addEntry( const QString& label,
|
||||||
const QString& type,
|
const QString& type,
|
||||||
|
quint64 attributes,
|
||||||
const QString& mountPoint,
|
const QString& mountPoint,
|
||||||
const QString& fs,
|
const QString& fs,
|
||||||
const QVariantMap& features,
|
const QVariantMap& features,
|
||||||
@ -141,6 +142,7 @@ PartitionLayout::addEntry( const QString& label,
|
|||||||
|
|
||||||
entry.partLabel = label;
|
entry.partLabel = label;
|
||||||
entry.partType = type;
|
entry.partType = type;
|
||||||
|
entry.partAttributes = attributes;
|
||||||
entry.partMountPoint = mountPoint;
|
entry.partMountPoint = mountPoint;
|
||||||
PartUtils::findFS( fs, &entry.partFileSystem );
|
PartUtils::findFS( fs, &entry.partFileSystem );
|
||||||
if ( entry.partFileSystem == FileSystem::Unknown )
|
if ( entry.partFileSystem == FileSystem::Unknown )
|
||||||
@ -250,6 +252,14 @@ PartitionLayout::execute( Device* dev,
|
|||||||
currentPartition->setType( part.partType );
|
currentPartition->setType( part.partType );
|
||||||
#else
|
#else
|
||||||
cWarning() << "Ignoring type; requires KPMcore >= 4.2.0.";
|
cWarning() << "Ignoring type; requires KPMcore >= 4.2.0.";
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
if ( part.partAttributes )
|
||||||
|
{
|
||||||
|
#if defined( WITH_KPMCORE42API )
|
||||||
|
currentPartition->setAttributes( part.partAttributes );
|
||||||
|
#else
|
||||||
|
cWarning() << "Ignoring attributes; requires KPMcore >= 4.2.0.";
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if ( !part.partFeatures.isEmpty() )
|
if ( !part.partFeatures.isEmpty() )
|
||||||
|
@ -42,6 +42,7 @@ public:
|
|||||||
{
|
{
|
||||||
QString partLabel;
|
QString partLabel;
|
||||||
QString partType;
|
QString partType;
|
||||||
|
quint64 partAttributes;
|
||||||
QString partMountPoint;
|
QString partMountPoint;
|
||||||
FileSystem::Type partFileSystem = FileSystem::Unknown;
|
FileSystem::Type partFileSystem = FileSystem::Unknown;
|
||||||
QVariantMap partFeatures;
|
QVariantMap partFeatures;
|
||||||
@ -77,6 +78,7 @@ public:
|
|||||||
const QString& max = QString() );
|
const QString& max = QString() );
|
||||||
bool addEntry( const QString& label,
|
bool addEntry( const QString& label,
|
||||||
const QString& type,
|
const QString& type,
|
||||||
|
quint64 attributes,
|
||||||
const QString& mountPoint,
|
const QString& mountPoint,
|
||||||
const QString& fs,
|
const QString& fs,
|
||||||
const QVariantMap& features,
|
const QVariantMap& features,
|
||||||
|
@ -106,6 +106,7 @@ defaultFileSystemType: "ext4"
|
|||||||
# size: 20%
|
# size: 20%
|
||||||
# minSize: 500M
|
# minSize: 500M
|
||||||
# maxSize: 10G
|
# maxSize: 10G
|
||||||
|
# attributes: 0xffff000000000003
|
||||||
# - name: "home"
|
# - name: "home"
|
||||||
# type = "933ac7e1-2eb4-4f13-b844-0e14e2aef915"
|
# type = "933ac7e1-2eb4-4f13-b844-0e14e2aef915"
|
||||||
# filesystem: "ext4"
|
# filesystem: "ext4"
|
||||||
@ -128,6 +129,7 @@ defaultFileSystemType: "ext4"
|
|||||||
# and
|
# and
|
||||||
# partition name (gpt only; since KPMCore 4.2.0)
|
# partition name (gpt only; since KPMCore 4.2.0)
|
||||||
# - type: partition type (optional parameter; gpt only; requires KPMCore >= 4.2.0)
|
# - type: partition type (optional parameter; gpt only; requires KPMCore >= 4.2.0)
|
||||||
|
# - attributes: partition attributes (optional parameter; gpt only; requires KPMCore >= 4.2.0)
|
||||||
# - filesystem: filesystem type
|
# - filesystem: filesystem type
|
||||||
# - mountPoint: partition mount point
|
# - mountPoint: partition mount point
|
||||||
# - size: partition size in bytes (append 'K', 'M' or 'G' for KiB, MiB or GiB)
|
# - size: partition size in bytes (append 'K', 'M' or 'G' for KiB, MiB or GiB)
|
||||||
|
Loading…
Reference in New Issue
Block a user