All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.saxon.lib.StringCollator Maven / Gradle / Ivy

There is a newer version: 12.5
Show newest version
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2018-2023 Saxonica Limited
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

package net.sf.saxon.lib;

import net.sf.saxon.expr.sort.AtomicMatchKey;
import net.sf.saxon.str.EmptyUnicodeString;
import net.sf.saxon.str.UnicodeString;

/**
 * This interface represents a "collation" as defined in XPath, that is, a set of rules for comparing strings
 * 

Note: an implementation of this interface that wraps a Java {@link java.text.RuleBasedCollator} is * available: see {@link net.sf.saxon.expr.sort.RuleBasedSubstringMatcher}.

*/ public interface StringCollator { /** * Get the collation URI. It must be possible to use this collation URI to reconstitute the collation * @return a collation URI that can be used to reconstruct the collation when an XSLT package is reloaded. */ String getCollationURI(); /** * Compare two strings * * @param o1 the first string * @param o2 the second string * @return 0 if the strings are considered equal, a negative integer if the first string is less than the second, * a positive integer if the first string is greater than the second */ int compareStrings(UnicodeString o1, UnicodeString o2); /** * Compare two strings for equality. This may be more efficient than using compareStrings and * testing whether the result is zero, but it must give the same result * * @param s1 the first string * @param s2 the second string * @return true if and only if the strings are considered equal, */ boolean comparesEqual(UnicodeString s1, UnicodeString s2); /** * Test if a supplied string compares equal to the empty string * @param s1 the supplied string */ default boolean isEqualToEmpty(UnicodeString s1) { return comparesEqual(s1, EmptyUnicodeString.getInstance()); } /** * Get a collation key for a String. The essential property of collation keys * is that if (and only if) two strings are equal under the collation, then * comparing the collation keys using the equals() method must return true. * * @param s the string whose collation key is required * @return the collation key */ AtomicMatchKey getCollationKey(UnicodeString s); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy