PMD
| |
---|---|
Basisdaten
| |
Hauptentwickler | Andreas Dangel, Juan Martín Sotuyo Dodero, Clément Fournier |
Erscheinungsjahr | 4. November 2002[1] |
Aktuelle Version | 7.6.0[2] (27. September 2024) |
Betriebssystem | plattformunabhängig |
Programmiersprache | Java |
Kategorie | Programmierwerkzeug |
Lizenz | BSD-style |
pmd.github.io |
PMD ist ein Programmierwerkzeug für die statische Codeanalyse von Quelltexten. Neben Java werden unter anderem Apex, JavaScript, XML und XSL sowie davon abgeleitete Dialekte unterstützt.[3] Der Name PMD selbst hat offiziell keine ausgeschriebene Bedeutung.[4]
Die Fehler, die PMD findet, sind typischerweise keine echten Fehler, sondern eher ineffizienter Code, d. h. die Software wird in der Regel trotzdem korrekt ausgeführt, wenn die Fehler nicht korrigiert werden. PMD findet auf Basis von statischen Regeln potentielle Probleme wie beispielsweise:
try/catch/finally/switch
-Blöcke.if/while
-Ausdrückeif
-Ausdrücke, oder for
-Schleifen, die stattdessen als while
-Schleifen genutzt werden könntenString/StringBuffer
PMD bietet eine Vielzahl eingebauter Regeln und die Möglichkeit, vorhandene Regeln zu erweitern oder eigene Regeln zu schreiben.
PMD stellt Plug-ins für Entwicklungsumgebungen wie JDeveloper, Eclipse, JBuilder, NetBeans, JCreator und IntelliJ IDEA sowie Editoren wie JEdit, Emacs und TextPad bereit.[5] Darüber hinaus existieren Erweiterungen für Build-Werkzeuge wie Apache Maven und Apache Ant, Continuous-Integration-Server wie Jenkins und Hudson sowie die statische Code-Analyse-Plattform SonarQube.
Der Copy-Paste-Detector (CPD) ist eine Erweiterung von PMD, die den Rabin-Karp-Algorithmus nutzt, um duplizierten Code zu finden. CPD kann auf Java, C, C++, C#, PHP, Ruby, Fortran, sowie JavaScript angewendet werden.[6]
Im Java-Umfeld werden üblicherweise neben PMD auch noch Checkstyle und FindBugs für die statische Codeanalyse verwendet. Microsoft stellt mit FxCop ein vergleichbares Werkzeug für die .NET-Plattform bereit. Siehe auch Liste von Werkzeugen zur statischen Codeanalyse.