Skip to content
/ pmd Public
forked from pmd/pmd

An extensible multilanguage static code analyzer.

License

Notifications You must be signed in to change notification settings

JLPacherie/pmd

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PMD

Join the chat at https://gitter.im/pmd/pmd Build Status Maven Central Coverage Status Codacy Badge Contributor Covenant

About

PMD is a source code analyzer. It finds common programming flaws like unused variables, empty catch blocks, unnecessary object creation, and so forth. It supports Java, JavaScript, Salesforce.com Apex and Visualforce, Modelica, PLSQL, Apache Velocity, XML, XSL, Scala.

Additionally it includes CPD, the copy-paste-detector. CPD finds duplicated code in C/C++, C#, Dart, Fortran, Go, Groovy, Java, JavaScript, JSP, Kotlin, Lua, Matlab, Modelica, Objective-C, Perl, PHP, PLSQL, Python, Ruby, Salesforce.com Apex, Scala, Swift, Visualforce and XML.

About this fork

This fork adds support for importing PMD defects into Coverity Connect. This will allow users of Coverity to analyze defects from various SAST tools from a same central repository with all the features Coverity provides for triaging, reporting, etc.

To make it work use the PDM format coverity and import the generated file with the regular cov-import-results command of Coverity CLI.

Building PMD:

There's a known issue with JDK11+ and maven-javadoc-plugin. If you have an error such as

[ERROR] Exit code: 1 - javadoc: error - The code being documented uses modules but the packages defined in https://docs.oracle.com/javase/8/docs/api/ are in the unnamed module.

during the compilation of javadoc your options are

  • Skip the javadoc creation by adding -Dmaven.javadoc.skip=true on the mvnw command line
  • Or, downgrade the javadoc plugin to 3.0.1 using -Djavadoc.plugin.version=3.0.1

Source and Documentation

Support

Source

Our latest source of PMD can be found on GitHub. Fork us!

The rule designer is developed over at pmd/pmd-designer. Please see its README for developer documentation.

Website

More information can be found on our Website.

About

An extensible multilanguage static code analyzer.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 82.5%
  • Apex 11.7%
  • ANTLR 2.0%
  • PLSQL 1.0%
  • Kotlin 0.9%
  • Shell 0.8%
  • Other 1.1%