diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2009-11-03 14:40:57 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2009-11-03 14:40:57 (GMT) |
commit | 78b2d5097cc3b5d96f67d3f90ca92f7418043bc0 (patch) | |
tree | f855d0d44f9a5d239fc83284accc6172ae708537 /Source/CPack/cmCPackCygwinSourceGenerator.cxx | |
parent | 1b1d954f7ec2aa49a0eccefed1a5b2b11886fd06 (diff) | |
download | CMake-78b2d5097cc3b5d96f67d3f90ca92f7418043bc0.zip CMake-78b2d5097cc3b5d96f67d3f90ca92f7418043bc0.tar.gz CMake-78b2d5097cc3b5d96f67d3f90ca92f7418043bc0.tar.bz2 |
Fix cygwin package stuff to work with libarchive
Diffstat (limited to 'Source/CPack/cmCPackCygwinSourceGenerator.cxx')
-rw-r--r-- | Source/CPack/cmCPackCygwinSourceGenerator.cxx | 92 |
1 files changed, 40 insertions, 52 deletions
diff --git a/Source/CPack/cmCPackCygwinSourceGenerator.cxx b/Source/CPack/cmCPackCygwinSourceGenerator.cxx index 32c4e38..cca8338 100644 --- a/Source/CPack/cmCPackCygwinSourceGenerator.cxx +++ b/Source/CPack/cmCPackCygwinSourceGenerator.cxx @@ -33,7 +33,6 @@ //---------------------------------------------------------------------- cmCPackCygwinSourceGenerator::cmCPackCygwinSourceGenerator() { - this->Compress = false; } //---------------------------------------------------------------------- @@ -45,18 +44,6 @@ cmCPackCygwinSourceGenerator::~cmCPackCygwinSourceGenerator() int cmCPackCygwinSourceGenerator::InitializeInternal() { this->SetOptionIfNotSet("CPACK_INCLUDE_TOPLEVEL_DIRECTORY", "0"); - std::vector<std::string> path; - std::string pkgPath = cmSystemTools::FindProgram("bzip2", path, false); - if ( pkgPath.empty() ) - { - cmCPackLogger(cmCPackLog::LOG_ERROR, "Cannot find BZip2" << std::endl); - return 0; - } - this->SetOptionIfNotSet("CPACK_INSTALLER_PROGRAM", pkgPath.c_str()); - cmCPackLogger(cmCPackLog::LOG_VERBOSE, "Found Compress program: " - << pkgPath.c_str() - << std::endl); - return this->Superclass::InitializeInternal(); } @@ -67,26 +54,22 @@ int cmCPackCygwinSourceGenerator::CompressFiles(const char* outFileName, // Create a tar file of the sources std::string packageDirFileName = this->GetOption("CPACK_TEMPORARY_DIRECTORY"); - packageDirFileName += ".tar"; + packageDirFileName += ".tar.bz2"; std::string output; - // skip one parent up to the cmCPackTGZGenerator to create tar file - this->Compress = false; // just create tar not tar.gz - if ( !this->cmCPackTGZGenerator::CompressFiles(packageDirFileName.c_str(), + // skip one parent up to the cmCPackTarBZip2Generator + // to create tar.bz2 file with the list of source + // files + this->Compress = BZIP2; + if ( !this->cmCPackTarBZip2Generator:: + CompressFiles(packageDirFileName.c_str(), toplevel, files) ) { return 0; } - // Now bzip2 the source tar file - if(!this->BZip2File(packageDirFileName.c_str())) - { - cmCPackLogger(cmCPackLog::LOG_ERROR, "Problem running BZip2 on file: " - << packageDirFileName.c_str()); - return 0; - } // Now create a tar file that contains the above .tar.bz2 file // and the CPACK_CYGWIN_PATCH_FILE and CPACK_TOPLEVEL_DIRECTORY // files - std::string compressOutFile = packageDirFileName + ".bz2"; + std::string compressOutFile = packageDirFileName; // at this point compressOutFile is the full path to // _CPack_Package/.../package-2.5.0.tar.bz2 // we want to create a tar _CPack_Package/.../package-2.5.0-1-src.tar.bz2 @@ -95,7 +78,17 @@ int cmCPackCygwinSourceGenerator::CompressFiles(const char* outFileName, // _CPack_Package/.../package-2.5.0-1.sh // _CPack_Package/.../package-2.5.0.tar.bz2 // the -1 is CPACK_CYGWIN_PATCH_NUMBER + + // first copy the patch file and the .sh file + // to the toplevel cpack temp dir + // copy the patch file into place + if(!this->GetOption("CPACK_CYGWIN_PATCH_FILE")) + { + cmCPackLogger(cmCPackLog::LOG_ERROR, + "No patch file specified for cygwin sources."); + return 0; + } if(!cmSystemTools::CopyFileAlways( this->GetOption("CPACK_CYGWIN_PATCH_FILE"), this->GetOption("CPACK_TOPLEVEL_DIRECTORY"))) @@ -105,6 +98,12 @@ int cmCPackCygwinSourceGenerator::CompressFiles(const char* outFileName, << this->GetOption("CPACK_TOPLEVEL_DIRECTORY") << "]\n"); return 0; } + if(!this->GetOption("CPACK_CYGWIN_BUILD_SCRIPT")) + { + cmCPackLogger(cmCPackLog::LOG_ERROR, + "No build script specified for cygwin sources."); + return 0; + } // copy the build script into place if(!cmSystemTools::CopyFileAlways( this->GetOption("CPACK_CYGWIN_BUILD_SCRIPT"), @@ -115,7 +114,6 @@ int cmCPackCygwinSourceGenerator::CompressFiles(const char* outFileName, << this->GetOption("CPACK_TOPLEVEL_DIRECTORY") << "]\n"); return 0; } - // create the tar file std::string outerTarFile = this->GetOption("CPACK_TEMPORARY_DIRECTORY"); outerTarFile += "-"; @@ -127,44 +125,34 @@ int cmCPackCygwinSourceGenerator::CompressFiles(const char* outFileName, patch = "1"; } outerTarFile += patch; - outerTarFile += "-src.tar"; - std::string buildScript = cmSystemTools::GetFilenameName( + outerTarFile += "-src.tar.bz2"; + std::string tmpDir = this->GetOption("CPACK_TOPLEVEL_DIRECTORY"); + std::string buildScript = tmpDir; + buildScript += "/"; + buildScript += cmSystemTools::GetFilenameName( this->GetOption("CPACK_CYGWIN_BUILD_SCRIPT")); - std::string patchFile = cmSystemTools::GetFilenameName( + std::string patchFile = tmpDir; + patchFile += "/"; + patchFile += cmSystemTools::GetFilenameName( this->GetOption("CPACK_CYGWIN_PATCH_FILE")); - std::vector<cmStdString> outerFiles; + std::vector<std::string> outerFiles; std::string file = cmSystemTools::GetFilenameName(compressOutFile); - std::string path = cmSystemTools::GetFilenamePath(compressOutFile); + std::string sourceTar = cmSystemTools::GetFilenamePath(compressOutFile); + sourceTar += "/"; + sourceTar += file; // a source release in cygwin should have the build script used // to build the package, the patch file that is different from the // regular upstream version of the sources, and a bziped tar file // of the original sources outerFiles.push_back(buildScript); outerFiles.push_back(patchFile); - outerFiles.push_back(file); - std::string saveDir= cmSystemTools::GetCurrentWorkingDirectory(); - cmSystemTools::ChangeDirectory(path.c_str()); - cmSystemTools::CreateTar(outerTarFile.c_str(), - outerFiles, false, false); - cmSystemTools::ChangeDirectory(saveDir.c_str()); - // now compress the outer tar file - if(!this->BZip2File(outerTarFile.c_str())) + outerFiles.push_back(sourceTar); + if ( !this->cmCPackTarBZip2Generator:: + CompressFiles(outerTarFile.c_str(), + tmpDir.c_str(), outerFiles) ) { return 0; } - compressOutFile = outerTarFile; - compressOutFile += ".bz2"; - // now rename the file to its final name - if ( !cmSystemTools::SameFile(compressOutFile.c_str(), outFileName ) ) - { - if ( !this->RenameFile(compressOutFile.c_str(), outFileName) ) - { - cmCPackLogger(cmCPackLog::LOG_ERROR, "Problem renaming: \"" - << compressOutFile.c_str() << "\" to \"" - << (outFileName ? outFileName : "(NULL)") << std::endl); - return 0; - } - } return 1; } |