Skip to content
| Marketplace
Sign in
Visual Studio Code>Programming Languages>Qualimetry Apex AnalyzerNew to Visual Studio Code? Get it now.
Qualimetry Apex Analyzer

Qualimetry Apex Analyzer

Qualimetry

|
1 install
| (0) | Free
Real-time static analysis for Salesforce Apex files (.cls, .trigger).
Installation
Launch VS Code Quick Open (Ctrl+P), paste the following command, and press enter.
Copied to clipboard
More Info

Qualimetry Apex Analyzer - VS Code Plugin

CI

A VS Code extension that provides real-time static analysis for Salesforce Apex source files (.cls, .trigger) directly in the editor.

Powered by the same analysis engine as the Qualimetry Apex Analyzer for SonarQube and the Qualimetry Apex Analyzer for IntelliJ.

Features

  • 283 rules covering convention, naming, design, security, error handling, performance, testing, complexity, and Salesforce platform best practices.
  • Real-time diagnostics — issues appear as you type, with squiggly underlines and Problems panel entries.
  • Configurable rules — override severity or disable rules; set rule-specific properties.
  • Import from SonarQube — pull your Apex quality profile (rules and severities) into workspace or user settings; URL and profile remembered, token never stored.
  • Consistent rule keys — rule keys and behavior align with the SonarQube and IntelliJ plugins so editor and CI findings match.

Rule categories

Category Examples
Convention Class/method/variable naming, braces, indentation
Design Boolean parameters, law of demeter, collapsible if, ternary
Security SOQL injection, field-level security, XSS, CSRF
Error Handling Empty catch, generic catch, preserve stack trace
Performance SOQL/DML in loops, eager describe, wrapper conversion
Complexity Cyclomatic, cognitive, NCSS, coupling, god class
Testing Assertions required, no SeeAllData, test method coverage
Salesforce One trigger per object, no trigger logic, API versions
Unused Code Unused variables, parameters, private fields/methods
Documentation Apexdoc required, comment density

Installation

From Marketplace

Install from the Visual Studio Marketplace or the Open VSX Registry and ensure Java 17+ is available.

From GitHub Releases

Download the latest .vsix from GitHub Releases, then install via Extensions: Install from VSIX... (Command Palette).

Requirements

  • Java 17+ - The analyzer runs on a Java-based language server. Java is auto-detected from JAVA_HOME or PATH. To set the path explicitly:

    {
      "apexAnalyzer.java.home": "C:\\path\\to\\java17"
    }
    

Configuration

Settings are under the apexAnalyzer namespace:

Setting Type Default Description
apexAnalyzer.enabled boolean true Enable or disable the analyzer.
apexAnalyzer.java.home string "" Path to a Java 17+ installation. When empty, the extension uses JAVA_HOME or PATH.
apexAnalyzer.rules object {} Per-rule configuration. List rules to override or replace the default set (see below).
apexAnalyzer.rulesReplaceDefaults boolean false When true, only the rules listed in apexAnalyzer.rules run (e.g. after Import from SonarQube). When false, listed rules are overrides and unlisted rules use the extension default profile.

How to customize rules

You can either override a few rules on top of the default profile, or replace the active set entirely (e.g. after importing from SonarQube).

  • Override mode (default) – Set apexAnalyzer.rulesReplaceDefaults to false or omit it. Add only the rule IDs you want to change (e.g. severity or enabled); all other rules use the extension default. You do not need to list all rules.
  • Replace mode – Set apexAnalyzer.rulesReplaceDefaults to true. Only the rules listed in apexAnalyzer.rules run. Use this when you have imported a profile from SonarQube or maintain your own full list.
  • Full default – Omit apexAnalyzer.rules or set it to {} with rulesReplaceDefaults false to use the built-in default profile.
  • After an upgrade – Entries for removed or renamed rules are ignored; you can delete them to tidy up.

Each rule can have enabled, severity (blocker | critical | major | minor | info), and rule-specific properties.

Example settings.json

{
  "apexAnalyzer.enabled": true,
  "apexAnalyzer.java.home": "",
  "apexAnalyzer.rulesReplaceDefaults": false,
  "apexAnalyzer.rules": {
    "qa-apex-syntax": {
      "enabled": true,
      "severity": "major"
    }
  }
}

Aligning with a SonarQube quality profile

Use the command Apex: Import rules from SonarQube (Command Palette). Enter your SonarQube server URL, the Apex quality profile name or key, and a token if required. The extension fetches the profile's active rules and severities and writes them to apexAnalyzer.rules and sets apexAnalyzer.rulesReplaceDefaults to true, so only those rules run (matching your SonarQube profile).

The last-used URL and profile are remembered (in the extension's global state, not in settings). Your token is never stored; it is used only for that run. To switch back to the extension default and only override a few rules, set apexAnalyzer.rulesReplaceDefaults to false.

Also available

The same analysis engine powers plugins for other platforms:

  • SonarQube plugin — enforce quality gates in CI/CD pipelines.
  • IntelliJ plugin — real-time analysis in JetBrains IDEs and Qodana CI/CD.

Rule keys and severities align across all three tools so findings are directly comparable.

Building from source

Prerequisites

  • JDK 17+ and Maven 3.6+
  • Node.js and npm

Build steps

  1. Build the Java modules (analyzer + LSP server):

    mvn clean package -pl apex-lsp-server -am -DskipTests
    
  2. Build the VS Code client:

    cd vscode-client
    npm install
    npm run compile
    
  3. Package as VSIX (copy LSP JAR into client, then package):

    mkdir -p vscode-client/server
    cp apex-lsp-server/target/apex-lsp-server-*-shaded.jar vscode-client/server/apex-lsp-server.jar
    cd vscode-client
    npx vsce package
    

    This produces a .vsix file in the vscode-client/ directory.

Contributing

Issues and feature requests are welcome. This project does not accept pull requests, commits, or other code contributions from third parties; the repository is maintained by the Qualimetry team only.

License

This extension is licensed under the Apache License, Version 2.0.

Copyright 2026 SHAZAM Analytics Ltd

  • Contact us
  • Jobs
  • Privacy
  • Manage cookies
  • Terms of use
  • Trademarks
© 2026 Microsoft