]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/i18n/unicode/sortkey.h
ICU-62123.0.1.tar.gz
[apple/icu.git] / icuSources / i18n / unicode / sortkey.h
index ef202dd9ba43b903a7e30ffc012f01bda9356acd..5ac1fe11723eabde57cc2a51ccabbf731153708a 100644 (file)
@@ -1,6 +1,8 @@
+// © 2016 and later: Unicode, Inc. and others.
+// License & terms of use: http://www.unicode.org/copyright.html
 /*
  *****************************************************************************
- * Copyright (C) 1996-2006, International Business Machines Corporation and others.
+ * Copyright (C) 1996-2014, International Business Machines Corporation and others.
  * All Rights Reserved.
  *****************************************************************************
  *
 #include "unicode/unistr.h"
 #include "unicode/coll.h"
 
+#if U_SHOW_CPLUSPLUS_API
 U_NAMESPACE_BEGIN
 
 /* forward declaration */
 class RuleBasedCollator;
+class CollationKeyByteSink;
 
 /**
  *
@@ -91,7 +95,7 @@ class RuleBasedCollator;
  * @see          RuleBasedCollator
  * @version      1.3 12/18/96
  * @author       Helena Shih
- * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+ * @stable ICU 2.0
  */
 class U_I18N_API CollationKey : public UObject {
 public:
@@ -100,7 +104,7 @@ public:
     * collation key contains no sorting information.  When comparing two empty
     * collation keys, the result is Collator::EQUAL.  Comparing empty collation key
     * with non-empty collation key is always Collator::LESS.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     CollationKey();
 
@@ -109,7 +113,7 @@ public:
     * Creates a collation key based on the collation key values.
     * @param values the collation key values
     * @param count number of collation key values, including trailing nulls.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     CollationKey(const  uint8_t*    values,
                 int32_t     count);
@@ -117,20 +121,20 @@ public:
     /**
     * Copy constructor.
     * @param other    the object to be copied.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     CollationKey(const CollationKey& other);
 
     /**
     * Sort key destructor.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     virtual ~CollationKey();
 
     /**
     * Assignment operator
     * @param other    the object to be copied.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     const   CollationKey&   operator=(const CollationKey& other);
 
@@ -138,7 +142,7 @@ public:
     * Compare if two collation keys are the same.
     * @param source the collation key to compare to.
     * @return Returns true if two collation keys are equal, false otherwise.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     UBool                   operator==(const CollationKey& source) const;
 
@@ -146,7 +150,7 @@ public:
     * Compare if two collation keys are not the same.
     * @param source the collation key to compare to.
     * @return Returns TRUE if two collation keys are different, FALSE otherwise.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     UBool                   operator!=(const CollationKey& source) const;
 
@@ -155,7 +159,7 @@ public:
     * Test to see if the key is in an invalid state. The key will be in an
     * invalid state if it couldn't allocate memory for some operation.
     * @return Returns TRUE if the key is in an invalid, FALSE otherwise.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     UBool                   isBogus(void) const;
 
@@ -166,7 +170,7 @@ public:
     * @param count the output parameter of number of collation key values,
     * including any trailing nulls.
     * @return a pointer to the collation key values.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     const    uint8_t*       getByteArray(int32_t& count) const;
 
@@ -181,6 +185,7 @@ public:
     uint8_t*                toByteArray(int32_t& count) const;
 #endif
 
+#ifndef U_HIDE_DEPRECATED_API 
     /**
     * Convenience method which does a string(bit-wise) comparison of the
     * two collation keys.
@@ -191,6 +196,7 @@ public:
     * @deprecated ICU 2.6 use the overload with error code
     */
     Collator::EComparisonResult compareTo(const CollationKey& target) const;
+#endif  /* U_HIDE_DEPRECATED_API */
 
     /**
     * Convenience method which does a string(bit-wise) comparison of the
@@ -200,7 +206,7 @@ public:
     * @return Returns UCOL_LESS if sourceKey < targetKey,
     * UCOL_GREATER if sourceKey > targetKey and UCOL_EQUAL
     * otherwise.
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.6
     */
     UCollationResult compareTo(const CollationKey& target, UErrorCode &status) const;
 
@@ -222,43 +228,45 @@ public:
     * </pre>
     * @return the hash value based on the string's collation order.
     * @see UnicodeString#hashCode
-    * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+    * @stable ICU 2.0
     */
     int32_t                 hashCode(void) const;
 
     /**
      * ICU "poor man's RTTI", returns a UClassID for the actual class.
-     * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+     * @stable ICU 2.2
      */
     virtual UClassID getDynamicClassID() const;
 
     /**
      * ICU "poor man's RTTI", returns a UClassID for this class.
-     * @deprecated ICU 2.8 Use Collator::getSortKey(...) instead
+     * @stable ICU 2.2
      */
     static UClassID U_EXPORT2 getStaticClassID();
 
 private:
     /**
-    * Returns an array of the collation key values as 16-bit integers.
-    * The caller owns the storage and must delete it.
-    * @param values Output param of the collation key values.
-    * @param count output parameter of the number of collation key values
-    * @return a pointer to an array of 16-bit collation key values.
-    */
-    void adopt(uint8_t *values, int32_t count);
-
-    /*
-    * Creates a collation key with a string.
-    */
-
+     * Replaces the current bytes buffer with a new one of newCapacity
+     * and copies length bytes from the old buffer to the new one.
+     * @return the new buffer, or NULL if the allocation failed
+     */
+    uint8_t *reallocate(int32_t newCapacity, int32_t length);
     /**
-    * If this CollationKey has capacity less than newSize,
-    * its internal capacity will be increased to newSize.
-    * @param newSize minimum size this CollationKey has to have
-    * @return this CollationKey
-    */
-    CollationKey&           ensureCapacity(int32_t newSize);
+     * Set a new length for a new sort key in the existing fBytes.
+     */
+    void setLength(int32_t newLength);
+
+    uint8_t *getBytes() {
+        return (fFlagAndLength >= 0) ? fUnion.fStackBuffer : fUnion.fFields.fBytes;
+    }
+    const uint8_t *getBytes() const {
+        return (fFlagAndLength >= 0) ? fUnion.fStackBuffer : fUnion.fFields.fBytes;
+    }
+    int32_t getCapacity() const {
+        return (fFlagAndLength >= 0) ? (int32_t)sizeof(fUnion) : fUnion.fFields.fCapacity;
+    }
+    int32_t getLength() const { return fFlagAndLength & 0x7fffffff; }
+
     /**
     * Set the CollationKey to a "bogus" or invalid state
     * @return this CollationKey
@@ -269,33 +277,42 @@ private:
     * @return this CollationKey
     */
     CollationKey&           reset(void);
-    
+
     /**
     * Allow private access to RuleBasedCollator
     */
     friend  class           RuleBasedCollator;
+    friend  class           CollationKeyByteSink;
+
+    // Class fields. sizeof(CollationKey) is intended to be 48 bytes
+    // on a machine with 64-bit pointers.
+    // We use a union to maximize the size of the internal buffer,
+    // similar to UnicodeString but not as tight and complex.
+
+    // (implicit) *vtable;
     /**
-    * Bogus status
-    */
-    UBool                   fBogus;
-    /**
-    * Size of fBytes used to store the sortkey. i.e. up till the 
-    * null-termination.
-    */
-    int32_t                 fCount;
-    /**
-    * Full size of the fBytes
-    */
-    int32_t                 fCapacity;
+     * Sort key length and flag.
+     * Bit 31 is set if the buffer is heap-allocated.
+     * Bits 30..0 contain the sort key length.
+     */
+    int32_t fFlagAndLength;
     /**
-    * Unique hash value of this CollationKey
+    * Unique hash value of this CollationKey.
+    * Special value 2 if the key is bogus.
     */
-    int32_t                 fHashCode;
+    mutable int32_t fHashCode;
     /**
-    * Array to store the sortkey
-    */
-    uint8_t*                fBytes;
-
+     * fUnion provides 32 bytes for the internal buffer or for
+     * pointer+capacity.
+     */
+    union StackBufferOrFields {
+        /** fStackBuffer is used iff fFlagAndLength>=0, else fFields is used */
+        uint8_t fStackBuffer[32];
+        struct {
+            uint8_t *fBytes;
+            int32_t fCapacity;
+        } fFields;
+    } fUnion;
 };
 
 inline UBool
@@ -307,17 +324,18 @@ CollationKey::operator!=(const CollationKey& other) const
 inline UBool
 CollationKey::isBogus() const
 {
-    return fBogus;
+    return fHashCode == 2;  // kBogusHashCode
 }
 
 inline const uint8_t*
 CollationKey::getByteArray(int32_t &count) const
 {
-    count = fCount;
-    return fBytes;
+    count = getLength();
+    return getBytes();
 }
 
 U_NAMESPACE_END
+#endif // U_SHOW_CPLUSPLUS_API
 
 #endif /* #if !UCONFIG_NO_COLLATION */