diff options
author | Brad King <brad.king@kitware.com> | 2009-01-22 18:16:27 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-01-22 18:16:27 (GMT) |
commit | 26bf8b2cda2f7aec429ac478c8ef1b9dbf436142 (patch) | |
tree | 5beae10e84662815dfc13bc3a6faab41fc747a94 /Source | |
parent | 3a4f76949acb99b53380c738a25c7bae4ba317c9 (diff) | |
download | CMake-26bf8b2cda2f7aec429ac478c8ef1b9dbf436142.zip CMake-26bf8b2cda2f7aec429ac478c8ef1b9dbf436142.tar.gz CMake-26bf8b2cda2f7aec429ac478c8ef1b9dbf436142.tar.bz2 |
ENH: Create notion of a 'weak' policy stack entry
A 'weak' poilcy stack entry responds normally to queries. However,
setting a policy in a weak entry will recursively set the policy in the
next entry too. This also gives the internal interface to create a weak
entry the option to provide an initial PolicyMap for it.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmMakefile.cxx | 19 | ||||
-rw-r--r-- | Source/cmMakefile.h | 14 |
2 files changed, 22 insertions, 11 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index 8fc4210..25d97fa 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -3666,8 +3666,14 @@ bool cmMakefile::SetPolicy(cmPolicies::PolicyID id, return false; } - // Store the setting. - this->PolicyStack.back()[id] = status; + // Update the policy stack from the top to the top-most strong entry. + bool previous_was_weak = true; + for(PolicyStackType::reverse_iterator psi = this->PolicyStack.rbegin(); + previous_was_weak && psi != this->PolicyStack.rend(); ++psi) + { + (*psi)[id] = status; + previous_was_weak = psi->Weak; + } // Special hook for presenting compatibility variable as soon as // the user requests it. @@ -3692,10 +3698,11 @@ bool cmMakefile::SetPolicy(cmPolicies::PolicyID id, } //---------------------------------------------------------------------------- -cmMakefile::PolicyPushPop::PolicyPushPop(cmMakefile* m): +cmMakefile::PolicyPushPop::PolicyPushPop(cmMakefile* m, bool weak, + cmPolicies::PolicyMap const& pm): Makefile(m), ReportError(true) { - this->Makefile->PushPolicy(); + this->Makefile->PushPolicy(weak, pm); this->Makefile->PushPolicyBarrier(); } @@ -3707,10 +3714,10 @@ cmMakefile::PolicyPushPop::~PolicyPushPop() } //---------------------------------------------------------------------------- -void cmMakefile::PushPolicy() +void cmMakefile::PushPolicy(bool weak, cmPolicies::PolicyMap const& pm) { // Allocate a new stack entry. - this->PolicyStack.push_back(PolicyStackEntry()); + this->PolicyStack.push_back(PolicyStackEntry(pm, weak)); } //---------------------------------------------------------------------------- diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h index b7b9dc7..a5fcec1 100644 --- a/Source/cmMakefile.h +++ b/Source/cmMakefile.h @@ -349,7 +349,9 @@ public: class PolicyPushPop { public: - PolicyPushPop(cmMakefile* m); + PolicyPushPop(cmMakefile* m, + bool weak = false, + cmPolicies::PolicyMap const& pm = cmPolicies::PolicyMap()); ~PolicyPushPop(); void Quiet() { this->ReportError = false; } private: @@ -943,7 +945,8 @@ private: std::map<cmStdString, cmTarget*> ImportedTargets; // Internal policy stack management. - void PushPolicy(); + void PushPolicy(bool weak = false, + cmPolicies::PolicyMap const& pm = cmPolicies::PolicyMap()); void PopPolicy(); void PushPolicyBarrier(); void PopPolicyBarrier(bool reportError = true); @@ -955,9 +958,10 @@ private: struct PolicyStackEntry: public cmPolicies::PolicyMap { typedef cmPolicies::PolicyMap derived; - PolicyStackEntry(): derived() {} - PolicyStackEntry(derived const& d): derived(d) {} - PolicyStackEntry(PolicyStackEntry const& r): derived(r) {} + PolicyStackEntry(bool w = false): derived(), Weak(w) {} + PolicyStackEntry(derived const& d, bool w = false): derived(d), Weak(w) {} + PolicyStackEntry(PolicyStackEntry const& r): derived(r), Weak(r.Weak) {} + bool Weak; }; typedef std::vector<PolicyStackEntry> PolicyStackType; PolicyStackType PolicyStack; |