| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622 | 
							- /* Distributed under the OSI-approved BSD 3-Clause License.  See accompanying
 
-    file LICENSE.rst or https://cmake.org/licensing for details.  */
 
- #include <algorithm>
 
- #include <cstddef>
 
- #include <functional>
 
- #include <iostream>
 
- #include <iterator>
 
- #include <map>
 
- #include <memory>
 
- #include <sstream>
 
- #include <string>
 
- #include <type_traits>
 
- #include <utility>
 
- #include <vector>
 
- #include <cm/optional>
 
- #include <cmext/algorithm>
 
- #include "cmsys/Encoding.hxx"
 
- #include "cmCMakePresetsGraph.h"
 
- #include "cmCPackGenerator.h"
 
- #include "cmCPackGeneratorFactory.h"
 
- #include "cmCPackLog.h"
 
- #include "cmCommandLineArgument.h"
 
- #include "cmConsoleBuf.h"
 
- #include "cmDocumentation.h"
 
- #include "cmDocumentationEntry.h"
 
- #include "cmGlobalGenerator.h"
 
- #include "cmJSONState.h"
 
- #include "cmList.h"
 
- #include "cmMakefile.h"
 
- #include "cmState.h"
 
- #include "cmStateSnapshot.h"
 
- #include "cmStdIoInit.h"
 
- #include "cmStringAlgorithms.h"
 
- #include "cmSystemTools.h"
 
- #include "cmValue.h"
 
- #include "cmake.h"
 
- namespace {
 
- cmDocumentationEntry const cmDocumentationName = {
 
-   {},
 
-   "  cpack - Packaging driver provided by CMake."
 
- };
 
- cmDocumentationEntry const cmDocumentationUsage = { {}, "  cpack [options]" };
 
- cmDocumentationEntry const cmDocumentationOptions[14] = {
 
-   { "-G <generators>", "Override/define CPACK_GENERATOR" },
 
-   { "-C <Configurations>", "Specify the project configuration(s)" },
 
-   { "-D <var>=<value>", "Set a CPack variable." },
 
-   { "--config <configFile>", "Specify the config file." },
 
-   { "-V,--verbose", "Enable verbose output" },
 
-   { "--trace", "Put underlying cmake scripts in trace mode." },
 
-   { "--trace-expand", "Put underlying cmake scripts in expanded trace mode." },
 
-   { "--debug", "Enable debug output (for CPack developers)" },
 
-   { "-P <packageName>", "Override/define CPACK_PACKAGE_NAME" },
 
-   { "-R <packageVersion>", "Override/define CPACK_PACKAGE_VERSION" },
 
-   { "-B <packageDirectory>", "Override/define CPACK_PACKAGE_DIRECTORY" },
 
-   { "--vendor <vendorName>", "Override/define CPACK_PACKAGE_VENDOR" },
 
-   { "--preset", "Read arguments from a package preset" },
 
-   { "--list-presets", "List available package presets" }
 
- };
 
- void cpackProgressCallback(std::string const& message, float /*unused*/)
 
- {
 
-   std::cout << "-- " << message << '\n';
 
- }
 
- std::vector<cmDocumentationEntry> makeGeneratorDocs(
 
-   cmCPackGeneratorFactory const& gf)
 
- {
 
-   auto const& generators = gf.GetGeneratorsList();
 
-   std::vector<cmDocumentationEntry> docs;
 
-   docs.reserve(generators.size());
 
-   std::transform(
 
-     generators.cbegin(), generators.cend(), std::back_inserter(docs),
 
-     [](std::decay<decltype(generators)>::type::value_type const& gen) {
 
-       return cmDocumentationEntry{ gen.first, gen.second };
 
-     });
 
-   return docs;
 
- }
 
- } // namespace
 
- // this is CPack.
 
- int main(int argc, char const* const* argv)
 
- {
 
-   cm::StdIo::Init();
 
-   // Replace streambuf so we can output Unicode to console
 
-   cmConsoleBuf consoleBuf;
 
-   consoleBuf.SetUTF8Pipes();
 
-   cmsys::Encoding::CommandLineArguments args =
 
-     cmsys::Encoding::CommandLineArguments::Main(argc, argv);
 
-   argc = args.argc();
 
-   argv = args.argv();
 
-   std::vector<std::string> inputArgs;
 
-   inputArgs.reserve(argc - 1);
 
-   cm::append(inputArgs, argv + 1, argv + argc);
 
-   cmSystemTools::InitializeLibUV();
 
-   cmSystemTools::FindCMakeResources(argv[0]);
 
-   cmCPackLog log;
 
-   log.SetErrorPrefix("CPack Error: ");
 
-   log.SetWarningPrefix("CPack Warning: ");
 
-   log.SetOutputPrefix("CPack: ");
 
-   log.SetVerbosePrefix("CPack Verbose: ");
 
-   if (cmSystemTools::GetLogicalWorkingDirectory().empty()) {
 
-     cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                 "Current working directory cannot be established.\n");
 
-     return 1;
 
-   }
 
