add_compile_options — CMake 4.0.1 Documentation (original) (raw)

Add options to the compilation of source files.

add_compile_options(

Adds options to the COMPILE_OPTIONS directory property. These options are used when compiling targets from the current directory and below.

Note

These options are not used when linking. See the add_link_options() command for that.

Arguments

Arguments to add_compile_options may use generator expressions with the syntax $<...>. See the cmake-generator-expressions(7)manual for available expressions. See the cmake-buildsystem(7) manual for more on defining buildsystem properties.

Option De-duplication

The final set of options used for a target is constructed by accumulating options from the current target and the usage requirements of its dependencies. The set of options is de-duplicated to avoid repetition.

Added in version 3.12: While beneficial for individual options, the de-duplication step can break up option groups. For example, -option A -option B becomes-option A B. One may specify a group of options using shell-like quoting along with a SHELL: prefix. The SHELL: prefix is dropped, and the rest of the option string is parsed using theseparate_arguments() UNIX_COMMAND mode. For example,"SHELL:-option A" "SHELL:-option B" becomes -option A -option B.

Example

Since different compilers support different options, a typical use of this command is in a compiler-specific conditional clause:

if (MSVC) # warning level 4 add_compile_options(/W4) else() # additional warnings add_compile_options(-Wall -Wextra -Wpedantic) endif()

To set per-language options, use the $<COMPILE_LANGUAGE>or $<COMPILE_LANGUAGE:languages> generator expressions.

See Also