It is very easy to manually analyze a C, C++ and Objective-C project with SonarQube:
-
Create a
sonar-project.properties
file to store your configuration-
Add a projectKey of your project
-
Generate a unique token and set it as "sonar.login" (
SONARQUBE_TOKEN
in this example project) -
Set
sonar.host.url
to your SonarQube server URL
-
-
Download and unzip the Build Wrapper for macOS from {SonarQube URL}/static/cpp/build-wrapper-macosx-x86.zip
-
Add the Build Wrapper to your
$PATH
-
Download and unzip the SonarScanner for macOS
-
Add the bin directory of the SonarScanner to your
$PATH
-
Wrap your clean build command with the Build Wrapper. E.g.:
build-wrapper-macosx-x86 --out-dir bw-output xcodebuild clean build
-
Run
sonar-scanner
specifying:-
-Dsonar.cfamily.compile-commands=bw-output/compile_commands.json
if you are using SonarQube version 10.6 or later -
-Dsonar.cfamily.build-wrapper-output=bw-output
if you are using SonarQube version 10.5 or earlier, as build-wrapper did not generate acompile_commands.json
file before SonarQube 10.6
Noting that
bw-output
is the directory passed to build wrapper as--out-dir
-
You can take a look at the sonar-project.properties and build-analyze.sh (a script that downloads the sonar-scanner
and the Build Wrapper before compiling and analyzing the project) to see it in practice. Please be aware that the SonarQube server URLs and the sonar.login
are not completed in these examples.
A build of the code repository on a macOS using XCode build system.
To build the code run from the repository root directory:
xcodebuild
An example of a flawed C++ code. The code repository is meant to be compiled with different build systems using different CI pipelines on Linux, macOS, and Windows.
The code repository is forked into other repositories in this collection to add a specific build system, platform, and CI. The downstream repositories are analyzed either with SonarQube or SonarCloud.
You can find examples for:
Using the following build systems:
Running on the following CI services:
-
Additionally, generic examples demonstrate integration with other CIs and manual-configuration examples should help you if you are running locally.
Configured for analysis on:
You can find also a few examples demonstrating:
See examples-structure.adoc for a description of the structure of this GitHub organization and the relations between its different repositories.