| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732 | 
							- /* Distributed under the OSI-approved BSD 3-Clause License.  See accompanying
 
-    file Copyright.txt or https://cmake.org/licensing for details.  */
 
- #include "QCMake.h"
 
- #include <algorithm>
 
- #include <cm/memory>
 
- #include "QCMakeSizeType.h"
 
- #include <QCoreApplication>
 
- #include <QDir>
 
- #include <QString>
 
- #include <QVector>
 
- #include "cmExternalMakefileProjectGenerator.h"
 
- #include "cmGlobalGenerator.h"
 
- #include "cmMessageMetadata.h"
 
- #include "cmState.h"
 
- #include "cmStringAlgorithms.h"
 
- #include "cmSystemTools.h"
 
- #ifdef Q_OS_WIN
 
- #  include "qt_windows.h" // For SetErrorMode
 
- #endif
 
- QCMake::QCMake(QObject* p)
 
-   : QObject(p)
 
-   , StartEnvironment(QProcessEnvironment::systemEnvironment())
 
-   , Environment(QProcessEnvironment::systemEnvironment())
 
- {
 
-   this->WarnUninitializedMode = false;
 
-   qRegisterMetaType<QCMakeProperty>();
 
-   qRegisterMetaType<QCMakePropertyList>();
 
-   qRegisterMetaType<QProcessEnvironment>();
 
-   qRegisterMetaType<QVector<QCMakePreset>>();
 
-   cmSystemTools::DisableRunCommandOutput();
 
-   cmSystemTools::SetRunCommandHideConsole(true);
 
-   cmSystemTools::SetMessageCallback(
 
-     [this](std::string const& msg, const cmMessageMetadata& md) {
 
-       this->messageCallback(msg, md.title);
 
-     });
 
-   cmSystemTools::SetStdoutCallback(
 
-     [this](std::string const& msg) { this->stdoutCallback(msg); });
 
-   cmSystemTools::SetStderrCallback(
 
-     [this](std::string const& msg) { this->stderrCallback(msg); });
 
-   this->CMakeInstance =
 
-     cm::make_unique<cmake>(cmake::RoleProject, cmState::Project);
 
-   this->CMakeInstance->SetCMakeEditCommand(
 
-     cmSystemTools::GetCMakeGUICommand());
 
-   this->CMakeInstance->SetProgressCallback(
 
-     [this](const std::string& msg, float percent) {
 
-       this->progressCallback(msg, percent);
 
-     });
 
-   cmSystemTools::SetInterruptCallback(
 
-     [this] { return this->interruptCallback(); });
 
-   std::vector<cmake::GeneratorInfo> generators;
 
-   this->CMakeInstance->GetRegisteredGenerators(
 
-     generators, /*includeNamesWithPlatform=*/false);
 
-   for (cmake::GeneratorInfo const& gen : generators) {
 
-     this->AvailableGenerators.push_back(gen);
 
-   }
 
-   connect(&this->LoadPresetsTimer, &QTimer::timeout, this, [this]() {
 
-     this->loadPresets();
 
-     if (!this->PresetName.isEmpty() &&
 
-         this->CMakePresetsGraph.ConfigurePresets.find(
 
-           std::string(this->PresetName.toStdString())) ==
 
-           this->CMakePresetsGraph.ConfigurePresets.end()) {
 
-       this->setPreset(QString{});
 
-     }
 
-   });
 
-   this->LoadPresetsTimer.start(1000);
 
- }
 
- QCMake::~QCMake() = default;
 
- void QCMake::loadCache(const QString& dir)
 
- {
 
-   this->setBinaryDirectory(dir);
 
- }
 
- void QCMake::setSourceDirectory(const QString& _dir)
 
- {
 
-   QString dir = QString::fromStdString(
 
-     cmSystemTools::GetActualCaseForPath(_dir.toStdString()));
 
-   if (this->SourceDirectory != dir) {
 
-     this->SourceDirectory = QDir::fromNativeSeparators(dir);
 
-     emit this->sourceDirChanged(this->SourceDirectory);
 
-     this->loadPresets();
 
-     this->setPreset(QString{});
 
-     if (!cmSystemTools::FileIsFullPath(
 
-           this->MaybeRelativeBinaryDirectory.toStdString())) {
 
-       this->setBinaryDirectory(this->MaybeRelativeBinaryDirectory);
 
-     }
 
-   }
 
- }
 
