[partition] Refactor filling combobox with moint points
- Move to one place which handles the standard mount points - While here, introduce explicit "(no mount point)" string into the combo box. This is prep-work for issue #951.
This commit is contained in:
parent
b5d667f76e
commit
fda2e54e0f
@ -38,6 +38,7 @@ if ( KPMcore_FOUND )
|
|||||||
gui/DeviceInfoWidget.cpp
|
gui/DeviceInfoWidget.cpp
|
||||||
gui/EditExistingPartitionDialog.cpp
|
gui/EditExistingPartitionDialog.cpp
|
||||||
gui/EncryptWidget.cpp
|
gui/EncryptWidget.cpp
|
||||||
|
gui/MountPoints.cpp
|
||||||
gui/PartitionPage.cpp
|
gui/PartitionPage.cpp
|
||||||
gui/PartitionBarsView.cpp
|
gui/PartitionBarsView.cpp
|
||||||
gui/PartitionLabelsView.cpp
|
gui/PartitionLabelsView.cpp
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include "core/PartitionInfo.h"
|
#include "core/PartitionInfo.h"
|
||||||
#include "core/PartUtils.h"
|
#include "core/PartUtils.h"
|
||||||
#include "core/KPMHelpers.h"
|
#include "core/KPMHelpers.h"
|
||||||
|
#include "gui/MountPoints.h"
|
||||||
#include "gui/PartitionSizeController.h"
|
#include "gui/PartitionSizeController.h"
|
||||||
|
|
||||||
#include "ui_CreatePartitionDialog.h"
|
#include "ui_CreatePartitionDialog.h"
|
||||||
@ -81,12 +82,7 @@ CreatePartitionDialog::CreatePartitionDialog( Device* device, PartitionNode* par
|
|||||||
m_ui->lvNameLineEdit->setValidator(validator);
|
m_ui->lvNameLineEdit->setValidator(validator);
|
||||||
}
|
}
|
||||||
|
|
||||||
QStringList mountPoints = { "/", "/boot", "/home", "/opt", "/usr", "/var" };
|
standardMountPoints( *(m_ui->mountPointComboBox) );
|
||||||
if ( PartUtils::isEfiSystem() )
|
|
||||||
mountPoints << Calamares::JobQueue::instance()->globalStorage()->value( "efiSystemPartition" ).toString();
|
|
||||||
mountPoints.removeDuplicates();
|
|
||||||
mountPoints.sort();
|
|
||||||
m_ui->mountPointComboBox->addItems( mountPoints );
|
|
||||||
|
|
||||||
if ( device->partitionTable()->type() == PartitionTable::msdos ||
|
if ( device->partitionTable()->type() == PartitionTable::msdos ||
|
||||||
device->partitionTable()->type() == PartitionTable::msdos_sectorbased )
|
device->partitionTable()->type() == PartitionTable::msdos_sectorbased )
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#include <core/PartitionInfo.h>
|
#include <core/PartitionInfo.h>
|
||||||
#include "core/PartUtils.h"
|
#include "core/PartUtils.h"
|
||||||
#include <core/KPMHelpers.h>
|
#include <core/KPMHelpers.h>
|
||||||
|
#include "gui/MountPoints.h"
|
||||||
#include <gui/PartitionSizeController.h>
|
#include <gui/PartitionSizeController.h>
|
||||||
|
|
||||||
#include <ui_EditExistingPartitionDialog.h>
|
#include <ui_EditExistingPartitionDialog.h>
|
||||||
@ -55,13 +56,7 @@ EditExistingPartitionDialog::EditExistingPartitionDialog( Device* device, Partit
|
|||||||
, m_usedMountPoints( usedMountPoints )
|
, m_usedMountPoints( usedMountPoints )
|
||||||
{
|
{
|
||||||
m_ui->setupUi( this );
|
m_ui->setupUi( this );
|
||||||
|
standardMountPoints( *(m_ui->mountPointComboBox) );
|
||||||
QStringList mountPoints = { "/", "/boot", "/home", "/opt", "/usr", "/var" };
|
|
||||||
if ( PartUtils::isEfiSystem() )
|
|
||||||
mountPoints << Calamares::JobQueue::instance()->globalStorage()->value( "efiSystemPartition" ).toString();
|
|
||||||
mountPoints.removeDuplicates();
|
|
||||||
mountPoints.sort();
|
|
||||||
m_ui->mountPointComboBox->addItems( mountPoints );
|
|
||||||
|
|
||||||
QColor color = ColorUtils::colorForPartition( m_partition );
|
QColor color = ColorUtils::colorForPartition( m_partition );
|
||||||
m_partitionSizeController->init( m_device, m_partition, color );
|
m_partitionSizeController->init( m_device, m_partition, color );
|
||||||
|
48
src/modules/partition/gui/MountPoints.cpp
Normal file
48
src/modules/partition/gui/MountPoints.cpp
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
* Copyright 2016, Teo Mrnjavac <teo@kde.org>
|
||||||
|
* Copyright 2018, 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "MountPoints.h"
|
||||||
|
|
||||||
|
#include "core/PartUtils.h"
|
||||||
|
|
||||||
|
#include "GlobalStorage.h"
|
||||||
|
#include "JobQueue.h"
|
||||||
|
|
||||||
|
#include <QComboBox>
|
||||||
|
|
||||||
|
QStringList
|
||||||
|
standardMountPoints()
|
||||||
|
{
|
||||||
|
QStringList mountPoints{ "/", "/boot", "/home", "/opt", "/usr", "/var" };
|
||||||
|
if ( PartUtils::isEfiSystem() )
|
||||||
|
mountPoints << Calamares::JobQueue::instance()->globalStorage()->value( "efiSystemPartition" ).toString();
|
||||||
|
mountPoints.removeDuplicates();
|
||||||
|
mountPoints.sort();
|
||||||
|
return mountPoints;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
standardMountPoints(QComboBox& combo)
|
||||||
|
{
|
||||||
|
combo.clear();
|
||||||
|
combo.addItem( combo.tr( "(no mount point)" ) );
|
||||||
|
combo.addItems( standardMountPoints() );
|
||||||
|
}
|
||||||
|
|
41
src/modules/partition/gui/MountPoints.h
Normal file
41
src/modules/partition/gui/MountPoints.h
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
* Copyright 2016, Teo Mrnjavac <teo@kde.org>
|
||||||
|
* Copyright 2018, 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 PARTITION_GUI_MOUNTPOINTS
|
||||||
|
#define PARTITION_GUI_MOUNTPOINTS
|
||||||
|
|
||||||
|
#include <QStringList>
|
||||||
|
|
||||||
|
class QComboBox;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a list of standard mount points (e.g. /, /usr, ...).
|
||||||
|
* This also includes the EFI mount point if that is necessary
|
||||||
|
* on the target system.
|
||||||
|
*/
|
||||||
|
QStringList standardMountPoints();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clears the combobox and fills it with "(no mount point)"
|
||||||
|
* and the elements of standardMountPoints(), above.
|
||||||
|
*/
|
||||||
|
void standardMountPoints( QComboBox& );
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user