-   std::string generator;
 
-   bool help = false;
 
-   bool helpVersion = false;
 
-   std::string helpFull;
 
-   std::string helpMAN;
 
-   std::string helpHTML;
 
-   std::string cpackProjectName;
 
-   std::string cpackProjectDirectory;
 
-   std::string cpackBuildConfig;
 
-   std::string cpackProjectVersion;
 
-   std::string cpackProjectPatch;
 
-   std::string cpackProjectVendor;
 
-   std::string cpackConfigFile;
 
-   std::string preset;
 
-   bool listPresets = false;
 
-   std::map<std::string, std::string> definitions;
 
-   auto const verboseLambda = [&log](std::string const&, cmake*,
 
-                                     cmMakefile*) -> bool {
 
-     log.SetVerbose(true);
 
-     cmCPack_Log(&log, cmCPackLog::LOG_OUTPUT, "Enable Verbose\n");
 
-     return true;
 
-   };
 
-   auto const debugLambda = [&log](std::string const&, cmake*,
 
-                                   cmMakefile*) -> bool {
 
-     log.SetDebug(true);
 
-     cmCPack_Log(&log, cmCPackLog::LOG_OUTPUT, "Enable Debug\n");
 
-     return true;
 
-   };
 
-   auto const traceLambda = [](std::string const&, cmake* state,
 
-                               cmMakefile*) -> bool {
 
-     state->SetTrace(true);
 
-     return true;
 
-   };
 
-   auto const traceExpandLambda = [](std::string const&, cmake* state,
 
-                                     cmMakefile*) -> bool {
 
-     state->SetTrace(true);
 
-     state->SetTraceExpand(true);
 
-     return true;
 
-   };
 
-   using CommandArgument =
 
-     cmCommandLineArgument<bool(std::string const&, cmake*, cmMakefile*)>;
 
-   std::vector<CommandArgument> arguments = {
 
-     CommandArgument{ "--help", CommandArgument::Values::Zero,
 
-                      CommandArgument::setToTrue(help) },
 
-     CommandArgument{ "--help-full", CommandArgument::Values::Zero,
 
-                      CommandArgument::setToValue(helpFull) },
 
-     CommandArgument{ "--help-html", CommandArgument::Values::Zero,
 
-                      CommandArgument::setToValue(helpHTML) },
 
-     CommandArgument{ "--help-man", CommandArgument::Values::Zero,
 
-                      CommandArgument::setToValue(helpMAN) },
 
-     CommandArgument{ "--version", CommandArgument::Values::Zero,
 
-                      CommandArgument::setToTrue(helpVersion) },
 
-     CommandArgument{ "-V", CommandArgument::Values::Zero, verboseLambda },
 
-     CommandArgument{ "--verbose", CommandArgument::Values::Zero,
 
-                      verboseLambda },
 
-     CommandArgument{ "--debug", CommandArgument::Values::Zero, debugLambda },
 
-     CommandArgument{ "--config", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackConfigFile) },
 
-     CommandArgument{ "--trace", CommandArgument::Values::Zero, traceLambda },
 
-     CommandArgument{ "--trace-expand", CommandArgument::Values::Zero,
 
-                      traceExpandLambda },
 
-     CommandArgument{ "-C", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackBuildConfig) },
 
-     CommandArgument{ "-G", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(generator) },
 
-     CommandArgument{ "-P", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackProjectName) },
 
-     CommandArgument{ "-R", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackProjectVersion) },
 
-     CommandArgument{ "-B", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackProjectDirectory) },
 
-     CommandArgument{ "--patch", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackProjectPatch) },
 
-     CommandArgument{ "--vendor", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(cpackProjectVendor) },
 
-     CommandArgument{ "--preset", CommandArgument::Values::One,
 
-                      CommandArgument::setToValue(preset) },
 
-     CommandArgument{ "--list-presets", CommandArgument::Values::Zero,
 
-                      CommandArgument::setToTrue(listPresets) },
 
