|  | @@ -11,17 +11,17 @@
 | 
	
		
			
				|  |  |  ============================================================================*/
 | 
	
		
			
				|  |  |  #include "cmCPackProductBuildGenerator.h"
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -#include "cmake.h"
 | 
	
		
			
				|  |  | +#include "cmCPackComponentGroup.h"
 | 
	
		
			
				|  |  | +#include "cmCPackLog.h"
 | 
	
		
			
				|  |  | +#include "cmGeneratedFileStream.h"
 | 
	
		
			
				|  |  |  #include "cmGlobalGenerator.h"
 | 
	
		
			
				|  |  |  #include "cmLocalGenerator.h"
 | 
	
		
			
				|  |  | -#include "cmSystemTools.h"
 | 
	
		
			
				|  |  |  #include "cmMakefile.h"
 | 
	
		
			
				|  |  | -#include "cmGeneratedFileStream.h"
 | 
	
		
			
				|  |  | -#include "cmCPackComponentGroup.h"
 | 
	
		
			
				|  |  | -#include "cmCPackLog.h"
 | 
	
		
			
				|  |  | +#include "cmSystemTools.h"
 | 
	
		
			
				|  |  | +#include "cmake.h"
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -#include <cmsys/SystemTools.hxx>
 | 
	
		
			
				|  |  |  #include <cmsys/Glob.hxx>
 | 
	
		
			
				|  |  | +#include <cmsys/SystemTools.hxx>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  cmCPackProductBuildGenerator::cmCPackProductBuildGenerator()
 | 
	
		
			
				|  |  |  {
 | 
	
	
		
			
				|  | @@ -37,56 +37,47 @@ int cmCPackProductBuildGenerator::PackageFiles()
 | 
	
		
			
				|  |  |    // TODO: Use toplevel
 | 
	
		
			
				|  |  |    //       It is used! Is this an obsolete comment?
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  std::string packageDirFileName
 | 
	
		
			
				|  |  | -    = this->GetOption("CPACK_TEMPORARY_DIRECTORY");
 | 
	
		
			
				|  |  | +  std::string packageDirFileName =
 | 
	
		
			
				|  |  | +    this->GetOption("CPACK_TEMPORARY_DIRECTORY");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // Create the directory where component packages will be built.
 | 
	
		
			
				|  |  |    std::string basePackageDir = packageDirFileName;
 | 
	
		
			
				|  |  |    basePackageDir += "/Contents/Packages";
 | 
	
		
			
				|  |  | -  if (!cmsys::SystemTools::MakeDirectory(basePackageDir.c_str()))
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | +  if (!cmsys::SystemTools::MakeDirectory(basePackageDir.c_str())) {
 | 
	
		
			
				|  |  |      cmCPackLogger(cmCPackLog::LOG_ERROR,
 | 
	
		
			
				|  |  |                    "Problem creating component packages directory: "
 | 
	
		
			
				|  |  |                      << basePackageDir << std::endl);
 | 
	
		
			
				|  |  |      return 0;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  if (!this->Components.empty())
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | +  if (!this->Components.empty()) {
 | 
	
		
			
				|  |  |      std::map<std::string, cmCPackComponent>::iterator compIt;
 | 
	
		
			
				|  |  |      for (compIt = this->Components.begin(); compIt != this->Components.end();
 | 
	
		
			
				|  |  | -         ++compIt)
 | 
	
		
			
				|  |  | -      {
 | 
	
		
			
				|  |  | +         ++compIt) {
 | 
	
		
			
				|  |  |        std::string packageDir = toplevel;
 | 
	
		
			
				|  |  |        packageDir += '/';
 | 
	
		
			
				|  |  |        packageDir += compIt->first;
 | 
	
		
			
				|  |  |        if (!this->GenerateComponentPackage(basePackageDir,
 | 
	
		
			
				|  |  |                                            GetPackageName(compIt->second),
 | 
	
		
			
				|  |  | -                                          packageDir,
 | 
	
		
			
				|  |  | -                                          &compIt->second))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | +                                          packageDir, &compIt->second)) {
 | 
	
		
			
				|  |  |          return 0;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  | -  else
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | -    if(!this->GenerateComponentPackage(basePackageDir,
 | 
	
		
			
				|  |  | -                                       this->GetOption("CPACK_PACKAGE_NAME"),
 | 
	
		
			
				|  |  | -                                       toplevel, NULL))
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | +  } else {
 | 
	
		
			
				|  |  | +    if (!this->GenerateComponentPackage(basePackageDir,
 | 
	
		
			
				|  |  | +                                        this->GetOption("CPACK_PACKAGE_NAME"),
 | 
	
		
			
				|  |  | +                                        toplevel, NULL)) {
 | 
	
		
			
				|  |  |        return 0;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // Copy or create all of the resource files we need.
 | 
	
		
			
				|  |  |    std::string resDir = packageDirFileName + "/Contents";
 | 
	
		
			
				|  |  | -  if ( !this->CopyCreateResourceFile("License", resDir.c_str())
 | 
	
		
			
				|  |  | -      || !this->CopyCreateResourceFile("ReadMe", resDir.c_str())
 | 
	
		
			
				|  |  | -      || !this->CopyCreateResourceFile("Welcome", resDir.c_str()))
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | +  if (!this->CopyCreateResourceFile("License", resDir.c_str()) ||
 | 
	
		
			
				|  |  | +      !this->CopyCreateResourceFile("ReadMe", resDir.c_str()) ||
 | 
	
		
			
				|  |  | +      !this->CopyCreateResourceFile("Welcome", resDir.c_str())) {
 | 
	
		
			
				|  |  |      cmCPackLogger(cmCPackLog::LOG_ERROR, "Problem copying the resource files"
 | 
	
		
			
				|  |  | -                  << std::endl);
 | 
	
		
			
				|  |  | +                    << std::endl);
 | 
	
		
			
				|  |  |      return 0;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -97,13 +88,13 @@ int cmCPackProductBuildGenerator::PackageFiles()
 | 
	
		
			
				|  |  |    std::string version = this->GetOption("CPACK_PACKAGE_VERSION");
 | 
	
		
			
				|  |  |    std::string productbuild = this->GetOption("CPACK_COMMAND_PRODUCTBUILD");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  pkgCmd << productbuild
 | 
	
		
			
				|  |  | -  << " --distribution \"" << packageDirFileName
 | 
	
		
			
				|  |  | -    << "/Contents/distribution.dist\""
 | 
	
		
			
				|  |  | -  << " --package-path \"" << packageDirFileName << "/Contents/Packages" << "\""
 | 
	
		
			
				|  |  | -  << " --resources \"" << resDir << "\""
 | 
	
		
			
				|  |  | -  << " --version \"" << version << "\""
 | 
	
		
			
				|  |  | -  << " \"" << packageFileNames[0] << "\"";
 | 
	
		
			
				|  |  | +  pkgCmd << productbuild << " --distribution \"" << packageDirFileName
 | 
	
		
			
				|  |  | +         << "/Contents/distribution.dist\""
 | 
	
		
			
				|  |  | +         << " --package-path \"" << packageDirFileName << "/Contents/Packages"
 | 
	
		
			
				|  |  | +         << "\""
 | 
	
		
			
				|  |  | +         << " --resources \"" << resDir << "\""
 | 
	
		
			
				|  |  | +         << " --version \"" << version << "\""
 | 
	
		
			
				|  |  | +         << " \"" << packageFileNames[0] << "\"";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // Run ProductBuild
 | 
	
		
			
				|  |  |    return RunProductBuild(pkgCmd.str());
 | 
	
	
		
			
				|  | @@ -123,7 +114,6 @@ int cmCPackProductBuildGenerator::InitializeInternal()
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    this->SetOptionIfNotSet("CPACK_COMMAND_PKGBUILD", program.c_str());
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |    program = cmSystemTools::FindProgram("productbuild", no_paths, false);
 | 
	
		
			
				|  |  |    if (program.empty()) {
 | 
	
		
			
				|  |  |      cmCPackLogger(cmCPackLog::LOG_ERROR, "Cannot find productbuild executable"
 | 
	
	
		
			
				|  | @@ -135,9 +125,7 @@ int cmCPackProductBuildGenerator::InitializeInternal()
 | 
	
		
			
				|  |  |    return this->Superclass::InitializeInternal();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -bool cmCPackProductBuildGenerator::RunProductBuild(
 | 
	
		
			
				|  |  | -  const std::string& command)
 | 
	
		
			
				|  |  | +bool cmCPackProductBuildGenerator::RunProductBuild(const std::string& command)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    std::string tmpFile = this->GetOption("CPACK_TOPLEVEL_DIRECTORY");
 | 
	
		
			
				|  |  |    tmpFile += "/ProductBuildOutput.log";
 | 
	
	
		
			
				|  | @@ -145,12 +133,11 @@ bool cmCPackProductBuildGenerator::RunProductBuild(
 | 
	
		
			
				|  |  |    cmCPackLogger(cmCPackLog::LOG_VERBOSE, "Execute: " << command << std::endl);
 | 
	
		
			
				|  |  |    std::string output, error_output;
 | 
	
		
			
				|  |  |    int retVal = 1;
 | 
	
		
			
				|  |  | -  bool res = cmSystemTools::RunSingleCommand(command.c_str(),
 | 
	
		
			
				|  |  | -    &output, &error_output, &retVal, 0, this->GeneratorVerbose, 0);
 | 
	
		
			
				|  |  | -  cmCPackLogger(cmCPackLog::LOG_VERBOSE, "Done running command"
 | 
	
		
			
				|  |  | -    << std::endl);
 | 
	
		
			
				|  |  | -  if ( !res || retVal )
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | +  bool res =
 | 
	
		
			
				|  |  | +    cmSystemTools::RunSingleCommand(command.c_str(), &output, &error_output,
 | 
	
		
			
				|  |  | +                                    &retVal, 0, this->GeneratorVerbose, 0);
 | 
	
		
			
				|  |  | +  cmCPackLogger(cmCPackLog::LOG_VERBOSE, "Done running command" << std::endl);
 | 
	
		
			
				|  |  | +  if (!res || retVal) {
 | 
	
		
			
				|  |  |      cmGeneratedFileStream ofs(tmpFile.c_str());
 | 
	
		
			
				|  |  |      ofs << "# Run command: " << command << std::endl
 | 
	
		
			
				|  |  |          << "# Output:" << std::endl
 | 
	
	
		
			
				|  | @@ -160,23 +147,20 @@ bool cmCPackProductBuildGenerator::RunProductBuild(
 | 
	
		
			
				|  |  |                                                << "Please check " << tmpFile
 | 
	
		
			
				|  |  |                                                << " for errors" << std::endl);
 | 
	
		
			
				|  |  |      return false;
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  |    return true;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  bool cmCPackProductBuildGenerator::GenerateComponentPackage(
 | 
	
		
			
				|  |  | -  const std::string& packageFileDir,
 | 
	
		
			
				|  |  | -  const std::string& packageFileName,
 | 
	
		
			
				|  |  | -  const std::string& packageDir,
 | 
	
		
			
				|  |  | -  const cmCPackComponent* component)
 | 
	
		
			
				|  |  | +  const std::string& packageFileDir, const std::string& packageFileName,
 | 
	
		
			
				|  |  | +  const std::string& packageDir, const cmCPackComponent* component)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    std::string packageFile = packageFileDir;
 | 
	
		
			
				|  |  |    packageFile += '/';
 | 
	
		
			
				|  |  |    packageFile += packageFileName;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  cmCPackLogger(cmCPackLog::LOG_OUTPUT,
 | 
	
		
			
				|  |  | -                "-   Building component package: " <<
 | 
	
		
			
				|  |  | -                packageFile << std::endl);
 | 
	
		
			
				|  |  | +  cmCPackLogger(cmCPackLog::LOG_OUTPUT, "-   Building component package: "
 | 
	
		
			
				|  |  | +                  << packageFile << std::endl);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    const char* comp_name = component ? component->Name.c_str() : NULL;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -184,15 +168,13 @@ bool cmCPackProductBuildGenerator::GenerateComponentPackage(
 | 
	
		
			
				|  |  |    const char* postflight = this->GetComponentScript("POSTFLIGHT", comp_name);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    std::string resDir = packageFileDir;
 | 
	
		
			
				|  |  | -  if(component)
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | +  if (component) {
 | 
	
		
			
				|  |  |      resDir += "/";
 | 
	
		
			
				|  |  |      resDir += component->Name;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    std::string scriptDir = resDir + "/scripts";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  if ( !cmsys::SystemTools::MakeDirectory(scriptDir.c_str()))
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | +  if (!cmsys::SystemTools::MakeDirectory(scriptDir.c_str())) {
 | 
	
		
			
				|  |  |      cmCPackLogger(cmCPackLog::LOG_ERROR,
 | 
	
		
			
				|  |  |                    "Problem creating installer directory: " << scriptDir
 | 
	
		
			
				|  |  |                                                             << std::endl);
 | 
	
	
		
			
				|  | @@ -202,20 +184,13 @@ bool cmCPackProductBuildGenerator::GenerateComponentPackage(
 | 
	
		
			
				|  |  |    // if preflight, postflight, or postupgrade are set
 | 
	
		
			
				|  |  |    // then copy them into the script directory and make
 | 
	
		
			
				|  |  |    // them executable
 | 
	
		
			
				|  |  | -  if(preflight)
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | -    this->CopyInstallScript(scriptDir.c_str(),
 | 
	
		
			
				|  |  | -                            preflight,
 | 
	
		
			
				|  |  | -                            "preinstall");
 | 
	
		
			
				|  |  | +  if (preflight) {
 | 
	
		
			
				|  |  | +    this->CopyInstallScript(scriptDir.c_str(), preflight, "preinstall");
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  | -  if(postflight)
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | -    this->CopyInstallScript(scriptDir.c_str(),
 | 
	
		
			
				|  |  | -                            postflight,
 | 
	
		
			
				|  |  | -                            "postinstall");
 | 
	
		
			
				|  |  | +  if (postflight) {
 | 
	
		
			
				|  |  | +    this->CopyInstallScript(scriptDir.c_str(), postflight, "postinstall");
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |    // The command that will be used to run ProductBuild
 | 
	
		
			
				|  |  |    std::ostringstream pkgCmd;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -223,17 +198,15 @@ bool cmCPackProductBuildGenerator::GenerateComponentPackage(
 | 
	
		
			
				|  |  |    pkgId += this->GetOption("CPACK_PACKAGE_VENDOR");
 | 
	
		
			
				|  |  |    pkgId += '.';
 | 
	
		
			
				|  |  |    pkgId += this->GetOption("CPACK_PACKAGE_NAME");
 | 
	
		
			
				|  |  | -  if(component)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | +  if (component) {
 | 
	
		
			
				|  |  |      pkgId += '.';
 | 
	
		
			
				|  |  |      pkgId += component->Name;
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    std::string version = this->GetOption("CPACK_PACKAGE_VERSION");
 | 
	
		
			
				|  |  |    std::string pkgbuild = this->GetOption("CPACK_COMMAND_PKGBUILD");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  pkgCmd << pkgbuild
 | 
	
		
			
				|  |  | -         << " --root \"" << packageDir << "\""
 | 
	
		
			
				|  |  | +  pkgCmd << pkgbuild << " --root \"" << packageDir << "\""
 | 
	
		
			
				|  |  |           << " --identifier \"" << pkgId << "\""
 | 
	
		
			
				|  |  |           << " --scripts \"" << scriptDir << "\""
 | 
	
		
			
				|  |  |           << " --version \"" << version << "\""
 | 
	
	
		
			
				|  | @@ -245,12 +218,10 @@ bool cmCPackProductBuildGenerator::GenerateComponentPackage(
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  const char* cmCPackProductBuildGenerator::GetComponentScript(
 | 
	
		
			
				|  |  | -  const char* script,
 | 
	
		
			
				|  |  | -  const char* component_name)
 | 
	
		
			
				|  |  | +  const char* script, const char* component_name)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |    std::string scriptname = std::string("CPACK_") + script + "_";
 | 
	
		
			
				|  |  | -  if(component_name)
 | 
	
		
			
				|  |  | -  {
 | 
	
		
			
				|  |  | +  if (component_name) {
 | 
	
		
			
				|  |  |      scriptname += cmSystemTools::UpperCase(component_name);
 | 
	
		
			
				|  |  |      scriptname += "_";
 | 
	
		
			
				|  |  |    }
 |