|  | @@ -22,23 +22,22 @@
 | 
											
												
													
														|  |  std::string const cmGhsMultiTargetGenerator::DDOption("-dynamic");
 |  |  std::string const cmGhsMultiTargetGenerator::DDOption("-dynamic");
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  cmGhsMultiTargetGenerator::cmGhsMultiTargetGenerator(cmGeneratorTarget *target)
 |  |  cmGhsMultiTargetGenerator::cmGhsMultiTargetGenerator(cmGeneratorTarget *target)
 | 
											
												
													
														|  | -  : Target(target->Target)
 |  | 
 | 
											
												
													
														|  | -  , GeneratorTarget(target)
 |  | 
 | 
											
												
													
														|  | 
 |  | +  : GeneratorTarget(target)
 | 
											
												
													
														|  |    , LocalGenerator(static_cast<cmLocalGhsMultiGenerator *>(
 |  |    , LocalGenerator(static_cast<cmLocalGhsMultiGenerator *>(
 | 
											
												
													
														|  |                       target->GetLocalGenerator()))
 |  |                       target->GetLocalGenerator()))
 | 
											
												
													
														|  |    , Makefile(target->Target->GetMakefile())
 |  |    , Makefile(target->Target->GetMakefile())
 | 
											
												
													
														|  |    , TargetGroup(DetermineIfTargetGroup(target))
 |  |    , TargetGroup(DetermineIfTargetGroup(target))
 | 
											
												
													
														|  |    , DynamicDownload(false)
 |  |    , DynamicDownload(false)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -  this->RelBuildFilePath = this->GetRelBuildFilePath(target->Target);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  this->RelBuildFilePath = this->GetRelBuildFilePath(target);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    this->RelOutputFileName =
 |  |    this->RelOutputFileName =
 | 
											
												
													
														|  | -    this->RelBuildFilePath + this->Target->GetName() + ".a";
 |  | 
 | 
											
												
													
														|  | 
 |  | +    this->RelBuildFilePath + target->GetName() + ".a";
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    this->RelBuildFileName = this->RelBuildFilePath;
 |  |    this->RelBuildFileName = this->RelBuildFilePath;
 | 
											
												
													
														|  | -  this->RelBuildFileName += this->GetBuildFileName(target->Target);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  this->RelBuildFileName += this->GetBuildFileName(target);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  std::string absPathToRoot = this->GetAbsPathToRoot(target->Target);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  std::string absPathToRoot = this->GetAbsPathToRoot(target);
 | 
											
												
													
														|  |    absPathToRoot = this->AddSlashIfNeededToPath(absPathToRoot);
 |  |    absPathToRoot = this->AddSlashIfNeededToPath(absPathToRoot);
 | 
											
												
													
														|  |    this->AbsBuildFilePath = absPathToRoot + this->RelBuildFilePath;
 |  |    this->AbsBuildFilePath = absPathToRoot + this->RelBuildFilePath;
 | 
											
												
													
														|  |    this->AbsBuildFileName = absPathToRoot + this->RelBuildFileName;
 |  |    this->AbsBuildFileName = absPathToRoot + this->RelBuildFileName;
 | 
											
										
											
												
													
														|  | @@ -51,7 +50,8 @@ cmGhsMultiTargetGenerator::~cmGhsMultiTargetGenerator()
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  std::string
 |  |  std::string
 | 
											
												
													
														|  | -cmGhsMultiTargetGenerator::GetRelBuildFilePath(const cmTarget *target)
 |  | 
 | 
											
												
													
														|  | 
 |  | +cmGhsMultiTargetGenerator::GetRelBuildFilePath(
 | 
											
												
													
														|  | 
 |  | +        const cmGeneratorTarget *target)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    std::string output;
 |  |    std::string output;
 | 
											
												
													
														|  |    char const *folderProp = target->GetProperty("FOLDER");
 |  |    char const *folderProp = target->GetProperty("FOLDER");
 | 
											
										
											
												
													
														|  | @@ -66,15 +66,13 @@ cmGhsMultiTargetGenerator::GetRelBuildFilePath(const cmTarget *target)
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  std::string
 |  |  std::string
 | 
											
												
													
														|  | -cmGhsMultiTargetGenerator::GetAbsPathToRoot(const cmTarget *target)
 |  | 
 | 
											
												
													
														|  | 
 |  | +cmGhsMultiTargetGenerator::GetAbsPathToRoot(const cmGeneratorTarget *target)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -  cmGeneratorTarget* gt = target->GetMakefile()->GetGlobalGenerator()
 |  | 
 | 
											
												
													
														|  | -      ->GetGeneratorTarget(target);
 |  | 
 | 
											
												
													
														|  | -  return gt->GetLocalGenerator()->GetBinaryDirectory();
 |  | 
 | 
											
												
													
														|  | 
 |  | +  return target->GetLocalGenerator()->GetBinaryDirectory();
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  std::string
 |  |  std::string
 | 
											
												
													
														|  | -cmGhsMultiTargetGenerator::GetAbsBuildFilePath(const cmTarget *target)
 |  | 
 | 
											
												
													
														|  | 
 |  | +cmGhsMultiTargetGenerator::GetAbsBuildFilePath(const cmGeneratorTarget *target)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    std::string output;
 |  |    std::string output;
 | 
											
												
													
														|  |    output = cmGhsMultiTargetGenerator::GetAbsPathToRoot(target);
 |  |    output = cmGhsMultiTargetGenerator::GetAbsPathToRoot(target);
 | 
											
										
											
												
													
														|  | @@ -84,7 +82,7 @@ cmGhsMultiTargetGenerator::GetAbsBuildFilePath(const cmTarget *target)
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  std::string
 |  |  std::string
 | 
											
												
													
														|  | -cmGhsMultiTargetGenerator::GetRelBuildFileName(const cmTarget *target)
 |  | 
 | 
											
												
													
														|  | 
 |  | +cmGhsMultiTargetGenerator::GetRelBuildFileName(const cmGeneratorTarget *target)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    std::string output;
 |  |    std::string output;
 | 
											
												
													
														|  |    output = cmGhsMultiTargetGenerator::GetRelBuildFilePath(target);
 |  |    output = cmGhsMultiTargetGenerator::GetRelBuildFilePath(target);
 | 
											
										
											
												
													
														|  | @@ -93,7 +91,8 @@ cmGhsMultiTargetGenerator::GetRelBuildFileName(const cmTarget *target)
 | 
											
												
													
														|  |    return  output;
 |  |    return  output;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -std::string cmGhsMultiTargetGenerator::GetBuildFileName(const cmTarget *target)
 |  | 
 | 
											
												
													
														|  | 
 |  | +std::string
 | 
											
												
													
														|  | 
 |  | +cmGhsMultiTargetGenerator::GetBuildFileName(const cmGeneratorTarget *target)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    std::string output;
 |  |    std::string output;
 | 
											
												
													
														|  |    output = target->GetName();
 |  |    output = target->GetName();
 | 
											
										
											
												
													
														|  | @@ -161,7 +160,8 @@ void cmGhsMultiTargetGenerator::Generate()
 | 
											
												
													
														|  |  bool cmGhsMultiTargetGenerator::IncludeThisTarget()
 |  |  bool cmGhsMultiTargetGenerator::IncludeThisTarget()
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |    bool output = true;
 |  |    bool output = true;
 | 
											
												
													
														|  | -  char const *excludeFromAll = this->Target->GetProperty("EXCLUDE_FROM_ALL");
 |  | 
 | 
											
												
													
														|  | 
 |  | +  char const *excludeFromAll =
 | 
											
												
													
														|  | 
 |  | +      this->GeneratorTarget->GetProperty("EXCLUDE_FROM_ALL");
 | 
											
												
													
														|  |    if (NULL != excludeFromAll && '1' == excludeFromAll[0] &&
 |  |    if (NULL != excludeFromAll && '1' == excludeFromAll[0] &&
 | 
											
												
													
														|  |        '\0' == excludeFromAll[1])
 |  |        '\0' == excludeFromAll[1])
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
										
											
												
													
														|  | @@ -367,13 +367,13 @@ void cmGhsMultiTargetGenerator::WriteTargetLinkLibraries()
 | 
											
												
													
														|  |    for (cmTargetDependSet::iterator tdsI = tds.begin(); tdsI != tds.end();
 |  |    for (cmTargetDependSet::iterator tdsI = tds.begin(); tdsI != tds.end();
 | 
											
												
													
														|  |         ++tdsI)
 |  |         ++tdsI)
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
												
													
														|  | -    const cmTarget *tg = (*tdsI)->Target;
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const cmGeneratorTarget *tg = *tdsI;
 | 
											
												
													
														|  |      *this->GetFolderBuildStreams() << "    -L\"" << GetAbsBuildFilePath(tg)
 |  |      *this->GetFolderBuildStreams() << "    -L\"" << GetAbsBuildFilePath(tg)
 | 
											
												
													
														|  |                                     << "\"" << std::endl;
 |  |                                     << "\"" << std::endl;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    // library targets
 |  |    // library targets
 | 
											
												
													
														|  |    cmTarget::LinkLibraryVectorType llv =
 |  |    cmTarget::LinkLibraryVectorType llv =
 | 
											
												
													
														|  | -    this->Target->GetOriginalLinkLibraries();
 |  | 
 | 
											
												
													
														|  | 
 |  | +    this->GeneratorTarget->Target->GetOriginalLinkLibraries();
 | 
											
												
													
														|  |    for (cmTarget::LinkLibraryVectorType::const_iterator llvI = llv.begin();
 |  |    for (cmTarget::LinkLibraryVectorType::const_iterator llvI = llv.begin();
 | 
											
												
													
														|  |         llvI != llv.end(); ++llvI)
 |  |         llvI != llv.end(); ++llvI)
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
										
											
												
													
														|  | @@ -391,10 +391,12 @@ void cmGhsMultiTargetGenerator::WriteTargetLinkLibraries()
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void cmGhsMultiTargetGenerator::WriteCustomCommands()
 |  |  void cmGhsMultiTargetGenerator::WriteCustomCommands()
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -  WriteCustomCommandsHelper(this->Target->GetPreBuildCommands(),
 |  | 
 | 
											
												
													
														|  | -                            cmTarget::PRE_BUILD);
 |  | 
 | 
											
												
													
														|  | -  WriteCustomCommandsHelper(this->Target->GetPostBuildCommands(),
 |  | 
 | 
											
												
													
														|  | -                            cmTarget::POST_BUILD);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  WriteCustomCommandsHelper(
 | 
											
												
													
														|  | 
 |  | +        this->GeneratorTarget->Target->GetPreBuildCommands(),
 | 
											
												
													
														|  | 
 |  | +        cmTarget::PRE_BUILD);
 | 
											
												
													
														|  | 
 |  | +  WriteCustomCommandsHelper(
 | 
											
												
													
														|  | 
 |  | +        this->GeneratorTarget->Target->GetPostBuildCommands(),
 | 
											
												
													
														|  | 
 |  | +        cmTarget::POST_BUILD);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void cmGhsMultiTargetGenerator::WriteCustomCommandsHelper(
 |  |  void cmGhsMultiTargetGenerator::WriteCustomCommandsHelper(
 | 
											
										
											
												
													
														|  | @@ -518,7 +520,7 @@ cmGhsMultiTargetGenerator::GetOutputDirectory(const std::string &config) const
 | 
											
												
													
														|  |    std::string outputDir(AbsBuildFilePath);
 |  |    std::string outputDir(AbsBuildFilePath);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    const char *runtimeOutputProp =
 |  |    const char *runtimeOutputProp =
 | 
											
												
													
														|  | -    this->Target->GetProperty("RUNTIME_OUTPUT_DIRECTORY");
 |  | 
 | 
											
												
													
														|  | 
 |  | +    this->GeneratorTarget->GetProperty("RUNTIME_OUTPUT_DIRECTORY");
 | 
											
												
													
														|  |    if (NULL != runtimeOutputProp)
 |  |    if (NULL != runtimeOutputProp)
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
												
													
														|  |      outputDir = runtimeOutputProp;
 |  |      outputDir = runtimeOutputProp;
 | 
											
										
											
												
													
														|  | @@ -526,7 +528,8 @@ cmGhsMultiTargetGenerator::GetOutputDirectory(const std::string &config) const
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    std::string configCapped(cmSystemTools::UpperCase(config));
 |  |    std::string configCapped(cmSystemTools::UpperCase(config));
 | 
											
												
													
														|  |    const char *runtimeOutputSProp =
 |  |    const char *runtimeOutputSProp =
 | 
											
												
													
														|  | -    this->Target->GetProperty("RUNTIME_OUTPUT_DIRECTORY_" + configCapped);
 |  | 
 | 
											
												
													
														|  | 
 |  | +    this->GeneratorTarget
 | 
											
												
													
														|  | 
 |  | +      ->GetProperty("RUNTIME_OUTPUT_DIRECTORY_" + configCapped);
 | 
											
												
													
														|  |    if (NULL != runtimeOutputSProp)
 |  |    if (NULL != runtimeOutputSProp)
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
												
													
														|  |      outputDir = runtimeOutputSProp;
 |  |      outputDir = runtimeOutputSProp;
 | 
											
										
											
												
													
														|  | @@ -544,9 +547,10 @@ cmGhsMultiTargetGenerator::GetOutputDirectory(const std::string &config) const
 | 
											
												
													
														|  |  std::string
 |  |  std::string
 | 
											
												
													
														|  |  cmGhsMultiTargetGenerator::GetOutputFilename(const std::string &config) const
 |  |  cmGhsMultiTargetGenerator::GetOutputFilename(const std::string &config) const
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -  std::string outputFilename(this->Target->GetName());
 |  | 
 | 
											
												
													
														|  | 
 |  | +  std::string outputFilename(this->GeneratorTarget->GetName());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const char *outputNameProp = this->Target->GetProperty("OUTPUT_NAME");
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const char *outputNameProp =
 | 
											
												
													
														|  | 
 |  | +      this->GeneratorTarget->GetProperty("OUTPUT_NAME");
 | 
											
												
													
														|  |    if (NULL != outputNameProp)
 |  |    if (NULL != outputNameProp)
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
												
													
														|  |      outputFilename = outputNameProp;
 |  |      outputFilename = outputNameProp;
 | 
											
										
											
												
													
														|  | @@ -554,7 +558,7 @@ cmGhsMultiTargetGenerator::GetOutputFilename(const std::string &config) const
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    std::string configCapped(cmSystemTools::UpperCase(config));
 |  |    std::string configCapped(cmSystemTools::UpperCase(config));
 | 
											
												
													
														|  |    const char *outputNameSProp =
 |  |    const char *outputNameSProp =
 | 
											
												
													
														|  | -    this->Target->GetProperty(configCapped + "_OUTPUT_NAME");
 |  | 
 | 
											
												
													
														|  | 
 |  | +    this->GeneratorTarget->GetProperty(configCapped + "_OUTPUT_NAME");
 | 
											
												
													
														|  |    if (NULL != outputNameSProp)
 |  |    if (NULL != outputNameSProp)
 | 
											
												
													
														|  |      {
 |  |      {
 | 
											
												
													
														|  |      outputFilename = outputNameSProp;
 |  |      outputFilename = outputNameSProp;
 |