-     CommandArgument{ "-D", CommandArgument::Values::One,
 
-                      CommandArgument::RequiresSeparator::No,
 
-                      [&log, &definitions](std::string const& arg, cmake*,
 
-                                           cmMakefile*) -> bool {
 
-                        std::string value = arg;
 
-                        size_t pos = value.find_first_of('=');
 
-                        if (pos == std::string::npos) {
 
-                          cmCPack_Log(
 
-                            &log, cmCPackLog::LOG_ERROR,
 
-                            "Please specify CPack definitions as: KEY=VALUE\n");
 
-                          return false;
 
-                        }
 
-                        std::string key = value.substr(0, pos);
 
-                        value.erase(0, pos + 1);
 
-                        definitions[key] = value;
 
-                        cmCPack_Log(&log, cmCPackLog::LOG_DEBUG,
 
-                                    "Set CPack variable: " << key << " to \""
 
-                                                           << value << "\"\n");
 
-                        return true;
 
-                      } },
 
-   };
 
-   cmake cminst(cmake::RoleScript, cmState::CPack);
 
-   cminst.SetHomeDirectory("");
 
-   cminst.SetHomeOutputDirectory("");
 
-   cminst.SetProgressCallback(cpackProgressCallback);
 
-   cminst.GetCurrentSnapshot().SetDefaultDefinitions();
 
-   cmGlobalGenerator cmgg(&cminst);
 
-   cmMakefile globalMF(&cmgg, cminst.GetCurrentSnapshot());
 
-   bool parsed = true;
 
-   for (std::size_t i = 0; i < inputArgs.size(); i++) {
 
-     auto const& arg = inputArgs[i];
 
-     for (auto const& m : arguments) {
 
-       if (m.matches(arg)) {
 
-         if (!m.parse(arg, i, inputArgs, &cminst, &globalMF)) {
 
-           parsed = false;
 
-         }
 
-         break;
 
-       }
 
-     }
 
-   }
 
-   cmCPackGeneratorFactory generators;
 
-   generators.SetLogger(&log);
 
-   // Set up presets
 
-   if (!preset.empty() || listPresets) {
 
-     auto const workingDirectory = cmSystemTools::GetLogicalWorkingDirectory();
 
-     auto const presetGeneratorsPresent =
 
-       [&generators](cmCMakePresetsGraph::PackagePreset const& p) {
 
-         return std::all_of(p.Generators.begin(), p.Generators.end(),
 
-                            [&generators](std::string const& gen) {
 
-                              return generators.GetGeneratorsList().count(
 
-                                       gen) != 0;
 
-                            });
 
-       };
 
-     cmCMakePresetsGraph presetsGraph;
 
-     auto result = presetsGraph.ReadProjectPresets(workingDirectory);
 
-     if (result != true) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Could not read presets from "
 
-                     << workingDirectory << ":"
 
-                     << presetsGraph.parseState.GetErrorMessage() << '\n');
 
-       return 1;
 
-     }
 
-     if (listPresets) {
 
-       presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
 
-       return 0;
 
-     }
 
-     auto presetPair = presetsGraph.PackagePresets.find(preset);
 
-     if (presetPair == presetsGraph.PackagePresets.end()) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "No such package preset in " << workingDirectory << ": \""
 
-                                                << preset << "\"\n");
 
-       presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
 
-       return 1;
 
-     }
 
-     if (presetPair->second.Unexpanded.Hidden) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Cannot use hidden package preset in "
 
-                     << workingDirectory << ": \"" << preset << "\"\n");
 
-       presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
 
-       return 1;
 
-     }
 
-     auto const& expandedPreset = presetPair->second.Expanded;
 
-     if (!expandedPreset) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Could not evaluate package preset \""
 
-                     << preset << "\": Invalid macro expansion\n");
 
-       presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
 
-       return 1;
 
-     }
 
-     if (!expandedPreset->ConditionResult) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Cannot use disabled package preset in "
 
-                     << workingDirectory << ": \"" << preset << "\"\n");
 
-       presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
 
-       return 1;
 
-     }
 
-     if (!presetGeneratorsPresent(presetPair->second.Unexpanded)) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR, "Cannot use preset");
 
-       presetsGraph.PrintPackagePresetList(presetGeneratorsPresent);
 
-       return 1;
 
-     }
 
-     auto configurePresetPair =
 
-       presetsGraph.ConfigurePresets.find(expandedPreset->ConfigurePreset);
 
