compare(_:options:range:locale:)
Compares the string using the specified options and returns the lexical ordering for the range.
Declaration
func compare(_ string: String, options mask: NSString.CompareOptions = [], range rangeOfReceiverToCompare: NSRange, locale: Any?) -> ComparisonResultParameters
- string:
The string with which to compare the range of the receiver specified by
range.This value must not be
nil. If this value isnil, the behavior is undefined and may change in future versions of macOS. - mask:
Options for the search—you can combine any of the following using a C bitwise OR operator:
NSCaseInsensitiveSearch,NSLiteralSearch,NSNumericSearch.See 10000035i for details on these options.
- rangeOfReceiverToCompare:
The range of the receiver over which to perform the comparison. The range must not exceed the bounds of the receiver.
- locale:
An instance of Nslocale. To use the current locale, pass [Nslocale Current]. For example, if you are comparing strings to present to the end-user, use the current locale. To use the system locale, pass
nil.
Return Value
Returns an ComparisonResult value that indicates the lexical ordering of a specified range within the receiver and a given string. ComparisonResult.orderedAscending if the substring of the receiver given by range precedes aString in lexical ordering for the locale given in dict, ComparisonResult.orderedSame if the substring of the receiver and aString are equivalent in lexical value, and ComparisonResult.orderedDescending if the substring of the receiver follows aString.
Discussion
The locale argument affects both equality and ordering algorithms. For example, in some locales, accented characters are ordered immediately after the base; other locales order them after “z”.