blob: cd4d93927b27c536e0add7934eabe410707bac31 [file] [log] [blame] [view] [edit]
# C++20 Modules Tools
## Overview
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
The format of DDI content is [p1689](https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2022/p1689r5.html).
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
}
```
## Tools
### `aggregate-ddi`
#### Description
`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.
#### Usage
```sh
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>
```
#### Command Line Arguments
- `-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.
#### Example
```sh
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`
#### Description
`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.
#### Usage
```sh
generate-modmap <ddi-file> <cpp20modules-info-file> <output-file> <compiler>
```
#### Command Line Arguments
- `<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.
#### Example
```sh
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.