[fsresizer] Refactor finding device
- Find device in separate function - If device isn't found, bail out
This commit is contained in:
parent
1c2714d832
commit
9e1c95ad05
@ -88,6 +88,32 @@ ResizeFSJob::prettyName() const
|
|||||||
return tr( "Resize Filesystem Job" );
|
return tr( "Resize Filesystem Job" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ResizeFSJob::PartitionMatch
|
||||||
|
ResizeFSJob::findPartition( CoreBackend* backend )
|
||||||
|
{
|
||||||
|
using DeviceList = QList< Device* >;
|
||||||
|
DeviceList devices = backend->scanDevices( false );
|
||||||
|
cDebug() << "ResizeFSJob found" << devices.count() << "devices.";
|
||||||
|
for ( DeviceList::iterator dev_it = devices.begin(); dev_it != devices.end(); ++dev_it )
|
||||||
|
{
|
||||||
|
if ( ! (*dev_it) )
|
||||||
|
continue;
|
||||||
|
cDebug() << "ResizeFSJob found" << ( *dev_it )->deviceNode();
|
||||||
|
for ( auto part_it = PartitionIterator::begin( *dev_it); part_it != PartitionIterator::end( *dev_it ); ++part_it )
|
||||||
|
{
|
||||||
|
cDebug() << ".." << ( *part_it )->mountPoint() << "on" << ( *part_it )->deviceNode();
|
||||||
|
if ( ( !m_fsname.isEmpty() && ( *part_it )->mountPoint() == m_fsname ) ||
|
||||||
|
( !m_devicename.isEmpty() && ( *part_it )->deviceNode() == m_devicename ) )
|
||||||
|
{
|
||||||
|
cDebug() << ".. matched configuration dev=" << m_devicename << "fs=" << m_fsname;
|
||||||
|
return PartitionMatch( *dev_it, *part_it );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cDebug() << "No match for configuration dev=" << m_devicename << "fs=" << m_fsname;
|
||||||
|
return PartitionMatch( nullptr, nullptr );
|
||||||
|
}
|
||||||
|
|
||||||
Calamares::JobResult
|
Calamares::JobResult
|
||||||
ResizeFSJob::exec()
|
ResizeFSJob::exec()
|
||||||
@ -124,30 +150,12 @@ ResizeFSJob::exec()
|
|||||||
tr( "Calamares cannot start KPMCore for the file-system resize job." ) );
|
tr( "Calamares cannot start KPMCore for the file-system resize job." ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
Device* resize_this_device = nullptr;
|
PartitionMatch m = findPartition( backend_p );
|
||||||
Partition* resize_this_partition = nullptr;
|
if ( !m.first || !m.second )
|
||||||
|
return Calamares::JobResult::error(
|
||||||
using DeviceList = QList< Device* >;
|
tr( "Resize Failed" ),
|
||||||
DeviceList devices = backend_p->scanDevices( false );
|
m_fsname.isEmpty() ? tr( "The filesystem %1 could not be found in this system, and can not be resized." ).arg(m_fsname)
|
||||||
cDebug() << "ResizeFSJob found" << devices.count() << "devices.";
|
: tr( "The device %1 could not be found in this system, and can not be resized." ).arg(m_devicename) );
|
||||||
for ( DeviceList::iterator dev_it = devices.begin(); dev_it != devices.end(); ++dev_it )
|
|
||||||
{
|
|
||||||
if ( ! (*dev_it) )
|
|
||||||
continue;
|
|
||||||
cDebug() << "ResizeFSJob found" << ( *dev_it )->deviceNode();
|
|
||||||
for ( auto part_it = PartitionIterator::begin( *dev_it); part_it != PartitionIterator::end( *dev_it ); ++part_it )
|
|
||||||
{
|
|
||||||
cDebug() << ".." << ( *part_it )->mountPoint() << "on" << ( *part_it )->deviceNode();
|
|
||||||
if ( ( !m_fsname.isEmpty() && ( *part_it )->mountPoint() == m_fsname ) ||
|
|
||||||
( !m_devicename.isEmpty() && ( *part_it )->deviceNode() == m_devicename ) )
|
|
||||||
{
|
|
||||||
resize_this_device = ( *dev_it );
|
|
||||||
resize_this_partition = ( *part_it );
|
|
||||||
cDebug() << ".. matched configuration dev=" << m_devicename << "fs=" << m_fsname;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return Calamares::JobResult::ok();
|
return Calamares::JobResult::ok();
|
||||||
}
|
}
|
||||||
|
@ -28,6 +28,10 @@
|
|||||||
|
|
||||||
#include <PluginDllMacro.h>
|
#include <PluginDllMacro.h>
|
||||||
|
|
||||||
|
class CoreBackend; // From KPMCore
|
||||||
|
class Device; // From KPMCore
|
||||||
|
class Partition;
|
||||||
|
|
||||||
class PLUGINDLLEXPORT ResizeFSJob : public Calamares::CppJob
|
class PLUGINDLLEXPORT ResizeFSJob : public Calamares::CppJob
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -74,6 +78,7 @@ public:
|
|||||||
|
|
||||||
void setConfigurationMap( const QVariantMap& configurationMap ) override;
|
void setConfigurationMap( const QVariantMap& configurationMap ) override;
|
||||||
|
|
||||||
|
/** @brief Is the configuration of this job valid? */
|
||||||
bool isValid() const
|
bool isValid() const
|
||||||
{
|
{
|
||||||
return ( !m_fsname.isEmpty() || !m_devicename.isEmpty() ) &&
|
return ( !m_fsname.isEmpty() || !m_devicename.isEmpty() ) &&
|
||||||
@ -85,6 +90,10 @@ private:
|
|||||||
RelativeSize m_atleast;
|
RelativeSize m_atleast;
|
||||||
QString m_fsname; // Either this, or devicename, is set, not both
|
QString m_fsname; // Either this, or devicename, is set, not both
|
||||||
QString m_devicename;
|
QString m_devicename;
|
||||||
|
|
||||||
|
using PartitionMatch = QPair<Device*, Partition*>;
|
||||||
|
/** @brief Find the configured FS using KPMCore @p backend */
|
||||||
|
PartitionMatch findPartition( CoreBackend* backend );
|
||||||
};
|
};
|
||||||
|
|
||||||
CALAMARES_PLUGIN_FACTORY_DECLARATION( ResizeFSJobFactory )
|
CALAMARES_PLUGIN_FACTORY_DECLARATION( ResizeFSJobFactory )
|
||||||
|
Loading…
Reference in New Issue
Block a user