-     if (configurePresetPair == presetsGraph.ConfigurePresets.end()) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "No such configure preset in "
 
-                     << workingDirectory << ": \""
 
-                     << expandedPreset->ConfigurePreset << "\"\n");
 
-       presetsGraph.PrintConfigurePresetList();
 
-       return 1;
 
-     }
 
-     if (configurePresetPair->second.Unexpanded.Hidden) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Cannot use hidden configure preset in "
 
-                     << workingDirectory << ": \""
 
-                     << expandedPreset->ConfigurePreset << "\"\n");
 
-       presetsGraph.PrintConfigurePresetList();
 
-       return 1;
 
-     }
 
-     auto const& expandedConfigurePreset = configurePresetPair->second.Expanded;
 
-     if (!expandedConfigurePreset) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Could not evaluate configure preset \""
 
-                     << expandedPreset->ConfigurePreset
 
-                     << "\": Invalid macro expansion\n");
 
-       return 1;
 
-     }
 
-     cmSystemTools::SetLogicalWorkingDirectory(
 
-       expandedConfigurePreset->BinaryDir);
 
-     auto presetEnvironment = expandedPreset->Environment;
 
-     for (auto const& var : presetEnvironment) {
 
-       if (var.second) {
 
-         cmSystemTools::PutEnv(cmStrCat(var.first, '=', *var.second));
 
-       }
 
-     }
 
-     if (!expandedPreset->ConfigFile.empty() && cpackConfigFile.empty()) {
 
-       cpackConfigFile = expandedPreset->ConfigFile;
 
-     }
 
-     if (!expandedPreset->Generators.empty() && generator.empty()) {
 
-       generator = cmList::to_string(expandedPreset->Generators);
 
-     }
 
-     if (!expandedPreset->Configurations.empty() && cpackBuildConfig.empty()) {
 
-       cpackBuildConfig = cmList::to_string(expandedPreset->Configurations);
 
-     }
 
-     definitions.insert(expandedPreset->Variables.begin(),
 
-                        expandedPreset->Variables.end());
 
-     if (expandedPreset->DebugOutput == true) {
 
-       debugLambda("", &cminst, &globalMF);
 
-     }
 
-     if (expandedPreset->VerboseOutput == true) {
 
-       verboseLambda("", &cminst, &globalMF);
 
-     }
 
-     if (!expandedPreset->PackageName.empty() && cpackProjectName.empty()) {
 
-       cpackProjectName = expandedPreset->PackageName;
 
-     }
 
-     if (!expandedPreset->PackageVersion.empty() &&
 
-         cpackProjectVersion.empty()) {
 
-       cpackProjectVersion = expandedPreset->PackageVersion;
 
-     }
 
-     if (!expandedPreset->PackageDirectory.empty() &&
 
-         cpackProjectDirectory.empty()) {
 
-       cpackProjectDirectory = expandedPreset->PackageDirectory;
 
-     }
 
-     if (!expandedPreset->VendorName.empty() && cpackProjectVendor.empty()) {
 
-       cpackProjectVendor = expandedPreset->VendorName;
 
-     }
 
-   }
 
-   cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
 
-               "Read CPack config file: " << cpackConfigFile << '\n');
 
-   bool cpackConfigFileSpecified = true;
 
-   if (!cpackConfigFile.empty()) {
 
-     cpackConfigFile = cmSystemTools::ToNormalizedPathOnDisk(cpackConfigFile);
 
-   } else {
 
-     cpackConfigFile = cmStrCat(cmSystemTools::GetLogicalWorkingDirectory(),
 
-                                "/CPackConfig.cmake");
 
-     cpackConfigFileSpecified = false;
 
-   }
 
-   cmDocumentation doc;
 
-   doc.addCPackStandardDocSections();
 
-   /* Were we invoked to display doc or to do some work ?
 
-    * Unlike cmake launching cpack with zero argument
 
-    * should launch cpack using "cpackConfigFile" if it exists
 
-    * in the current directory.
 
-    */
 
-   help = doc.CheckOptions(argc, argv, "-G") && argc != 1;
 
-   // This part is used for cpack documentation lookup as well.
 
-   cminst.AddCMakePaths();
 
-   if (parsed && !help) {
 
-     // find out which system cpack is running on, so it can setup the search
 
-     // paths, so FIND_XXX() commands can be used in scripts
 
-     std::string systemFile =
 
-       globalMF.GetModulesFile("CMakeDetermineSystem.cmake");
 
-     if (!globalMF.ReadListFile(systemFile)) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Error reading CMakeDetermineSystem.cmake\n");
 
-       return 1;
 
-     }
 