- void QCMake::setBinaryDirectory(const QString& _dir)
 
- {
 
-   QString dir = QString::fromStdString(
 
-     cmSystemTools::GetActualCaseForPath(_dir.toStdString()));
 
-   QString absDir = dir;
 
-   if (!cmSystemTools::FileIsFullPath(absDir.toStdString())) {
 
-     if (!this->SourceDirectory.isEmpty()) {
 
-       if (!this->SourceDirectory.endsWith("/")) {
 
-         absDir = "/" + absDir;
 
-       }
 
-       absDir = this->SourceDirectory + absDir;
 
-     }
 
-   }
 
-   if (this->BinaryDirectory != absDir ||
 
-       this->MaybeRelativeBinaryDirectory != dir) {
 
-     this->MaybeRelativeBinaryDirectory = QDir::fromNativeSeparators(dir);
 
-     this->BinaryDirectory = QDir::fromNativeSeparators(absDir);
 
-     emit this->binaryDirChanged(this->MaybeRelativeBinaryDirectory);
 
-     cmState* state = this->CMakeInstance->GetState();
 
-     this->setGenerator(QString());
 
-     this->setToolset(QString());
 
-     this->setPlatform(QString());
 
-     if (!this->CMakeInstance->LoadCache(this->BinaryDirectory.toStdString())) {
 
-       QDir testDir(this->BinaryDirectory);
 
-       if (testDir.exists("CMakeCache.txt")) {
 
-         cmSystemTools::Error(
 
-           "There is a CMakeCache.txt file for the current binary "
 
-           "tree but cmake does not have permission to read it.  "
 
-           "Please check the permissions of the directory you are trying to "
 
-           "run CMake on.");
 
-       }
 
-     }
 
-     QCMakePropertyList props = this->properties();
 
-     emit this->propertiesChanged(props);
 
-     cmValue homeDir = state->GetCacheEntryValue("CMAKE_HOME_DIRECTORY");
 
-     if (homeDir) {
 
-       setSourceDirectory(QString(homeDir->c_str()));
 
-     }
 
-     cmValue gen = state->GetCacheEntryValue("CMAKE_GENERATOR");
 
-     if (gen) {
 
-       cmValue extraGen =
 
-         state->GetInitializedCacheValue("CMAKE_EXTRA_GENERATOR");
 
-       std::string curGen =
 
-         cmExternalMakefileProjectGenerator::CreateFullGeneratorName(*gen,
 
-                                                                     *extraGen);
 
-       this->setGenerator(QString::fromStdString(curGen));
 
-     }
 
-     cmValue platform = state->GetCacheEntryValue("CMAKE_GENERATOR_PLATFORM");
 
-     if (platform) {
 
-       this->setPlatform(QString(platform->c_str()));
 
-     }
 
-     cmValue toolset = state->GetCacheEntryValue("CMAKE_GENERATOR_TOOLSET");
 
-     if (toolset) {
 
-       this->setToolset(QString(toolset->c_str()));
 
-     }
 
-     checkOpenPossible();
 
-   }
 
- }
 
- void QCMake::setPreset(const QString& name, bool setBinary)
 
