Class SiteUtil
java.lang.Object
com.puppycrawl.tools.checkstyle.site.SiteUtil
Utility class for site generation.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprivate static final classUtility class for extracting description from a method's Javadoc.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate static final StringThe string 'api'.static final StringThe string 'charset'.Set of properties that every check has.private static final StringThe string 'checks'.private static final StringThe url of the checkstyle website.Class name and their corresponding parent module name.static final StringThe string ','.static final StringThe string ', '.static final StringThe string '.'.static final StringThe string 'fileExtensions'.Set of properties that every FileSet check has.static final PatternThe 'Check' pattern at the end of string.private static final StringCheck and property name.Set of properties that every Javadoc check has.static final StringThe string 'javadocTokens'.private static final StringPath to main source code folder.List of files who are superclasses and contain certain properties that checks inherit.private static final StringThe string 'naming'.static final StringThe path to the JavadocTokenTypes.html file.static final StringThe path to the TokenTypes.html file.Properties that can not be gathered from class instance.private static final StringCheck and property name.private static final PatternPrecompiled regex pattern to remove the "Setter to " prefix from strings.static final StringThe string of JavaDoc module marking 'Since version'.private static final StringThe string 'src'.private static final Map<String,DetailNode> Map of all superclasses properties and their javadocs.private static final StringTemplate file extension.static final StringThe string 'TokenTypes'.static final StringThe string 'tokens'.Set of properties that are undocumented.static final StringThe whitespace.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprivate static voidassertAllPropertySetterJavadocsAreFound(Set<String> properties, String moduleName, Map<String, DetailNode> javadocs) Assert that each property has a corresponding setter javadoc that is not null.getCheckMessageKeysFields(Class<?> module) Gets the check's messages keys.static StringgetDefaultValue(String propertyName, Field field, Object classInstance, String moduleName) Get the default value of the property.private static StringgetDescriptionFromJavadocForXdoc(DetailNode javadoc, String moduleName) Extracts the description from the javadoc detail node.getDifference(int[] tokens, int... subtractions) Get the difference between two lists of tokens.static FieldGets the field with the given name from the given class.static Class<?>getFieldClass(Field field, String propertyName, String moduleName, Object instance) Gets the class of the given field.static ObjectgetFieldValue(Field field, Object instance) Returns the value of the given field.private static StringgetFileContents(Path pathToFile) Get file contents as string.static List<DetailNode>getFirstJavadocParagraphNodes(DetailNode javadoc) Extracts first paragraph nodes from javadoc.static StringgetFirstParagraphFromJavadoc(DetailNode javadoc) Get 1st paragraph from the Javadoc with no additional processing.private static StringgetIntArrayPropertyValue(Object value) Returns the name of the bean property's default value for the int array class.private static IntStreamgetIntStream(Object value) Get the int stream from the given value.static StringgetLinkToDocument(String moduleName, String document) Constructs string with relative link to the provided document.getMessageKeys(Class<?> module) Get string values of the message keys from the given check class.static ObjectgetModuleInstance(String moduleName) Returns the instance of the module with the given name.static DetailNodegetModuleJavadoc(String moduleClassName, Path modulePath) Gets the javadoc of module class.static StringgetModuleName(File file) Get the module name from the file.static StringgetNewlineAndIndentSpaces(int amountOfSpaces) Construct a string with a leading newline character and followed by the given amount of spaces.static List<DetailNode>getNodesOfSpecificType(DetailNode[] allNodes, int neededType) Gets all javadoc nodes of selected type.getNonExplicitProperties(Object instance, Class<?> clss) Gets properties that are not explicitly captured but should be documented if certain conditions are met.private static PackageObjectFactoryReturns the default PackageObjectFactory with the default package names.static StringgetParentModule(Class<?> moduleClass) Returns the parent module name for the given module class.private static StringgetPatternArrayPropertyValue(Object fieldValue) Gets the name of the bean property's default value for the Pattern array class.getProperties(Class<?> clss) Get a set of properties for the given class.getPropertiesForDocumentation(Class<?> clss, Object instance) Get a set of properties for the given class that should be documented.static Map<String,DetailNode> getPropertiesJavadocs(Set<String> properties, String moduleName, Path modulePath) Get the javadocs of the properties of the module.static Class<?>getPropertyClass(String propertyName, Object instance) Gets the class of the given java property.static StringgetPropertyDescriptionForXdoc(String propertyName, DetailNode javadoc, String moduleName) Get the description of the property.private static Optional<DetailNode>getPropertySinceJavadocTag(DetailNode javadoc) Find the propertySince Javadoc tag node in the given property Javadoc.static StringgetPropertySinceVersion(String moduleName, DetailNode moduleJavadoc, DetailNode propertyJavadoc) Get the since version of the property.getPropertyVersionFromItsJavadoc(DetailNode propertyJavadoc) Extract the property since version from its Javadoc.private static DetailNodegetSinceJavadocTag(DetailNode javadoc) Find the since Javadoc tag node in the given Javadoc.private static StringgetSinceVersionFromJavadoc(DetailNode javadoc) Extract the since version from the Javadoc.private static StringGets the name of the bean property's default value for the string array class.static PathgetTemplatePath(String moduleName) Returns path to the template for the given module name or throws an exception if the template cannot be found.Get all templates whose content contains properties macro.static StringGet the type of the property.private static Stream<?>getValuesStream(Object value) Generates a stream of values from the given value.Gets xdocs template file paths.static booleanDetermines if the given child index is the end of the first Javadoc paragraph.private static booleanisGlobalProperty(Class<?> clss, String propertyName) Checks if the property is a global property.private static booleanisUndocumentedProperty(Class<?> clss, String propertyName) Checks if the property is supposed to be documented.private static booleanisVersionAtLeast(String actualVersion, String requiredVersion) ReturnstrueifactualVersion≥requiredVersion.private static voidprocessModule(String moduleName, Path modulePath) Scrape the Javadocs of the class and its properties setters with ClassAndPropertiesSettersJavadocScraper.private static voidCollect the properties setters javadocs of the superclasses.private static StringremoveSquareBrackets(String value) Removes square brackets [ and ] from the given string.static StringsimplifyTypeName(String fullTypeName) Simplifies type name just to the name of the class, rather than entire package.
- 
Field Details- 
TOKENSThe string 'tokens'.- See Also:
 
