Merge branch 'issue-1393' into calamares

This commit is contained in:
Adriaan de Groot 2020-07-08 13:11:28 +02:00
commit 80cad17e97
3 changed files with 22 additions and 8 deletions

View File

@ -92,6 +92,19 @@ isIso9660( const Device* device )
return false; return false;
} }
static inline bool
isZRam( const Device* device )
{
const QString path = device->deviceNode();
return path.startsWith( "/dev/zram" );
}
static inline bool
isFloppyDrive( const Device* device )
{
const QString path = device->deviceNode();
return path.startsWith( "/dev/fd" ) || path.startsWith( "/dev/floppy" );
}
static inline QDebug& static inline QDebug&
operator<<( QDebug& s, QList< Device* >::iterator& it ) operator<<( QDebug& s, QList< Device* >::iterator& it )
@ -112,7 +125,7 @@ erase( DeviceList& l, DeviceList::iterator& it )
} }
QList< Device* > QList< Device* >
getDevices( DeviceType which, qint64 minimumSize ) getDevices( DeviceType which )
{ {
bool writableOnly = ( which == DeviceType::WritableOnly ); bool writableOnly = ( which == DeviceType::WritableOnly );
@ -138,11 +151,16 @@ getDevices( DeviceType which, qint64 minimumSize )
cDebug() << Logger::SubEntry << "Skipping nullptr device"; cDebug() << Logger::SubEntry << "Skipping nullptr device";
it = erase( devices, it ); it = erase( devices, it );
} }
else if ( ( *it )->deviceNode().startsWith( "/dev/zram" ) ) else if ( isZRam( *it ) )
{ {
cDebug() << Logger::SubEntry << "Removing zram" << it; cDebug() << Logger::SubEntry << "Removing zram" << it;
it = erase( devices, it ); it = erase( devices, it );
} }
else if ( isFloppyDrive( ( *it ) ) )
{
cDebug() << Logger::SubEntry << "Removing floppy disk" << it;
it = erase( devices, it );
}
else if ( writableOnly && hasRootPartition( *it ) ) else if ( writableOnly && hasRootPartition( *it ) )
{ {
cDebug() << Logger::SubEntry << "Removing device with root filesystem (/) on it" << it; cDebug() << Logger::SubEntry << "Removing device with root filesystem (/) on it" << it;
@ -153,11 +171,6 @@ getDevices( DeviceType which, qint64 minimumSize )
cDebug() << Logger::SubEntry << "Removing device with iso9660 filesystem (probably a CD) on it" << it; cDebug() << Logger::SubEntry << "Removing device with iso9660 filesystem (probably a CD) on it" << it;
it = erase( devices, it ); it = erase( devices, it );
} }
else if ( ( minimumSize >= 0 ) && !( ( *it )->capacity() > minimumSize ) )
{
cDebug() << Logger::SubEntry << "Removing too-small" << it;
it = erase( devices, it );
}
else else
{ {
++it; ++it;

View File

@ -45,7 +45,7 @@ enum class DeviceType
* greater than @p minimumSize will be returned. * greater than @p minimumSize will be returned.
* @return a list of Devices meeting this criterium. * @return a list of Devices meeting this criterium.
*/ */
QList< Device* > getDevices( DeviceType which = DeviceType::All, qint64 minimumSize = -1 ); QList< Device* > getDevices( DeviceType which = DeviceType::All );
} // namespace PartUtils } // namespace PartUtils

View File

@ -122,6 +122,7 @@ PartitionViewStep::~PartitionViewStep()
{ {
m_manualPartitionPage->deleteLater(); m_manualPartitionPage->deleteLater();
} }
delete m_core;
} }