The C++ Community Plugin uses the following properties during analysis. See here for the ways how to pass them to the plugin.
Beside the general SonarQube Analysis Parameters the latest released plugin supports the parameter below:
- sonar.cxx.suffixes.sources
- sonar.cxx.suffixes.headers
- sonar.cxx.includeDirectories
- sonar.cxx.forceIncludes
- sonar.cxx.defines
- sonar.cxx.cFilesPatterns
- sonar.cxx.errorRecoveryEnabled
- sonar.cxx.cpd.ignoreLiterals
- sonar.cxx.cpd.ignoreIdentifiers
- sonar.cxx.cppcheck.reportPath
- sonar.cxx.rats.reportPath
- sonar.cxx.valgrind.reportPath
- sonar.cxx.vera.reportPath
- sonar.cxx.drmemory.reportPath
- sonar.cxx.xunit.reportPath
- sonar.cxx.xunit.xsltURL
- sonar.cxx.xunit.provideDetails
- sonar.cxx.vstest.reportsPaths
- sonar.cxx.nunit.reportsPaths
- sonar.cxx.xunit.reportsPaths
- sonar.cxx.pclint.reportPath
- sonar.cxx.other.reportPath
- sonar.cxx.other.sqales
- sonar.cxx.coverage.reportPath
- sonar.cxx.coverage.itReportPath
- sonar.cxx.coverage.overallReportPath
- sonar.cxx.coverage.forceZeroCoverage
- sonar.cxx.compiler.parser
- sonar.cxx.compiler.reportPath
- sonar.cxx.compiler.regex
- sonar.cxx.compiler.charset
- sonar.cxx.jsonCompilationDatabase
- sonar.cxx.scanOnlySpecifiedSources
- sonar.cxx.clangsa.reportPath
sonar.cxx.suffixes.sources
Scope: system, project
Default: .cxx,.cpp,.cc,.c
Comma separated list of file name extensions to be considered as C++ source files during analysis.
Example:
sonar.cxx.suffixes.headers
Scope: system, project
Default: .hxx,.hpp,.hh,.h
Comma separated list of file name extensions to be considered as C++ header files during analysis.
Example:
sonar.cxx.includeDirectories
Scope: system, project
Default: ---
Comma separated list of directories where the plugin will be looking for included files.
- Note: the plugin doesn't know any standard include paths. If they should be used, configure them manually using this property.
*Example:* `include, /usr/include`
sonar.cxx.forceIncludes
Scope: system, project
Default: ---
Comma separated list of header files to be implicitly included at the beginning of each source file, for details see [[Force Include]]
Example: VS10Macros.h
sonar.cxx.defines
Scope: system, project
Default: ---
List of macros which should be used during analysis. The syntax is the same the body of #define-directives, except the #define keyword itself. This is a multiline property, which means:
- If you're using Sonar's Web UI just write a macro per line
- When setting via .properties-file separate macros using
\n\
*Example:*
va_arg(a, b) 0, \n\ PRIx64 "" \n\ DEBUG 1
sonar.cxx.cFilesPatterns
Scope: project
Default: *.c,*.C
Comma-separated list of wildcard patterns used to detect C files. When
a file matches any of the patterns, it is parsed in C-compatibility mode.
Example:
sonar.cxx.errorRecoveryEnabled
Scope: project, module
Default: True
Defines tolerant or strict error handling mode. This setting has impact on parsing the source files and reading report files:
- report files:
- error in an report file could be for example invalid file references or line numbers
- in tolerant mode (
True
) analysis continue in case of errors in a report file - in strict mode (
False
) an error in a report file will stop the analysis - source code parsing:
- parsing error means that source code file does not fit to C/C++ grammar
- in tolerant mode (
True
) syntax errors within a declaration are skipped, analysis is continued with next declaration in source code file. For details see Error Recovery. - in strict mode (
False
) analysis of source code file fails after an syntax error. Source code file is ignored.
*Example:* `sonar.cxx.errorRecoveryEnabled=True`
sonar.cxx.cpd.ignoreLiterals
Scope: project, module
Default: False
CPD ignores literal value differences when evaluating a duplicate block. This means that foo=42; and foo=43; will be seen as equivalent.
Example: sonar.cxx.cpd.ignoreLiterals=False
sonar.cxx.cpd.ignoreIdentifiers
Scope: project, module
Default: False
CPD ignores identifier value differences when evaluating a duplicate block.; i.e., variable names, methods names, and so forth.
Example: sonar.cxx.cpd.ignoreIdentifiers=True
sonar.cxx.cppcheck.reportPath
Scope: project
Default: ---
Ant pattern describing the path to Cppcheck reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.rats.reportPath
Scope: project
Default: ---
Ant pattern describing the path to RATS reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.valgrind.reportPath
Scope: project
Default: ---
Ant pattern describing the path to Valgrind reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.vera.reportPath
Scope: project
Default: ---
Ant pattern describing the path to Vera++ reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.drmemory.reportPath
Scope: project
Default: ---
Ant pattern describing the path to Dr Memory reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.xunit.reportPath
Scope: project
Default: ---
Ant pattern describing the path to unit test execution reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.xunit.xsltURL
Scope: project
Default: ---
A name of a built in XSLT-file or an URL to an external one. Available builtins:
- boosttest-1.x-to-junit-1.0.xsl: For transforming Boost-reports
- boosttest-1.x-to-junit-dummy-1.0.xsl: For transforming Boost-reports, simulating virtual files
- cpptestunit-1.x-to-junit-1.0.xsl: For transforming CppTestUnit-reports
- cppunit-1.x-to-junit-1.0.xsl: For transforming CppUnit-reports
*Example*: `cppunit-1.x-to-junit-1.0.xsl`
sonar.cxx.xunit.provideDetails
Scope: project
Default: False
History: no more supported with v0.9.7+
If "True", tries to assign testcases in reports to test resources in SonarQube,
thus making the drilldown to details possible
Example:
sonar.cxx.vstest.reportsPaths
Scope: project
Default: ---
Ant pattern describing the path to unit test execution reports. TRX output from VSTest. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.nunit.reportsPaths
Scope: project
Default: ---
Ant pattern describing the path to unit test execution reports. XML output from the NUnit console runner. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.xunit.reportsPaths
Scope: project
Default: ---
Ant pattern describing the path to unit test execution reports (XUnit XML output). Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.pclint.reportPath
Scope: project
Default: ---
Ant pattern describing the path to PC-lint reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.other.reportPath
Scope: project
Default: ---
Ant pattern describing the path to other reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.other.sqales
Scope: project
Default: ---
History: no more supported with v0.9.6+
SQALE characteristics for 'external' code analysers. Ant pattern describing the path to SQALE characteristics, relative to projects root.
Example:
sonar.cxx.coverage.reportPath
Scope: project
Default: ---
Ant pattern describing the path of unit test coverage reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.coverage.itReportPath
Scope: project
Default: ---
History: no more supported with v0.9.9+ (or SQ6.2+)
Ant pattern describing the path of integration test coverage reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.coverage.overallReportPath
Scope: project
Default: ---
History: no more supported with v0.9.9+ (or SQ6.2+)
Ant pattern describing the path of overall test coverage reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Example:
sonar.cxx.coverage.forceZeroCoverage
Scope: project
Default: True
History: no more supported with v0.9.9+ (or SQ6.2+)
If 'True', source files without coverage report results are set to zero coverage. This results in more realistic overall Technical Debt values. This setting is only enabled if one ore more of the keys sonar.cxx.coverage.reportPath, sonar.cxx.coverage.itReportPath or sonar.cxx.coverage.overallReportPath is defined (e.g. sonar.cxx.coverage.forceZeroCoverage and sonar.cxx.coverage.reportPath for line coverage). In case you have no report you have to assign a dummy report.
Example:
sonar.cxx.compiler.parser
Scope: project
Default: Visual C++
The format of the warnings file. Currently supported are 'Visual C++' and 'GCC'.
Example:
sonar.cxx.compiler.reportPath
Scope: project
Default: ---
Ant pattern describing the path to compiler output file. Path can be relative or absolute. Single path or comma separated list of paths is supported.
The current default settings can be used for VC++ compiler log file. If available compiler macros and includes will be taken also from build log and used during the pre processing of sources. See [[Compilers]]
Example:
sonar.cxx.compiler.regex
Scope: project
Default: ^.*[\\\\,/](.*)\\(([0-9]+)\\)\\x20:\\x20warning\\x20(C\\d\\d\\d\\d):(.*)$
Regular expression for four groups with this sequence:
- file name
- line number
- message id
- message text
*Example:*
sonar.cxx.compiler.charset
Scope: project
Default: UTF-16
Charset used for the compiler log file (sonar.cxx.compiler.reportPath) e.g. UTF-8, UTF-16 (for more see java.nio.charset.Charset)
Example:
sonar.cxx.jsonCompilationDatabase
Scope: project
Default: ---
Scope: project
Default: ---
History: no more supported with v1.0.0+
Enable Sonar C++ analysis to utilize JSON compilation database support. Specifies file to be used as JSON compilation database. JSON compilation database is used to improve C++ symbol and include directory knowledge. Sonar C++ plugin also supports extension to allow importing of used compiler's internal symbols and includes.
For more information please see: JSON compilation database format specification support
Example:
sonar.cxx.scanOnlySpecifiedSources
Scope: project
Default: False
When using JSON compilation database support limit Sonar C++ plugin analysis to specified files in JSON compilation database. This setting can be used to limit analysis to only compiled files.
Example:
sonar.cxx.clangsa.reportPath
Scope: project
Default: ---
Ant pattern describing the path to Clang Static Analyzer plist reports. Path can be relative or absolute. Single path or comma separated list of paths is supported.
Examples:
sonar.cxx.clangsa.reportPath=divzero.plist
or
sonar.cxx.clangsa.reportPath=analyzer_reports/*/*.plist
Hints V1.0.0:
- Usage of C plugin in parallel.
- Please keep in mind that the C plugin is still experimental.
- You can use all cxx configuration properties also for the C plugin: use
sonar.c.xxx
instead ofsonar.cxx.xxx
- You have to set specific file extensions in
sonar.cxx.suffixes.sources
andsonar.c.suffixes.sources
. -
sonar.cxx.cFilesPatterns
should be set in the C plugin configuration but not in the Cxx plugin configuration.
- Json compilation database support
sonar.cxx.jsonCompilationDatabase
is also experimental only-
sonar.cxx.scanOnlySpecifiedSources
is no more supported. There were conflicts withsonar.sources
andsonar.tests
.
-
Hints V0.9.8:Hints V0.9.9:
- There are some changes in the SQ core API, starting with SQ 6.2:
- The property
sonar.cxx.forceZeroCoverage
is no more supported. There is now a SQ core support basing onEXECUTABLE_LINES_DATA
.
- The property
-
sonar.cxx.coverage.itReportPath
andsonar.cxx.coverage.overallReportPath
are no more supported by the SQ core. There is no replacement available. - Usagage of C plugin in parallel.
- Please keep in mind that the C plugin is still experimental.
- You can use all cxx configuration properties also for the C plugin: use
sonar.c.xxx
instead ofsonar.cxx.xxx
- You have to set specific file extensions in
sonar.cxx.suffixes.sources
. -
sonar.cxx.cFilesPatterns
should be set in the C plugin configuration but not in the Cxx plugin configuration.
- Json compilation database support
sonar.cxx.jsonCompilationDatabase
is also experimental only.
Hints V0.9.8:
- Clang Static Analyzer support v5.0.0 (plist reports) available:
sonar.cxx.clangsa.reportPath
. - Clang Tidy support available:
sonar.cxx.clangtidy.reportPath
. - CxxOtherSensor: XSLT pre-analyse support available:
-
sonar.cxx.other.N.inputs
,sonar.cxx.other.N.outputs
,sonar.cxx.other.N.stylesheet
(N=1...9)
-
- There are some changes in the SQ core API, starting with SQ 6.2:
- The property
sonar.cxx.forceZeroCoverage
is no more supported. There is now a SQ core support basing onEXECUTABLE_LINES_DATA
.
- The property
-
sonar.cxx.coverage.itReportPath
andsonar.cxx.coverage.overallReportPath
are no more supported by the SQ core. There is no replacement available. - Usagage of C plugin in parallel.
- Please keep in mind that the C plugin is still experimental.
- You can use all cxx configuration properties also for the C plugin: use
sonar.c.xxx
instead ofsonar.cxx.xxx
- You have to set specific file extensions in
sonar.cxx.suffixes.sources
. -
sonar.cxx.cFilesPatterns
should be set in the C plugin configuration but not in the Cxx plugin configuration.
- Json compilation database support
sonar.cxx.jsonCompilationDatabase
is also experimental only.
Hints V0.9.7:
- Improved report handling: there is a tolerant and a strict mode now. In tolerant mode analysis continue in case of errors in a report file. In strict mode an error in a report file will stop the analysis (
sonar.cxx.errorRecoveryEnabled
). In versions before this one behaviour was sometimes strict and sometimes tolerant. - The default value of
sonar.cxx.errorRecoveryEnabled
is True now. To go back to old behaviour set the value to False. -
sonar.cxx.forceZeroCoverage
: better detection of executable lines. Resulting coverage can be slightly different. - Improved CPD algorithm with additional configuration settings
sonar.cxx.cpd.ignoreLiterals
andsonar.cxx.cpd.ignoreIdentifiers
. To get same numbers as before set both toFalse
. -
sonar.cxx.xunit.provideDetails
is no more supported
Hints V0.9.6:
- SQALE quality model is no more supported:
sonar.cxx.other.sqales
- support of new SonarQube Quality Model
- support of Dr Memory reports:
sonar.cxx.drmemory.reportPath
-
sonar.cxx.xunit.reportsPaths
: XUnit over sonar-dotnet-tests-library is supported now
Hints V0.9.5:
-
sonar.cxx.vstest.reportsPaths
: TRX output from VSTest is supported now -
sonar.cxx.nunit.reportsPaths
: XML output from the NUnit console runner is supported now -
reportPath
: path can be relative or absolute now. Paths inside and outside of root folder are supported. -
reportPath
: Single path or comma separated list of paths is supported. - Support of placeholder in configuration file. Format is ${xxx}, supported are environment variables, Java system properties and SonarQube properties.
Hints V0.9.4:
- Default values for
reportPath
values has been removed to get meaningful error messages. In case you were using the defaults you have to explicit define them in thesonar-project.properties
file now. -
forceZeroCoverage
: Depends on which key (sonar.cxx.coverage.reportPath
,sonar.cxx.coverage.itReportPath
,sonar.cxx.coverage.overallReportPath
) is defined in thesonar-project.properties
file now. DefiningforceZeroCoverage
alone will no more work. - EXPERIMENTAL: It is now possible to define SQALE characteristics for external rules (other)
sonar.cxx.other.sqales
.
Hints V0.9.3:
- Starting with this version it is possible to automatically retrieve includes, defines and compiler options from a Visual Studio log file. Create the log file with the option
/v:Diagnostic
and assign it tosonar.cxx.compiler.reportPath
.
Hints V0.9.2:
- New property
sonar.cxx.coverage.forceZeroCoverage
set coverage for source files without coverage report to 0. For V0.9.1 compatibility set value to 'false'. - New property
sonar.cxx.xunit.provideDetails
. To get detailed unit test information set property to 'true'. This is also the V0.9.1 compatibility value. Because SonarQube does not support 'virtual files' any more test resources must be available. - new property
sonar.cxx.cFilesPatterns
Hints V0.9.1:
- Configuration setting
sonar.cxx.cppncss.reportPath
is no longer supported. - Rename configuration setting
sonar.cxx.externalrules.reportPath
tosonar.cxx.other.reportPath
- Rename configuration setting
sonar.cxx.include_directories
tosonar.cxx.includeDirectories
- new property
sonar.cxx.forceIncludes
Hints V0.9.0:
- Use
sonar.cxx.include_directories
instead ofsonar.cxx.includeDirectories