- 
JAVADOC_TOKENSThe string 'javadocTokens'.- See Also:
 
- 
DOTThe string '.'.- See Also:
 
- 
COMMAThe string ','.- See Also:
 
- 
WHITESPACEThe whitespace.- See Also:
 
- 
COMMA_SPACEThe string ', '.- See Also:
 
- 
TOKEN_TYPESThe string 'TokenTypes'.- See Also:
 
- 
PATH_TO_TOKEN_TYPESThe path to the TokenTypes.html file.- See Also:
 
- 
PATH_TO_JAVADOC_TOKEN_TYPESThe path to the JavadocTokenTypes.html file.- See Also:
 
- 
SINCE_VERSIONThe string of JavaDoc module marking 'Since version'.- See Also:
 
- 
FINAL_CHECKThe 'Check' pattern at the end of string.
- 
FILE_EXTENSIONSThe string 'fileExtensions'.- See Also:
 
- 
CHARSETThe string 'charset'.- See Also:
 
- 
CHECKSTYLE_ORG_URLThe url of the checkstyle website.- See Also:
 
- 
CHECKSThe string 'checks'.- See Also:
 
- 
NAMINGThe string 'naming'.- See Also:
 
- 
SRCThe string 'src'.- See Also:
 
- 
TEMPLATE_FILE_EXTENSIONTemplate file extension.- See Also:
 
