Class GoogleMemberNameCheck
java.lang.Object
com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
com.puppycrawl.tools.checkstyle.api.AbstractCheck
com.puppycrawl.tools.checkstyle.checks.naming.GoogleMemberNameCheck
- All Implemented Interfaces:
Configurable,Contextualizable
Checks that member names conform to the
Google Java Style Guide for non-constant field naming.
This check enforces Google's specific member naming requirements:
- Member names must start with a lowercase letter and use uppercase letters for word boundaries.
- Underscores may be used to separate adjacent numbers (e.g., version
numbers like
guava33_4_5), but NOT between letters and digits.
- Since:
- 13.1.0
-
Nested Class Summary
Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
AbstractAutomaticBean.OutputStreamOptions -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final PatternPattern to detect invalid underscore usage: leading, trailing, consecutive, or between letter-letter, letter-digit, or digit-letter combinations.private static final PatternPattern for valid member names in Google style.static final StringA key is pointing to the violation message text in "messages.properties" file.static final StringA key pointing to the violation message for invalid underscore usage.private static final PatternPattern to strip trailing numbering suffix (underscore followed by digits). -
Constructor Summary
Constructors -
Method Summary
Modifier 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 booleanmustCheckName(DetailAST ast) Checks if this field should be validated.private voidvalidateMemberName(DetailAST nameAst, String memberName) Validates a member name according to Google style.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheck
beginTree, 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.AbstractViolationReporter
finishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
configure, contextualize, getConfiguration, setupChild
-
Field Details
-
MSG_KEY_INVALID_FORMAT
A key is pointing to the violation message text in "messages.properties" file.- See Also:
-
MSG_KEY_INVALID_UNDERSCORE
A key pointing to the violation message for invalid underscore usage.- See Also:
-
MEMBER_NAME_PATTERN
Pattern for valid member names in Google style. Format: lowerCamelCase, optionally followed by numbering suffix.Explanation:
^(?![a-z]$)- Negative lookahead: cannot be single lowercase char(?![a-z][A-Z])- Negative lookahead: cannot be like "fO"[a-z]- Must start with lowercase[a-z0-9]*- Followed by lowercase or digits(?:[A-Z][a-z0-9]*)*- CamelCase humps (uppercase followed by lowercase)$- End of string (numbering suffix validated separately)
-
NUMBERING_SUFFIX_PATTERN
Pattern to strip trailing numbering suffix (underscore followed by digits). -
INVALID_UNDERSCORE_PATTERN
Pattern to detect invalid underscore usage: leading, trailing, consecutive, or between letter-letter, letter-digit, or digit-letter combinations.
-
-
Constructor Details
-
GoogleMemberNameCheck
public GoogleMemberNameCheck()
-
-
Method Details
-
getDefaultTokens
Description 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 classAbstractCheck- Returns:
- the default tokens
- See Also:
-
getAcceptableTokens
Description 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 classAbstractCheck- Returns:
- the token set this check is designed for.
- See Also:
-
getRequiredTokens
Description copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
getRequiredTokensin classAbstractCheck- Returns:
- the token set this must be registered for.
- See Also:
-
visitToken
Description copied from class:AbstractCheckCalled to process a token.- Overrides:
visitTokenin classAbstractCheck- Parameters:
ast- the token to process
-
mustCheckName
Checks if this field should be validated. Returns true for instance fields and static non-final fields. Constants (static final), local variables, and interface/annotation fields are excluded.- Parameters:
ast- the VARIABLE_DEF AST node- Returns:
- true if this variable should be checked
-
validateMemberName
Validates a member name according to Google style.- Parameters:
nameAst- the IDENT AST node containing the member namememberName- the member name string
-