Package net.sf.saxon.expr.sort
Class HTML5CaseBlindCollator
- java.lang.Object
-
- net.sf.saxon.expr.sort.HTML5CaseBlindCollator
-
- All Implemented Interfaces:
StringCollator
,SubstringMatcher
public class HTML5CaseBlindCollator extends java.lang.Object implements StringCollator, SubstringMatcher
A collating sequence that compares strings according to the HTML5 rules for case-blind matching. Specifically, case is ignored for ASCII (English) letters, but not for letters outside the ASCII range.
-
-
Constructor Summary
Constructors Constructor Description HTML5CaseBlindCollator()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
comparesEqual(UnicodeString s1, UnicodeString s2)
Test whether one string is equal to another, according to the rules of the XPath compare() function.int
compareStrings(UnicodeString a, UnicodeString b)
Compare two string objects.boolean
contains(UnicodeString s1, UnicodeString s2)
Test whether one string contains another, according to the rules of the XPath contains() functionboolean
endsWith(UnicodeString s1, UnicodeString s2)
Test whether one string ends with another, according to the rules of the XPath ends-with() functionAtomicMatchKey
getCollationKey(UnicodeString s)
Get a collation key for a string.java.lang.String
getCollationURI()
Get the collation URI.static HTML5CaseBlindCollator
getInstance()
boolean
startsWith(UnicodeString s1, UnicodeString s2)
Test whether one string starts with another, according to the rules of the XPath starts-with() functionUnicodeString
substringAfter(UnicodeString s1, UnicodeString s2)
Return the part of a string after a given substring, according to the rules of the XPath substring-after() functionUnicodeString
substringBefore(UnicodeString s1, UnicodeString s2)
Return the part of a string before a given substring, according to the rules of the XPath substring-before() function-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface net.sf.saxon.lib.StringCollator
isEqualToEmpty
-
-
-
-
Method Detail
-
getInstance
public static HTML5CaseBlindCollator getInstance()
-
getCollationURI
public java.lang.String getCollationURI()
Get the collation URI. It must be possible to use this collation URI to reconstitute the collation- Specified by:
getCollationURI
in interfaceStringCollator
- Returns:
- a collation URI that can be used to reconstruct the collation when an XSLT package is reloaded.
-
compareStrings
public int compareStrings(UnicodeString a, UnicodeString b)
Compare two string objects.- Specified by:
compareStrings
in interfaceStringCollator
- Parameters:
a
- the first stringb
- the second string- Returns:
- <0 if a<b, 0 if a=b, >0 if a>b
- Throws:
java.lang.ClassCastException
- if the objects are of the wrong type for this Comparer
-
comparesEqual
public boolean comparesEqual(UnicodeString s1, UnicodeString s2)
Test whether one string is equal to another, according to the rules of the XPath compare() function. The result is true if and only if the compare() method returns zero: but the implementation may be more efficient than calling compare and testing the result for zero- Specified by:
comparesEqual
in interfaceStringCollator
- Parameters:
s1
- the first strings2
- the second string- Returns:
- true iff s1 equals s2
-
contains
public boolean contains(UnicodeString s1, UnicodeString s2)
Test whether one string contains another, according to the rules of the XPath contains() function- Specified by:
contains
in interfaceSubstringMatcher
- Parameters:
s1
- the containing strings2
- the contained string- Returns:
- true iff s1 contains s2
-
endsWith
public boolean endsWith(UnicodeString s1, UnicodeString s2)
Test whether one string ends with another, according to the rules of the XPath ends-with() function- Specified by:
endsWith
in interfaceSubstringMatcher
- Parameters:
s1
- the containing strings2
- the contained string- Returns:
- true iff s1 ends with s2
-
startsWith
public boolean startsWith(UnicodeString s1, UnicodeString s2)
Test whether one string starts with another, according to the rules of the XPath starts-with() function- Specified by:
startsWith
in interfaceSubstringMatcher
- Parameters:
s1
- the containing strings2
- the contained string- Returns:
- true iff s1 starts with s2
-
substringAfter
public UnicodeString substringAfter(UnicodeString s1, UnicodeString s2)
Return the part of a string after a given substring, according to the rules of the XPath substring-after() function- Specified by:
substringAfter
in interfaceSubstringMatcher
- Parameters:
s1
- the containing strings2
- the contained string- Returns:
- the part of s1 that follows the first occurrence of s2
-
substringBefore
public UnicodeString substringBefore(UnicodeString s1, UnicodeString s2)
Return the part of a string before a given substring, according to the rules of the XPath substring-before() function- Specified by:
substringBefore
in interfaceSubstringMatcher
- Parameters:
s1
- the containing strings2
- the contained string- Returns:
- the part of s1 that precedes the first occurrence of s2
-
getCollationKey
public AtomicMatchKey getCollationKey(UnicodeString s)
Get a collation key for a string. The essential property of collation keys is that if two values are equal under the collation, then the collation keys are compare correctly under the equals() method.- Specified by:
getCollationKey
in interfaceStringCollator
- Parameters:
s
- the string whose collation key is required- Returns:
- the collation key
-
-