- 
SETTER_PATTERNPrecompiled regex pattern to remove the "Setter to " prefix from strings.
- 
CLASS_TO_PARENT_MODULEClass name and their corresponding parent module name.
- 
CHECK_PROPERTIESSet of properties that every check has.
- 
JAVADOC_CHECK_PROPERTIESSet of properties that every Javadoc check has.
- 
FILESET_PROPERTIESSet of properties that every FileSet check has.
- 
HEADER_CHECK_HEADERCheck and property name.- See Also:
 
- 
REGEXP_HEADER_CHECK_HEADERCheck and property name.- See Also:
 
- 
APIThe string 'api'.- See Also:
 
- 
UNDOCUMENTED_PROPERTIESSet of properties that are undocumented. Those are internal properties.
- 
PROPERTIES_ALLOWED_GET_TYPES_FROM_METHODProperties that can not be gathered from class instance.
- 
SUPER_CLASS_PROPERTIES_JAVADOCSMap of all superclasses properties and their javadocs.
- 
MAIN_FOLDER_PATHPath to main source code folder.
- 
MODULE_SUPER_CLASS_PATHSList of files who are superclasses and contain certain properties that checks inherit.
 
- 
- 
Constructor Details- 
SiteUtilprivate SiteUtil()Private utility constructor.
 
- 
- 
Method Details- 
getMessageKeyspublic static Set<String> getMessageKeys(Class<?> module) throws org.apache.maven.doxia.macro.MacroExecutionException Get string values of the message keys from the given check class.- Parameters:
- module- class to examine.
- Returns:
- a set of checkstyle's module message keys.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if extraction of message keys fails.
 
- 
getCheckMessageKeysFieldsprivate static Set<Field> getCheckMessageKeysFields(Class<?> module) throws org.apache.maven.doxia.macro.MacroExecutionException Gets the check's messages keys.- Parameters:
- module- class to examine.
- Returns:
- a set of checkstyle's module message fields.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the attempt to read a protected class fails.
 
- 
getFieldValuepublic static Object getFieldValue(Field field, Object instance) throws org.apache.maven.doxia.macro.MacroExecutionException Returns the value of the given field.- Parameters:
- field- the field.
- instance- the instance of the module.
- Returns:
- the value of the field.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the value could not be retrieved.
 
- 
getModuleInstancepublic static Object getModuleInstance(String moduleName) throws org.apache.maven.doxia.macro.MacroExecutionException Returns the instance of the module with the given name.- Parameters:
- moduleName- the name of the module.
- Returns:
- the instance of the module.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the module could not be created.
 
- 
getPackageObjectFactoryprivate static PackageObjectFactory getPackageObjectFactory() throws org.apache.maven.doxia.macro.MacroExecutionExceptionReturns the default PackageObjectFactory with the default package names.- Returns:
- the default PackageObjectFactory.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the PackageObjectFactory cannot be created.
 
- 
getNewlineAndIndentSpacesConstruct a string with a leading newline character and followed by the given amount of spaces. We use this method only to match indentation in regular xdocs and have minimal diff when parsing the templates. This method exists until 13426- Parameters:
- amountOfSpaces- the amount of spaces to add after the newline.
- Returns:
- the constructed string.
 
- 
getTemplatePathpublic static Path getTemplatePath(String moduleName) throws org.apache.maven.doxia.macro.MacroExecutionException Returns path to the template for the given module name or throws an exception if the template cannot be found.- Parameters:
- moduleName- the module whose template we are looking for.
- Returns:
- path to the template.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the template cannot be found.
 
- 
getXdocsTemplatesFilePathspublic static Set<Path> getXdocsTemplatesFilePaths() throws org.apache.maven.doxia.macro.MacroExecutionExceptionGets xdocs template file paths. These are files ending with .xml.template. This method will be changed to gather .xml once #13426 is resolved.- Returns:
- a set of xdocs template file paths.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an I/O error occurs.
 
