Class ClassMemberImpliedModifierCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
This check is effectively the opposite of RedundantModifier. It checks the modifiers on nested types in classes and records, ensuring that certain modifiers are explicitly specified even though they are actually redundant.
 Nested enums, interfaces, and records within a class are always static and as such the
 compiler does not require the static modifier. This check provides the ability to enforce
 that the static modifier is explicitly coded and not implicitly added by the compiler.
 
 public final class Person {
   enum Age {  // violation
     CHILD, ADULT
   }
 }
 
 Rationale for this check: Nested enums, interfaces, and records are treated differently from
 nested classes as they are only allowed to be static. Developers should not need to
 remember this rule, and this check provides the means to enforce that the modifier is coded
 explicitly.
 
- 
 Property violateImpliedStaticOnNestedEnum- Control whether to enforce thatstaticis explicitly coded on nested enums in classes and records. Type isboolean. Default value istrue.
- 
 Property violateImpliedStaticOnNestedInterface- Control whether to enforce thatstaticis explicitly coded on nested interfaces in classes and records. Type isboolean. Default value istrue.
- 
 Property violateImpliedStaticOnNestedRecord- Control whether to enforce thatstaticis explicitly coded on nested records in classes and records. Type isboolean. Default value istrue.
 Parent is com.puppycrawl.tools.checkstyle.TreeWalker
 
Violation Message Keys:
- 
 class.implied.modifier
- Since:
- 8.16
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringA key is pointing to the warning message text in "messages.properties" file.private static final StringName for 'static' keyword.private booleanControl whether to enforce thatstaticis explicitly coded on nested enums in classes and records.private booleanControl whether to enforce thatstaticis explicitly coded on nested interfaces in classes and records.private booleanControl whether to enforce thatstaticis explicitly coded on nested records in classes and records.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionint[]The configurable token set.int[]Returns the default token a check is interested in.int[]The tokens that this check must be registered for.private static booleanisInTypeBlock(DetailAST ast) Checks if ast is in a class, enum, anon class or record block.voidsetViolateImpliedStaticOnNestedEnum(boolean violateImplied) Setter to control whether to enforce thatstaticis explicitly coded on nested enums in classes and records.voidsetViolateImpliedStaticOnNestedInterface(boolean violateImplied) Setter to control whether to enforce thatstaticis explicitly coded on nested interfaces in classes and records.voidsetViolateImpliedStaticOnNestedRecord(boolean violateImplied) Setter to control whether to enforce thatstaticis explicitly coded on nested records in classes and records.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckbeginTree, clearViolations, destroy, finishTree, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, leaveToken, log, log, log, setFileContents, setTabWidth, setTokensMethods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporterfinishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanconfigure, contextualize, getConfiguration, setupChild
- 
Field Details- 
MSG_KEYA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
STATIC_KEYWORDName for 'static' keyword.- See Also:
 
- 
violateImpliedStaticOnNestedEnumControl whether to enforce thatstaticis explicitly coded on nested enums in classes and records.
- 
violateImpliedStaticOnNestedInterfaceControl whether to enforce thatstaticis explicitly coded on nested interfaces in classes and records.
- 
violateImpliedStaticOnNestedRecordControl whether to enforce thatstaticis explicitly coded on nested records in classes and records.
 
- 
- 
Constructor Details- 
ClassMemberImpliedModifierCheckpublic ClassMemberImpliedModifierCheck()
 
- 
- 
Method Details- 
setViolateImpliedStaticOnNestedEnumSetter to control whether to enforce thatstaticis explicitly coded on nested enums in classes and records.- Parameters:
- violateImplied- True to perform the check, false to turn the check off.
- Since:
- 8.16
 
- 
setViolateImpliedStaticOnNestedInterfaceSetter to control whether to enforce thatstaticis explicitly coded on nested interfaces in classes and records.- Parameters:
- violateImplied- True to perform the check, false to turn the check off.
- Since:
- 8.16
 
- 
setViolateImpliedStaticOnNestedRecordSetter to control whether to enforce thatstaticis explicitly coded on nested records in classes and records.- Parameters:
- violateImplied- True to perform the check, false to turn the check off.
- Since:
- 8.36
 
- 
getDefaultTokensDescription copied from class:AbstractCheckReturns the default token a check is interested in. Only used if the configuration for a check does not define the tokens.- Specified by:
- getDefaultTokensin class- AbstractCheck
- Returns:
- the default tokens
- See Also:
 
- 
getRequiredTokensDescription copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
- getRequiredTokensin class- AbstractCheck
- Returns:
- the token set this must be registered for.
- See Also:
 
- 
getAcceptableTokensDescription copied from class:AbstractCheckThe configurable token set. Used to protect Checks against malicious users who specify an unacceptable token set in the configuration file. The default implementation returns the check's default tokens.- Specified by:
- getAcceptableTokensin class- AbstractCheck
- Returns:
- the token set this check is designed for.
- See Also:
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
isInTypeBlockChecks if ast is in a class, enum, anon class or record block.- Parameters:
- ast- the current ast
- Returns:
- true if ast is in a class, enum, anon class or record
 
 
-