|
|
@@ -18,6 +18,7 @@
|
|
|
#include "cmCustomCommand.h" // IWYU pragma: keep
|
|
|
#include "cmCustomCommandGenerator.h"
|
|
|
#include "cmGeneratedFileStream.h"
|
|
|
+#include "cmGeneratorExpression.h"
|
|
|
#include "cmGeneratorOptions.h"
|
|
|
#include "cmGeneratorTarget.h"
|
|
|
#include "cmGlobalNinjaGenerator.h"
|
|
|
@@ -446,8 +447,10 @@ void cmNinjaNormalTargetGenerator::WriteDeviceLinkRules(
|
|
|
this->GetGlobalGenerator()->AddRule(rule);
|
|
|
}
|
|
|
|
|
|
-void cmNinjaNormalTargetGenerator::WriteLinkRule(bool useResponseFile,
|
|
|
- std::string const& config)
|
|
|
+void cmNinjaNormalTargetGenerator::WriteLinkRule(
|
|
|
+ bool useResponseFile, std::string const& config,
|
|
|
+ std::vector<std::string> const& preLinkComments,
|
|
|
+ std::vector<std::string> const& postBuildComments)
|
|
|
{
|
|
|
cmStateEnums::TargetType targetType = this->GetGeneratorTarget()->GetType();
|
|
|
|
|
|
@@ -604,9 +607,19 @@ void cmNinjaNormalTargetGenerator::WriteLinkRule(bool useResponseFile,
|
|
|
rule.Comment =
|
|
|
cmStrCat("Rule for linking ", this->TargetLinkLanguage(config), ' ',
|
|
|
this->GetVisibleTypeName(), '.');
|
|
|
- rule.Description =
|
|
|
- cmStrCat("Linking ", this->TargetLinkLanguage(config), ' ',
|
|
|
- this->GetVisibleTypeName(), " $TARGET_FILE");
|
|
|
+ char const* presep = "";
|
|
|
+ char const* postsep = "";
|
|
|
+ auto prelink = cmJoin(preLinkComments, "; ");
|
|
|
+ if (!prelink.empty()) {
|
|
|
+ presep = "; ";
|
|
|
+ }
|
|
|
+ auto postbuild = cmJoin(postBuildComments, "; ");
|
|
|
+ if (!postbuild.empty()) {
|
|
|
+ postsep = "; ";
|
|
|
+ }
|
|
|
+ rule.Description = cmStrCat(
|
|
|
+ prelink, presep, "Linking ", this->TargetLinkLanguage(config), ' ',
|
|
|
+ this->GetVisibleTypeName(), " $TARGET_FILE", postsep, postbuild);
|
|
|
rule.Restat = "$RESTAT";
|
|
|
this->GetGlobalGenerator()->AddRule(rule);
|
|
|
}
|
|
|
@@ -1398,12 +1411,19 @@ void cmNinjaNormalTargetGenerator::WriteLinkStatement(
|
|
|
>->GetPostBuildCommands()
|
|
|
};
|
|
|
|
|
|
+ std::vector<std::string> preLinkComments;
|
|
|
+ std::vector<std::string> postBuildComments;
|
|
|
+
|
|
|
std::vector<std::string> preLinkCmdLines;
|
|
|
std::vector<std::string> postBuildCmdLines;
|
|
|
|
|
|
+ std::vector<std::string>* cmdComments[3] = { &preLinkComments,
|
|
|
+ &preLinkComments,
|
|
|
+ &postBuildComments };
|
|
|
std::vector<std::string>* cmdLineLists[3] = { &preLinkCmdLines,
|
|
|
&preLinkCmdLines,
|
|
|
&postBuildCmdLines };
|
|
|
+ cmGeneratorExpression ge(*this->GetLocalGenerator()->GetCMakeInstance());
|
|
|
|
|
|
for (unsigned i = 0; i != 3; ++i) {
|
|
|
for (cmCustomCommand const& cc : *cmdLists[i]) {
|
|
|
@@ -1413,6 +1433,11 @@ void cmNinjaNormalTargetGenerator::WriteLinkStatement(
|
|
|
cmCustomCommandGenerator ccg(cc, fileConfig, this->GetLocalGenerator(),
|
|
|
true, config);
|
|
|
localGen.AppendCustomCommandLines(ccg, *cmdLineLists[i]);
|
|
|
+ if (cc.GetComment()) {
|
|
|
+ auto cge = ge.Parse(cc.GetComment());
|
|
|
+ cmdComments[i]->emplace_back(
|
|
|
+ cge->Evaluate(this->GetLocalGenerator(), config));
|
|
|
+ }
|
|
|
std::vector<std::string> const& ccByproducts = ccg.GetByproducts();
|
|
|
byproducts.Add(ccByproducts);
|
|
|
std::transform(
|
|
|
@@ -1566,7 +1591,8 @@ void cmNinjaNormalTargetGenerator::WriteLinkStatement(
|
|
|
bool usedResponseFile = false;
|
|
|
globalGen->WriteBuild(this->GetImplFileStream(fileConfig), linkBuild,
|
|
|
commandLineLengthLimit, &usedResponseFile);
|
|
|
- this->WriteLinkRule(usedResponseFile, config);
|
|
|
+ this->WriteLinkRule(usedResponseFile, config, preLinkComments,
|
|
|
+ postBuildComments);
|
|
|
|
|
|
if (symlinkNeeded) {
|
|
|
if (targetType == cmStateEnums::EXECUTABLE) {
|