| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- file Copyright.txt or https://cmake.org/licensing for details. */
- #include "cmMarkAsAdvancedCommand.h"
- #include "cmExecutionStatus.h"
- #include "cmMakefile.h"
- #include "cmMessageType.h"
- #include "cmPolicies.h"
- #include "cmProperty.h"
- #include "cmState.h"
- #include "cmStateTypes.h"
- #include "cmStringAlgorithms.h"
- #include "cmSystemTools.h"
- #include "cmake.h"
- // cmMarkAsAdvancedCommand
- bool cmMarkAsAdvancedCommand(std::vector<std::string> const& args,
- cmExecutionStatus& status)
- {
- if (args.empty()) {
- status.SetError("called with incorrect number of arguments");
- return false;
- }
- unsigned int i = 0;
- const char* value = "1";
- bool overwrite = false;
- if (args[0] == "CLEAR" || args[0] == "FORCE") {
- overwrite = true;
- if (args[0] == "CLEAR") {
- value = "0";
- }
- i = 1;
- }
- cmMakefile& mf = status.GetMakefile();
- cmState* state = mf.GetState();
- for (; i < args.size(); ++i) {
- std::string const& variable = args[i];
- bool issueMessage = false;
- bool oldBehavior = false;
- bool ignoreVariable = false;
- switch (mf.GetPolicyStatus(cmPolicies::CMP0102)) {
- case cmPolicies::WARN:
- if (mf.PolicyOptionalWarningEnabled("CMAKE_POLICY_WARNING_CMP0102")) {
- if (!state->GetCacheEntryValue(variable)) {
- issueMessage = true;
- }
- }
- CM_FALLTHROUGH;
- case cmPolicies::OLD:
- oldBehavior = true;
- break;
- case cmPolicies::NEW:
- case cmPolicies::REQUIRED_IF_USED:
- case cmPolicies::REQUIRED_ALWAYS:
- if (!state->GetCacheEntryValue(variable)) {
- ignoreVariable = true;
- }
- break;
- }
- // First see if we should issue a message about CMP0102
- if (issueMessage) {
- std::string err = cmStrCat(
- "Policy CMP0102 is not set: The variable named \"", variable,
- "\" is not in the cache. This results in an empty cache entry which "
- "is no longer created when policy CMP0102 is set to NEW. Run \"cmake "
- "--help-policy CMP0102\" for policy details. Use the cmake_policy "
- "command to set the policy and suppress this warning.");
- mf.IssueMessage(MessageType::AUTHOR_WARNING, err);
- }
- // If it's not in the cache and we're using the new behavior, nothing to
- // see here.
- if (ignoreVariable) {
- continue;
- }
- // Check if we want the old behavior of making a dummy cache entry.
- if (oldBehavior) {
- if (!state->GetCacheEntryValue(variable)) {
- status.GetMakefile().GetCMakeInstance()->AddCacheEntry(
- variable, nullptr, nullptr, cmStateEnums::UNINITIALIZED);
- overwrite = true;
- }
- }
- // We need a cache entry to do this.
- if (!state->GetCacheEntryValue(variable)) {
- cmSystemTools::Error("This should never happen...");
- return false;
- }
- if (!state->GetCacheEntryProperty(variable, "ADVANCED") || overwrite) {
- state->SetCacheEntryProperty(variable, "ADVANCED", value);
- }
- }
- return true;
- }
|