- 
getParentModulepublic static String getParentModule(Class<?> moduleClass) throws org.apache.maven.doxia.macro.MacroExecutionException Returns the parent module name for the given module class. Returns either "TreeWalker" or "Checker". Returns null if the module class is null.- Parameters:
- moduleClass- the module class.
- Returns:
- the parent module name as a string.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the parent module cannot be found.
 
- 
getPropertiesForDocumentationGet a set of properties for the given class that should be documented.- Parameters:
- clss- the class to get the properties for.
- instance- the instance of the module.
- Returns:
- a set of properties for the given class.
 
- 
getModuleJavadocpublic static DetailNode getModuleJavadoc(String moduleClassName, Path modulePath) throws org.apache.maven.doxia.macro.MacroExecutionException Gets the javadoc of module class.- Parameters:
- moduleClassName- name of module class.
- modulePath- module's path.
- Returns:
- javadoc of module.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during processing.
 
- 
getPropertiesJavadocspublic static Map<String,DetailNode> getPropertiesJavadocs(Set<String> properties, String moduleName, Path modulePath) throws org.apache.maven.doxia.macro.MacroExecutionException Get the javadocs of the properties of the module. If the property is not present in the module, then the javadoc of the property from the superclass(es) is used.- Parameters:
- properties- the properties of the module.
- moduleName- the name of the module.
- modulePath- the module file path.
- Returns:
- the javadocs of the properties of the module.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during processing.
 
- 
assertAllPropertySetterJavadocsAreFoundprivate static void assertAllPropertySetterJavadocsAreFound(Set<String> properties, String moduleName, Map<String, DetailNode> javadocs) throws org.apache.maven.doxia.macro.MacroExecutionExceptionAssert that each property has a corresponding setter javadoc that is not null. 'tokens' and 'javadocTokens' are excluded from this check, because their description is different from the description of the setter.- Parameters:
- properties- the properties of the module.
- moduleName- the name of the module.
- javadocs- the javadocs of the properties of the module.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during processing.
 
- 
processSuperclassesprivate static void processSuperclasses() throws org.apache.maven.doxia.macro.MacroExecutionExceptionCollect the properties setters javadocs of the superclasses.- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during processing.
 
- 
processModuleprivate static void processModule(String moduleName, Path modulePath) throws org.apache.maven.doxia.macro.MacroExecutionException Scrape the Javadocs of the class and its properties setters with ClassAndPropertiesSettersJavadocScraper.- Parameters:
- moduleName- the name of the module.
- modulePath- the module Path.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during processing.
 
- 
getPropertiesGet a set of properties for the given class.- Parameters:
- clss- the class to get the properties for.
- Returns:
- a set of properties for the given class.
 
- 
isGlobalPropertyChecks if the property is a global property. Global properties come from the base classes and are common to all checks. For example id, severity, tabWidth, etc.- Parameters:
- clss- the class of the module.
- propertyName- the name of the property.
- Returns:
- true if the property is a global property.
 
- 
isUndocumentedPropertyChecks if the property is supposed to be documented.- Parameters:
- clss- the class of the module.
- propertyName- the name of the property.
- Returns:
- true if the property is supposed to be documented.
 
- 
getNonExplicitPropertiesGets properties that are not explicitly captured but should be documented if certain conditions are met.- Parameters:
- instance- the instance of the module.
- clss- the class of the module.
- Returns:
- the non explicit properties.
 
- 
getPropertyDescriptionForXdocpublic static String getPropertyDescriptionForXdoc(String propertyName, DetailNode javadoc, String moduleName) throws org.apache.maven.doxia.macro.MacroExecutionException Get the description of the property.- Parameters:
- propertyName- the name of the property.
- javadoc- the Javadoc of the property setter method.
- moduleName- the name of the module.
- Returns:
- the description of the property.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the description could not be extracted.
 
