[partition] Factor out the descriptions per-disk
This commit is contained in:
parent
400a5751f9
commit
e8b17b9878
@ -109,6 +109,12 @@ PartitionViewStep::prettyName() const
|
|||||||
return tr( "Partitions" );
|
return tr( "Partitions" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @brief Gather the pretty descriptions of all the partitioning jobs
|
||||||
|
*
|
||||||
|
* Returns a QStringList of each job's pretty description, including
|
||||||
|
* empty strings and duplicates. The list is in-order of how the
|
||||||
|
* jobs will be run.
|
||||||
|
*/
|
||||||
static QStringList jobDescriptions( const Calamares::JobList& jobs )
|
static QStringList jobDescriptions( const Calamares::JobList& jobs )
|
||||||
{
|
{
|
||||||
QStringList jobsLines;
|
QStringList jobsLines;
|
||||||
@ -122,6 +128,10 @@ static QStringList jobDescriptions( const Calamares::JobList& jobs )
|
|||||||
return jobsLines;
|
return jobsLines;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @brief A top-level description of what @p choice does
|
||||||
|
*
|
||||||
|
* Returns a (branded) string describing what @p choice will do.
|
||||||
|
*/
|
||||||
static QString modeDescription( Config::InstallChoice choice )
|
static QString modeDescription( Config::InstallChoice choice )
|
||||||
{
|
{
|
||||||
const auto* branding = Calamares::Branding::instance();
|
const auto* branding = Calamares::Branding::instance();
|
||||||
@ -146,15 +156,62 @@ static QString modeDescription( Config::InstallChoice choice )
|
|||||||
return QString();
|
return QString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @brief A top-level description of what @p choice does to disk @p info
|
||||||
|
*
|
||||||
|
* Returns a (branded, and device-specific) string describing what
|
||||||
|
* will be done to device @p info when @p choice is made. The @p listLength
|
||||||
|
* is used to provide context; when more than one disk is in use, the description
|
||||||
|
* works differently.
|
||||||
|
*/
|
||||||
|
static QString diskDescription( int listLength, const PartitionCoreModule::SummaryInfo& info, Config::InstallChoice choice )
|
||||||
|
{
|
||||||
|
const auto* branding = Calamares::Branding::instance();
|
||||||
|
static const char context[] = "PartitionViewStep";
|
||||||
|
|
||||||
|
if ( listLength == 1 ) // this is the only disk preview
|
||||||
|
{
|
||||||
|
switch ( choice )
|
||||||
|
{
|
||||||
|
case Config::Alongside:
|
||||||
|
return QCoreApplication::translate( context, "Install %1 <strong>alongside</strong> another operating system on disk "
|
||||||
|
"<strong>%2</strong> (%3)." )
|
||||||
|
.arg( branding->shortVersionedName() )
|
||||||
|
.arg( info.deviceNode )
|
||||||
|
.arg( info.deviceName );
|
||||||
|
break;
|
||||||
|
case Config::Erase:
|
||||||
|
return QCoreApplication::translate( context, "<strong>Erase</strong> disk <strong>%2</strong> (%3) and install %1." )
|
||||||
|
.arg( branding->shortVersionedName() )
|
||||||
|
.arg( info.deviceNode )
|
||||||
|
.arg( info.deviceName );
|
||||||
|
break;
|
||||||
|
case Config::Replace:
|
||||||
|
return QCoreApplication::translate( context, "<strong>Replace</strong> a partition on disk <strong>%2</strong> (%3) with %1." )
|
||||||
|
.arg( branding->shortVersionedName() )
|
||||||
|
.arg( info.deviceNode )
|
||||||
|
.arg( info.deviceName );
|
||||||
|
break;
|
||||||
|
case Config::NoChoice:
|
||||||
|
case Config::Manual:
|
||||||
|
return QCoreApplication::translate( context, "<strong>Manual</strong> partitioning on disk <strong>%1</strong> (%2)." )
|
||||||
|
.arg( info.deviceNode )
|
||||||
|
.arg( info.deviceName );
|
||||||
|
}
|
||||||
|
return QString();
|
||||||
|
}
|
||||||
|
else // multiple disk previews!
|
||||||
|
{
|
||||||
|
return QCoreApplication::translate( context, "Disk <strong>%1</strong> (%2)" ).arg( info.deviceNode ).arg( info.deviceName ) ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
QString
|
QString
|
||||||
PartitionViewStep::prettyStatus() const
|
PartitionViewStep::prettyStatus() const
|
||||||
{
|
{
|
||||||
QString jobsLabel, modeText, diskInfoLabel;
|
QString jobsLabel, modeText, diskInfoLabel;
|
||||||
|
|
||||||
Config::InstallChoice choice = m_config->installChoice();
|
const Config::InstallChoice choice = m_config->installChoice();
|
||||||
const auto* branding = Calamares::Branding::instance();
|
const QList< PartitionCoreModule::SummaryInfo > list = m_core->createSummaryInfo();
|
||||||
|
|
||||||
QList< PartitionCoreModule::SummaryInfo > list = m_core->createSummaryInfo();
|
|
||||||
|
|
||||||
cDebug() << "Summary for Partition" << list.length() << choice;
|
cDebug() << "Summary for Partition" << list.length() << choice;
|
||||||
if ( list.length() > 1 ) // There are changes on more than one disk
|
if ( list.length() > 1 ) // There are changes on more than one disk
|
||||||
@ -164,40 +221,8 @@ PartitionViewStep::prettyStatus() const
|
|||||||
|
|
||||||
for ( const auto& info : list )
|
for ( const auto& info : list )
|
||||||
{
|
{
|
||||||
if ( list.length() == 1 ) // this is the only disk preview
|
// TODO: this overwrites each iteration
|
||||||
{
|
diskInfoLabel = diskDescription( list.length(), info, choice );
|
||||||
switch ( choice )
|
|
||||||
{
|
|
||||||
case Config::Alongside:
|
|
||||||
diskInfoLabel = tr( "Install %1 <strong>alongside</strong> another operating system on disk "
|
|
||||||
"<strong>%2</strong> (%3)." )
|
|
||||||
.arg( branding->shortVersionedName() )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
break;
|
|
||||||
case Config::Erase:
|
|
||||||
diskInfoLabel = tr( "<strong>Erase</strong> disk <strong>%2</strong> (%3) and install %1." )
|
|
||||||
.arg( branding->shortVersionedName() )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
break;
|
|
||||||
case Config::Replace:
|
|
||||||
diskInfoLabel = tr( "<strong>Replace</strong> a partition on disk <strong>%2</strong> (%3) with %1." )
|
|
||||||
.arg( branding->shortVersionedName() )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
break;
|
|
||||||
case Config::NoChoice:
|
|
||||||
case Config::Manual:
|
|
||||||
diskInfoLabel = tr( "<strong>Manual</strong> partitioning on disk <strong>%1</strong> (%2)." )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else // multiple disk previews!
|
|
||||||
{
|
|
||||||
diskInfoLabel = tr( "Disk <strong>%1</strong> (%2)" ).arg( info.deviceNode ).arg( info.deviceName ) ;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const QStringList jobsLines = jobDescriptions( jobs() );
|
const QStringList jobsLines = jobDescriptions( jobs() );
|
||||||
@ -224,8 +249,7 @@ PartitionViewStep::createSummaryWidget() const
|
|||||||
formLayout->setContentsMargins( MARGIN, 0, MARGIN, MARGIN );
|
formLayout->setContentsMargins( MARGIN, 0, MARGIN, MARGIN );
|
||||||
mainLayout->addLayout( formLayout );
|
mainLayout->addLayout( formLayout );
|
||||||
|
|
||||||
const auto* branding = Calamares::Branding::instance();
|
const QList< PartitionCoreModule::SummaryInfo > list = m_core->createSummaryInfo();
|
||||||
QList< PartitionCoreModule::SummaryInfo > list = m_core->createSummaryInfo();
|
|
||||||
if ( list.length() > 1 ) // There are changes on more than one disk
|
if ( list.length() > 1 ) // There are changes on more than one disk
|
||||||
{
|
{
|
||||||
//NOTE: all of this should only happen when Manual partitioning is active.
|
//NOTE: all of this should only happen when Manual partitioning is active.
|
||||||
@ -237,43 +261,7 @@ PartitionViewStep::createSummaryWidget() const
|
|||||||
for ( const auto& info : list )
|
for ( const auto& info : list )
|
||||||
{
|
{
|
||||||
QLabel* diskInfoLabel = new QLabel;
|
QLabel* diskInfoLabel = new QLabel;
|
||||||
if ( list.length() == 1 ) // this is the only disk preview
|
diskInfoLabel->setText( diskDescription( list.length(), info, choice ) );
|
||||||
{
|
|
||||||
QString modeText;
|
|
||||||
switch ( choice )
|
|
||||||
{
|
|
||||||
case Config::InstallChoice::Alongside:
|
|
||||||
modeText = tr( "Install %1 <strong>alongside</strong> another operating system on disk "
|
|
||||||
"<strong>%2</strong> (%3)." )
|
|
||||||
.arg( branding->shortVersionedName() )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
break;
|
|
||||||
case Config::InstallChoice::Erase:
|
|
||||||
modeText = tr( "<strong>Erase</strong> disk <strong>%2</strong> (%3) and install %1." )
|
|
||||||
.arg( branding->shortVersionedName() )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
break;
|
|
||||||
case Config::InstallChoice::Replace:
|
|
||||||
modeText = tr( "<strong>Replace</strong> a partition on disk <strong>%2</strong> (%3) with %1." )
|
|
||||||
.arg( branding->shortVersionedName() )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
break;
|
|
||||||
case Config::InstallChoice::NoChoice:
|
|
||||||
case Config::InstallChoice::Manual:
|
|
||||||
modeText = tr( "<strong>Manual</strong> partitioning on disk <strong>%1</strong> (%2)." )
|
|
||||||
.arg( info.deviceNode )
|
|
||||||
.arg( info.deviceName );
|
|
||||||
}
|
|
||||||
diskInfoLabel->setText( modeText );
|
|
||||||
}
|
|
||||||
else // multiple disk previews!
|
|
||||||
{
|
|
||||||
diskInfoLabel->setText(
|
|
||||||
tr( "Disk <strong>%1</strong> (%2)" ).arg( info.deviceNode ).arg( info.deviceName ) );
|
|
||||||
}
|
|
||||||
formLayout->addRow( diskInfoLabel );
|
formLayout->addRow( diskInfoLabel );
|
||||||
|
|
||||||
PartitionBarsView* preview;
|
PartitionBarsView* preview;
|
||||||
|
Loading…
Reference in New Issue
Block a user