|  | @@ -1072,11 +1072,22 @@ cmTarget* cmLocalGenerator::AddCustomCommandToTarget(
 | 
											
												
													
														|  |      return nullptr;
 |  |      return nullptr;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  detail::AddCustomCommandToTarget(
 |  | 
 | 
											
												
													
														|  | -    *this, this->DirectoryBacktrace, cmCommandOrigin::Generator, t, byproducts,
 |  | 
 | 
											
												
													
														|  | -    depends, commandLines, type, comment, workingDir, escapeOldStyle,
 |  | 
 | 
											
												
													
														|  | -    uses_terminal, depfile, job_pool, command_expand_lists, stdPipesUTF8,
 |  | 
 | 
											
												
													
														|  | -    cmp0116);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  auto cc = cm::make_unique<cmCustomCommand>();
 | 
											
												
													
														|  | 
 |  | +  cc->SetBacktrace(this->DirectoryBacktrace);
 | 
											
												
													
														|  | 
 |  | +  cc->SetByproducts(byproducts);
 | 
											
												
													
														|  | 
 |  | +  cc->SetDepends(depends);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCommandLines(commandLines);
 | 
											
												
													
														|  | 
 |  | +  cc->SetComment(comment);
 | 
											
												
													
														|  | 
 |  | +  cc->SetWorkingDirectory(workingDir);
 | 
											
												
													
														|  | 
 |  | +  cc->SetEscapeOldStyle(escapeOldStyle);
 | 
											
												
													
														|  | 
 |  | +  cc->SetUsesTerminal(uses_terminal);
 | 
											
												
													
														|  | 
 |  | +  cc->SetDepfile(depfile);
 | 
											
												
													
														|  | 
 |  | +  cc->SetJobPool(job_pool);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCommandExpandLists(command_expand_lists);
 | 
											
												
													
														|  | 
 |  | +  cc->SetStdPipesUTF8(stdPipesUTF8);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCMP0116Status(cmp0116);
 | 
											
												
													
														|  | 
 |  | +  detail::AddCustomCommandToTarget(*this, cmCommandOrigin::Generator, t, type,
 | 
											
												
													
														|  | 
 |  | +                                   std::move(cc));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    return t;
 |  |    return t;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -1113,11 +1124,25 @@ cmSourceFile* cmLocalGenerator::AddCustomCommandToOutput(
 | 
											
												
													
														|  |      return nullptr;
 |  |      return nullptr;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  return detail::AddCustomCommandToOutput(
 |  | 
 | 
											
												
													
														|  | -    *this, this->DirectoryBacktrace, cmCommandOrigin::Generator, outputs,
 |  | 
 | 
											
												
													
														|  | -    byproducts, depends, main_dependency, implicit_depends, commandLines,
 |  | 
 | 
											
												
													
														|  | -    comment, workingDir, replace, escapeOldStyle, uses_terminal,
 |  | 
 | 
											
												
													
														|  | -    command_expand_lists, depfile, job_pool, stdPipesUTF8, cmp0116);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  auto cc = cm::make_unique<cmCustomCommand>();
 | 
											
												
													
														|  | 
 |  | +  cc->SetBacktrace(this->DirectoryBacktrace);
 | 
											
												
													
														|  | 
 |  | +  cc->SetOutputs(outputs);
 | 
											
												
													
														|  | 
 |  | +  cc->SetByproducts(byproducts);
 | 
											
												
													
														|  | 
 |  | +  cc->SetDepends(depends);
 | 
											
												
													
														|  | 
 |  | +  cc->SetImplicitDepends(implicit_depends);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCommandLines(commandLines);
 | 
											
												
													
														|  | 
 |  | +  cc->SetComment(comment);
 | 
											
												
													
														|  | 
 |  | +  cc->SetWorkingDirectory(workingDir);
 | 
											
												
													
														|  | 
 |  | +  cc->SetEscapeOldStyle(escapeOldStyle);
 | 
											
												
													
														|  | 
 |  | +  cc->SetUsesTerminal(uses_terminal);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCommandExpandLists(command_expand_lists);
 | 
											
												
													
														|  | 
 |  | +  cc->SetDepfile(depfile);
 | 
											
												
													
														|  | 
 |  | +  cc->SetJobPool(job_pool);
 | 
											
												
													
														|  | 
 |  | +  cc->SetStdPipesUTF8(stdPipesUTF8);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCMP0116Status(cmp0116);
 | 
											
												
													
														|  | 
 |  | +  return detail::AddCustomCommandToOutput(*this, cmCommandOrigin::Generator,
 | 
											
												
													
														|  | 
 |  | +                                          main_dependency, std::move(cc),
 | 
											
												
													
														|  | 
 |  | +                                          replace);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  cmTarget* cmLocalGenerator::AddUtilityCommand(
 |  |  cmTarget* cmLocalGenerator::AddUtilityCommand(
 | 
											
										
											
												
													
														|  | @@ -1136,10 +1161,21 @@ cmTarget* cmLocalGenerator::AddUtilityCommand(
 | 
											
												
													
														|  |      return target;
 |  |      return target;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  detail::AddUtilityCommand(
 |  | 
 | 
											
												
													
														|  | -    *this, this->DirectoryBacktrace, cmCommandOrigin::Generator, target,
 |  | 
 | 
											
												
													
														|  | -    workingDir, byproducts, depends, commandLines, escapeOldStyle, comment,
 |  | 
 | 
											
												
													
														|  | -    uses_terminal, command_expand_lists, job_pool, stdPipesUTF8, cmp0116);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  auto cc = cm::make_unique<cmCustomCommand>();
 | 
											
												
													
														|  | 
 |  | +  cc->SetBacktrace(this->DirectoryBacktrace);
 | 
											
												
													
														|  | 
 |  | +  cc->SetWorkingDirectory(workingDir);
 | 
											
												
													
														|  | 
 |  | +  cc->SetByproducts(byproducts);
 | 
											
												
													
														|  | 
 |  | +  cc->SetDepends(depends);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCommandLines(commandLines);
 | 
											
												
													
														|  | 
 |  | +  cc->SetEscapeOldStyle(escapeOldStyle);
 | 
											
												
													
														|  | 
 |  | +  cc->SetComment(comment);
 | 
											
												
													
														|  | 
 |  | +  cc->SetUsesTerminal(uses_terminal);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCommandExpandLists(command_expand_lists);
 | 
											
												
													
														|  | 
 |  | +  cc->SetJobPool(job_pool);
 | 
											
												
													
														|  | 
 |  | +  cc->SetStdPipesUTF8(stdPipesUTF8);
 | 
											
												
													
														|  | 
 |  | +  cc->SetCMP0116Status(cmp0116);
 | 
											
												
													
														|  | 
 |  | +  detail::AddUtilityCommand(*this, cmCommandOrigin::Generator, target,
 | 
											
												
													
														|  | 
 |  | +                            std::move(cc));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    return target;
 |  |    return target;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -4051,19 +4087,16 @@ std::string ComputeCustomCommandRuleFileName(cmLocalGenerator& lg,
 | 
											
												
													
														|  |                    h.HashString(output).substr(0, 16));
 |  |                    h.HashString(output).substr(0, 16));
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -cmSourceFile* AddCustomCommand(
 |  | 
 | 
											
												
													
														|  | -  cmLocalGenerator& lg, const cmListFileBacktrace& lfbt,
 |  | 
 | 
											
												
													
														|  | -  cmCommandOrigin origin, const std::vector<std::string>& outputs,
 |  | 
 | 
											
												
													
														|  | -  const std::vector<std::string>& byproducts,
 |  | 
 | 
											
												
													
														|  | -  const std::vector<std::string>& depends, const std::string& main_dependency,
 |  | 
 | 
											
												
													
														|  | -  const cmImplicitDependsList& implicit_depends,
 |  | 
 | 
											
												
													
														|  | -  const cmCustomCommandLines& commandLines, const char* comment,
 |  | 
 | 
											
												
													
														|  | -  const char* workingDir, bool replace, bool escapeOldStyle,
 |  | 
 | 
											
												
													
														|  | -  bool uses_terminal, bool command_expand_lists, const std::string& depfile,
 |  | 
 | 
											
												
													
														|  | -  const std::string& job_pool, bool stdPipesUTF8,
 |  | 
 | 
											
												
													
														|  | -  cmPolicies::PolicyStatus cmp0116)
 |  | 
 | 
											
												
													
														|  | 
 |  | +cmSourceFile* AddCustomCommand(cmLocalGenerator& lg, cmCommandOrigin origin,
 | 
											
												
													
														|  | 
 |  | +                               const std::string& main_dependency,
 | 
											
												
													
														|  | 
 |  | +                               std::unique_ptr<cmCustomCommand> cc,
 | 
											
												
													
														|  | 
 |  | +                               bool replace)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    cmMakefile* mf = lg.GetMakefile();
 |  |    cmMakefile* mf = lg.GetMakefile();
 | 
											
												
													
														|  | 
 |  | +  const auto& lfbt = cc->GetBacktrace();
 | 
											
												
													
														|  | 
 |  | +  const auto& outputs = cc->GetOutputs();
 | 
											
												
													
														|  | 
 |  | +  const auto& byproducts = cc->GetByproducts();
 | 
											
												
													
														|  | 
 |  | +  const auto& commandLines = cc->GetCommandLines();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    // Choose a source file on which to store the custom command.
 |  |    // Choose a source file on which to store the custom command.
 | 
											
												
													
														|  |    cmSourceFile* file = nullptr;
 |  |    cmSourceFile* file = nullptr;
 | 
											
										
											
												
													
														|  | @@ -4118,34 +4151,18 @@ cmSourceFile* AddCustomCommand(
 | 
											
												
													
														|  |    // Attach the custom command to the file.
 |  |    // Attach the custom command to the file.
 | 
											
												
													
														|  |    if (file) {
 |  |    if (file) {
 | 
											
												
													
														|  |      // Construct a complete list of dependencies.
 |  |      // Construct a complete list of dependencies.
 | 
											
												
													
														|  | -    std::vector<std::string> depends2(depends);
 |  | 
 | 
											
												
													
														|  |      if (!main_dependency.empty()) {
 |  |      if (!main_dependency.empty()) {
 | 
											
												
													
														|  | -      depends2.push_back(main_dependency);
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    std::unique_ptr<cmCustomCommand> cc = cm::make_unique<cmCustomCommand>();
 |  | 
 | 
											
												
													
														|  | -    cc->SetByproducts(byproducts);
 |  | 
 | 
											
												
													
														|  | -    cc->SetDepends(std::move(depends2));
 |  | 
 | 
											
												
													
														|  | -    cc->SetOutputs(outputs);
 |  | 
 | 
											
												
													
														|  | -    cc->SetCommandLines(commandLines);
 |  | 
 | 
											
												
													
														|  | -    cc->SetComment(comment);
 |  | 
 | 
											
												
													
														|  | -    cc->SetBacktrace(lfbt);
 |  | 
 | 
											
												
													
														|  | -    cc->SetWorkingDirectory(workingDir);
 |  | 
 | 
											
												
													
														|  | -    cc->SetStdPipesUTF8(stdPipesUTF8);
 |  | 
 | 
											
												
													
														|  | -    cc->SetEscapeOldStyle(escapeOldStyle);
 |  | 
 | 
											
												
													
														|  | 
 |  | +      cc->AppendDepends({ main_dependency });
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      cc->SetEscapeAllowMakeVars(true);
 |  |      cc->SetEscapeAllowMakeVars(true);
 | 
											
												
													
														|  | -    cc->SetImplicitDepends(implicit_depends);
 |  | 
 | 
											
												
													
														|  | -    cc->SetUsesTerminal(uses_terminal);
 |  | 
 | 
											
												
													
														|  | -    cc->SetCommandExpandLists(command_expand_lists);
 |  | 
 | 
											
												
													
														|  | -    cc->SetDepfile(depfile);
 |  | 
 | 
											
												
													
														|  | -    cc->SetJobPool(job_pool);
 |  | 
 | 
											
												
													
														|  | -    cc->SetCMP0116Status(cmp0116);
 |  | 
 | 
											
												
													
														|  | -    file->SetCustomCommand(std::move(cc));
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      lg.AddSourceOutputs(file, outputs, cmLocalGenerator::OutputRole::Primary,
 |  |      lg.AddSourceOutputs(file, outputs, cmLocalGenerator::OutputRole::Primary,
 | 
											
												
													
														|  |                          lfbt, origin);
 |  |                          lfbt, origin);
 | 
											
												
													
														|  |      lg.AddSourceOutputs(file, byproducts,
 |  |      lg.AddSourceOutputs(file, byproducts,
 | 
											
												
													
														|  |                          cmLocalGenerator::OutputRole::Byproduct, lfbt, origin);
 |  |                          cmLocalGenerator::OutputRole::Byproduct, lfbt, origin);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    file->SetCustomCommand(std::move(cc));
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    return file;
 |  |    return file;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -4174,68 +4191,39 @@ bool AnyTargetCommandOutputMatches(
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  namespace detail {
 |  |  namespace detail {
 | 
											
												
													
														|  | -void AddCustomCommandToTarget(cmLocalGenerator& lg,
 |  | 
 | 
											
												
													
														|  | -                              const cmListFileBacktrace& lfbt,
 |  | 
 | 
											
												
													
														|  | -                              cmCommandOrigin origin, cmTarget* target,
 |  | 
 | 
											
												
													
														|  | -                              const std::vector<std::string>& byproducts,
 |  | 
 | 
											
												
													
														|  | -                              const std::vector<std::string>& depends,
 |  | 
 | 
											
												
													
														|  | -                              const cmCustomCommandLines& commandLines,
 |  | 
 | 
											
												
													
														|  | -                              cmCustomCommandType type, const char* comment,
 |  | 
 | 
											
												
													
														|  | -                              const char* workingDir, bool escapeOldStyle,
 |  | 
 | 
											
												
													
														|  | -                              bool uses_terminal, const std::string& depfile,
 |  | 
 | 
											
												
													
														|  | -                              const std::string& job_pool,
 |  | 
 | 
											
												
													
														|  | -                              bool command_expand_lists, bool stdPipesUTF8,
 |  | 
 | 
											
												
													
														|  | -                              cmPolicies::PolicyStatus cmp0116)
 |  | 
 | 
											
												
													
														|  | 
 |  | +void AddCustomCommandToTarget(cmLocalGenerator& lg, cmCommandOrigin origin,
 | 
											
												
													
														|  | 
 |  | +                              cmTarget* target, cmCustomCommandType type,
 | 
											
												
													
														|  | 
 |  | +                              std::unique_ptr<cmCustomCommand> cc)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    // Add the command to the appropriate build step for the target.
 |  |    // Add the command to the appropriate build step for the target.
 | 
											
												
													
														|  | -  cmCustomCommand cc;
 |  | 
 | 
											
												
													
														|  | -  cc.SetByproducts(byproducts);
 |  | 
 | 
											
												
													
														|  | -  cc.SetDepends(depends);
 |  | 
 | 
											
												
													
														|  | -  cc.SetCommandLines(commandLines);
 |  | 
 | 
											
												
													
														|  | -  cc.SetComment(comment);
 |  | 
 | 
											
												
													
														|  | -  cc.SetBacktrace(lfbt);
 |  | 
 | 
											
												
													
														|  | -  cc.SetWorkingDirectory(workingDir);
 |  | 
 | 
											
												
													
														|  | -  cc.SetStdPipesUTF8(stdPipesUTF8);
 |  | 
 | 
											
												
													
														|  | -  cc.SetEscapeOldStyle(escapeOldStyle);
 |  | 
 | 
											
												
													
														|  | -  cc.SetEscapeAllowMakeVars(true);
 |  | 
 | 
											
												
													
														|  | -  cc.SetUsesTerminal(uses_terminal);
 |  | 
 | 
											
												
													
														|  | -  cc.SetCommandExpandLists(command_expand_lists);
 |  | 
 | 
											
												
													
														|  | -  cc.SetDepfile(depfile);
 |  | 
 | 
											
												
													
														|  | -  cc.SetJobPool(job_pool);
 |  | 
 | 
											
												
													
														|  | -  cc.SetCMP0116Status(cmp0116);
 |  | 
 | 
											
												
													
														|  | -  cc.SetTarget(target->GetName());
 |  | 
 | 
											
												
													
														|  | 
 |  | +  cc->SetEscapeAllowMakeVars(true);
 | 
											
												
													
														|  | 
 |  | +  cc->SetTarget(target->GetName());
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  lg.AddTargetByproducts(target, cc->GetByproducts(), cc->GetBacktrace(),
 | 
											
												
													
														|  | 
 |  | +                         origin);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |    switch (type) {
 |  |    switch (type) {
 | 
											
												
													
														|  |      case cmCustomCommandType::PRE_BUILD:
 |  |      case cmCustomCommandType::PRE_BUILD:
 | 
											
												
													
														|  | -      target->AddPreBuildCommand(std::move(cc));
 |  | 
 | 
											
												
													
														|  | 
 |  | +      target->AddPreBuildCommand(std::move(*cc));
 | 
											
												
													
														|  |        break;
 |  |        break;
 | 
											
												
													
														|  |      case cmCustomCommandType::PRE_LINK:
 |  |      case cmCustomCommandType::PRE_LINK:
 | 
											
												
													
														|  | -      target->AddPreLinkCommand(std::move(cc));
 |  | 
 | 
											
												
													
														|  | 
 |  | +      target->AddPreLinkCommand(std::move(*cc));
 | 
											
												
													
														|  |        break;
 |  |        break;
 | 
											
												
													
														|  |      case cmCustomCommandType::POST_BUILD:
 |  |      case cmCustomCommandType::POST_BUILD:
 | 
											
												
													
														|  | -      target->AddPostBuildCommand(std::move(cc));
 |  | 
 | 
											
												
													
														|  | 
 |  | +      target->AddPostBuildCommand(std::move(*cc));
 | 
											
												
													
														|  |        break;
 |  |        break;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  lg.AddTargetByproducts(target, byproducts, lfbt, origin);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  cc.reset();
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -cmSourceFile* AddCustomCommandToOutput(
 |  | 
 | 
											
												
													
														|  | -  cmLocalGenerator& lg, const cmListFileBacktrace& lfbt,
 |  | 
 | 
											
												
													
														|  | -  cmCommandOrigin origin, const std::vector<std::string>& outputs,
 |  | 
 | 
											
												
													
														|  | -  const std::vector<std::string>& byproducts,
 |  | 
 | 
											
												
													
														|  | -  const std::vector<std::string>& depends, const std::string& main_dependency,
 |  | 
 | 
											
												
													
														|  | -  const cmImplicitDependsList& implicit_depends,
 |  | 
 | 
											
												
													
														|  | -  const cmCustomCommandLines& commandLines, const char* comment,
 |  | 
 | 
											
												
													
														|  | -  const char* workingDir, bool replace, bool escapeOldStyle,
 |  | 
 | 
											
												
													
														|  | -  bool uses_terminal, bool command_expand_lists, const std::string& depfile,
 |  | 
 | 
											
												
													
														|  | -  const std::string& job_pool, bool stdPipesUTF8,
 |  | 
 | 
											
												
													
														|  | -  cmPolicies::PolicyStatus cmp0116)
 |  | 
 | 
											
												
													
														|  | 
 |  | +cmSourceFile* AddCustomCommandToOutput(cmLocalGenerator& lg,
 | 
											
												
													
														|  | 
 |  | +                                       cmCommandOrigin origin,
 | 
											
												
													
														|  | 
 |  | +                                       const std::string& main_dependency,
 | 
											
												
													
														|  | 
 |  | +                                       std::unique_ptr<cmCustomCommand> cc,
 | 
											
												
													
														|  | 
 |  | +                                       bool replace)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -  return AddCustomCommand(lg, lfbt, origin, outputs, byproducts, depends,
 |  | 
 | 
											
												
													
														|  | -                          main_dependency, implicit_depends, commandLines,
 |  | 
 | 
											
												
													
														|  | -                          comment, workingDir, replace, escapeOldStyle,
 |  | 
 | 
											
												
													
														|  | -                          uses_terminal, command_expand_lists, depfile,
 |  | 
 | 
											
												
													
														|  | -                          job_pool, stdPipesUTF8, cmp0116);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  return AddCustomCommand(lg, origin, main_dependency, std::move(cc), replace);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void AppendCustomCommandToOutput(cmLocalGenerator& lg,
 |  |  void AppendCustomCommandToOutput(cmLocalGenerator& lg,
 | 
											
										
											
												
													
														|  | @@ -4278,33 +4266,27 @@ void AppendCustomCommandToOutput(cmLocalGenerator& lg,
 | 
											
												
													
														|  |      lfbt);
 |  |      lfbt);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -void AddUtilityCommand(cmLocalGenerator& lg, const cmListFileBacktrace& lfbt,
 |  | 
 | 
											
												
													
														|  | -                       cmCommandOrigin origin, cmTarget* target,
 |  | 
 | 
											
												
													
														|  | -                       const char* workingDir,
 |  | 
 | 
											
												
													
														|  | -                       const std::vector<std::string>& byproducts,
 |  | 
 | 
											
												
													
														|  | -                       const std::vector<std::string>& depends,
 |  | 
 | 
											
												
													
														|  | -                       const cmCustomCommandLines& commandLines,
 |  | 
 | 
											
												
													
														|  | -                       bool escapeOldStyle, const char* comment,
 |  | 
 | 
											
												
													
														|  | -                       bool uses_terminal, bool command_expand_lists,
 |  | 
 | 
											
												
													
														|  | -                       const std::string& job_pool, bool stdPipesUTF8,
 |  | 
 | 
											
												
													
														|  | -                       cmPolicies::PolicyStatus cmp0116)
 |  | 
 | 
											
												
													
														|  | 
 |  | +void AddUtilityCommand(cmLocalGenerator& lg, cmCommandOrigin origin,
 | 
											
												
													
														|  | 
 |  | +                       cmTarget* target, std::unique_ptr<cmCustomCommand> cc)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | 
 |  | +  // They might be moved away
 | 
											
												
													
														|  | 
 |  | +  auto byproducts = cc->GetByproducts();
 | 
											
												
													
														|  | 
 |  | +  auto lfbt = cc->GetBacktrace();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |    // Use an empty comment to avoid generation of default comment.
 |  |    // Use an empty comment to avoid generation of default comment.
 | 
											
												
													
														|  | -  if (!comment) {
 |  | 
 | 
											
												
													
														|  | -    comment = "";
 |  | 
 | 
											
												
													
														|  | 
 |  | +  if (!cc->GetComment()) {
 | 
											
												
													
														|  | 
 |  | +    cc->SetComment("");
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    // Create the generated symbolic output name of the utility target.
 |  |    // Create the generated symbolic output name of the utility target.
 | 
											
												
													
														|  |    std::string output =
 |  |    std::string output =
 | 
											
												
													
														|  |      lg.CreateUtilityOutput(target->GetName(), byproducts, lfbt);
 |  |      lg.CreateUtilityOutput(target->GetName(), byproducts, lfbt);
 | 
											
												
													
														|  | 
 |  | +  cc->SetOutputs(output);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    std::string no_main_dependency;
 |  |    std::string no_main_dependency;
 | 
											
												
													
														|  | -  cmImplicitDependsList no_implicit_depends;
 |  | 
 | 
											
												
													
														|  | -  cmSourceFile* rule = AddCustomCommand(
 |  | 
 | 
											
												
													
														|  | -    lg, lfbt, origin, { output }, byproducts, depends, no_main_dependency,
 |  | 
 | 
											
												
													
														|  | -    no_implicit_depends, commandLines, comment, workingDir,
 |  | 
 | 
											
												
													
														|  | -    /*replace=*/false, escapeOldStyle, uses_terminal, command_expand_lists,
 |  | 
 | 
											
												
													
														|  | -    /*depfile=*/"", job_pool, stdPipesUTF8, cmp0116);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  cmSourceFile* rule =
 | 
											
												
													
														|  | 
 |  | +    AddCustomCommand(lg, origin, no_main_dependency, std::move(cc),
 | 
											
												
													
														|  | 
 |  | +                     /*replace=*/false);
 | 
											
												
													
														|  |    if (rule) {
 |  |    if (rule) {
 | 
											
												
													
														|  |      lg.AddTargetByproducts(target, byproducts, lfbt, origin);
 |  |      lg.AddTargetByproducts(target, byproducts, lfbt, origin);
 | 
											
												
													
														|  |    }
 |  |    }
 |