Skip to content

CMake: Set Your C++ Standard With Cmake’s Global Variables

If you’re serious about your coding standards, you’re probably using the latest and greatest C++ features. For this reason, you need to set your compiler’s C++ standards to whatever new version you need. In this post, we will set the C++ standard with CMake.

Illustrations of a space station made of up cogs in the deep space. Representing how complex CMake is, yet very easy to set your C++ standard.
Figure 1: A nice illustration of the infinite cogs that make up CMake’s usefulness. Setting the C++ standard is just about turning some of these cogs.

With CMake, this isn’t as difficult as many think. In fact, you only need to set three main variables: CMAKE_CXX_STANDARD, CMAKE_CXX_STANDARD_REQUIRED, and CMAKE_CXX_EXTENSIONS.

Let’s Talk About The C++ Standard CMake Variables

Firstly, let’s discuss how CMake sets the standard throughout your project.

Essentially, every executable or library you declared in your CMakeSettings.txtis a target. For example, creating executables in CMake will in turn generate a named target for it in CMake. Each target has properties set by CMake, and some of those properties relate to the C++ standard for the compilation:

  • CXX_STANDARD dictates which standard version the target will be compiled with. Specifically, at the time of writing the possible values are {98, 11, 14, 17, 20, 23, 26}. If you’re reading this from the far future, this list may have expanded.
  • CXX_STANDARD_REQUIRED is a boolean that makes the standard defined in CXX_STANDARD a requirement. Therefore, configuring the project will not succeed if the compiler used does not support the standard you specified if this flag is set to On.
  • CXX_EXTENSIONS is another boolean value. Briefly speaking, it tells CMake whether compiler extensions (such as inline assembly) are allowed or not. For more portable code, set this value to Off to ensure your code will compile in all compilers.

Setting these properties to targets can be done with the following snippets.

set_property(TARGET target PROPERTY CXX_STANDARD 17)
set_property(TARGET target PROPERTY CXX_STANDARD_REQUIRED On)
set_property(TARGET target PROPERTY CXX_EXTENSIONS Off)

As you can see, we set the standard of targetto 17, requiring that standard, and also turning extensions off.

The Recommended Approach To Set The C++ Standard In CMake

Although you can set the standard property on a “target” basis, essentially being able to have different standards for different parts of your codebase, it’s generally recommended not to.

Unless you have a very good reason, you probably want to set the same standard for every target in your project at once. Therefore, the CMAKE_* global variables are very handy here.

Long story short, the CMake documentation specifies that the properties CXX_STANDARD, CXX_STANDARD_REQUIRED, and CXX_EXTENSIONS have initial values. Specifically, they get initialised to the value of CMAKE_CXX_STANDARD, CMAKE_CXX_STANDARD_REQUIRED, and CMAKE_CXX_EXTENSIONS respectively.

In other words, if you don’t specify these properties on a target, the default values of these properties will be set as the global variables mentioned above. Therefore, you can fully specify the standard settings like the example below.

set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED On)
set(CMAKE_CXX_EXTENSIONS Off)

For this reason, stick to the code above when you can! In addition, make sure you call the CMake functions above straight after the project(...) call, or before you create any targets.

When Should You Have Different Versions For Different Targets?

Unfortunately, there aren’t many reasons for having different standard versions in different parts of your codebase.

The C++ standard has always been backwards compatible with previous standard versions. Therefore, if your code compiles in C++14, rest assured it will also compile in C++20. So you can always set the standard as the latest standard your compiler supports.

However, you may have different compilers being used in your project. Therefore, they may not support the same C++ standards. In this case, it’s plausible that you may want to have different versions for different targets.

What Happens If You Don’t Set The C++ Standard In CMake?

In simple terms, the compiler will dictate what standard to use by default. You can check out this compiler standard defaults gist to find out what version is used by default in your compiler.

For example, for gcc 10.2, the default version is 201402L, and the first four digits indicate that it uses C++ 2014 standard (or 14 for CMAKE_CXX_STANDARD).

Learning The CMake C++ Standards Settings By Video Example

If you’re still interested in seeing more action regarding setting the C++ compiler settings, the video below shows the usage, examples, and tips on using the CMake features for setting the C++ standard.

If you haven’t already done so, check out my Youtube channel, and if possible, subscribe as that helps out massively!

Further Reading & Notes

All the properties and settings mentioned in this post show work for both executables and libraries created with CMake. Check out how to create executables using CMake, and while you’re at it, also learn how to create libraries with CMake.


Thanks for reading this post!

More importantly: do you have any questions, feedback, or suggestions? Spotted a typo? Feel free to post a comment below!

Published inCMakeCPP