Skip to content
Snippets Groups Projects
Commit 2ca76a66 authored by Gregor Jasny's avatar Gregor Jasny
Browse files

Validate target name in ALIASED_TARGET property getter

parent c68cf9e4
No related branches found
No related tags found
No related merge requests found
......@@ -248,15 +248,14 @@ bool cmGetPropertyCommand::HandleTargetMode()
return false;
}
if (this->PropertyName == "ALIASED_TARGET") {
if (this->Makefile->IsAlias(this->Name)) {
if (cmTarget* target = this->Makefile->FindTargetToUse(this->Name)) {
if (cmTarget* target = this->Makefile->FindTargetToUse(this->Name)) {
if (this->PropertyName == "ALIASED_TARGET") {
if (this->Makefile->IsAlias(this->Name)) {
return this->StoreResult(target->GetName().c_str());
} else {
return this->StoreResult((this->Variable + "-NOTFOUND").c_str());
}
}
return this->StoreResult((this->Variable + "-NOTFOUND").c_str());
}
if (cmTarget* target = this->Makefile->FindTargetToUse(this->Name)) {
return this->StoreResult(
target->GetProperty(this->PropertyName, this->Makefile));
} else {
......
......@@ -24,22 +24,18 @@ bool cmGetTargetPropertyCommand::InitialPass(
std::string prop;
bool prop_exists = false;
if (args[2] == "ALIASED_TARGET") {
if (this->Makefile->IsAlias(targetName)) {
if (cmTarget* target = this->Makefile->FindTargetToUse(targetName)) {
prop = target->GetName();
if (cmTarget* tgt = this->Makefile->FindTargetToUse(targetName)) {
if (args[2] == "ALIASED_TARGET") {
if (this->Makefile->IsAlias(targetName)) {
prop = tgt->GetName();
prop_exists = true;
}
} else if (!args[2].empty()) {
const char* prop_cstr = tgt->GetProperty(args[2], this->Makefile);
if (prop_cstr) {
prop = prop_cstr;
prop_exists = true;
}
}
} else if (cmTarget* tgt = this->Makefile->FindTargetToUse(targetName)) {
cmTarget& target = *tgt;
const char* prop_cstr = 0;
if (!args[2].empty()) {
prop_cstr = target.GetProperty(args[2], this->Makefile);
}
if (prop_cstr) {
prop = prop_cstr;
prop_exists = true;
}
} else {
bool issueMessage = false;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment