/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- * * The contents of this file are subject to the Netscape Public License * Version 1.0 (the "NPL"); you may not use this file except in * compliance with the NPL. You may obtain a copy of the NPL at * http://www.mozilla.org/NPL/ * * Software distributed under the NPL is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL * for the specific language governing rights and limitations under the * NPL. * * The Initial Developer of this code under the NPL is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1998 Netscape Communications Corporation. All Rights * Reserved. */ #ifndef nsICollation_h__ #define nsICollation_h__ #include "nsISupports.h" #include "nscore.h" #include "nsString.h" #include "nsILocale.h" // {D4CF2F80-A98B-11d2-9119-006008A6EDF6} #define NS_ICOLLATIONFACTORY_IID \ { 0xd4cf2f80, 0xa98b, 0x11d2, \ { 0x91, 0x19, 0x0, 0x60, 0x8, 0xa6, 0xed, 0xf6 } } // {CDBFD3F0-A4FE-11d2-9119-006008A6EDF6} #define NS_ICOLLATION_IID \ { 0xcdbfd3f0, 0xa4fe, 0x11d2, \ { 0x91, 0x19, 0x0, 0x60, 0x8, 0xa6, 0xed, 0xf6 } } typedef enum { kCollationStrengthDefault = 0, // use the primary comparison for the given local - no flags) kCollationCaseInsensitiveAscii = 1, // do not consider case differences when doing the comparison i.e. A=a) kCollationAccentInsenstive = 2, // do not consider accent differences when doing the comparison a=á) kCollationCaseSensitive = kCollationStrengthDefault, kCollationCaseInSensitive = (kCollationCaseInsensitiveAscii | kCollationAccentInsenstive) } nsCollationStrength; class nsICollation; // Create a collation interface for an input locale. // class nsICollationFactory : public nsISupports { public: static const nsIID& GetIID() { static nsIID iid = NS_ICOLLATIONFACTORY_IID; return iid; } NS_IMETHOD CreateCollation(nsILocale* locale, nsICollation** instancePtr) = 0; }; // Locale sensitive collation interface // class nsICollation : public nsISupports { public: static const nsIID& GetIID() { static nsIID iid = NS_ICOLLATION_IID; return iid; } // compare two strings // result is same as strcmp NS_IMETHOD CompareString(const nsCollationStrength strength, const nsString& string1, const nsString& string2, PRInt32* result) = 0; // get a length (of character) of a sort key to be generated by an input string // length is a byte length NS_IMETHOD GetSortKeyLen(const nsCollationStrength strength, const nsString& stringIn, PRUint32* outLen) = 0; // create sort key from input string // length is a byte length, caller should allocate a memory for a key NS_IMETHOD CreateRawSortKey(const nsCollationStrength strength, const nsString& stringIn, PRUint8* key, PRUint32 *outLen) = 0; // create a sort key (nsString) NS_IMETHOD CreateSortKey(const nsCollationStrength strength, const nsString& stringIn, nsString& key) = 0; // compare two sort keys // length is a byte length, result is same as strcmp NS_IMETHOD CompareRawSortKey(const PRUint8* key1, const PRUint32 len1, const PRUint8* key2, const PRUint32 len2, PRInt32* result) = 0; // compare two sort keys (nsString) NS_IMETHOD CompareSortKey(const nsString& key1, const nsString& key2, PRInt32* result) = 0; // init this interface to a specified locale (should only be called by collation factory) // NS_IMETHOD Initialize(nsILocale* locale) = 0; }; #endif /* nsICollation_h__ */