|
@@ -1814,26 +1814,40 @@ void cmFindPackageCommand::PushFindPackageRootPathStack()
|
|
|
|
|
|
// Add root paths from <PackageName>_ROOT CMake and environment variables,
|
|
// Add root paths from <PackageName>_ROOT CMake and environment variables,
|
|
// subject to CMP0074.
|
|
// subject to CMP0074.
|
|
|
|
+ std::string const rootVar = this->Name + "_ROOT";
|
|
|
|
+ cmValue rootDef = this->Makefile->GetDefinition(rootVar);
|
|
|
|
+ if (rootDef && rootDef.IsEmpty()) {
|
|
|
|
+ rootDef = nullptr;
|
|
|
|
+ }
|
|
|
|
+ cm::optional<std::string> rootEnv = cmSystemTools::GetEnvVar(rootVar);
|
|
|
|
+ if (rootEnv && rootEnv->empty()) {
|
|
|
|
+ rootEnv = cm::nullopt;
|
|
|
|
+ }
|
|
switch (this->Makefile->GetPolicyStatus(cmPolicies::CMP0074)) {
|
|
switch (this->Makefile->GetPolicyStatus(cmPolicies::CMP0074)) {
|
|
case cmPolicies::WARN:
|
|
case cmPolicies::WARN:
|
|
- this->Makefile->MaybeWarnCMP0074(this->Name);
|
|
|
|
|
|
+ this->Makefile->MaybeWarnCMP0074(rootVar, rootDef, rootEnv);
|
|
CM_FALLTHROUGH;
|
|
CM_FALLTHROUGH;
|
|
case cmPolicies::OLD:
|
|
case cmPolicies::OLD:
|
|
- // OLD behavior is to ignore the <pkg>_ROOT variables.
|
|
|
|
- break;
|
|
|
|
|
|
+ // OLD behavior is to ignore the <PackageName>_ROOT variables.
|
|
|
|
+ return;
|
|
case cmPolicies::REQUIRED_IF_USED:
|
|
case cmPolicies::REQUIRED_IF_USED:
|
|
case cmPolicies::REQUIRED_ALWAYS:
|
|
case cmPolicies::REQUIRED_ALWAYS:
|
|
this->Makefile->IssueMessage(
|
|
this->Makefile->IssueMessage(
|
|
MessageType::FATAL_ERROR,
|
|
MessageType::FATAL_ERROR,
|
|
cmPolicies::GetRequiredPolicyError(cmPolicies::CMP0074));
|
|
cmPolicies::GetRequiredPolicyError(cmPolicies::CMP0074));
|
|
- break;
|
|
|
|
|
|
+ return;
|
|
case cmPolicies::NEW: {
|
|
case cmPolicies::NEW: {
|
|
- // NEW behavior is to honor the <pkg>_ROOT variables.
|
|
|
|
- std::string const rootVar = this->Name + "_ROOT";
|
|
|
|
- this->Makefile->GetDefExpandList(rootVar, rootPaths, false);
|
|
|
|
- cmSystemTools::GetPath(rootPaths, rootVar.c_str());
|
|
|
|
|
|
+ // NEW behavior is to honor the <PackageName>_ROOT variables.
|
|
} break;
|
|
} break;
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ if (rootDef) {
|
|
|
|
+ cmExpandList(*rootDef, rootPaths);
|
|
|
|
+ }
|
|
|
|
+ if (rootEnv) {
|
|
|
|
+ std::vector<std::string> p = cmSystemTools::SplitEnvPath(*rootEnv);
|
|
|
|
+ std::move(p.begin(), p.end(), std::back_inserter(rootPaths));
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
void cmFindPackageCommand::PopFindPackageRootPathStack()
|
|
void cmFindPackageCommand::PopFindPackageRootPathStack()
|