dzada
dzada

Reputation: 5874

How to use CMAKE_EXPORT_COMPILE_COMMANDS?

I've been trying to use clang-modernize with CMAKE_EXPORT_COMPILE_COMMANDS as recommended in the help of this tool.

With this option cmake generates a JSON file containing compile info like include paths (see also).

This variable is accepted on the command line of cmake, but cmake --help-variable CMAKE_EXPORT_COMPILE_COMMANDS doesn't work (which is coherent with this mailing list posting).

Has someone any idea on how to use it?

I could also use it with cppcheck.

Some more info

I've discovered on a clang developer forum that this cmake feature is not available on all generators. This might change in the future, in the mean time my question remains and I will try too see what happen if I use other generators than Visual Studio.

Upvotes: 89

Views: 138327

Answers (6)

jpr42
jpr42

Reputation: 1858

CMake 3.17

As of CMake 3.17 you can now set CMAKE_EXPORT_COMPILE_COMMANDS as an environment variable.

The default value for CMAKE_EXPORT_COMPILE_COMMANDS when there is no explicit configuration given on the first run while creating a new build tree. On later runs in an existing build tree the value persists in the cache as CMAKE_EXPORT_COMPILE_COMMANDS.

This is the best approach since you don't have to pollute project code or remember to set it individually for each project.

# Set this in your .bashrc or whatever environment you choose to set env variables
export CMAKE_EXPORT_COMPILE_COMMANDS=1

CMake 3.5

The second best approach is to pass CMAKE_EXPORT_COMPILE_COMMANDS as a cache variable when configuring the project.

cmake -S . -B build -D CMAKE_EXPORT_COMPILE_COMMANDS=1

I prefer the new CMake 3.17 approach, since the 3.5 approach is easy to forget.

Upvotes: 2

badcode
badcode

Reputation: 610

The first one you use CMAKE_EXPORT_COMPILE_COMMANDS ON in your CMakelists.txt Or run CMake with following parameters:

cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 ..

1.Option:

Here is a simple source and build tree to make it clear.

.
├── build
├── cars
│   ├── car.cpp
│   ├── car.h
│   └── CMakeLists.txt
├── CMakeLists.txt
└── main.cpp

main.cpp

#include <iostream>

#include "car.h"

int main (int argc, char *argv[])
{
    std::cout << "car - main function" << std::endl;
    showCarName();
    return 0;
}

CMakeLists.txt:

cmake_minimum_required(VERSION 3.20)
project(Cars
    VERSION 0.1
    HOMEPAGE_URL "github/alitokur"
    LANGUAGES CXX
    )

set(CMAKE_EXPORT_COMPILE_COMMANDS ON)

    add_executable(carApp main.cpp)
    add_subdirectory(cars)
    target_link_libraries(carApp PRIVATE cars)

cars/CMakeLists.txt

add_library(cars OBJECT
    car.cpp
    )
target_include_directories(cars PUBLIC .)

And that's all, target link directories allow main.cpp to include the cars.h file without providing a relative path. You should use set(CMAKE_EXPORT_COMPILE_COMMANDS ON) after the project() definition because sometimes other tools override this setting and that's why you can't see compile_commands.json.

enter image description here

Upvotes: 2

J&#246;rn Reimerdes
J&#246;rn Reimerdes

Reputation: 1413

I suggest setting

set(CMAKE_EXPORT_COMPILE_COMMANDS ON)

in the CMakeList.txt

Upvotes: 104

maxschlepzig
maxschlepzig

Reputation: 39205

As of CMake 3.5 the CMAKE_EXPORT_COMPILE_COMMANDS option is supported by the Ninja and Makefiles generators.

That means to generate a JSON compile database one has to select a generator that supports it.

For example on UNIX just:

cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 /path/to/src

(as it uses the makefile generator there, by default)

Otherwise you can explicitly specify a generator like this:

cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 /path/to/src -G Ninja

Or:

cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 /path/to/src -G 'Unix Makefiles'

Or another makefiles variant that your cmake supports - a list of supported generators is included in the output of cmake --help.

Note that the compile database JSON file is generated at cmake execution time - not at compile time. Also, with recent clang versions (e.g. clang >= 3.8), clang-modernize was merged into clang-tidy.

Upvotes: 41

zr.
zr.

Reputation: 7798

I too was not able to get to work on the Visual Studio generator. It did, however, work using the "NMake Makefiles" generator.

C:\work\build>cmake -G "NMake Makefiles"  -DCMAKE_EXPORT_COMPILE_COMMANDS=ON  ..

Upvotes: 5

Related Questions