From 54a46448930f1ddede870d74af0e4546230b3f1f Mon Sep 17 00:00:00 2001 From: Adriaan de Groot Date: Thu, 27 Feb 2020 14:29:54 +0100 Subject: [PATCH] [partition] Store filesystem types - Write a new GS key filesystems_use, which is a map of filesystems in use on the target system. --- .../partition/jobs/FillGlobalStorageJob.cpp | 49 ++++++++++++++++--- 1 file changed, 43 insertions(+), 6 deletions(-) diff --git a/src/modules/partition/jobs/FillGlobalStorageJob.cpp b/src/modules/partition/jobs/FillGlobalStorageJob.cpp index 347dcb0a7..ac65b5ff6 100644 --- a/src/modules/partition/jobs/FillGlobalStorageJob.cpp +++ b/src/modules/partition/jobs/FillGlobalStorageJob.cpp @@ -40,9 +40,9 @@ #include #include +using CalamaresUtils::Partition::PartitionIterator; using CalamaresUtils::Partition::untranslatedFS; using CalamaresUtils::Partition::userVisibleFS; -using CalamaresUtils::Partition::PartitionIterator; typedef QHash< QString, QString > UuidForPartitionHash; @@ -107,10 +107,8 @@ mapForPartition( Partition* partition, const QString& uuid ) Logger::CDebug deb; using TR = Logger::DebugRow< const char* const, const QString& >; deb << Logger::SubEntry << "mapping for" << partition->partitionPath() << partition->deviceNode() - << TR( "mtpoint:", PartitionInfo::mountPoint( partition ) ) - << TR( "fs:", map[ "fs" ].toString() ) - << TR( "fsName", map[ "fsName" ].toString() ) - << TR( "uuid", uuid ) + << TR( "mtpoint:", PartitionInfo::mountPoint( partition ) ) << TR( "fs:", map[ "fs" ].toString() ) + << TR( "fsName", map[ "fsName" ].toString() ) << TR( "uuid", uuid ) << TR( "claimed", map[ "claimed" ].toString() ); if ( partition->roles().has( PartitionRole::Luks ) ) @@ -212,12 +210,51 @@ FillGlobalStorageJob::prettyStatusMessage() const return tr( "Setting up mount points." ); } + +/** @brief note which FS'ses are in use in GS + * + * .. mark as "1" if it's on the system, somewhere + * .. mark as "2" if it's one of the claimed / in-use FSses + * + * Stores a GS key called "filesystems_use" with this mapping. + */ +static void +storeFSUse( Calamares::GlobalStorage* storage, const QVariantList& partitions ) +{ + QMap< QString, int > fsUses; + for ( const auto& p : partitions ) + { + const auto pmap = p.toMap(); + + QString fs = pmap.value( "fs" ).toString(); + int thisUse = pmap.value( "claimed" ).toBool() ? 2 : 1; + + if ( fs.isEmpty() ) + { + continue; + } + + int newUse = qMax( fsUses.value( fs ), thisUse ); // value() is 0 if not present + fsUses.insert( fs, newUse ); + } + + QVariantMap fsUsesVariant; + for ( auto it = fsUses.cbegin(); it != fsUses.cend(); ++it ) + { + fsUsesVariant.insert( it.key(), it.value() ); + } + + storage->insert( "filesystems_use", fsUsesVariant ); +} + Calamares::JobResult FillGlobalStorageJob::exec() { Calamares::GlobalStorage* storage = Calamares::JobQueue::instance()->globalStorage(); - storage->insert( "partitions", createPartitionList() ); + const auto partitions = createPartitionList(); cDebug() << "Saving partition information map to GlobalStorage[\"partitions\"]"; + storage->insert( "partitions", partitions ); + storeFSUse( storage, partitions ); if ( !m_bootLoaderPath.isEmpty() ) {