- 
getPropertySinceVersionpublic static String getPropertySinceVersion(String moduleName, DetailNode moduleJavadoc, DetailNode propertyJavadoc) throws org.apache.maven.doxia.macro.MacroExecutionException Get the since version of the property.- Parameters:
- moduleName- the name of the module.
- moduleJavadoc- the Javadoc of the module.
- propertyJavadoc- the Javadoc of the property setter method.
- Returns:
- the since version of the property.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the module since version could not be extracted.
 
- 
getPropertyVersionFromItsJavadoc@Nullable private static Optional<String> getPropertyVersionFromItsJavadoc(DetailNode propertyJavadoc) Extract the property since version from its Javadoc.- Parameters:
- propertyJavadoc- the property Javadoc to extract the since version from.
- Returns:
- the Optional of property version specified in its javadoc.
 
- 
getPropertySinceJavadocTagFind the propertySince Javadoc tag node in the given property Javadoc.- Parameters:
- javadoc- the Javadoc to search.
- Returns:
- the Optional of propertySince Javadoc tag node or null if not found.
 
- 
getNodesOfSpecificTypeGets all javadoc nodes of selected type.- Parameters:
- allNodes- Nodes to choose from.
- neededType- the Javadoc token type to select.
- Returns:
- the List of DetailNodes of selected type.
 
- 
getSinceVersionFromJavadocExtract the since version from the Javadoc.- Parameters:
- javadoc- the Javadoc to extract the since version from.
- Returns:
- the since version of the setter.
 
- 
getSinceJavadocTagFind the since Javadoc tag node in the given Javadoc.- Parameters:
- javadoc- the Javadoc to search.
- Returns:
- the since Javadoc tag node or null if not found.
 
- 
isVersionAtLeastReturnstrueifactualVersion≥requiredVersion. Both versions have any trailing "-SNAPSHOT" stripped before comparison.- Parameters:
- actualVersion- e.g. "8.3" or "8.3-SNAPSHOT"
- requiredVersion- e.g. "8.3"
- Returns:
- trueif actualVersion exists, and, numerically, is at least requiredVersion
 
- 
getTypepublic static String getType(Field field, String propertyName, String moduleName, Object instance) throws org.apache.maven.doxia.macro.MacroExecutionException Get the type of the property.- Parameters:
- field- the field to get the type of.
- propertyName- the name of the property.
- moduleName- the name of the module.
- instance- the instance of the module.
- Returns:
- the type of the property.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during getting the type.
 
- 
getDefaultValuepublic static String getDefaultValue(String propertyName, Field field, Object classInstance, String moduleName) throws org.apache.maven.doxia.macro.MacroExecutionException Get the default value of the property.- Parameters:
- propertyName- the name of the property.
- field- the field to get the default value of.
- classInstance- the instance of the class to get the default value of.
- moduleName- the name of the module.
- Returns:
- the default value of the property.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during getting the default value.
 
- 
getPatternArrayPropertyValueGets the name of the bean property's default value for the Pattern array class.- Parameters:
- fieldValue- The bean property's value
- Returns:
- String form of property's default value
 
- 
removeSquareBracketsRemoves square brackets [ and ] from the given string.- Parameters:
- value- the string to remove square brackets from.
- Returns:
- the string without square brackets.
 
- 
getStringArrayPropertyValueGets the name of the bean property's default value for the string array class.- Parameters:
- value- The bean property's value
- Returns:
- String form of property's default value
 
- 
getValuesStreamGenerates a stream of values from the given value.- Parameters:
- value- the value to generate the stream from.
- Returns:
- the stream of values.
 
- 
getIntArrayPropertyValueReturns the name of the bean property's default value for the int array class.- Parameters:
- value- The bean property's value.
- Returns:
- String form of property's default value.
 
- 
getIntStreamGet the int stream from the given value.- Parameters:
- value- the value to get the int stream from.
- Returns:
- the int stream.
 
