Skip to content

Visualizing issues with secondary locations

duncanp-sonar edited this page Oct 6, 2020 · 9 revisions

Requirements

Minimum SLVS version required: v4.26

Supported languages: C, C++

Overview

All SonarLint issues specify a location in the code showing where the issue occurs. However, some of the more complex rules produce issues for which a single location is not enough to adequately explain why the issue has occurred. These more complex rules often identify additional locations in the code to help understand the problem. These additional locations are referred to as secondary locations.

For some rules (i.e. cpp:S3529) the secondary locations identify a ‘flow’ through the code that leads to the issue. For other rules (i.e. cpp:S1871), the secondary locations indicate other locations that are related to the issue.

SonarLint for Visual Studio shows these secondary locations in the editor and in a separate tool window.

SonarLint Issue Visualization tool window

SonarLint Issue Visualization tool window screenshot

By default, the tool window will only be visible in the following cases:

  • When an issue with secondary locations is selected in the Error List i.e. the window will automatically appear and disappear as the Error List selection changes.
  • When lightbulb suggested action SonarLint: show issue visualization is invoked. The suggested action will appear when hovering over an issue with secondary locations in the Editor as shown in the following screenshot:

images/SecondaryLocations/SecondaryLoc_lightbulb_v4_26.png

Manually re-opening SonarLint Issue Visualization tool window

If you manually close the tool window it will no longer appear and disappear automatically. You can show the window again using one of three menu commands:

  • The menu command View, Other Windows, SonarLint Issue Visualization, which is always visible
  • The lightbulb suggested action SonarLint: show issue visualization when hovering over an issue in the Editor (see screenshot above)
  • The Show SonarLint Issue Visualization command on the Error List context menu, which is available for issues with secondary locations as shown in the following screenshot:

images/SecondaryLocations/SecondaryLoc_errorlist_contextmenu_v4_26.png

Navigating between secondary locations

Selecting a secondary location in the tool window will move the edit cursor to the specified location in the code.

It is also possible to navigate between secondary locations using the keyboard with the following shortcuts:

  • Go to next location: Ctrl+Shift+Alt+Q, Ctrl+Shift+Alt+Right Arrow
  • Go to next location: Ctrl+Shift+Alt+Q, Ctrl+Shift+Alt+Left Arrow

These shortcut key combinations were chosen to avoid conflicts with existing Visual Studio shortcuts and shortcuts in popular third-party extensions. As always, it is possible to customize these shortcuts in Visual Studio. See the MS documentation for more information.

Non-navigable locations

It is not always possible to navigate to a location in the code e.g. because the code has been changed since the file was analyzed, or the source file has been deleted. The tool window will show which locations are non-navigable:

Non-navigable location shown the the tool window screenshot

Known issues

  • #1646: SelectedLocation is cleared when the user navigates to a location outside of the Error List scope

  • Issue Visualization panel no longer appears and disappears automatically: the panel was likely closed manually and therefore needs to be re-open manually (see “Manually re-opening SonarLint Issue Visualization tool window” section for more information).