mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-14 02:08:27 +08:00

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.
64 lines
2.3 KiB
C++
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.
|
|
};
|