cpack.cxx 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615
  1. /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. file LICENSE.rst or https://cmake.org/licensing for details. */
  3. #include <algorithm>
  4. #include <cstddef>
  5. #include <functional>
  6. #include <iostream>
  7. #include <iterator>
  8. #include <map>
  9. #include <memory>
  10. #include <sstream>
  11. #include <string>
  12. #include <type_traits>
  13. #include <utility>
  14. #include <vector>
  15. #include <cm/optional>
  16. #include <cmext/algorithm>
  17. #include "cmsys/Encoding.hxx"
  18. #include "cmCMakePresetsGraph.h"
  19. #include "cmCPackGenerator.h"
  20. #include "cmCPackGeneratorFactory.h"
  21. #include "cmCPackLog.h"
  22. #include "cmCommandLineArgument.h"
  23. #include "cmDocumentation.h"
  24. #include "cmDocumentationEntry.h"
  25. #include "cmGlobalGenerator.h"
  26. #include "cmJSONState.h"
  27. #include "cmList.h"
  28. #include "cmMakefile.h"
  29. #include "cmState.h"
  30. #include "cmStateSnapshot.h"
  31. #include "cmStdIoConsole.h"
  32. #include "cmStringAlgorithms.h"
  33. #include "cmSystemTools.h"
  34. #include "cmValue.h"
  35. #include "cmake.h"
  36. namespace {
  37. cmDocumentationEntry const cmDocumentationName = {
  38. {},
  39. " cpack - Packaging driver provided by CMake."
  40. };
  41. cmDocumentationEntry const cmDocumentationUsage = { {}, " cpack [options]" };
  42. cmDocumentationEntry const cmDocumentationOptions[14] = {
  43. { "-G <generators>", "Override/define CPACK_GENERATOR" },
  44. { "-C <Configurations>", "Specify the project configuration(s)" },
  45. { "-D <var>=<value>", "Set a CPack variable." },
  46. { "--config <configFile>", "Specify the config file." },
  47. { "-V,--verbose", "Enable verbose output" },
  48. { "--trace", "Put underlying cmake scripts in trace mode." },
  49. { "--trace-expand", "Put underlying cmake scripts in expanded trace mode." },
  50. { "--debug", "Enable debug output (for CPack developers)" },
  51. { "-P <packageName>", "Override/define CPACK_PACKAGE_NAME" },
  52. { "-R <packageVersion>", "Override/define CPACK_PACKAGE_VERSION" },
  53. { "-B <packageDirectory>", "Override/define CPACK_PACKAGE_DIRECTORY" },
  54. { "--vendor <vendorName>", "Override/define CPACK_PACKAGE_VENDOR" },
  55. { "--preset", "Read arguments from a package preset" },
  56. { "--list-presets", "List available package presets" }
  57. };
  58. void cpackProgressCallback(std::string const& message, float /*unused*/)
  59. {
  60. std::cout << "-- " << message << '\n';
  61. }
  62. std::vector<cmDocumentationEntry> makeGeneratorDocs(
  63. cmCPackGeneratorFactory const& gf)
  64. {
  65. auto const& generators = gf.GetGeneratorsList();
  66. std::vector<cmDocumentationEntry> docs;
  67. docs.reserve(generators.size());
  68. std::transform(
  69. generators.cbegin(), generators.cend(), std::back_inserter(docs),
  70. [](std::decay<decltype(generators)>::type::value_type const& gen) {
  71. return cmDocumentationEntry{ gen.first, gen.second };
  72. });
  73. return docs;
  74. }
  75. } // namespace
  76. // this is CPack.
  77. int main(int argc, char const* const* argv)
  78. {
  79. cm::StdIo::Console console;
  80. cmsys::Encoding::CommandLineArguments args =
  81. cmsys::Encoding::CommandLineArguments::Main(argc, argv);
  82. argc = args.argc();
  83. argv = args.argv();
  84. std::vector<std::string> inputArgs;
  85. inputArgs.reserve(argc - 1);
  86. cm::append(inputArgs, argv + 1, argv + argc);
  87. cmSystemTools::InitializeLibUV();
  88. cmSystemTools::FindCMakeResources(argv[0]);
  89. cmCPackLog log;
  90. log.SetErrorPrefix("CPack Error: ");
  91. log.SetWarningPrefix("CPack Warning: ");
  92. log.SetOutputPrefix("CPack: ");
  93. log.SetVerbosePrefix("CPack Verbose: ");
  94. if (cmSystemTools::GetLogicalWorkingDirectory().empty()) {
  95. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  96. "Current working directory cannot be established.\n");
  97. return 1;
  98. }
  99. std::string generator;
  100. bool help = false;
  101. bool helpVersion = false;
  102. std::string helpFull;
  103. std::string helpMAN;
  104. std::string helpHTML;
  105. std::string cpackProjectName;
  106. std::string cpackProjectDirectory;
  107. std::string cpackBuildConfig;
  108. std::string cpackProjectVersion;
  109. std::string cpackProjectPatch;
  110. std::string cpackProjectVendor;
  111. std::string cpackConfigFile;
  112. std::string preset;
  113. bool listPresets = false;
  114. std::map<std::string, std::string> definitions;
  115. auto const verboseLambda = [&log](std::string const&, cmake*,
  116. cmMakefile*) -> bool {
  117. log.SetVerbose(true);
  118. cmCPack_Log(&log, cmCPackLog::LOG_OUTPUT, "Enable Verbose\n");
  119. return true;
  120. };
  121. auto const debugLambda = [&log](std::string const&, cmake*,
  122. cmMakefile*) -> bool {
  123. log.SetDebug(true);
  124. cmCPack_Log(&log, cmCPackLog::LOG_OUTPUT, "Enable Debug\n");
  125. return true;
  126. };
  127. auto const traceLambda = [](std::string const&, cmake* state,
  128. cmMakefile*) -> bool {
  129. state->SetTrace(true);
  130. return true;
  131. };
  132. auto const traceExpandLambda = [](std::string const&, cmake* state,
  133. cmMakefile*) -> bool {
  134. state->SetTrace(true);
  135. state->SetTraceExpand(true);
  136. return true;
  137. };
  138. using CommandArgument =
  139. cmCommandLineArgument<bool(std::string const&, cmake*, cmMakefile*)>;
  140. std::vector<CommandArgument> arguments = {
  141. CommandArgument{ "--help", CommandArgument::Values::Zero,
  142. CommandArgument::setToTrue(help) },
  143. CommandArgument{ "--help-full", CommandArgument::Values::Zero,
  144. CommandArgument::setToValue(helpFull) },
  145. CommandArgument{ "--help-html", CommandArgument::Values::Zero,
  146. CommandArgument::setToValue(helpHTML) },
  147. CommandArgument{ "--help-man", CommandArgument::Values::Zero,
  148. CommandArgument::setToValue(helpMAN) },
  149. CommandArgument{ "--version", CommandArgument::Values::Zero,
  150. CommandArgument::setToTrue(helpVersion) },
  151. CommandArgument{ "-V", CommandArgument::Values::Zero, verboseLambda },
  152. CommandArgument{ "--verbose", CommandArgument::Values::Zero,
  153. verboseLambda },
  154. CommandArgument{ "--debug", CommandArgument::Values::Zero, debugLambda },
  155. CommandArgument{ "--config", CommandArgument::Values::One,
  156. CommandArgument::setToValue(cpackConfigFile) },
  157. CommandArgument{ "--trace", CommandArgument::Values::Zero, traceLambda },
  158. CommandArgument{ "--trace-expand", CommandArgument::Values::Zero,
  159. traceExpandLambda },
  160. CommandArgument{ "-C", CommandArgument::Values::One,
  161. CommandArgument::setToValue(cpackBuildConfig) },
  162. CommandArgument{ "-G", CommandArgument::Values::One,
  163. CommandArgument::setToValue(generator) },
  164. CommandArgument{ "-P", CommandArgument::Values::One,
  165. CommandArgument::setToValue(cpackProjectName) },
  166. CommandArgument{ "-R", CommandArgument::Values::One,
  167. CommandArgument::setToValue(cpackProjectVersion) },
  168. CommandArgument{ "-B", CommandArgument::Values::One,
  169. CommandArgument::setToValue(cpackProjectDirectory) },
  170. CommandArgument{ "--patch", CommandArgument::Values::One,
  171. CommandArgument::setToValue(cpackProjectPatch) },
  172. CommandArgument{ "--vendor", CommandArgument::Values::One,
  173. CommandArgument::setToValue(cpackProjectVendor) },
  174. CommandArgument{ "--preset", CommandArgument::Values::One,
  175. CommandArgument::setToValue(preset) },
  176. CommandArgument{ "--list-presets", CommandArgument::Values::Zero,
  177. CommandArgument::setToTrue(listPresets) },
  178. CommandArgument{ "-D", CommandArgument::Values::One,
  179. CommandArgument::RequiresSeparator::No,
  180. [&log, &definitions](std::string const& arg, cmake*,
  181. cmMakefile*) -> bool {
  182. std::string value = arg;
  183. size_t pos = value.find_first_of('=');
  184. if (pos == std::string::npos) {
  185. cmCPack_Log(
  186. &log, cmCPackLog::LOG_ERROR,
  187. "Please specify CPack definitions as: KEY=VALUE\n");
  188. return false;
  189. }
  190. std::string key = value.substr(0, pos);
  191. value.erase(0, pos + 1);
  192. definitions[key] = value;
  193. cmCPack_Log(&log, cmCPackLog::LOG_DEBUG,
  194. "Set CPack variable: " << key << " to \""
  195. << value << "\"\n");
  196. return true;
  197. } },
  198. };
  199. cmake cminst(cmake::RoleScript, cmState::CPack);
  200. cminst.SetProgressCallback(cpackProgressCallback);
  201. cminst.GetCurrentSnapshot().SetDefaultDefinitions();
  202. cmGlobalGenerator cmgg(&cminst);
  203. cmMakefile globalMF(&cmgg, cminst.GetCurrentSnapshot());
  204. bool parsed = true;
  205. for (std::size_t i = 0; i < inputArgs.size(); i++) {
  206. auto const& arg = inputArgs[i];
  207. for (auto const& m : arguments) {
  208. if (m.matches(arg)) {
  209. if (!m.parse(arg, i, inputArgs, &cminst, &globalMF)) {
  210. parsed = false;
  211. }
  212. break;
  213. }
  214. }
  215. }
  216. cmCPackGeneratorFactory generators;
  217. generators.SetLogger(&log);
  218. // Set up presets
  219. if (!preset.empty() || listPresets) {
  220. auto const workingDirectory = cmSystemTools::GetLogicalWorkingDirectory();
  221. auto const presetGeneratorsPresent =
  222. [&generators](cmCMakePresetsGraph::PackagePreset const& p) {
  223. return std::all_of(p.Generators.begin(), p.Generators.end(),
  224. [&generators](std::string const& gen) {
  225. return generators.GetGeneratorsList().count(
  226. gen) != 0;
  227. });
  228. };
  229. cmCMakePresetsGraph presetsGraph;
  230. auto result = presetsGraph.ReadProjectPresets(workingDirectory);
  231. if (result != true) {
  232. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  233. "Could not read presets from "
  234. << workingDirectory << ":"
  235. << presetsGraph.parseState.GetErrorMessage() << '\n');
  236. return 1;
  237. }
  238. if (listPresets) {
  239. presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
  240. return 0;
  241. }
  242. auto presetPair = presetsGraph.PackagePresets.find(preset);
  243. if (presetPair == presetsGraph.PackagePresets.end()) {
  244. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  245. "No such package preset in " << workingDirectory << ": \""
  246. << preset << "\"\n");
  247. presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
  248. return 1;
  249. }
  250. if (presetPair->second.Unexpanded.Hidden) {
  251. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  252. "Cannot use hidden package preset in "
  253. << workingDirectory << ": \"" << preset << "\"\n");
  254. presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
  255. return 1;
  256. }
  257. auto const& expandedPreset = presetPair->second.Expanded;
  258. if (!expandedPreset) {
  259. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  260. "Could not evaluate package preset \""
  261. << preset << "\": Invalid macro expansion\n");
  262. presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
  263. return 1;
  264. }
  265. if (!expandedPreset->ConditionResult) {
  266. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  267. "Cannot use disabled package preset in "
  268. << workingDirectory << ": \"" << preset << "\"\n");
  269. presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
  270. return 1;
  271. }
  272. if (!presetGeneratorsPresent(presetPair->second.Unexpanded)) {
  273. cmCPack_Log(&log, cmCPackLog::LOG_ERROR, "Cannot use preset");
  274. presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
  275. return 1;
  276. }
  277. auto configurePresetPair =
  278. presetsGraph.ConfigurePresets.find(expandedPreset->ConfigurePreset);
  279. if (configurePresetPair == presetsGraph.ConfigurePresets.end()) {
  280. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  281. "No such configure preset in "
  282. << workingDirectory << ": \""
  283. << expandedPreset->ConfigurePreset << "\"\n");
  284. presetsGraph.PrintConfigurePresetList();
  285. return 1;
  286. }
  287. if (configurePresetPair->second.Unexpanded.Hidden) {
  288. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  289. "Cannot use hidden configure preset in "
  290. << workingDirectory << ": \""
  291. << expandedPreset->ConfigurePreset << "\"\n");
  292. presetsGraph.PrintConfigurePresetList();
  293. return 1;
  294. }
  295. auto const& expandedConfigurePreset = configurePresetPair->second.Expanded;
  296. if (!expandedConfigurePreset) {
  297. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  298. "Could not evaluate configure preset \""
  299. << expandedPreset->ConfigurePreset
  300. << "\": Invalid macro expansion\n");
  301. return 1;
  302. }
  303. cmSystemTools::SetLogicalWorkingDirectory(
  304. expandedConfigurePreset->BinaryDir);
  305. auto presetEnvironment = expandedPreset->Environment;
  306. for (auto const& var : presetEnvironment) {
  307. if (var.second) {
  308. cmSystemTools::PutEnv(cmStrCat(var.first, '=', *var.second));
  309. }
  310. }
  311. if (!expandedPreset->ConfigFile.empty() && cpackConfigFile.empty()) {
  312. cpackConfigFile = expandedPreset->ConfigFile;
  313. }
  314. if (!expandedPreset->Generators.empty() && generator.empty()) {
  315. generator = cmList::to_string(expandedPreset->Generators);
  316. }
  317. if (!expandedPreset->Configurations.empty() && cpackBuildConfig.empty()) {
  318. cpackBuildConfig = cmList::to_string(expandedPreset->Configurations);
  319. }
  320. definitions.insert(expandedPreset->Variables.begin(),
  321. expandedPreset->Variables.end());
  322. if (expandedPreset->DebugOutput == true) {
  323. debugLambda("", &cminst, &globalMF);
  324. }
  325. if (expandedPreset->VerboseOutput == true) {
  326. verboseLambda("", &cminst, &globalMF);
  327. }
  328. if (!expandedPreset->PackageName.empty() && cpackProjectName.empty()) {
  329. cpackProjectName = expandedPreset->PackageName;
  330. }
  331. if (!expandedPreset->PackageVersion.empty() &&
  332. cpackProjectVersion.empty()) {
  333. cpackProjectVersion = expandedPreset->PackageVersion;
  334. }
  335. if (!expandedPreset->PackageDirectory.empty() &&
  336. cpackProjectDirectory.empty()) {
  337. cpackProjectDirectory = expandedPreset->PackageDirectory;
  338. }
  339. if (!expandedPreset->VendorName.empty() && cpackProjectVendor.empty()) {
  340. cpackProjectVendor = expandedPreset->VendorName;
  341. }
  342. }
  343. cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
  344. "Read CPack config file: " << cpackConfigFile << '\n');
  345. bool cpackConfigFileSpecified = true;
  346. if (!cpackConfigFile.empty()) {
  347. cpackConfigFile = cmSystemTools::ToNormalizedPathOnDisk(cpackConfigFile);
  348. } else {
  349. cpackConfigFile = cmStrCat(cmSystemTools::GetLogicalWorkingDirectory(),
  350. "/CPackConfig.cmake");
  351. cpackConfigFileSpecified = false;
  352. }
  353. cmDocumentation doc;
  354. doc.addCPackStandardDocSections();
  355. /* Were we invoked to display doc or to do some work ?
  356. * Unlike cmake launching cpack with zero argument
  357. * should launch cpack using "cpackConfigFile" if it exists
  358. * in the current directory.
  359. */
  360. help = doc.CheckOptions(argc, argv, "-G") && argc != 1;
  361. // This part is used for cpack documentation lookup as well.
  362. cminst.AddCMakePaths();
  363. if (parsed && !help) {
  364. // find out which system cpack is running on, so it can setup the search
  365. // paths, so FIND_XXX() commands can be used in scripts
  366. std::string systemFile =
  367. globalMF.GetModulesFile("CMakeDetermineSystem.cmake");
  368. if (!globalMF.ReadListFile(systemFile)) {
  369. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  370. "Error reading CMakeDetermineSystem.cmake\n");
  371. return 1;
  372. }
  373. systemFile =
  374. globalMF.GetModulesFile("CMakeSystemSpecificInformation.cmake");
  375. if (!globalMF.ReadListFile(systemFile)) {
  376. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  377. "Error reading CMakeSystemSpecificInformation.cmake\n");
  378. return 1;
  379. }
  380. if (!cpackBuildConfig.empty()) {
  381. globalMF.AddDefinition("CPACK_BUILD_CONFIG", cpackBuildConfig);
  382. }
  383. if (cmSystemTools::FileExists(cpackConfigFile)) {
  384. cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
  385. "Read CPack configuration file: " << cpackConfigFile
  386. << '\n');
  387. if (!globalMF.ReadListFile(cpackConfigFile)) {
  388. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  389. "Problem reading CPack config file: \"" << cpackConfigFile
  390. << "\"\n");
  391. return 1;
  392. }
  393. } else if (cpackConfigFileSpecified) {
  394. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  395. "Cannot find CPack config file: \"" << cpackConfigFile
  396. << "\"\n");
  397. return 1;
  398. }
  399. if (!generator.empty()) {
  400. globalMF.AddDefinition("CPACK_GENERATOR", generator);
  401. }
  402. if (!cpackProjectName.empty()) {
  403. globalMF.AddDefinition("CPACK_PACKAGE_NAME", cpackProjectName);
  404. }
  405. if (!cpackProjectVersion.empty()) {
  406. globalMF.AddDefinition("CPACK_PACKAGE_VERSION", cpackProjectVersion);
  407. }
  408. if (!cpackProjectVendor.empty()) {
  409. globalMF.AddDefinition("CPACK_PACKAGE_VENDOR", cpackProjectVendor);
  410. }
  411. if (!cpackProjectDirectory.empty()) {
  412. // The value has been set on the command line. Ensure it is absolute.
  413. cpackProjectDirectory =
  414. cmSystemTools::ToNormalizedPathOnDisk(cpackProjectDirectory);
  415. } else {
  416. // The value has not been set on the command line. Check config file.
  417. if (cmValue pd = globalMF.GetDefinition("CPACK_PACKAGE_DIRECTORY")) {
  418. // The value has been set in the config file. Ensure it is absolute.
  419. cpackProjectDirectory = cmSystemTools::CollapseFullPath(*pd);
  420. } else {
  421. // Default to the current working directory.
  422. cpackProjectDirectory = cmSystemTools::GetLogicalWorkingDirectory();
  423. }
  424. }
  425. globalMF.AddDefinition("CPACK_PACKAGE_DIRECTORY", cpackProjectDirectory);
  426. for (auto const& cd : definitions) {
  427. globalMF.AddDefinition(cd.first, cd.second);
  428. }
  429. cmValue cpackModulesPath = globalMF.GetDefinition("CPACK_MODULE_PATH");
  430. if (cpackModulesPath) {
  431. globalMF.AddDefinition("CMAKE_MODULE_PATH", *cpackModulesPath);
  432. }
  433. cmValue genList = globalMF.GetDefinition("CPACK_GENERATOR");
  434. if (!genList) {
  435. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  436. "CPack generator not specified\n");
  437. } else {
  438. cmList generatorsList{ *genList };
  439. for (std::string const& gen : generatorsList) {
  440. cmMakefile::ScopePushPop raii(&globalMF);
  441. cmMakefile* mf = &globalMF;
  442. cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
  443. "Specified generator: " << gen << '\n');
  444. if (!mf->GetDefinition("CPACK_PACKAGE_NAME")) {
  445. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  446. "CPack project name not specified" << '\n');
  447. parsed = false;
  448. }
  449. if (parsed &&
  450. !(mf->GetDefinition("CPACK_PACKAGE_VERSION") ||
  451. (mf->GetDefinition("CPACK_PACKAGE_VERSION_MAJOR") &&
  452. mf->GetDefinition("CPACK_PACKAGE_VERSION_MINOR") &&
  453. mf->GetDefinition("CPACK_PACKAGE_VERSION_PATCH")))) {
  454. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  455. "CPack project version not specified\n"
  456. "Specify CPACK_PACKAGE_VERSION, or "
  457. "CPACK_PACKAGE_VERSION_MAJOR, "
  458. "CPACK_PACKAGE_VERSION_MINOR, and "
  459. "CPACK_PACKAGE_VERSION_PATCH.\n");
  460. parsed = false;
  461. }
  462. if (parsed) {
  463. std::unique_ptr<cmCPackGenerator> cpackGenerator =
  464. generators.NewGenerator(gen);
  465. if (cpackGenerator) {
  466. cpackGenerator->SetTrace(cminst.GetTrace());
  467. cpackGenerator->SetTraceExpand(cminst.GetTraceExpand());
  468. } else {
  469. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  470. "Could not create CPack generator: " << gen << '\n');
  471. // Print out all the valid generators
  472. cmDocumentation generatorDocs;
  473. generatorDocs.SetSection("Generators",
  474. makeGeneratorDocs(generators));
  475. std::cerr << '\n';
  476. generatorDocs.PrintDocumentation(cmDocumentation::ListGenerators,
  477. std::cerr);
  478. parsed = false;
  479. }
  480. if (parsed && !cpackGenerator->Initialize(gen, mf)) {
  481. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  482. "Cannot initialize the generator " << gen << '\n');
  483. parsed = false;
  484. }
  485. if (!mf->GetDefinition("CPACK_INSTALL_COMMANDS") &&
  486. !mf->GetDefinition("CPACK_INSTALL_SCRIPT") &&
  487. !mf->GetDefinition("CPACK_INSTALLED_DIRECTORIES") &&
  488. !mf->GetDefinition("CPACK_INSTALL_CMAKE_PROJECTS")) {
  489. cmCPack_Log(
  490. &log, cmCPackLog::LOG_ERROR,
  491. "Please specify build tree of the project that uses CMake "
  492. "using CPACK_INSTALL_CMAKE_PROJECTS, specify "
  493. "CPACK_INSTALL_COMMANDS, CPACK_INSTALL_SCRIPT, or "
  494. "CPACK_INSTALLED_DIRECTORIES.\n");
  495. parsed = false;
  496. }
  497. if (parsed) {
  498. cmValue projName = mf->GetDefinition("CPACK_PACKAGE_NAME");
  499. cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
  500. "Use generator: " << cpackGenerator->GetNameOfClass()
  501. << '\n');
  502. cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
  503. "For project: " << *projName << '\n');
  504. cmValue projVersion = mf->GetDefinition("CPACK_PACKAGE_VERSION");
  505. if (!projVersion) {
  506. cmValue projVersionMajor =
  507. mf->GetDefinition("CPACK_PACKAGE_VERSION_MAJOR");
  508. cmValue projVersionMinor =
  509. mf->GetDefinition("CPACK_PACKAGE_VERSION_MINOR");
  510. cmValue projVersionPatch =
  511. mf->GetDefinition("CPACK_PACKAGE_VERSION_PATCH");
  512. std::ostringstream ostr;
  513. ostr << *projVersionMajor << '.' << *projVersionMinor << '.'
  514. << *projVersionPatch;
  515. mf->AddDefinition("CPACK_PACKAGE_VERSION", ostr.str());
  516. }
  517. int res = cpackGenerator->DoPackage();
  518. if (!res) {
  519. cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
  520. "Error when generating package: " << *projName
  521. << '\n');
  522. return 1;
  523. }
  524. }
  525. }
  526. }
  527. }
  528. }
  529. /* In this case we are building the documentation object
  530. * instance in order to create appropriate structure
  531. * in order to satisfy the appropriate --help-xxx request
  532. */
  533. if (help) {
  534. // Construct and print requested documentation.
  535. doc.SetName("cpack");
  536. doc.SetSection("Name", cmDocumentationName);
  537. doc.SetSection("Usage", cmDocumentationUsage);
  538. doc.PrependSection("Options", cmDocumentationOptions);
  539. doc.SetSection("Generators", makeGeneratorDocs(generators));
  540. return !doc.PrintRequestedDocumentation(std::cout);
  541. }
  542. return int(cmSystemTools::GetErrorOccurredFlag());
  543. }