This folder contains two tools: aggregate-ddi
and generate-modmap
. These tools are designed to facilitate the processing of C++20 modules information and direct dependent information (DDI). They can aggregate module information, process dependencies, and generate module maps for use in C++20 modular projects.
The format of DDI content is p1689. for example,
{ "revision": 0, "rules": [ { "primary-output": "path/to/a.pcm", "provides": [ { "is-interface": true, "logical-name": "a", "source-path": "path/to/a.cppm" } ], "requires": [ { "logical-name": "b" } ] } ], "version": 1 }
aggregate-ddi
aggregate-ddi
is a tool that aggregates C++20 module information from multiple sources and processes DDI files to generate a consolidated output containing module paths and their dependencies.
aggregate-ddi -m <cpp20modules-info-file1> -m <cpp20modules-info-file2> ... -d <ddi-file1> <path/to/pcm1> -d <ddi-file2> <path/to/pcm2> ... -o <output-file>
-m <cpp20modules-info-file>
: Path to a JSON file containing C++20 module information.-d <ddi-file> <pcm-path>
: Path to a DDI file and its associated PCM path.-o <output-file>
: Path to the output file where the aggregated information will be stored.aggregate-ddi -m module-info1.json -m module-info2.json -d ddi1.json /path/to/pcm1 -d ddi2.json /path/to/pcm2 -o output.json
generate-modmap
generate-modmap
is a tool that generates a module map from a DDI file and C++20 modules information file. It creates two output files: one for the module map and one for the input module paths.
generate-modmap <ddi-file> <cpp20modules-info-file> <output-file> <compiler>
<ddi-file>
: Path to the DDI file containing module dependencies.<cpp20modules-info-file>
: Path to the JSON file containing C++20 modules information.<output-file>
: Path to the output file where the module map will be stored.<compiler>
: Compiler type the modmap to use. Only clang
, gcc
, msvc-cl
supported.generate-modmap ddi.json cpp20modules-info.json modmap clang
This command will generate two files:
modmap
: containing the module map.modmap.input
: containing the module paths.