-     systemFile =
 
-       globalMF.GetModulesFile("CMakeSystemSpecificInformation.cmake");
 
-     if (!globalMF.ReadListFile(systemFile)) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Error reading CMakeSystemSpecificInformation.cmake\n");
 
-       return 1;
 
-     }
 
-     if (!cpackBuildConfig.empty()) {
 
-       globalMF.AddDefinition("CPACK_BUILD_CONFIG", cpackBuildConfig);
 
-     }
 
-     if (cmSystemTools::FileExists(cpackConfigFile)) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
 
-                   "Read CPack configuration file: " << cpackConfigFile
 
-                                                     << '\n');
 
-       if (!globalMF.ReadListFile(cpackConfigFile)) {
 
-         cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                     "Problem reading CPack config file: \"" << cpackConfigFile
 
-                                                             << "\"\n");
 
-         return 1;
 
-       }
 
-     } else if (cpackConfigFileSpecified) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "Cannot find CPack config file: \"" << cpackConfigFile
 
-                                                       << "\"\n");
 
-       return 1;
 
-     }
 
-     if (!generator.empty()) {
 
-       globalMF.AddDefinition("CPACK_GENERATOR", generator);
 
-     }
 
-     if (!cpackProjectName.empty()) {
 
-       globalMF.AddDefinition("CPACK_PACKAGE_NAME", cpackProjectName);
 
-     }
 
-     if (!cpackProjectVersion.empty()) {
 
-       globalMF.AddDefinition("CPACK_PACKAGE_VERSION", cpackProjectVersion);
 
-     }
 
-     if (!cpackProjectVendor.empty()) {
 
-       globalMF.AddDefinition("CPACK_PACKAGE_VENDOR", cpackProjectVendor);
 
-     }
 
-     if (!cpackProjectDirectory.empty()) {
 
-       // The value has been set on the command line.  Ensure it is absolute.
 
-       cpackProjectDirectory =
 
-         cmSystemTools::ToNormalizedPathOnDisk(cpackProjectDirectory);
 
-     } else {
 
-       // The value has not been set on the command line.  Check config file.
 
-       if (cmValue pd = globalMF.GetDefinition("CPACK_PACKAGE_DIRECTORY")) {
 
-         // The value has been set in the config file.  Ensure it is absolute.
 
-         cpackProjectDirectory = cmSystemTools::CollapseFullPath(*pd);
 
-       } else {
 
-         // Default to the current working directory.
 
-         cpackProjectDirectory = cmSystemTools::GetLogicalWorkingDirectory();
 
-       }
 
-     }
 
-     globalMF.AddDefinition("CPACK_PACKAGE_DIRECTORY", cpackProjectDirectory);
 
-     for (auto const& cd : definitions) {
 
-       globalMF.AddDefinition(cd.first, cd.second);
 
-     }
 
-     cmValue cpackModulesPath = globalMF.GetDefinition("CPACK_MODULE_PATH");
 
-     if (cpackModulesPath) {
 
-       globalMF.AddDefinition("CMAKE_MODULE_PATH", *cpackModulesPath);
 
-     }
 
-     cmValue genList = globalMF.GetDefinition("CPACK_GENERATOR");
 
-     if (!genList) {
 
-       cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                   "CPack generator not specified\n");
 
-     } else {
 
-       cmList generatorsList{ *genList };
 
-       for (std::string const& gen : generatorsList) {
 
-         cmMakefile::ScopePushPop raii(&globalMF);
 
-         cmMakefile* mf = &globalMF;
 
-         cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
 
-                     "Specified generator: " << gen << '\n');
 
-         if (!mf->GetDefinition("CPACK_PACKAGE_NAME")) {
 
-           cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                       "CPack project name not specified" << '\n');
 
-           parsed = false;
 
-         }
 
-         if (parsed &&
 
-             !(mf->GetDefinition("CPACK_PACKAGE_VERSION") ||
 
-               (mf->GetDefinition("CPACK_PACKAGE_VERSION_MAJOR") &&
 
-                mf->GetDefinition("CPACK_PACKAGE_VERSION_MINOR") &&
 
-                mf->GetDefinition("CPACK_PACKAGE_VERSION_PATCH")))) {
 
-           cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                       "CPack project version not specified\n"
 
-                       "Specify CPACK_PACKAGE_VERSION, or "
 
-                       "CPACK_PACKAGE_VERSION_MAJOR, "
 
-                       "CPACK_PACKAGE_VERSION_MINOR, and "
 
-                       "CPACK_PACKAGE_VERSION_PATCH.\n");
 