- 
getFieldClasspublic static Class<?> getFieldClass(Field field, String propertyName, String moduleName, Object instance) throws org.apache.maven.doxia.macro.MacroExecutionException Gets the class of the given field.- Parameters:
- field- the field to get the class of.
- propertyName- the name of the property.
- moduleName- the name of the module.
- instance- the instance of the module.
- Returns:
- the class of the field.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during getting the class.
 
- 
getPropertyClasspublic static Class<?> getPropertyClass(String propertyName, Object instance) throws org.apache.maven.doxia.macro.MacroExecutionException Gets the class of the given java property.- Parameters:
- propertyName- the name of the property.
- instance- the instance of the module.
- Returns:
- the class of the java property.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if an error occurs during getting the class.
 
- 
getDifferenceGet the difference between two lists of tokens.- Parameters:
- tokens- the list of tokens to remove from.
- subtractions- the tokens to remove.
- Returns:
- the difference between the two lists.
 
- 
getFieldGets the field with the given name from the given class.- Parameters:
- fieldClass- the class to get the field from.
- propertyName- the name of the field.
- Returns:
- the field we are looking for.
 
- 
getLinkToDocumentpublic static String getLinkToDocument(String moduleName, String document) throws org.apache.maven.doxia.macro.MacroExecutionException Constructs string with relative link to the provided document.- Parameters:
- moduleName- the name of the module.
- document- the path of the document.
- Returns:
- relative link to the document.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if link to the document cannot be constructed.
 
- 
getTemplatesThatContainPropertiesMacropublic static List<Path> getTemplatesThatContainPropertiesMacro() throws CheckstyleException, org.apache.maven.doxia.macro.MacroExecutionExceptionGet all templates whose content contains properties macro.- Returns:
- templates whose content contains properties macro.
- Throws:
- CheckstyleException- if file could not be read.
- org.apache.maven.doxia.macro.MacroExecutionException- if template file is not found.
 
- 
getFileContentsGet file contents as string.- Parameters:
- pathToFile- path to file.
- Returns:
- file contents as string.
- Throws:
- CheckstyleException- if file could not be read.
 
- 
getModuleNameGet the module name from the file. The module name is the file name without the extension.- Parameters:
- file- file to extract the module name from.
- Returns:
- module name.
 
- 
getDescriptionFromJavadocForXdocprivate static String getDescriptionFromJavadocForXdoc(DetailNode javadoc, String moduleName) throws org.apache.maven.doxia.macro.MacroExecutionException Extracts the description from the javadoc detail node. Performs a DFS traversal on the detail node and extracts the text nodes. This description is additionally processed to fit Xdoc format.- Parameters:
- javadoc- the Javadoc to extract the description from.
- moduleName- the name of the module.
- Returns:
- the description of the setter.
- Throws:
- org.apache.maven.doxia.macro.MacroExecutionException- if the description could not be extracted.
 
- 
getFirstParagraphFromJavadocGet 1st paragraph from the Javadoc with no additional processing.- Parameters:
- javadoc- the Javadoc to extract first paragraph from.
- Returns:
- first paragraph of javadoc.
 
- 
getFirstJavadocParagraphNodesExtracts first paragraph nodes from javadoc.- Parameters:
- javadoc- the Javadoc to extract the description from.
- Returns:
- the first paragraph nodes of the setter.
 
- 
isEndOfFirstJavadocParagraphDetermines if the given child index is the end of the first Javadoc paragraph. The end of the description is defined as 4 consecutive nodes of type NEWLINE, LEADING_ASTERISK, NEWLINE, LEADING_ASTERISK. This is an asterisk that is alone on a line. Just like the one below this line.- Parameters:
- child- the child to check.
- Returns:
- true if the given child index is the end of the first javadoc paragraph.
 
- 
simplifyTypeNameSimplifies type name just to the name of the class, rather than entire package.- Parameters:
- fullTypeName- full type name.
- Returns:
- simplified type name, that is, name of the class.
 
 
-