1
0
mirror of https://github.com/Kitware/CMake.git synced 2025-10-14 02:08:27 +08:00
Files
CMake/Source/cmExportInstallPackageInfoGenerator.h
Matthew Woehlke 0ccbe5a2e1 CPS: Refactor argument parsing
CPS package metadata involves a fair amount of passing around a
particular set of values, as well as shared argument handling, which is
only going to increase as additional features are added. In order to
reduce code duplication (now and going forward), create a helper class
to handle the shared argument parsing and to serve as a container to
pass metadata values.
2025-06-02 10:31:35 -04:00

64 lines
2.3 KiB
C++

/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file LICENSE.rst or https://cmake.org/licensing for details. */
#pragma once
#include "cmConfigure.h" // IWYU pragma: keep
#include <iosfwd>
#include <string>
#include "cmExportInstallFileGenerator.h"
#include "cmExportPackageInfoGenerator.h"
class cmGeneratorTarget;
class cmInstallExportGenerator;
class cmPackageInfoArguments;
/** \class cmExportInstallPackageInfoGenerator
* \brief Generate files exporting targets from an install tree.
*
* cmExportInstallPackageInfoGenerator generates files exporting targets from
* an installation tree. The files are placed in a temporary location for
* installation by cmInstallExportGenerator. The file format is the Common
* Package Specification (https://cps-org.github.io/cps/).
*
* One main file is generated that describes the imported targets. Additional,
* per-configuration files describe target locations and settings for each
* configuration.
*
* This is used to implement the INSTALL(PACKAGE_INFO) command.
*/
class cmExportInstallPackageInfoGenerator
: public cmExportPackageInfoGenerator
, public cmExportInstallFileGenerator
{
public:
/** Construct with the export installer that will install the
files. */
cmExportInstallPackageInfoGenerator(cmInstallExportGenerator* iegen,
cmPackageInfoArguments arguments);
/** Compute the globbing expression used to load per-config import
files from the main file. */
std::string GetConfigImportFileGlob() const override;
protected:
std::string const& GetExportName() const override;
// Implement virtual methods from the superclass.
bool GenerateMainFile(std::ostream& os) override;
void GenerateImportTargetsConfig(std::ostream& os, std::string const& config,
std::string const& suffix) override;
char GetConfigFileNameSeparator() const override { return '@'; }
/** Generate the cps_path, which determines the import prefix. */
std::string GenerateImportPrefix() const;
std::string InstallNameDir(cmGeneratorTarget const* target,
std::string const& config) override;
std::string GetCxxModulesDirectory() const override;
// TODO: Generate C++ module info in a not-CMake-specific format.
};