Class AvoidEscapedUnicodeCharactersCheck
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.AvoidEscapedUnicodeCharactersCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Restricts using
 
 Unicode escapes
 (such as \u221e). It is possible to allow using escapes for
 
 non-printable, control characters.
 Also, this check can be configured to allow using escapes
 if trail comment is present. By the option it is possible to
 allow using escapes if literal contains only them.
 
 - 
 Property allowByTailComment- Allow use escapes if trail comment is present. Type isboolean. Default value isfalse.
- 
 Property allowEscapesForControlCharacters- Allow use escapes for non-printable, control characters. Type isboolean. Default value isfalse.
- 
 Property allowIfAllCharactersEscaped- Allow if all characters in literal are escaped. Type isboolean. Default value isfalse.
- 
 Property allowNonPrintableEscapes- Allow use escapes for non-printable, whitespace characters. Type isboolean. Default value isfalse.
 Parent is com.puppycrawl.tools.checkstyle.TreeWalker
 
Violation Message Keys:
- 
 forbid.escaped.unicode.char
- Since:
- 5.8
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate static final PatternRegular expression for all escaped chars.private booleanAllow use escapes if trail comment is present.private booleanAllow use escapes for non-printable, control characters.private booleanAllow if all characters in literal are escaped.private booleanAllow use escapes for non-printable, whitespace characters.C style comments.private static final PatternRegular expression for escaped backslash.static final StringA key is pointing to the warning message text in "messages.properties" file.private static final PatternRegular expression for non-printable unicode chars.Cpp style comments.private static final PatternRegular expression Unicode control characters.private static final PatternRegular expression for Unicode chars.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidCalled before the starting to process a tree.private static intcountMatches(Pattern pattern, String target) Count regexp matches into String literal.int[]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 booleanhasTrailComment(DetailAST ast) Check if trail comment is present after ast token.private static booleanhasUnicodeChar(String literal) Checks if literal has Unicode chars.private booleanisAllCharactersEscaped(String literal) Checks if all characters in String literal is escaped.private static booleanisOnlyUnicodeValidChars(String literal, Pattern pattern) Check if String literal contains Unicode control chars.private static booleanisTrailingBlockComment(TextBlock comment, int... codePoints) Whether the C style comment is trailing.final voidsetAllowByTailComment(boolean allow) Setter to allow use escapes if trail comment is present.final voidsetAllowEscapesForControlCharacters(boolean allow) Setter to allow use escapes for non-printable, control characters.final voidsetAllowIfAllCharactersEscaped(boolean allow) Setter to allow if all characters in literal are escaped.final voidsetAllowNonPrintableEscapes(boolean allow) Setter to allow use escapes for non-printable, whitespace characters.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckclearViolations, 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:
 
- 
UNICODE_REGEXPRegular expression for Unicode chars.
- 
UNICODE_CONTROLRegular expression Unicode control characters.- See Also:
 
- 
ALL_ESCAPED_CHARSRegular expression for all escaped chars. See EscapeSequence
- 
ESCAPED_BACKSLASHRegular expression for escaped backslash.
- 
NON_PRINTABLE_CHARSRegular expression for non-printable unicode chars.
- 
singlelineCommentsCpp style comments.
- 
blockCommentsC style comments.
- 
allowEscapesForControlCharactersAllow use escapes for non-printable, control characters.
- 
allowByTailCommentAllow use escapes if trail comment is present.
- 
allowIfAllCharactersEscapedAllow if all characters in literal are escaped.
- 
allowNonPrintableEscapesAllow use escapes for non-printable, whitespace characters.
 
- 
- 
Constructor Details- 
AvoidEscapedUnicodeCharactersCheckpublic AvoidEscapedUnicodeCharactersCheck()
 
- 
- 
Method Details- 
setAllowEscapesForControlCharactersSetter to allow use escapes for non-printable, control characters.- Parameters:
- allow- user's value.
- Since:
- 5.8
 
- 
setAllowByTailCommentSetter to allow use escapes if trail comment is present.- Parameters:
- allow- user's value.
- Since:
- 5.8
 
- 
setAllowIfAllCharactersEscapedSetter to allow if all characters in literal are escaped.- Parameters:
- allow- user's value.
- Since:
- 5.8
 
- 
setAllowNonPrintableEscapesSetter to allow use escapes for non-printable, whitespace characters.- Parameters:
- allow- user's value.
- Since:
- 5.8
 
- 
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:
 
- 
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:
 
- 
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:
 
- 
beginTreeDescription copied from class:AbstractCheckCalled before the starting to process a tree. Ideal place to initialize information that is to be collected whilst processing a tree.- Overrides:
- beginTreein class- AbstractCheck
- Parameters:
- rootAST- the root of the tree
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
hasUnicodeCharChecks if literal has Unicode chars.- Parameters:
- literal- String literal.
- Returns:
- true if literal has Unicode chars.
 
- 
isOnlyUnicodeValidCharsCheck if String literal contains Unicode control chars.- Parameters:
- literal- String literal.
- pattern- RegExp for valid characters.
- Returns:
- true, if String literal contains Unicode control chars.
 
- 
hasTrailCommentCheck if trail comment is present after ast token.- Parameters:
- ast- current token.
- Returns:
- true if trail comment is present after ast token.
 
- 
isTrailingBlockCommentWhether the C style comment is trailing.- Parameters:
- comment- the comment to check.
- codePoints- the first line of the comment, in unicode code points
- Returns:
- true if the comment is trailing.
 
- 
countMatchesCount regexp matches into String literal.- Parameters:
- pattern- pattern.
- target- String literal.
- Returns:
- count of regexp matches.
 
- 
isAllCharactersEscapedChecks if all characters in String literal is escaped.- Parameters:
- literal- current literal.
- Returns:
- true if all characters in String literal is escaped.
 
 
-