compile_commands.json¶A compilation database is
a JSON-formatted file named compile_commands.json that
contains structured data about every compilation unit in your project.
You can generate a project compile_commands.json using the
pio run --target command and compiledb target.
A default location for compile_commands.json is a project directory.
The following build variables can be used for customization using Advanced Scripting:
Variable |
Description |
|---|---|
|
A path where the |
|
A boolean flag to control if toolchain paths should be included in the compilation unit.
A default value is |
Example
Generate compile_commands.json with toolchain includes for each project environment
and save database to the “build_dir/envname” folder:
platformio.ini:
[env:myenv]
platform = ...
board = ...
extra_scripts = post:extra_script.py
extra_script.py:
import os
Import("env")
# include toolchain paths
env.Replace(COMPILATIONDB_INCLUDE_TOOLCHAIN=True)
# override compilation DB path
env.Replace(COMPILATIONDB_PATH=os.path.join("$BUILD_DIR", "compile_commands.json"))
Generate compile_commands.json
> pio run -t compiledb