- {
 
-   if (this->PresetName != name) {
 
-     this->PresetName = name;
 
-     emit this->presetChanged(this->PresetName);
 
-     if (!name.isNull()) {
 
-       std::string presetName(name.toStdString());
 
-       auto const& expandedPreset =
 
-         this->CMakePresetsGraph.ConfigurePresets[presetName].Expanded;
 
-       if (expandedPreset) {
 
-         if (setBinary && !expandedPreset->BinaryDir.empty()) {
 
-           QString binaryDir =
 
-             QString::fromStdString(expandedPreset->BinaryDir);
 
-           this->setBinaryDirectory(binaryDir);
 
-         }
 
-         if (expandedPreset->WarnDev) {
 
-           this->CMakeInstance->SetSuppressDevWarnings(
 
-             !*expandedPreset->WarnDev);
 
-         }
 
-         if (expandedPreset->ErrorDev) {
 
-           this->CMakeInstance->SetDevWarningsAsErrors(
 
-             *expandedPreset->ErrorDev);
 
-         }
 
-         if (expandedPreset->WarnDeprecated) {
 
-           this->CMakeInstance->SetSuppressDeprecatedWarnings(
 
-             !*expandedPreset->WarnDeprecated);
 
-         }
 
-         if (expandedPreset->ErrorDeprecated) {
 
-           this->CMakeInstance->SetDeprecatedWarningsAsErrors(
 
-             *expandedPreset->ErrorDeprecated);
 
-         }
 
-         if (expandedPreset->WarnUninitialized) {
 
-           this->WarnUninitializedMode = *expandedPreset->WarnUninitialized;
 
-           emit this->warnUninitializedModeChanged(
 
-             *expandedPreset->WarnUninitialized);
 
-         }
 
-         this->Environment = this->StartEnvironment;
 
-         for (auto const& v : expandedPreset->Environment) {
 
-           if (v.second) {
 
-             this->Environment.insert(QString::fromStdString(v.first),
 
-                                      QString::fromStdString(v.second.value()));
 
-           }
 
-         }
 
-       }
 
-     }
 
-     emit this->propertiesChanged(this->properties());
 
-   }
 
- }
 
- void QCMake::setGenerator(const QString& gen)
 
- {
 
-   if (this->Generator != gen) {
 
-     this->Generator = gen;
 
-     emit this->generatorChanged(this->Generator);
 
-   }
 
- }
 
- void QCMake::setPlatform(const QString& platform)
 
- {
 
-   if (this->Platform != platform) {
 
-     this->Platform = platform;
 
-     emit this->platformChanged(this->Platform);
 
-   }
 
- }
 
- void QCMake::setToolset(const QString& toolset)
 
- {
 
-   if (this->Toolset != toolset) {
 
-     this->Toolset = toolset;
 
-     emit this->toolsetChanged(this->Toolset);
 
-   }
 
- }
 
- void QCMake::setEnvironment(const QProcessEnvironment& environment)
 
- {
 
-   this->Environment = environment;
 
- }
 
- void QCMake::configure()
 
- {
 
-   int err;
 
-   {
 
-     cmSystemTools::SaveRestoreEnvironment restoreEnv;
 
-     this->setUpEnvironment();
 
- #ifdef Q_OS_WIN
 
-     UINT lastErrorMode = SetErrorMode(0);
 
- #endif
 
-     // Apply the same transformations that the command-line invocation does
 
-     auto sanitizePath = [](QString const& value) -> std::string {
 
-       return cmSystemTools::ToNormalizedPathOnDisk(value.toStdString());
 
-     };
 
-     this->CMakeInstance->SetHomeDirectory(sanitizePath(this->SourceDirectory));
 
-     this->CMakeInstance->SetHomeOutputDirectory(
 
-       sanitizePath(this->BinaryDirectory));
 
-     this->CMakeInstance->SetGlobalGenerator(
 
-       this->CMakeInstance->CreateGlobalGenerator(
 
-         this->Generator.toStdString()));
 
-     this->CMakeInstance->SetGeneratorPlatform(this->Platform.toStdString());
 
-     this->CMakeInstance->SetGeneratorToolset(this->Toolset.toStdString());
 
-     this->CMakeInstance->LoadCache();
 
-     this->CMakeInstance->SetWarnUninitialized(this->WarnUninitializedMode);
 
-     this->CMakeInstance->PreLoadCMakeFiles();
 
-     InterruptFlag = 0;
 
-     cmSystemTools::ResetErrorOccurredFlag();
 
-     err = this->CMakeInstance->Configure();
 
- #ifdef Q_OS_WIN
 
-     SetErrorMode(lastErrorMode);
 
- #endif
 
-   }
 
-   emit this->propertiesChanged(this->properties());
 
-   emit this->configureDone(err);
 
- }
 
- void QCMake::generate()
 
