Interface Language

  • All Superinterfaces:
    java.lang.Comparable<Language>
    All Known Implementing Classes:
    BaseLanguageModule

    public interface Language
    extends java.lang.Comparable<Language>
    Interface each Language implementation has to implement. It is used by the LanguageRregistry to access constants and implementation classes in order to provide support for the language.

    The following are key components of a Language in PMD:

    • Name - Full name of the Language
    • Short name - The common short form of the Language
    • Terse name - The shortest and simplest possible form of the Language name, generally used for Rule configuration
    • Extensions - File extensions associated with the Language
    • Rule Chain Visitor - The RuleChainVisitor implementation used for this Language
    • Versions - The LanguageVersions associated with the Language
    See Also:
    LanguageVersion, LanguageVersionDiscoverer
    • Method Summary

      All Methods Instance Methods Abstract Methods 
      Modifier and Type Method Description
      LanguageVersion getDefaultVersion()
      Get the current PMD defined default LanguageVersion for this Language.
      java.util.List<java.lang.String> getExtensions()
      Get the list of file extensions associated with this Language.
      java.lang.String getName()
      Get the full name of this Language.
      java.lang.Class<?> getRuleChainVisitorClass()
      Get the RuleChainVisitor implementation class used when visiting the AST structure for this Rules for this Language.
      java.lang.String getShortName()
      Get the short name of this Language.
      java.lang.String getTerseName()
      Get the terse name of this Language.
      LanguageVersion getVersion​(java.lang.String version)
      Get the LanguageVersion for the version string from this Language.
      java.util.List<LanguageVersion> getVersions()
      Gets the list of supported LanguageVersion for this Language.
      boolean hasExtension​(java.lang.String extension)
      Returns whether the given Language handles the given file extension.
      boolean hasVersion​(java.lang.String version)  
      • Methods inherited from interface java.lang.Comparable

        compareTo
    • Field Detail

      • LANGUAGE_MODULES_CLASS_NAMES_PROPERTY

        static final java.lang.String LANGUAGE_MODULES_CLASS_NAMES_PROPERTY
        See Also:
        Constant Field Values
    • Method Detail

      • getName

        java.lang.String getName()
        Get the full name of this Language. This is generally the name of this Language without the use of acronyms.
        Returns:
        The full name of this Language.
      • getShortName

        java.lang.String getShortName()
        Get the short name of this Language. This is the commonly used short form of this Language's name, perhaps an acronym.
        Returns:
        The short name of this Language.
      • getTerseName

        java.lang.String getTerseName()
        Get the terse name of this Language. This is used for Rule configuration.
        Returns:
        The terse name of this Language.
      • getExtensions

        java.util.List<java.lang.String> getExtensions()
        Get the list of file extensions associated with this Language.
        Returns:
        List of file extensions.
      • hasExtension

        boolean hasExtension​(java.lang.String extension)
        Returns whether the given Language handles the given file extension. The comparison is done ignoring case.
        Parameters:
        extension - A file extension.
        Returns:
        true if this Language handles this extension, false otherwise.
      • getRuleChainVisitorClass

        java.lang.Class<?> getRuleChainVisitorClass()
        Get the RuleChainVisitor implementation class used when visiting the AST structure for this Rules for this Language.
        Returns:
        The RuleChainVisitor class.
        See Also:
        RuleChainVisitor
      • getVersions

        java.util.List<LanguageVersion> getVersions()
        Gets the list of supported LanguageVersion for this Language.
        Returns:
        The LanguageVersion for this Language.
      • hasVersion

        boolean hasVersion​(java.lang.String version)
      • getVersion

        LanguageVersion getVersion​(java.lang.String version)
        Get the LanguageVersion for the version string from this Language.
        Parameters:
        version - The language version string.
        Returns:
        The corresponding LanguageVersion, null if the version string is not recognized.
      • getDefaultVersion

        LanguageVersion getDefaultVersion()
        Get the current PMD defined default LanguageVersion for this Language. This is an arbitrary choice made by the PMD product, and can change between PMD releases. Every Language has a default version.
        Returns:
        The current default LanguageVersion for this Language.