Cppcheck est un outil d'analyse de code statique pour les langages de programmation C et C++. C'est un outil polyvalent qui permet de vérifier du code non standard[2]. Le créateur et développeur principal est Daniel Marjamäki.

Cppcheck
Description de l'image Cppcheck icon.png.
Description de l'image CppcheckPortable 2.13.0 en.png.
Informations
Créateur Daniel Marjamäki
Première version 8 mai 2007; 11 ans auparavant
Dernière version 2.21.0 (4 juin 2026)[1]Voir et modifier les données sur Wikidata
Dépôt github.com/danmar/cppcheckVoir et modifier les données sur Wikidata
Écrit en C++
Système d'exploitation Type UnixVoir et modifier les données sur Wikidata
Environnement Cross-platform
Langues Anglais, Néerlandais, Finlandais, Suédois, Allemand, Russe, Polonais, Japonais, Serbe
Type Qualité logicielle
Licence GNU General Public License
Site web cppcheck.sourceforge.net

Cppcheck est un un logiciel open-core avec sa version de base sous la Licence Publique Générale de GNU.

Caractéristiques

modifier

Cppcheck prend en charge une large variété de vérifications statiques qui peuvent ne pas être couverts par le compilateur lui-même. Ces vérifications sont des contrôles d'analyse statique qui peuvent être effectués au niveau du code source. Le programme se concentre sur les contrôles rigoureux de l'analyse statique, plutôt que par heuristique.

Certains des contrôles qui sont pris en charge comprennent :

  • Vérification de variables automatiques.
  • La vérification des limites de la taille des tableaux pour éviter un dépassement
  • La vérification des classes (par exemple les fonctions inutilisées, l'initialisation d'une variable ou la duplication de mémoire)
  • L'utilisation des fonctions obsolètes ou remplacées conformément à l'Open Group[3]
  • Vérification des exceptions de sécurité, par exemple les vérifications des utilisations d'allocation et de destruction de mémoire.
  • Les fuites de mémoire, par exemple due à la perte de portée sans libération
  • Les fuites de ressource, par exemple oublier de fermer un descripteur de fichier.
  • L'utilisation non valide de fonctions de la Bibliothèque de modèles Standard et d'expressions idiomatiques
  • Divers stylistiques et des erreurs de performance

Comme dans le cas de nombreux programmes d'analyse, il existe beaucoup de cas inhabituels d'expressions idiomatiques qui peuvent être acceptables, dans des cas particuliers ciblés, ou hors de la portée du programmeur lors de la correction du code source. Une étude menée en mars 2009, a identifié plusieurs domaines où des faux positifs ont été trouvés par Cppcheck, mais sans spécifier la version du programme examiné[4]. Cppcheck est utilisé dans des systèmes tels que le méta-anlayseur de paquet du CERN 4DSOFT[5], pour le code de vérification dans les dispositifs de détecteur de particules à haute énergie[6], le système de surveillance de radio-télescopes[7] ainsi que pour l'analyse d'erreurs dans de grands projets, tels que OpenOffice.org[8] et l'archive Debian[9].

Développement

modifier

Le projet est activement en cours de développement[10] et est maintenu dans plusieurs distributions[11],[12]. Il a déjà trouvé plusieurs bugs dans un certain nombre de projets populaires[13] comme le noyau Linux ou MPlayer[14].

Les Plugins

modifier

Des Plugins pour les IDE suivant existent[15] :

Intégration dans Visual Studio

modifier

Le programme commercial tiers Visual Lint de la société britannique Riverblade peut être utilisé pour intégrer CppCheck dans Visual Studio[28].
Il y a également un plugin open-source cppcheck-vs-addin[29] qui est disponible.
Il est également possible d'ajouter Cppcheck en tant qu'un outil externe[30].

Voir aussi

modifier

Références