- {
 
-   int err;
 
-   {
 
-     cmSystemTools::SaveRestoreEnvironment restoreEnv;
 
-     this->setUpEnvironment();
 
- #ifdef Q_OS_WIN
 
-     UINT lastErrorMode = SetErrorMode(0);
 
- #endif
 
-     InterruptFlag = 0;
 
-     cmSystemTools::ResetErrorOccurredFlag();
 
-     err = this->CMakeInstance->Generate();
 
- #ifdef Q_OS_WIN
 
-     SetErrorMode(lastErrorMode);
 
- #endif
 
-   }
 
-   emit this->generateDone(err);
 
-   checkOpenPossible();
 
- }
 
- void QCMake::open()
 
- {
 
- #ifdef Q_OS_WIN
 
-   UINT lastErrorMode = SetErrorMode(0);
 
- #endif
 
-   InterruptFlag = 0;
 
-   cmSystemTools::ResetErrorOccurredFlag();
 
-   auto successful =
 
-     this->CMakeInstance->Open(this->BinaryDirectory.toStdString(), false);
 
- #ifdef Q_OS_WIN
 
-   SetErrorMode(lastErrorMode);
 
- #endif
 
-   emit this->openDone(successful);
 
- }
 
- void QCMake::setProperties(const QCMakePropertyList& newProps)
 
- {
 
-   QCMakePropertyList props = newProps;
 
-   QStringList toremove;
 
-   // set the value of properties
 
-   cmState* state = this->CMakeInstance->GetState();
 
-   std::vector<std::string> cacheKeys = state->GetCacheEntryKeys();
 
-   for (std::string const& key : cacheKeys) {
 
-     cmStateEnums::CacheEntryType t = state->GetCacheEntryType(key);
 
-     if (t == cmStateEnums::INTERNAL || t == cmStateEnums::STATIC) {
 
-       continue;
 
-     }
 
-     QCMakeProperty prop;
 
-     prop.Key = QString::fromStdString(key);
 
-     cm_qsizetype idx = props.indexOf(prop);
 
-     if (idx == -1) {
 
-       toremove.append(QString::fromStdString(key));
 
-     } else {
 
-       prop = props[idx];
 
- #if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0))
 
-       const bool isBool = prop.Value.type() == QVariant::Bool;
 
- #else
 
-       const bool isBool = prop.Value.metaType() == QMetaType::fromType<bool>();
 
- #endif
 
-       if (isBool) {
 
-         state->SetCacheEntryValue(key, prop.Value.toBool() ? "ON" : "OFF");
 
-       } else {
 
-         state->SetCacheEntryValue(key, prop.Value.toString().toStdString());
 
-       }
 
-       props.removeAt(idx);
 
-     }
 
-   }
 
-   // remove some properties
 
-   foreach (QString const& s, toremove) {
 
-     this->CMakeInstance->UnwatchUnusedCli(s.toStdString());
 
-     state->RemoveCacheEntry(s.toStdString());
 
-   }
 
-   // add some new properties
 
-   foreach (QCMakeProperty const& s, props) {
 
-     this->CMakeInstance->WatchUnusedCli(s.Key.toStdString());
 
-     if (s.Type == QCMakeProperty::BOOL) {
 
-       this->CMakeInstance->AddCacheEntry(
 
-         s.Key.toStdString(), s.Value.toBool() ? "ON" : "OFF",
 
-         s.Help.toStdString(), cmStateEnums::BOOL);
 
-     } else if (s.Type == QCMakeProperty::STRING) {
 
-       this->CMakeInstance->AddCacheEntry(
 
-         s.Key.toStdString(), s.Value.toString().toStdString(),
 
-         s.Help.toStdString(), cmStateEnums::STRING);
 
-     } else if (s.Type == QCMakeProperty::PATH) {
 
-       this->CMakeInstance->AddCacheEntry(
 
-         s.Key.toStdString(), s.Value.toString().toStdString(),
 
-         s.Help.toStdString(), cmStateEnums::PATH);
 
-     } else if (s.Type == QCMakeProperty::FILEPATH) {
 
-       this->CMakeInstance->AddCacheEntry(
 
-         s.Key.toStdString(), s.Value.toString().toStdString(),
 
-         s.Help.toStdString(), cmStateEnums::FILEPATH);
 
-     }
 
-   }
 
-   this->CMakeInstance->SaveCache(this->BinaryDirectory.toStdString());
 
- }
 
