Code quality analyzers are now included with the.NET 5 SDK and enabled by default. The diagnostic ID, or code, for these analyzers is of the format CAxxxx, for example, CA1822. For more information, see Overview of.NET code quality analysis. Third party analyzers can be installed as a NuGet package or a Visual Studio extension. SonarLint for Visual Studio is based on and benefits from the.NET Compiler Platform (aka 'Roslyn') and its code analysis API to provide a fully-integrated user experience in Visual Studio 2015, Visual Studio 2017 and Visual Studio 2019. SonarLint is free, open source, and available in the Visual Studio Gallery. On-the-fly feedback. Subsequently, one may also ask, how do I use SonarLint code in Visual Studio? Using SonarLint in your project Add in the SonarQube server, username, and password information. Once you connect, you will see SonarLint connect to the SonarQube server. Then you will see a screen that will ask you to select a SonarQube project to bind your solution to.
Language Support for Java(TM) by Red Hat also provides formatting settings. You can export an Eclipse formatter file and then use it for your project in VS Code.
In addition, there are also the Checkstyle for Java and SonarLint extensions, which provide features for live linting and code analysis.
Checkstyle
With the Checkstyle for Java extension, you can use either existing checkstyle
configurations (Google's or Sun's Check) or your own customized files for your project. When editing a Java file, the extension will check the file format and provide Quick Fixes if possible on the fly.
Set Checkstyle configuration file.
The Checkstyle for Java extension supports live linting.
And batch check.
The Problems panel will open when you click the Checkstyle status icon in the Status bar.
Set Checkstyle configuration file
To set the configuration file, right-click the
.xml
file and select Set the Checkstyle Configuration File.You can also trigger the command Checkstyle: Set Checkstyle Configuration File to choose the configuration file in the File Explorer. The extension looks for a
checkstyle.xml
file in your workspace to make Checkstyle configuration easier. You will also see the two built-in configurations:- Google's Check
- Sun's Check
Command Checkstyle: Set the Checkstyle Configuration detects potential Checkstyle configuration files and lists them. You can also provide a configuration file by directly writing a URL in the input box.
You can also set the Checkstyle version by using the command Checkstyle: Set the Checkstyle Version.
The command will:
- List the latest Checkstyle version from the main repo.
- List all the downloaded versions.
- List all the supported versions.
- Mark the currently used version with a check symbol.
In addition, you can also bring any 3rd-party modules for Checkstyle by configuring its path. For example, after using the configuration below, you can add <module name='SingleBreakOrContinueCheck'/>
or <module name='com.github.sevntu.checkstyle.checks.naming.SingleBreakOrContinueCheck'/>
to checkstyle.xml
to leverage those checks.
Check the style and fix the violations
- When editing a Java file, the extension will check the file format and provide Quick Fixes if possible. You can click the lightbulb button in the editor to show the available Quick Fixes.
For more details about Checkstyle for Java, visit its GitHub Repository.
SonarLint
The SonarLint extension lets you detect bugs and vulnerabilities as you write code in VS Code. Java is one of the languages supported, and the extension will run in the background and highlight source code that poses a quality or security concern.
Code Analysis on the fly
Issues are highlighted directly in the editor with hovers to provide detailed explanations.
Issues found in the opened file can also be reviewed through the Problems panel of VS Code. When applicable, secondary code locations are mentioned so you can understand where the issue originates from (for example, the code path that led to a bug).
Rule documentation and remediation guidance
For any issue detected, SonarLint provides full documentation about the rule that was violated, and the coding best practice it relates to. This lets you understand why an issue is raised, and most importantly how to best fix it.
Enabling more quality and security rules
By default, SonarLint provides a wide array of rules to detect bugs and vulnerabilities. More checks can be enabled through the SonarLint Rules view.
For more details about the SonarLint for VS Code extension, visit the SonarLint website.
Formatter
Currently, you need an Eclipse formatter file like Google Style.
Set the following property:
The property can point to a URL or a local file path.
If the formatter XML file contains more than one profile, you can set the profile name:
You can also define the formatting preferences in your project's .settings/org.eclipse.jdt.core.prefs. It will override the global formatting settings.
We are working on a solution to allow editing your formatting preferences from within VS Code. For now, the best way to edit them is to use Eclipse. See Formatter Settings for details.
SonarSource delivers what is probably the best static code analyzer you can find for C#.Based on the Microsoft Roslyn compiler front-end, it uses the most advanced techniques (pattern matching, dataflow analysis)to analyze code and find Code Smells, Bugs, and Security Vulnerabilities.As with everything we develop at SonarSource, it was built on the principles of depth, accuracy, and speed.
SonarSource's C# analysis has a great coverage of well-established quality standards. This capability is available in Visual Studio for developers (SonarLint) as well as throughoutthe development chain for automated code review with self-hosted SonarQube or cloud-based SonarCloud.
Sonarlint Visual Studio Code Analysis
Sonarlint Visual Studio Code Not Working
- Easy analysis of any existing Visual Studio Solution or MSBuild project
- Native integration with any existing build in Azure DevOps
SonarSource's C# analysis supports all the standard metrics implemented by SonarQube including Cognitive Complexity. Additionally, it supports the import of Microsoft Visual Studio, dotCover, OpenCover, Coverlet and NCover 3 test coverage reports.
SonarSource's C# analysis supports custom rules written in Roslyn, and packaged via the SonarQube Roslyn SDK project.
Free & Open Source
Related Content