Package com.ibm.icu.impl
Class Norm2AllModes.ComposeNormalizer2
java.lang.Object
com.ibm.icu.text.Normalizer2
com.ibm.icu.impl.Norm2AllModes.Normalizer2WithImpl
com.ibm.icu.impl.Norm2AllModes.ComposeNormalizer2
- Enclosing class:
Norm2AllModes
public static final class Norm2AllModes.ComposeNormalizer2
extends Norm2AllModes.Normalizer2WithImpl
-
Nested Class Summary
Nested classes/interfaces inherited from class com.ibm.icu.text.Normalizer2
Normalizer2.Mode
-
Field Summary
FieldsFields inherited from class com.ibm.icu.impl.Norm2AllModes.Normalizer2WithImpl
impl
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionint
getQuickCheck
(int c) boolean
hasBoundaryAfter
(int c) Tests if the character always has a normalization boundary after it, regardless of context.boolean
hasBoundaryBefore
(int c) Tests if the character always has a normalization boundary before it, regardless of context.boolean
isInert
(int c) Tests if the character is normalization-inert.boolean
Tests if the string is normalized.protected void
normalize
(CharSequence src, Normalizer2Impl.ReorderingBuffer buffer) protected void
normalizeAndAppend
(CharSequence src, boolean doNormalize, Normalizer2Impl.ReorderingBuffer buffer) Tests if the string is normalized.int
Returns the end of the normalized substring of the input string.Methods inherited from class com.ibm.icu.impl.Norm2AllModes.Normalizer2WithImpl
append, composePair, getCombiningClass, getDecomposition, getRawDecomposition, normalize, normalize, normalizeSecondAndAppend, normalizeSecondAndAppend
Methods inherited from class com.ibm.icu.text.Normalizer2
getInstance, getNFCInstance, getNFDInstance, getNFKCCasefoldInstance, getNFKCInstance, getNFKCSimpleCasefoldInstance, getNFKDInstance, normalize
-
Field Details
-
onlyContiguous
private final boolean onlyContiguous
-
-
Constructor Details
-
ComposeNormalizer2
-
-
Method Details
-
normalize
- Specified by:
normalize
in classNorm2AllModes.Normalizer2WithImpl
-
normalizeAndAppend
protected void normalizeAndAppend(CharSequence src, boolean doNormalize, Normalizer2Impl.ReorderingBuffer buffer) - Specified by:
normalizeAndAppend
in classNorm2AllModes.Normalizer2WithImpl
-
isNormalized
Description copied from class:Normalizer2
Tests if the string is normalized. Internally, in cases where the quickCheck() method would return "maybe" (which is only possible for the two COMPOSE modes) this method resolves to "yes" or "no" to provide a definitive result, at the cost of doing more work in those cases.- Overrides:
isNormalized
in classNorm2AllModes.Normalizer2WithImpl
- Parameters:
s
- input string- Returns:
- true if s is normalized
-
quickCheck
Description copied from class:Normalizer2
Tests if the string is normalized. For the two COMPOSE modes, the result could be "maybe" in cases that would take a little more work to resolve definitively. Use spanQuickCheckYes() and normalizeSecondAndAppend() for a faster combination of quick check + normalization, to avoid re-checking the "yes" prefix.- Overrides:
quickCheck
in classNorm2AllModes.Normalizer2WithImpl
- Parameters:
s
- input string- Returns:
- the quick check result
-
spanQuickCheckYes
Description copied from class:Normalizer2
Returns the end of the normalized substring of the input string. In other words, withend=spanQuickCheckYes(s);
the substrings.subSequence(0, end)
will pass the quick check with a "yes" result.The returned end index is usually one or more characters before the "no" or "maybe" character: The end index is at a normalization boundary. (See the class documentation for more about normalization boundaries.)
When the goal is a normalized string and most input strings are expected to be normalized already, then call this method, and if it returns a prefix shorter than the input string, copy that prefix and use normalizeSecondAndAppend() for the remainder.
- Specified by:
spanQuickCheckYes
in classNormalizer2
- Parameters:
s
- input string- Returns:
- "yes" span end index
-
getQuickCheck
public int getQuickCheck(int c) - Specified by:
getQuickCheck
in classNorm2AllModes.Normalizer2WithImpl
-
hasBoundaryBefore
public boolean hasBoundaryBefore(int c) Description copied from class:Normalizer2
Tests if the character always has a normalization boundary before it, regardless of context. If true, then the character does not normalization-interact with preceding characters. In other words, a string containing this character can be normalized by processing portions before this character and starting from this character independently. This is used for iterative normalization. See the class documentation for details.- Specified by:
hasBoundaryBefore
in classNormalizer2
- Parameters:
c
- character to test- Returns:
- true if c has a normalization boundary before it
-
hasBoundaryAfter
public boolean hasBoundaryAfter(int c) Description copied from class:Normalizer2
Tests if the character always has a normalization boundary after it, regardless of context. If true, then the character does not normalization-interact with following characters. In other words, a string containing this character can be normalized by processing portions up to this character and after this character independently. This is used for iterative normalization. See the class documentation for details.Note that this operation may be significantly slower than hasBoundaryBefore().
- Specified by:
hasBoundaryAfter
in classNormalizer2
- Parameters:
c
- character to test- Returns:
- true if c has a normalization boundary after it
-
isInert
public boolean isInert(int c) Description copied from class:Normalizer2
Tests if the character is normalization-inert. If true, then the character does not change, nor normalization-interact with preceding or following characters. In other words, a string containing this character can be normalized by processing portions before this character and after this character independently. This is used for iterative normalization. See the class documentation for details.Note that this operation may be significantly slower than hasBoundaryBefore().
- Specified by:
isInert
in classNormalizer2
- Parameters:
c
- character to test- Returns:
- true if c is normalization-inert
-