modifier
  1. « Release 2.21.0 », 4 juin 2026 (consulté le 5 juin 2026)
  2. « A Survey of C and C++ Software Tools for Computational Science » [archive du 12 mars 2012], Science and Technologies Facility Council, sur Science and Technologies Facility Council, Chilbolton, Daresbury, and Rutherford Appleton Laboratories, décembre 2009 (consulté le 14 septembre 2010), p. 14
  3. « System Interfaces », sur opengroup.org (consulté le 31 mai 2023).
  4. « Static Code Analysis For Embedded Systems »
  5. « Dissemination and use of knowledge plan (EU Deliverable DNA2.11 », 2010
  6. « Entwurf und Implementierung eines adaptiven, strahlentoleranten eingebetteten Systems am Beispiel eines Read-Out-Controllers (En: Development and implementation of an adaptive, radiation tolerant embedded system for operation of a Read-Out controller) » [archive du 11 mars 2012], 2010
  7. « The Wettzell System Monitoring Concept and First Realizations », International VLBI Service for Geodesy & Astrometry, 2010, p. 447
  8. « Hunting for vulnerabilities in large software : the OpenOffice suite »
  9. « Introducing the "Debian's Automated Code Analysis" (DACA) project », LWN.net
  10. Cppcheck on Github
  11. Cppcheck on Debian's Package Tracking System
  12. FreeBSD port
  13. « List of user reported bugs found by cppcheck »
  14. « Found Bugs list » [archive du 14 octobre 2013], SourceForge, sur SourceForge
  15. « SourceForge.net: cppcheck », sourceforge.net, sur sourceforge.net
  16. « cppcheck plugin for CLion », plugins.jetbrains.com, sur plugins.jetbrains.com
  17. « Cppcheclipse », github.com, sur github.com
  18. « Flycheck », github.com, sur github.com
  19. « gedit Cppcheck plugin », github.com, sur github.com
  20. « Cppcheck Plugin », hudson-ci.org, sur hudson-ci.org
  21. « Cppcheck Plugin », jenkins-ci.org, sur jenkins-ci.org
  22. Christoph Cullmann, « Kate Project Plugin News – Code Analysis », sur Kate | Get an Edge in Editing, 2 février 2013 (consulté le 14 décembre 2016)
  23. Kevin Funk, « KDevelop's Cppcheck plugin merged into kdevelop.git, will be released with 5.1 », 6 décembre 2016 (consulté le 14 décembre 2016)
  24. « Qt Creator Plug-in Gallery », Qt Wiki, sur Qt Wiki
  25. « Sublimelinter plugin », github.com, sur github.com
  26. « Cppcheck add-in », Visual Studio Marketplace, sur Visual Studio Marketplace
  27. Michael Scovetta, « Yasca »
  28. Riverblade, « Visual Lint homepage » (consulté le 11 décembre 2012)
  29. VioletGiraffe, « Homepage cppcheck-vs-addin » (consulté le 3 mars 2014)
  30. Srix, « Simple open source static analysis tool for Visual Studio » [archive du 10 février 2015] (consulté le 27 août 2012)

Liens externes

modifier

📚 Artikel Terkait di Wikipedia

Division

iValue; public static implicit operator UInt32_Register(UInt32 value) { return new UInt32_Register { iValue = value }; } public static implicit operator

Gynécomastie

Plastic and Reconstructive Surgery, 2012, volume 1 : http://www.egms.de/static/pdf/journals/iprs/2012-1/iprs000003.pdf Mathur R, Braunstein GD, Gynecomastia:

UML (informatique)

Les diagrammes de structure (structure diagrams) ou diagrammes statiques (static diagrams) rassemblent : Diagramme de classes (class diagram) : représentation

Liste d'abréviations en informatique

(Microsoft) RC2, RC6 : Ron's Code ou Rivest Cipher RCA : Radio Corporation of America, voir prise RCA Root Cause Analysis, voir Analyse de cause racine(fr)

Web application firewall

Chung-Hung Tsai, D. T. Lee et Sy-Yen Kuo, « Securing web application code by static analysis and runtime protection », WWW04 Proceedings of the 13th international

Injection de code dans les applications web

« Cross-Site Scripting Prevention with Dynamic Data Tainting and Static Analysis », NDSS’07 Proceeding of the Network and Distributed System Security

Liste des avions de chasse de quatrième génération

auteurs). Hoh, Roger H. and David G. Mitchell, Flying Qualities of Relaxed Static Stability Aircraft - Volume I: Flying Qualities Airworthiness Assessment

GrammaTech

matérielle.. Liste des références GrammaTech (en) Richard A. Quinnell, « Static analysis stomps on bugs », EETimes,‎ 6 mars 2008 (lire en ligne, consulté le