|  | @@ -4,88 +4,101 @@
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #include <sstream>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +#include "cmExecutionStatus.h"
 | 
	
		
			
				|  |  |  #include "cmMakefile.h"
 | 
	
		
			
				|  |  |  #include "cmMessageType.h"
 | 
	
		
			
				|  |  |  #include "cmPolicies.h"
 | 
	
		
			
				|  |  |  #include "cmState.h"
 | 
	
		
			
				|  |  |  #include "cmStateTypes.h"
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -class cmExecutionStatus;
 | 
	
		
			
				|  |  | +namespace {
 | 
	
		
			
				|  |  | +bool HandleSetMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                   cmExecutionStatus& status);
 | 
	
		
			
				|  |  | +bool HandleGetMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                   cmExecutionStatus& status);
 | 
	
		
			
				|  |  | +bool HandleVersionMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                       cmExecutionStatus& status);
 | 
	
		
			
				|  |  | +bool HandleGetWarningMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                          cmExecutionStatus& status);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  // cmCMakePolicyCommand
 | 
	
		
			
				|  |  | -bool cmCMakePolicyCommand::InitialPass(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | -                                       cmExecutionStatus&)
 | 
	
		
			
				|  |  | +bool cmCMakePolicyCommand(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                          cmExecutionStatus& status)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    if (args.empty()) {
 | 
	
		
			
				|  |  | -    this->SetError("requires at least one argument.");
 | 
	
		
			
				|  |  | +    status.SetError("requires at least one argument.");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    if (args[0] == "SET") {
 | 
	
		
			
				|  |  | -    return this->HandleSetMode(args);
 | 
	
		
			
				|  |  | +    return HandleSetMode(args, status);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args[0] == "GET") {
 | 
	
		
			
				|  |  | -    return this->HandleGetMode(args);
 | 
	
		
			
				|  |  | +    return HandleGetMode(args, status);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args[0] == "PUSH") {
 | 
	
		
			
				|  |  |      if (args.size() > 1) {
 | 
	
		
			
				|  |  | -      this->SetError("PUSH may not be given additional arguments.");
 | 
	
		
			
				|  |  | +      status.SetError("PUSH may not be given additional arguments.");
 | 
	
		
			
				|  |  |        return false;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  | -    this->Makefile->PushPolicy();
 | 
	
		
			
				|  |  | +    status.GetMakefile().PushPolicy();
 | 
	
		
			
				|  |  |      return true;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args[0] == "POP") {
 | 
	
		
			
				|  |  |      if (args.size() > 1) {
 | 
	
		
			
				|  |  | -      this->SetError("POP may not be given additional arguments.");
 | 
	
		
			
				|  |  | +      status.SetError("POP may not be given additional arguments.");
 | 
	
		
			
				|  |  |        return false;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  | -    this->Makefile->PopPolicy();
 | 
	
		
			
				|  |  | +    status.GetMakefile().PopPolicy();
 | 
	
		
			
				|  |  |      return true;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args[0] == "VERSION") {
 | 
	
		
			
				|  |  | -    return this->HandleVersionMode(args);
 | 
	
		
			
				|  |  | +    return HandleVersionMode(args, status);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args[0] == "GET_WARNING") {
 | 
	
		
			
				|  |  | -    return this->HandleGetWarningMode(args);
 | 
	
		
			
				|  |  | +    return HandleGetWarningMode(args, status);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    std::ostringstream e;
 | 
	
		
			
				|  |  |    e << "given unknown first argument \"" << args[0] << "\"";
 | 
	
		
			
				|  |  | -  this->SetError(e.str());
 | 
	
		
			
				|  |  | +  status.SetError(e.str());
 | 
	
		
			
				|  |  |    return false;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -bool cmCMakePolicyCommand::HandleSetMode(std::vector<std::string> const& args)
 | 
	
		
			
				|  |  | +namespace {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +bool HandleSetMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                   cmExecutionStatus& status)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    if (args.size() != 3) {
 | 
	
		
			
				|  |  | -    this->SetError("SET must be given exactly 2 additional arguments.");
 | 
	
		
			
				|  |  | +    status.SetError("SET must be given exactly 2 additional arguments.");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  cmPolicies::PolicyStatus status;
 | 
	
		
			
				|  |  | +  cmPolicies::PolicyStatus policyStatus;
 | 
	
		
			
				|  |  |    if (args[2] == "OLD") {
 | 
	
		
			
				|  |  | -    status = cmPolicies::OLD;
 | 
	
		
			
				|  |  | +    policyStatus = cmPolicies::OLD;
 | 
	
		
			
				|  |  |    } else if (args[2] == "NEW") {
 | 
	
		
			
				|  |  | -    status = cmPolicies::NEW;
 | 
	
		
			
				|  |  | +    policyStatus = cmPolicies::NEW;
 | 
	
		
			
				|  |  |    } else {
 | 
	
		
			
				|  |  |      std::ostringstream e;
 | 
	
		
			
				|  |  |      e << "SET given unrecognized policy status \"" << args[2] << "\"";
 | 
	
		
			
				|  |  | -    this->SetError(e.str());
 | 
	
		
			
				|  |  | +    status.SetError(e.str());
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  if (!this->Makefile->SetPolicy(args[1].c_str(), status)) {
 | 
	
		
			
				|  |  | -    this->SetError("SET failed to set policy.");
 | 
	
		
			
				|  |  | +  if (!status.GetMakefile().SetPolicy(args[1].c_str(), policyStatus)) {
 | 
	
		
			
				|  |  | +    status.SetError("SET failed to set policy.");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args[1] == "CMP0001" &&
 | 
	
		
			
				|  |  | -      (status == cmPolicies::WARN || status == cmPolicies::OLD)) {
 | 
	
		
			
				|  |  | -    if (!(this->Makefile->GetState()->GetInitializedCacheValue(
 | 
	
		
			
				|  |  | +      (policyStatus == cmPolicies::WARN || policyStatus == cmPolicies::OLD)) {
 | 
	
		
			
				|  |  | +    if (!(status.GetMakefile().GetState()->GetInitializedCacheValue(
 | 
	
		
			
				|  |  |            "CMAKE_BACKWARDS_COMPATIBILITY"))) {
 | 
	
		
			
				|  |  |        // Set it to 2.4 because that is the last version where the
 | 
	
		
			
				|  |  |        // variable had meaning.
 | 
	
		
			
				|  |  | -      this->Makefile->AddCacheDefinition(
 | 
	
		
			
				|  |  | +      status.GetMakefile().AddCacheDefinition(
 | 
	
		
			
				|  |  |          "CMAKE_BACKWARDS_COMPATIBILITY", "2.4",
 | 
	
		
			
				|  |  |          "For backwards compatibility, what version of CMake "
 | 
	
		
			
				|  |  |          "commands and "
 | 
	
	
		
			
				|  | @@ -96,14 +109,15 @@ bool cmCMakePolicyCommand::HandleSetMode(std::vector<std::string> const& args)
 | 
	
		
			
				|  |  |    return true;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -bool cmCMakePolicyCommand::HandleGetMode(std::vector<std::string> const& args)
 | 
	
		
			
				|  |  | +bool HandleGetMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                   cmExecutionStatus& status)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    bool parent_scope = false;
 | 
	
		
			
				|  |  |    if (args.size() == 4 && args[3] == "PARENT_SCOPE") {
 | 
	
		
			
				|  |  |      // Undocumented PARENT_SCOPE option for use within CMake.
 | 
	
		
			
				|  |  |      parent_scope = true;
 | 
	
		
			
				|  |  |    } else if (args.size() != 3) {
 | 
	
		
			
				|  |  | -    this->SetError("GET must be given exactly 2 additional arguments.");
 | 
	
		
			
				|  |  | +    status.SetError("GET must be given exactly 2 additional arguments.");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -117,25 +131,25 @@ bool cmCMakePolicyCommand::HandleGetMode(std::vector<std::string> const& args)
 | 
	
		
			
				|  |  |      std::ostringstream e;
 | 
	
		
			
				|  |  |      e << "GET given policy \"" << id << "\" which is not known to this "
 | 
	
		
			
				|  |  |        << "version of CMake.";
 | 
	
		
			
				|  |  | -    this->SetError(e.str());
 | 
	
		
			
				|  |  | +    status.SetError(e.str());
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // Lookup the policy setting.
 | 
	
		
			
				|  |  | -  cmPolicies::PolicyStatus status =
 | 
	
		
			
				|  |  | -    this->Makefile->GetPolicyStatus(pid, parent_scope);
 | 
	
		
			
				|  |  | -  switch (status) {
 | 
	
		
			
				|  |  | +  cmPolicies::PolicyStatus policyStatus =
 | 
	
		
			
				|  |  | +    status.GetMakefile().GetPolicyStatus(pid, parent_scope);
 | 
	
		
			
				|  |  | +  switch (policyStatus) {
 | 
	
		
			
				|  |  |      case cmPolicies::OLD:
 | 
	
		
			
				|  |  |        // Report that the policy is set to OLD.
 | 
	
		
			
				|  |  | -      this->Makefile->AddDefinition(var, "OLD");
 | 
	
		
			
				|  |  | +      status.GetMakefile().AddDefinition(var, "OLD");
 | 
	
		
			
				|  |  |        break;
 | 
	
		
			
				|  |  |      case cmPolicies::WARN:
 | 
	
		
			
				|  |  |        // Report that the policy is not set.
 | 
	
		
			
				|  |  | -      this->Makefile->AddDefinition(var, "");
 | 
	
		
			
				|  |  | +      status.GetMakefile().AddDefinition(var, "");
 | 
	
		
			
				|  |  |        break;
 | 
	
		
			
				|  |  |      case cmPolicies::NEW:
 | 
	
		
			
				|  |  |        // Report that the policy is set to NEW.
 | 
	
		
			
				|  |  | -      this->Makefile->AddDefinition(var, "NEW");
 | 
	
		
			
				|  |  | +      status.GetMakefile().AddDefinition(var, "NEW");
 | 
	
		
			
				|  |  |        break;
 | 
	
		
			
				|  |  |      case cmPolicies::REQUIRED_IF_USED:
 | 
	
		
			
				|  |  |      case cmPolicies::REQUIRED_ALWAYS:
 | 
	
	
		
			
				|  | @@ -146,22 +160,22 @@ bool cmCMakePolicyCommand::HandleGetMode(std::vector<std::string> const& args)
 | 
	
		
			
				|  |  |            << "The call to cmake_policy(GET " << id << " ...) at which this "
 | 
	
		
			
				|  |  |            << "error appears requests the policy, and this version of CMake "
 | 
	
		
			
				|  |  |            << "requires that the policy be set to NEW before it is checked.";
 | 
	
		
			
				|  |  | -        this->Makefile->IssueMessage(MessageType::FATAL_ERROR, e.str());
 | 
	
		
			
				|  |  | +        status.GetMakefile().IssueMessage(MessageType::FATAL_ERROR, e.str());
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    return true;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -bool cmCMakePolicyCommand::HandleVersionMode(
 | 
	
		
			
				|  |  | -  std::vector<std::string> const& args)
 | 
	
		
			
				|  |  | +bool HandleVersionMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                       cmExecutionStatus& status)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    if (args.size() <= 1) {
 | 
	
		
			
				|  |  | -    this->SetError("VERSION not given an argument");
 | 
	
		
			
				|  |  | +    status.SetError("VERSION not given an argument");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    if (args.size() >= 3) {
 | 
	
		
			
				|  |  | -    this->SetError("VERSION given too many arguments");
 | 
	
		
			
				|  |  | +    status.SetError("VERSION given too many arguments");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    std::string const& version_string = args[1];
 | 
	
	
		
			
				|  | @@ -177,19 +191,19 @@ bool cmCMakePolicyCommand::HandleVersionMode(
 | 
	
		
			
				|  |  |      std::ostringstream e;
 | 
	
		
			
				|  |  |      e << "VERSION \"" << version_string
 | 
	
		
			
				|  |  |        << R"(" does not have a version on both sides of "...".)";
 | 
	
		
			
				|  |  | -    this->SetError(e.str());
 | 
	
		
			
				|  |  | +    status.SetError(e.str());
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  this->Makefile->SetPolicyVersion(version_min, version_max);
 | 
	
		
			
				|  |  | +  status.GetMakefile().SetPolicyVersion(version_min, version_max);
 | 
	
		
			
				|  |  |    return true;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -bool cmCMakePolicyCommand::HandleGetWarningMode(
 | 
	
		
			
				|  |  | -  std::vector<std::string> const& args)
 | 
	
		
			
				|  |  | +bool HandleGetWarningMode(std::vector<std::string> const& args,
 | 
	
		
			
				|  |  | +                          cmExecutionStatus& status)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    if (args.size() != 3) {
 | 
	
		
			
				|  |  | -    this->SetError(
 | 
	
		
			
				|  |  | +    status.SetError(
 | 
	
		
			
				|  |  |        "GET_WARNING must be given exactly 2 additional arguments.");
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
	
		
			
				|  | @@ -204,12 +218,13 @@ bool cmCMakePolicyCommand::HandleGetWarningMode(
 | 
	
		
			
				|  |  |      std::ostringstream e;
 | 
	
		
			
				|  |  |      e << "GET_WARNING given policy \"" << id
 | 
	
		
			
				|  |  |        << "\" which is not known to this version of CMake.";
 | 
	
		
			
				|  |  | -    this->SetError(e.str());
 | 
	
		
			
				|  |  | +    status.SetError(e.str());
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // Lookup the policy warning.
 | 
	
		
			
				|  |  | -  this->Makefile->AddDefinition(var, cmPolicies::GetPolicyWarning(pid));
 | 
	
		
			
				|  |  | +  status.GetMakefile().AddDefinition(var, cmPolicies::GetPolicyWarning(pid));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    return true;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | +}
 |