data:image/s3,"s3://crabby-images/bb26f/bb26f520e8e696e119b11934757569a829e121f1" alt="Cmake set cxx flags"
data:image/s3,"s3://crabby-images/27369/27369922a0930672ad8c09e1cc7221ff66ce82e6" alt="cmake set cxx flags cmake set cxx flags"
In that use case, the INTERFACE library encapsulates a set of properties that describe the library headers – most importantly the include paths, but also possibly compiler defines and flags/switches, and whatever else is necessary. I had given one of the use cases for INTERFACE libraries there – modularizing header-only libraries. I already discussed OBJECT “libraries” in part 2 of the series, but only mentioned INTERFACE libraries briefly in the previous post.
data:image/s3,"s3://crabby-images/a39f9/a39f94f82aa933702bb56a59fc5f2519ec34bf4e" alt="cmake set cxx flags cmake set cxx flags"
Quite the opposite, the add_library command name may actually be a little misleading, or at least suggesting limited use. However, the remaining “library” types – OBJECT and INTERFACE may not be as obvious.
data:image/s3,"s3://crabby-images/bc323/bc323a57e1652d15f76c4f78bdf4630ac7d05159" alt="cmake set cxx flags cmake set cxx flags"
When dealing with static or shared libraries this makes sense and is totally intuitive – it immediately brings into mind the correlation between the declared target and the resulting binary library file. Interface targetsĬMake uses the command add_library to define all kinds of library-related targets.
#Cmake set cxx flags how to#
In this post I present a concrete use case for INTERFACE targets, discuss how to handle compiler and linker flags and introduce the include command. The INTERFACE keyword was mentioned, but left without a fully fleshed out exmaple. While we were at it I described how properties work and gave examples of using the PRIVATE and PUBLIC transitivity keywords. In part 4 of the series we’ve had a first look at modular design.
data:image/s3,"s3://crabby-images/bb26f/bb26f520e8e696e119b11934757569a829e121f1" alt="Cmake set cxx flags"