[libcalamares] Build complete instanceDescriptor list

- there's no reason to ignore custom instances that are **not**
  mentioned in the *instances* section: it may be useful to
  name more that one even without distinct config files.
This commit is contained in:
Adriaan de Groot 2020-08-11 14:47:59 +02:00
parent 4968efdaa7
commit 57f5a92d96
2 changed files with 21 additions and 17 deletions

View File

@ -268,32 +268,22 @@ Settings::validateSequence()
if ( !k.isValid() ) if ( !k.isValid() )
{ {
cWarning() << "Invalid instance key in *sequence*," << instance; cWarning() << "Invalid instance key in *sequence*," << instance;
continue;
} }
if ( k.isValid() && k.isCustom() )
{
targetKey = k; targetKey = k;
const auto it const auto it = std::find_if( m_moduleInstances.constBegin(), m_moduleInstances.constEnd(), moduleFinder );
= std::find_if( m_moduleInstances.constBegin(), m_moduleInstances.constEnd(), moduleFinder );
if ( it == m_moduleInstances.constEnd() ) if ( it == m_moduleInstances.constEnd() )
{
if ( k.isCustom() )
{ {
cWarning() << "Custom instance key" << instance << "is not listed in the *instances*"; cWarning() << "Custom instance key" << instance << "is not listed in the *instances*";
// don't add it, let this fail later.
} }
}
if ( k.isValid() && !k.isCustom() )
{
targetKey = k;
const auto it
= std::find_if( m_moduleInstances.constBegin(), m_moduleInstances.constEnd(), moduleFinder );
if ( it == m_moduleInstances.constEnd() )
{
// Non-custom instance, just mentioned in *sequence*
m_moduleInstances.append( InstanceDescription( k ) ); m_moduleInstances.append( InstanceDescription( k ) );
} }
} }
} }
} }
}
void void
Settings::setConfiguration( const QByteArray& ba, const QString& explainName ) Settings::setConfiguration( const QByteArray& ba, const QString& explainName )

View File

@ -101,9 +101,23 @@ public:
QStringList modulesSearchPaths() const; QStringList modulesSearchPaths() const;
using InstanceDescriptionList = QList< InstanceDescription >; using InstanceDescriptionList = QList< InstanceDescription >;
/** @brief All the module instances used
*
* Each module-instance mentioned in `settings.conf` has an entry
* in the moduleInstances list -- both custom entries that are
* in the *instances* section, and each module mentioned in the
* *sequence*.
*/
InstanceDescriptionList moduleInstances() const; InstanceDescriptionList moduleInstances() const;
using ModuleSequence = QList< QPair< ModuleSystem::Action, QStringList > >; using ModuleSequence = QList< QPair< ModuleSystem::Action, QStringList > >;
/** @brief Representation of *sequence* of execution
*
* Each "section" of the *sequence* key in `settings.conf` gets an
* entry here, stating what kind of action is taken and which modules
* take part (in order). Each entry in the list is an instance key
* which can be found in the moduleInstances() list.
*/
ModuleSequence modulesSequence() const; ModuleSequence modulesSequence() const;
QString brandingComponentName() const; QString brandingComponentName() const;