Skip to content

An example C++ repository manually built with GNU Autotools(automake; make) on Linux and analyzed on SonarQube

Notifications You must be signed in to change notification settings

sanjeevaReddych/linux-autotools-manual-sq

 
 

Repository files navigation

C++ example project manually scanned on SonarQube

ℹ️
This simple example ignores analysis cache and multithreaded execution both of which can boost analysis significantly.

It is very easy to manually analyze a C, C++ and Objective-C project with SonarQube:

  1. Create a sonar-project.properties file to store your configuration

    1. Add a projectKey of your project

    2. Add a Build Wrapper output directory

    3. Generate a unique token and set it as "sonar.login"

    4. Set sonar.host.url to your SonarQube server URL

  2. Download and unzip the Build Wrapper for Linux from {SonarQube URL}/static/cpp/build-wrapper-linux-x86.zip

  3. Add the Build Wrapper to your $PATH

  4. Download and unzip the SonarScanner for Linux

  5. Add the bin directory of the SonarScanner to your $PATH

  6. Wrap your clean build command with the Build Wrapper. E.g.: build-wrapper-linux-x86-64 --out-dir bw-output make clean all (with bw-output being the same directory as the one set in sonar-project.properties)

  7. Run sonar-scanner

You can take a look at the sonar-project.properties and build-analyze-project.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.

Documentation

Linux\Autotools

A build of the code repository on a Linux platform using GNU Autotools build system.

To build the code run:

autoreconf --install
./configure
make clean all

Code Description

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:

Configured for analysis on:

See examples-structure.adoc for a description of the structure of this GitHub organization and the relations between its different repositories.

About

An example C++ repository manually built with GNU Autotools(automake; make) on Linux and analyzed on SonarQube

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 70.7%
  • C++ 20.3%
  • M4 5.5%
  • Makefile 3.5%