- namespace {
 
- template <typename T>
 
- QCMakeProperty cache_to_property(const T& v)
 
- {
 
-   QCMakeProperty prop;
 
-   prop.Key = QString::fromStdString(v.first);
 
-   prop.Value = QString::fromStdString(v.second->Value);
 
-   prop.Type = QCMakeProperty::STRING;
 
-   if (!v.second->Type.empty()) {
 
-     auto type = cmState::StringToCacheEntryType(v.second->Type);
 
-     switch (type) {
 
-       case cmStateEnums::BOOL:
 
-         prop.Type = QCMakeProperty::BOOL;
 
-         prop.Value = cmIsOn(v.second->Value);
 
-         break;
 
-       case cmStateEnums::PATH:
 
-         prop.Type = QCMakeProperty::PATH;
 
-         break;
 
-       case cmStateEnums::FILEPATH:
 
-         prop.Type = QCMakeProperty::FILEPATH;
 
-         break;
 
-       default:
 
-         prop.Type = QCMakeProperty::STRING;
 
-         break;
 
-     }
 
-   }
 
-   return prop;
 
- }
 
- void add_to_property_list(QCMakePropertyList& list, QCMakeProperty&& prop)
 
- {
 
-   // QCMakeCacheModel prefers variables earlier in the list rather than
 
-   // later, so overwrite them if they already exist rather than simply
 
-   // appending
 
-   bool found = false;
 
-   for (auto& orig : list) {
 
-     if (orig.Key == prop.Key) {
 
-       orig = prop;
 
-       found = true;
 
-       break;
 
-     }
 
-   }
 
-   if (!found) {
 
-     list.append(prop);
 
-   }
 
- }
 
- }
 
- QCMakePropertyList QCMake::properties() const
 
- {
 
-   QCMakePropertyList ret;
 
-   cmState* state = this->CMakeInstance->GetState();
 
-   std::vector<std::string> cacheKeys = state->GetCacheEntryKeys();
 
-   for (std::string const& key : cacheKeys) {
 
-     cmStateEnums::CacheEntryType t = state->GetCacheEntryType(key);
 
-     if (t == cmStateEnums::INTERNAL || t == cmStateEnums::STATIC ||
 
-         t == cmStateEnums::UNINITIALIZED) {
 
-       continue;
 
-     }
 
-     cmValue cachedValue = state->GetCacheEntryValue(key);
 
-     QCMakeProperty prop;
 
-     prop.Key = QString::fromStdString(key);
 
-     if (cmValue hs = state->GetCacheEntryProperty(key, "HELPSTRING")) {
 
-       prop.Help = QString(hs->c_str());
 
-     }
 
-     prop.Value = QString(cachedValue->c_str());
 
-     prop.Advanced = state->GetCacheEntryPropertyAsBool(key, "ADVANCED");
 
-     if (t == cmStateEnums::BOOL) {
 
-       prop.Type = QCMakeProperty::BOOL;
 
-       prop.Value = cmIsOn(*cachedValue);
 
-     } else if (t == cmStateEnums::PATH) {
 
-       prop.Type = QCMakeProperty::PATH;
 
-     } else if (t == cmStateEnums::FILEPATH) {
 
-       prop.Type = QCMakeProperty::FILEPATH;
 
-     } else if (t == cmStateEnums::STRING) {
 
-       prop.Type = QCMakeProperty::STRING;
 
-       cmValue stringsProperty = state->GetCacheEntryProperty(key, "STRINGS");
 
-       if (stringsProperty) {
 
-         prop.Strings = QString(stringsProperty->c_str()).split(";");
 
-       }
 
-     }
 
-     ret.append(prop);
 
-   }
 
-   if (!this->PresetName.isNull()) {
 
-     std::string presetName(this->PresetName.toStdString());
 
-     auto const& p =
 
-       this->CMakePresetsGraph.ConfigurePresets.at(presetName).Expanded;
 
-     if (p) {
 
-       if (!p->ToolchainFile.empty()) {
 
-         using CacheVariable = cmCMakePresetsGraph::CacheVariable;
 
-         CacheVariable var{ "FILEPATH", p->ToolchainFile };
 
-         std::pair<std::string, cm::optional<CacheVariable>> value = {
 
-           "CMAKE_TOOLCHAIN_FILE", var
 
-         };
 
-         auto prop = cache_to_property(value);
 
-         add_to_property_list(ret, std::move(prop));
 
-       }
 
-       for (auto const& v : p->CacheVariables) {
 
-         if (!v.second) {
 
-           continue;
 
-         }
 
-         auto prop = cache_to_property(v);
 
-         add_to_property_list(ret, std::move(prop));
 
-       }
 
-     }
 
-   }
 
-   return ret;
 
- }
 
