Merge topic 'cpack-deb-component-vars-prepare'
c8375e15 CPackDeb: Refactor package variable lookup by generator
This commit is contained in:
commit
0d852d4c65
@ -223,6 +223,7 @@ if(NOT UNIX)
|
||||
message(FATAL_ERROR "CPackDeb.cmake may only be used under UNIX.")
|
||||
endif()
|
||||
|
||||
function(cpack_deb_prepare_package_vars)
|
||||
# CPACK_DEBIAN_PACKAGE_SHLIBDEPS
|
||||
# If specify OFF, only user depends are used
|
||||
if(NOT DEFINED CPACK_DEBIAN_PACKAGE_SHLIBDEPS)
|
||||
@ -453,3 +454,29 @@ endif()
|
||||
# "debhelper (>> 5.0.0), libncurses5-dev, tcl8.4"
|
||||
# )
|
||||
#endif()
|
||||
|
||||
# move variables to parent scope so that they may be used to create debian package
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_NAME "${CPACK_DEBIAN_PACKAGE_NAME}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_VERSION "${CPACK_DEBIAN_PACKAGE_VERSION}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_SECTION "${CPACK_DEBIAN_PACKAGE_SECTION}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_PRIORITY "${CPACK_DEBIAN_PACKAGE_PRIORITY}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_ARCHITECTURE "${CPACK_DEBIAN_PACKAGE_ARCHITECTURE}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_MAINTAINER "${CPACK_DEBIAN_PACKAGE_MAINTAINER}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_DESCRIPTION "${CPACK_DEBIAN_PACKAGE_DESCRIPTION}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_DEPENDS}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_FAKEROOT_EXECUTABLE "${CPACK_DEBIAN_FAKEROOT_EXECUTABLE}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_COMPRESSION_TYPE "${CPACK_DEBIAN_COMPRESSION_TYPE}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_RECOMMENDS "${CPACK_DEBIAN_PACKAGE_RECOMMENDS}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_SUGGESTS "${CPACK_DEBIAN_PACKAGE_SUGGESTS}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_HOMEPAGE "${CPACK_DEBIAN_PACKAGE_HOMEPAGE}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_PREDEPENDS "${CPACK_DEBIAN_PACKAGE_PREDEPENDS}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_ENHANCES "${CPACK_DEBIAN_PACKAGE_ENHANCES}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_BREAKS "${CPACK_DEBIAN_PACKAGE_BREAKS}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_CONFLICTS "${CPACK_DEBIAN_PACKAGE_CONFLICTS}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_PROVIDES "${CPACK_DEBIAN_PACKAGE_PROVIDES}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_REPLACES "${CPACK_DEBIAN_PACKAGE_REPLACES}" PARENT_SCOPE)
|
||||
set(GEN_CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA "${CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA}" PARENT_SCOPE)
|
||||
set(GEN_WDIR "${WDIR}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
cpack_deb_prepare_package_vars()
|
||||
|
@ -90,7 +90,7 @@ int cmCPackDebGenerator::PackageOnePack(std::string initialTopLevel,
|
||||
}
|
||||
|
||||
cmsys::Glob gl;
|
||||
std::string findExpr(this->GetOption("WDIR"));
|
||||
std::string findExpr(this->GetOption("GEN_WDIR"));
|
||||
findExpr += "/*";
|
||||
gl.RecurseOn();
|
||||
if ( !gl.FindFiles(findExpr) )
|
||||
@ -217,7 +217,7 @@ int cmCPackDebGenerator::PackageComponentsAllInOne()
|
||||
}
|
||||
|
||||
cmsys::Glob gl;
|
||||
std::string findExpr(this->GetOption("WDIR"));
|
||||
std::string findExpr(this->GetOption("GEN_WDIR"));
|
||||
findExpr += "/*";
|
||||
gl.RecurseOn();
|
||||
if ( !gl.FindFiles(findExpr) )
|
||||
@ -286,7 +286,7 @@ int cmCPackDebGenerator::createDeb()
|
||||
|
||||
// debian-binary file
|
||||
std::string dbfilename;
|
||||
dbfilename += this->GetOption("WDIR");
|
||||
dbfilename += this->GetOption("GEN_WDIR");
|
||||
dbfilename += "/debian-binary";
|
||||
{ // the scope is needed for cmGeneratedFileStream
|
||||
cmGeneratedFileStream out(dbfilename.c_str());
|
||||
@ -296,44 +296,47 @@ int cmCPackDebGenerator::createDeb()
|
||||
|
||||
// control file
|
||||
std::string ctlfilename;
|
||||
ctlfilename = this->GetOption("WDIR");
|
||||
ctlfilename = this->GetOption("GEN_WDIR");
|
||||
ctlfilename += "/control";
|
||||
|
||||
// debian policy enforce lower case for package name
|
||||
// mandatory entries:
|
||||
std::string debian_pkg_name = cmsys::SystemTools::LowerCase(
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_NAME") );
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_NAME") );
|
||||
const char* debian_pkg_version =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_VERSION");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_VERSION");
|
||||
const char* debian_pkg_section =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_SECTION");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_SECTION");
|
||||
const char* debian_pkg_priority =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_PRIORITY");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_PRIORITY");
|
||||
const char* debian_pkg_arch =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_ARCHITECTURE");
|
||||
const char* maintainer = this->GetOption("CPACK_DEBIAN_PACKAGE_MAINTAINER");
|
||||
const char* desc = this->GetOption("CPACK_DEBIAN_PACKAGE_DESCRIPTION");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_ARCHITECTURE");
|
||||
const char* maintainer =
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_MAINTAINER");
|
||||
const char* desc =
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_DESCRIPTION");
|
||||
|
||||
// optional entries
|
||||
const char* debian_pkg_dep = this->GetOption("CPACK_DEBIAN_PACKAGE_DEPENDS");
|
||||
const char* debian_pkg_dep =
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_DEPENDS");
|
||||
const char* debian_pkg_rec =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_RECOMMENDS");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_RECOMMENDS");
|
||||
const char* debian_pkg_sug =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_SUGGESTS");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_SUGGESTS");
|
||||
const char* debian_pkg_url =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_HOMEPAGE");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_HOMEPAGE");
|
||||
const char* debian_pkg_predep =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_PREDEPENDS");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_PREDEPENDS");
|
||||
const char* debian_pkg_enhances =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_ENHANCES");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_ENHANCES");
|
||||
const char* debian_pkg_breaks =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_BREAKS");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_BREAKS");
|
||||
const char* debian_pkg_conflicts =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_CONFLICTS");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_CONFLICTS");
|
||||
const char* debian_pkg_provides =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_PROVIDES");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_PROVIDES");
|
||||
const char* debian_pkg_replaces =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_REPLACES");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_REPLACES");
|
||||
|
||||
{ // the scope is needed for cmGeneratedFileStream
|
||||
cmGeneratedFileStream out(ctlfilename.c_str());
|
||||
@ -399,13 +402,10 @@ int cmCPackDebGenerator::createDeb()
|
||||
out << std::endl;
|
||||
}
|
||||
|
||||
std::string cmd;
|
||||
if (NULL != this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE")) {
|
||||
cmd += this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE");
|
||||
}
|
||||
std::string cmd(this->GetOption("GEN_CPACK_DEBIAN_FAKEROOT_EXECUTABLE"));
|
||||
|
||||
const char* debian_compression_type =
|
||||
this->GetOption("CPACK_DEBIAN_COMPRESSION_TYPE");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_COMPRESSION_TYPE");
|
||||
if(!debian_compression_type)
|
||||
{
|
||||
debian_compression_type = "gzip";
|
||||
@ -440,8 +440,9 @@ int cmCPackDebGenerator::createDeb()
|
||||
// now add all directories which have to be compressed
|
||||
// collect all top level install dirs for that
|
||||
// e.g. /opt/bin/foo, /usr/bin/bar and /usr/bin/baz would give /usr and /opt
|
||||
size_t topLevelLength = std::string(this->GetOption("WDIR")).length();
|
||||
cmCPackLogger(cmCPackLog::LOG_DEBUG, "WDIR: \"" << this->GetOption("WDIR")
|
||||
size_t topLevelLength = std::string(this->GetOption("GEN_WDIR")).length();
|
||||
cmCPackLogger(cmCPackLog::LOG_DEBUG, "WDIR: \""
|
||||
<< this->GetOption("GEN_WDIR")
|
||||
<< "\", length = " << topLevelLength
|
||||
<< std::endl);
|
||||
std::set<std::string> installDirs;
|
||||
@ -467,7 +468,7 @@ int cmCPackDebGenerator::createDeb()
|
||||
std::string output;
|
||||
int retval = -1;
|
||||
int res = cmSystemTools::RunSingleCommand(cmd.c_str(), &output, &output,
|
||||
&retval, this->GetOption("WDIR"), this->GeneratorVerbose, 0);
|
||||
&retval, this->GetOption("GEN_WDIR"), this->GeneratorVerbose, 0);
|
||||
|
||||
if ( !res || retval )
|
||||
{
|
||||
@ -485,7 +486,7 @@ int cmCPackDebGenerator::createDeb()
|
||||
}
|
||||
|
||||
std::string md5filename;
|
||||
md5filename = this->GetOption("WDIR");
|
||||
md5filename = this->GetOption("GEN_WDIR");
|
||||
md5filename += "/md5sums";
|
||||
|
||||
{ // the scope is needed for cmGeneratedFileStream
|
||||
@ -523,14 +524,10 @@ int cmCPackDebGenerator::createDeb()
|
||||
// Do not end the md5sum file with yet another (invalid)
|
||||
}
|
||||
|
||||
cmd = "";
|
||||
if (NULL != this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE"))
|
||||
{
|
||||
cmd = this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE");
|
||||
}
|
||||
cmd = this->GetOption("GEN_CPACK_DEBIAN_FAKEROOT_EXECUTABLE");
|
||||
cmd += cmake_tar + "tar czf control.tar.gz ./control ./md5sums";
|
||||
const char* controlExtra =
|
||||
this->GetOption("CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA");
|
||||
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA");
|
||||
if( controlExtra )
|
||||
{
|
||||
std::vector<std::string> controlExtraList;
|
||||
@ -540,7 +537,7 @@ int cmCPackDebGenerator::createDeb()
|
||||
{
|
||||
std::string filenamename =
|
||||
cmsys::SystemTools::GetFilenameName(*i);
|
||||
std::string localcopy = this->GetOption("WDIR");
|
||||
std::string localcopy = this->GetOption("GEN_WDIR");
|
||||
localcopy += "/";
|
||||
localcopy += filenamename;
|
||||
// if we can copy the file, it means it does exist, let's add it:
|
||||
@ -554,7 +551,7 @@ int cmCPackDebGenerator::createDeb()
|
||||
}
|
||||
}
|
||||
res = cmSystemTools::RunSingleCommand(cmd.c_str(), &output, &output,
|
||||
&retval, this->GetOption("WDIR"), this->GeneratorVerbose, 0);
|
||||
&retval, this->GetOption("GEN_WDIR"), this->GeneratorVerbose, 0);
|
||||
|
||||
if ( !res || retval )
|
||||
{
|
||||
@ -575,7 +572,7 @@ int cmCPackDebGenerator::createDeb()
|
||||
// since debian packages require BSD ar (most Linux distros and even
|
||||
// FreeBSD and NetBSD ship GNU ar) we use a copy of OpenBSD ar here.
|
||||
std::vector<std::string> arFiles;
|
||||
std::string topLevelString = this->GetOption("WDIR");
|
||||
std::string topLevelString = this->GetOption("GEN_WDIR");
|
||||
topLevelString += "/";
|
||||
arFiles.push_back(topLevelString + "debian-binary");
|
||||
arFiles.push_back(topLevelString + "control.tar.gz");
|
||||
|
Loading…
x
Reference in New Issue
Block a user