CLion Nova inlay hints for C++
Settings | Editor | Inlay Hints | C++
note
The settings page and inlay hints described below are only available in CLion Nova. Make sure to switch to CLion Nova in Advanced Settings.
CLion Nova provides additional inlay hints and introduces a Push-to-Hint mode.
data:image/s3,"s3://crabby-images/71a82/71a82710c16bd3fa7edb9e4e53243c718171dc32" alt="CLion Nova inlay hints CLion Nova inlay hints"
Parameter name hints are editor adornments that show parameter names next to the corresponding arguments at method calls. They can help you find your way through long (and sometimes nested) lists of parameters in function calls and aggregate initialization.
In the example below, parameter name hints help to spot the fact that height and width arguments are mixed up:
data:image/s3,"s3://crabby-images/97b6b/97b6b4d03493e1a3ed11ee11545a9a3d13b47eb1" alt="Parameter name hints Parameter name hints"
Parameter name hints show the names of the members you are initializing and help disentangle complex aggregate initializations in C++17 and later:
data:image/s3,"s3://crabby-images/24b0f/24b0fd27e69ede2a8ca5be571d1fcfaacc935979" alt="Parameter name hints in aggregate initialization Parameter name hints in aggregate initialization"
tip
The braces around the nested initializer lists may be elided. To make code more readable in this case, you can press AltEnter and use the
missing-braces
Clang diagnostic to add braces around the initialization of subobjects.
Type name hints help you when a type is deduced automatically by the compiler from the surrounding code. CLion Nova provides type name hints for auto variables, function and lambda return types, in structured bindings, dependent code, and after function calls.
tip
If you want to quickly disable or configure hints, right-click a hint to open the context menu. From the same menu, you can go to the options page or navigate to the related declaration.
This kind of hints is available for variables with automatically deduced type, which use the auto
or decltype(auto)
type specifiers. By default, the hint will be hidden if the deduced type is clear from the initializer expression, for example when the initializer is a constructor call, a constant, or an explicit cast.
data:image/s3,"s3://crabby-images/4ca44/4ca44ecd6a475fe957f17c99af310d03b8dbbba5" alt="Type name hints for auto variables Type name hints for auto variables"
In C++17’s structured binding declarations, type hints are especially useful since the type of a structured binding cannot be explicitly specified.
data:image/s3,"s3://crabby-images/eea55/eea554e1581d20c97b3da350cf984a883d98cb06" alt="Type name hints for structured bindings Type name hints for structured bindings"
Type conversion hints help make hidden implicit conversions visible, so that you are aware of potential performance and correctness implications.
CLion Nova displays hints for different kinds of class type conversions, including object copying, object initialization using converting constructors or aggregate initialization, and calls to conversion operators.
data:image/s3,"s3://crabby-images/e7ce8/e7ce8d92416866c24eef356504ce5bfa35af78a9" alt="Type conversion hints Type conversion hints"
You can also enable hints for standard conversions between built-in types, for example, conversions between numeric types that might lose precision or change the signedness of the type.
Preprocessor directive hints help you quickly understand how conditional inclusions (#ifdef
, #ifndef
, #if
, #endif
, #else
, and #elif
) correspond to macro definitions:
data:image/s3,"s3://crabby-images/05cd6/05cd6916e78bbc30f1aaff84fba42f26ab49e14d" alt="Preprocessor directive hints Preprocessor directive hints"
Inlay hints can be helpful, but on the other hand they take editor space and may seem redundant in some cases.
The Push-to-Hint mode (enabled by default) lets you keep the hints hidden, and only view them when needed by pressing and holding the Ctrl key.
To change the hints visibility, use the Default visibility switcher in Settings | Editor | Inlay Hints | C++:
data:image/s3,"s3://crabby-images/6867e/6867edd33750177e7ca588b3afa57f5b709031bb" alt="Inlay hints visibility iptions Inlay hints visibility iptions"
Thanks for your feedback!