- void QCMake::interrupt()
 
- {
 
-   this->InterruptFlag.ref();
 
- }
 
- bool QCMake::interruptCallback()
 
- {
 
- #if QT_VERSION < QT_VERSION_CHECK(5, 14, 0)
 
-   return this->InterruptFlag.load();
 
- #else
 
-   return this->InterruptFlag.loadRelaxed();
 
- #endif
 
- }
 
- void QCMake::progressCallback(const std::string& msg, float percent)
 
- {
 
-   if (percent >= 0) {
 
-     emit this->progressChanged(QString::fromStdString(msg), percent);
 
-   } else {
 
-     emit this->outputMessage(QString::fromStdString(msg));
 
-   }
 
-   QCoreApplication::processEvents();
 
- }
 
- void QCMake::messageCallback(std::string const& msg, const char* /*title*/)
 
- {
 
-   emit this->errorMessage(QString::fromStdString(msg));
 
-   QCoreApplication::processEvents();
 
- }
 
- void QCMake::stdoutCallback(std::string const& msg)
 
- {
 
-   emit this->outputMessage(QString::fromStdString(msg));
 
-   QCoreApplication::processEvents();
 
- }
 
- void QCMake::stderrCallback(std::string const& msg)
 
- {
 
-   emit this->outputMessage(QString::fromStdString(msg));
 
-   QCoreApplication::processEvents();
 
- }
 
- void QCMake::setUpEnvironment() const
 
- {
 
-   auto env = QProcessEnvironment::systemEnvironment();
 
-   for (auto const& key : env.keys()) {
 
-     cmSystemTools::UnsetEnv(key.toStdString().c_str());
 
-   }
 
-   for (auto const& var : this->Environment.toStringList()) {
 
-     cmSystemTools::PutEnv(var.toStdString());
 
-   }
 
- }
 
- void QCMake::loadPresets()
 
- {
 
-   auto result = this->CMakePresetsGraph.ReadProjectPresets(
 
-     this->SourceDirectory.toStdString(), true);
 
-   if (result != this->LastLoadPresetsResult && !result) {
 
-     emit this->presetLoadError(
 
-       this->SourceDirectory,
 
-       QString::fromStdString(
 
-         this->CMakePresetsGraph.parseState.GetErrorMessage(false)));
 
-   }
 
-   this->LastLoadPresetsResult = result;
 
-   QVector<QCMakePreset> presets;
 
-   for (auto const& name : this->CMakePresetsGraph.ConfigurePresetOrder) {
 
-     auto const& it = this->CMakePresetsGraph.ConfigurePresets[name];
 
-     auto const& p = it.Unexpanded;
 
-     if (p.Hidden) {
 
-       continue;
 
-     }
 
-     QCMakePreset preset;
 
-     preset.name = QString::fromStdString(p.Name);
 
-     preset.displayName = QString::fromStdString(p.DisplayName);
 
-     preset.description = QString::fromStdString(p.Description);
 
-     preset.generator = QString::fromStdString(p.Generator);
 
-     preset.architecture = QString::fromStdString(p.Architecture);
 
-     preset.setArchitecture = !p.ArchitectureStrategy ||
 
-       p.ArchitectureStrategy == cmCMakePresetsGraph::ArchToolsetStrategy::Set;
 
-     preset.toolset = QString::fromStdString(p.Toolset);
 
-     preset.setToolset = !p.ToolsetStrategy ||
 
-       p.ToolsetStrategy == cmCMakePresetsGraph::ArchToolsetStrategy::Set;
 
-     preset.enabled = it.Expanded && it.Expanded->ConditionResult &&
 
-       std::find_if(this->AvailableGenerators.begin(),
 
-                    this->AvailableGenerators.end(),
 
-                    [&p](const cmake::GeneratorInfo& g) {
 
-                      return g.name == p.Generator;
 
-                    }) != this->AvailableGenerators.end();
 
-     presets.push_back(preset);
 
-   }
 
-   emit this->presetsChanged(presets);
 
- }
 