-           parsed = false;
 
-         }
 
-         if (parsed) {
 
-           std::unique_ptr<cmCPackGenerator> cpackGenerator =
 
-             generators.NewGenerator(gen);
 
-           if (cpackGenerator) {
 
-             cpackGenerator->SetTrace(cminst.GetTrace());
 
-             cpackGenerator->SetTraceExpand(cminst.GetTraceExpand());
 
-           } else {
 
-             cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                         "Could not create CPack generator: " << gen << '\n');
 
-             // Print out all the valid generators
 
-             cmDocumentation generatorDocs;
 
-             generatorDocs.SetSection("Generators",
 
-                                      makeGeneratorDocs(generators));
 
-             std::cerr << '\n';
 
-             generatorDocs.PrintDocumentation(cmDocumentation::ListGenerators,
 
-                                              std::cerr);
 
-             parsed = false;
 
-           }
 
-           if (parsed && !cpackGenerator->Initialize(gen, mf)) {
 
-             cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                         "Cannot initialize the generator " << gen << '\n');
 
-             parsed = false;
 
-           }
 
-           if (!mf->GetDefinition("CPACK_INSTALL_COMMANDS") &&
 
-               !mf->GetDefinition("CPACK_INSTALL_SCRIPT") &&
 
-               !mf->GetDefinition("CPACK_INSTALLED_DIRECTORIES") &&
 
-               !mf->GetDefinition("CPACK_INSTALL_CMAKE_PROJECTS")) {
 
-             cmCPack_Log(
 
-               &log, cmCPackLog::LOG_ERROR,
 
-               "Please specify build tree of the project that uses CMake "
 
-               "using CPACK_INSTALL_CMAKE_PROJECTS, specify "
 
-               "CPACK_INSTALL_COMMANDS, CPACK_INSTALL_SCRIPT, or "
 
-               "CPACK_INSTALLED_DIRECTORIES.\n");
 
-             parsed = false;
 
-           }
 
-           if (parsed) {
 
-             cmValue projName = mf->GetDefinition("CPACK_PACKAGE_NAME");
 
-             cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
 
-                         "Use generator: " << cpackGenerator->GetNameOfClass()
 
-                                           << '\n');
 
-             cmCPack_Log(&log, cmCPackLog::LOG_VERBOSE,
 
-                         "For project: " << *projName << '\n');
 
-             cmValue projVersion = mf->GetDefinition("CPACK_PACKAGE_VERSION");
 
-             if (!projVersion) {
 
-               cmValue projVersionMajor =
 
-                 mf->GetDefinition("CPACK_PACKAGE_VERSION_MAJOR");
 
-               cmValue projVersionMinor =
 
-                 mf->GetDefinition("CPACK_PACKAGE_VERSION_MINOR");
 
-               cmValue projVersionPatch =
 
-                 mf->GetDefinition("CPACK_PACKAGE_VERSION_PATCH");
 
-               std::ostringstream ostr;
 
-               ostr << *projVersionMajor << '.' << *projVersionMinor << '.'
 
-                    << *projVersionPatch;
 
-               mf->AddDefinition("CPACK_PACKAGE_VERSION", ostr.str());
 
-             }
 
-             int res = cpackGenerator->DoPackage();
 
-             if (!res) {
 
-               cmCPack_Log(&log, cmCPackLog::LOG_ERROR,
 
-                           "Error when generating package: " << *projName
 
-                                                             << '\n');
 
-               return 1;
 
-             }
 
-           }
 
-         }
 
-       }
 
-     }
 
-   }
 
-   /* In this case we are building the documentation object
 
-    * instance in order to create appropriate structure
 
-    * in order to satisfy the appropriate --help-xxx request
 
-    */
 
-   if (help) {
 
-     // Construct and print requested documentation.
 
-     doc.SetName("cpack");
 
-     doc.SetSection("Name", cmDocumentationName);
 
-     doc.SetSection("Usage", cmDocumentationUsage);
 
-     doc.PrependSection("Options", cmDocumentationOptions);
 
-     doc.SetSection("Generators", makeGeneratorDocs(generators));
 
-     return !doc.PrintRequestedDocumentation(std::cout);
 
-   }
 
-   return int(cmSystemTools::GetErrorOccurredFlag());
 
- }
 
 
  |