Code Inspection and Quick-Fixes in C++
The key features of ReSharper's code analysis are also supported in C++. You can find the detailed information on these features in the corresponding topics of the Code analysis section. In the main topic of the section, you can also find the feature matrix and check what exactly is supported in C++.
In this topic, you can find some examples of using code analysis features in C++.
By default, code inspection, quick-fixes, and context actions are available in all solution files. If necessary, you can enable these features in external files referenced from solution with the Enable inspections, quick fixes and context actions in files external to the solution checkbox on the page of ReSharper options (Alt+R, O).
Code Inspection
ReSharper's static code analysis detects most of compiler errors and some compiler warnings in C++ files.
Besides, it finds other code issues, which otherwise would be found in runtime. For example, using a virtual method in constructor leads to unexpected behavior as mentioned in this StackOverflow question. ReSharper points at this problem before you even compile:
![ReSharper warning. virtual method in constructor ReSharper warning. virtual method in constructor](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_virtual_in_constructor.png)
The analysis is performed by applying Code inspections to the current document or in any specified scope.
![Code inspection results in a C++ project Code inspection results in a C++ project](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_inspection_results.png)
To find out what kind of code inspections ReSharper provides, check out the full list of ReSharper C++ code inspections.
To learn how to customize code inspection, see Configure code inspection settings.
To quickly turn off a particular inspection or suppress all the inspections, use the inspection context menu:
![Disable inspections in C++ Disable inspections in C++](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_disable_inspections.png)
Quick-fixes
Quick-fixes let you automatically resolve most of code issues found with code inspection. If one or more quick-fixes are available for a code issue, you will see the corresponding action indicator when your caret is on the highlighted code. Press Alt+Enter to see and apply the desired fix.
ReSharper provides over 290 quick-fixes for C++. Here are some examples:
Add missing #include directive
If you use a symbol that is defined in the standard libraries or elsewhere in your solution, ReSharper helps you add the missing #include
directives automatically:
You can use the Show popups for import actions checkbox on the page of ReSharper options (Alt+R, O) to disable the popup.
If the checkbox is not selected, the corresponding action will be available in the action list when you press Alt+Enter.
Add forward declaration
ReSharper can also generate a forward declaration for an unresolved symbol:
![ReSharper: Add forward declaration quick-fix ReSharper: Add forward declaration quick-fix](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_add_forward_declaration_fix.png)
Add [[maybe_unused]]
The [[maybe_unused]]
attribute can be added to avoid warnings from the compiler about an unused name or entity. When the caret is on an unused entity, the following quick-fix will be available:
![Add [[maybe_unused]]](https://resources.jetbrains.com/help/img/dotnet/2021.2/maybe_unused_attr.png)
And another context action will help you to replace usages of UNREFERENCED_PARAMETER
and Q_UNUSED
with a [[maybe_unused]]
attribute:
![add [[maybe_unused]]](https://resources.jetbrains.com/help/img/dotnet/2021.2/unreferenced_parameter.png)
Add to capture list
If a local variable is used inside a lambda body but not captured by this lambda, ReSharper suggests quick-fixes to update the capture list. You can capture the variable or this
by value, by reference, or implicitly capture all the used automatic variables:
![ReSharper C++: quick-fix to update the capture list](https://resources.jetbrains.com/help/img/dotnet/2021.2/capture_lambda.png)
Change return type
If a function return type does not match the value it actually returns, ReSharper lets you quickly fix the return type:
![ReSharper helps fixing types of variables and fields ReSharper helps fixing types of variables and fields](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_change_return_type_fix.png)
Change variable type
If the specified type of a variable or a field does not match to the assigned value, ReSharper provides a quick-fix to use the correct type in the declaration:
![ReSharper helps fixing types of variables and fields ReSharper helps fixing types of variables and fields](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_change_var_type_fix.png)
Create declaration
If a member function in a C++ file does not have declaration in the header file, ReSharper helps you create the missing declaration according to the signature of the implementation:
![Generating declaration for C++ class member Generating declaration for C++ class member](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_qf_create_declaration.png)
Create from usage
If you use an undeclared symbol, ReSharper suggests one or more quick-fixes for creating the symbol based on the usage:
![Generating C++ field from usage Generating C++ field from usage](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_generate_from_usage.png)
Initialize members
If ReSharper detects uninitialized type members, it suggests initializing all members in one fix. You can also use the sub-menu of this fix to generate initializations for specific members.
![ReSharper C++: quick-fix to initialize members ReSharper C++: quick-fix to initialize members](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_fix_initialize_members.png)
Initialize variable
ReSharper detects uninitialized variables and helps initializing them with the default value:
![ReSharper helps initialize variables in C++ ReSharper helps initialize variables in C++](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_init_var.png)
Remove unused #include directives
All unused #include
are highlighted and can be easily removed with a quick-fix:
![Removing unused #include directives Removing unused #include directives](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_remove_include.png)
Remove unused lambda capture
If a local variable is captured by a lambda but not used inside the lambda body, ReSharper notifies you and suggests removing the unused capture:
![Remove unused lambda capture Remove unused lambda capture](https://resources.jetbrains.com/help/img/dotnet/2021.2/inspection_unused_lambda.png)
Replace the dot (.) with arrow (->) and vice versa
If the dot .
operator is erroneously applied to a pointer, ReSharper helps you replace it with the arrow ->
operator:
![ReSharper helps replacing the dot operator with arrow ReSharper helps replacing the dot operator with arrow](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_qf_dot_to_arrow.png)
The reverse quick-fix is also available:
![ReSharper helps replacing the arrow operator with the dot ReSharper helps replacing the arrow operator with the dot](https://resources.jetbrains.com/help/img/dotnet/2021.2/cpp_qf_arrow_to_dot.png)
Use explicit template parameters in lambda
ReSharper detects when lambda can be rewritten to use the new C++20 template syntax:
![Use explicit template parameters in lambda](https://resources.jetbrains.com/help/img/dotnet/2021.2/explicit_template.png)
If the parameter’s type is an rvalue reference, you may want to pass that type directly to std::forward
. In this case, you can use familiar perfect forwarding syntax:
![perfect forwarding syntax](https://resources.jetbrains.com/help/img/dotnet/2021.2/perfect_forwarding.png)
Use static_cast
ReSharper detects cases when you should prefer static_cast
and helps you update your code:
Functional-style cast used instead of a C++ cast:
reinterpret_cast
used instead of astatic_cast
when casting tovoid*
:
Make ReSharper ignore specific code
To exclude parts of your solution's code from code analysis, navigation, and other features, ReSharper allows you to ignore specific files, folders and file masks in different ways.