- QString QCMake::binaryDirectory() const
 
- {
 
-   return this->BinaryDirectory;
 
- }
 
- QString QCMake::relativeBinaryDirectory() const
 
- {
 
-   return this->MaybeRelativeBinaryDirectory;
 
- }
 
- QString QCMake::sourceDirectory() const
 
- {
 
-   return this->SourceDirectory;
 
- }
 
- QString QCMake::generator() const
 
- {
 
-   return this->Generator;
 
- }
 
- QProcessEnvironment QCMake::environment() const
 
- {
 
-   return this->Environment;
 
- }
 
- std::vector<cmake::GeneratorInfo> const& QCMake::availableGenerators() const
 
- {
 
-   return AvailableGenerators;
 
- }
 
- void QCMake::deleteCache()
 
- {
 
-   // delete cache
 
-   this->CMakeInstance->DeleteCache(this->BinaryDirectory.toStdString());
 
-   // reload to make our cache empty
 
-   this->CMakeInstance->LoadCache(this->BinaryDirectory.toStdString());
 
-   // emit no generator and no properties
 
-   this->setGenerator(QString());
 
-   this->setToolset(QString());
 
-   QCMakePropertyList props = this->properties();
 
-   emit this->propertiesChanged(props);
 
- }
 
- void QCMake::reloadCache()
 
- {
 
-   // emit that the cache was cleaned out
 
-   QCMakePropertyList props;
 
-   emit this->propertiesChanged(props);
 
-   // reload
 
-   this->CMakeInstance->LoadCache(this->BinaryDirectory.toStdString());
 
-   // emit new cache properties
 
-   props = this->properties();
 
-   emit this->propertiesChanged(props);
 
- }
 
- void QCMake::setDebugOutput(bool flag)
 
- {
 
-   if (flag != this->CMakeInstance->GetDebugOutput()) {
 
-     this->CMakeInstance->SetDebugOutputOn(flag);
 
-     emit this->debugOutputChanged(flag);
 
-   }
 
- }
 
- bool QCMake::getDebugOutput() const
 
- {
 
-   return this->CMakeInstance->GetDebugOutput();
 
- }
 
- bool QCMake::getSuppressDevWarnings()
 
- {
 
-   return this->CMakeInstance->GetSuppressDevWarnings();
 
- }
 
- void QCMake::setSuppressDevWarnings(bool value)
 
- {
 
-   this->CMakeInstance->SetSuppressDevWarnings(value);
 
- }
 
- bool QCMake::getSuppressDeprecatedWarnings()
 
- {
 
-   return this->CMakeInstance->GetSuppressDeprecatedWarnings();
 
- }
 
- void QCMake::setSuppressDeprecatedWarnings(bool value)
 
- {
 
-   this->CMakeInstance->SetSuppressDeprecatedWarnings(value);
 
- }
 
- bool QCMake::getDevWarningsAsErrors()
 
- {
 
-   return this->CMakeInstance->GetDevWarningsAsErrors();
 
- }
 
- void QCMake::setDevWarningsAsErrors(bool value)
 
- {
 
-   this->CMakeInstance->SetDevWarningsAsErrors(value);
 
- }
 
- bool QCMake::getDeprecatedWarningsAsErrors()
 
- {
 
-   return this->CMakeInstance->GetDeprecatedWarningsAsErrors();
 
- }
 
- void QCMake::setDeprecatedWarningsAsErrors(bool value)
 
- {
 
-   this->CMakeInstance->SetDeprecatedWarningsAsErrors(value);
 
- }
 
- void QCMake::setWarnUninitializedMode(bool value)
 
- {
 
-   this->WarnUninitializedMode = value;
 
- }
 
- void QCMake::checkOpenPossible()
 
- {
 
-   std::string data = this->BinaryDirectory.toStdString();
 
-   auto possible = this->CMakeInstance->Open(data, true);
 
-   emit openPossible(possible);
 
- }
 
 
  |