diff options
author | th <th@openoffice.org> | 2001-03-16 14:16:05 +0000 |
---|---|---|
committer | th <th@openoffice.org> | 2001-03-16 14:16:05 +0000 |
commit | 6616b77b735948034c85f234c086d28352de9e03 (patch) | |
tree | beeb1f117db6318282544736f4a2f73e488c88d1 /sal/inc/rtl/ustring.h | |
parent | 09a6b8da642aa14e1073f9b62afcd16f876a8ab4 (diff) |
rework/to.../better documentation/SAL_THROW_EXTERN_C
Diffstat (limited to 'sal/inc/rtl/ustring.h')
-rw-r--r-- | sal/inc/rtl/ustring.h | 987 |
1 files changed, 624 insertions, 363 deletions
diff --git a/sal/inc/rtl/ustring.h b/sal/inc/rtl/ustring.h index 952bb431a330..5b97d67101b8 100644 --- a/sal/inc/rtl/ustring.h +++ b/sal/inc/rtl/ustring.h @@ -2,9 +2,9 @@ * * $RCSfile: ustring.h,v $ * - * $Revision: 1.1.1.1 $ + * $Revision: 1.2 $ * - * last change: $Author: hr $ $Date: 2000-09-18 15:17:15 $ + * last change: $Author: th $ $Date: 2001-03-16 15:16:05 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -59,14 +59,12 @@ * ************************************************************************/ - #ifndef _RTL_USTRING_H_ #define _RTL_USTRING_H_ #ifndef _SAL_TYPES_H_ #include <sal/types.h> #endif - #ifndef _RTL_STRING_H_ #include <rtl/string.h> #endif @@ -78,16 +76,625 @@ extern "C" { #endif +/* ======================================================================= */ + +/** + Returns the length of a string. + The length is equal to the number of 16-bit Unicode characters in the + string without the terminating NULL-character. + + @param str must be a NULL-terminated string. + @return the length of the sequence of characters represented by this + string, excluding the terminating NULL-character. +*/ +sal_Int32 SAL_CALL rtl_ustr_getLength( const sal_Unicode * str ) SAL_THROW_EXTERN_C(); + +/** + Compares two strings. + The comparison is based on the numeric value of each character in + the strings and return a value indicating their relationship. + This function can't be used for language specific sorting. + Both strings must be NULL-terminated. + + @param first the first NULL-terminated string to be compared. + @param second the second NULL-terminated string which is compared + with the first param. + @return <code>0</code> - if both strings are equal + <code>< 0</code> - if the first string is less than the second string + <code>> 0</code> - if the first string is greater than the second string +*/ +sal_Int32 SAL_CALL rtl_ustr_compare( const sal_Unicode * first, const sal_Unicode * second ) SAL_THROW_EXTERN_C(); + +/** + Compares two strings with a maximum count of characters for each string. + The comparison is based on the numeric value of each character in + the strings and return a value indicating their relationship. + This function can't be used for language specific sorting. + Both string lengths must be equal or greater as there given length. + + @param first the first string to be compared. + @param firstLen the length of the first string or the number of + characters to compared. The first string length + must be greater or equal than this value. + @param second the second string which is compared with the first + param. + @param secondLen the length of the second string or the number of + characters to compared. The second string length + must be greater or equal than this value. + @return <code>0</code> - if both substrings are equal + <code>< 0</code> - if the first substring is less than the second substring + <code>> 0</code> - if the first substring is greater than the second substring +*/ +sal_Int32 SAL_CALL rtl_ustr_compare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C(); + +/** + Returns a hashcode for a string. + It is not allowed to store the hash code, because newer versions + could return other hashcodes. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @return a hash code value for str. +*/ +sal_Int32 SAL_CALL rtl_ustr_hashCode( const sal_Unicode * str ) SAL_THROW_EXTERN_C(); + +/** + Returns a hashcode for a substring. + It is not allowed to store the hash code, because newer versions + could return other hashcodes. + + @param str a string. + @param len the maximum number of characters for creating the + hashcode. The string length must be greater or equal + than this value. + @return a hash code value for str. +*/ +sal_Int32 SAL_CALL rtl_ustr_hashCode_WithLength( const sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the first occurrence of the + specified character. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @param ch character to be located. + @return the index of the first occurrence of the character in the + character sequence represented by the string, or + <code>-1</code> if the character does not occur. +*/ +sal_Int32 SAL_CALL rtl_ustr_indexOfChar( const sal_Unicode * str, sal_Unicode ch ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the substring of the first occurrence of the + specified character. + The string length must be greater or equal as the given len. + + @param str a substring. + @param len the maximum number of characters. The string length + must be greater or equal than this value. + @param ch character to be located. + @return the index of the first occurrence of the character in the + character sequence represented by the string, or + <code>-1</code> if the character does not occur. +*/ +sal_Int32 SAL_CALL rtl_ustr_indexOfChar_WithLength( const sal_Unicode * str, sal_Int32 len, sal_Unicode ch ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the last occurrence of the + specified character, searching backward starting at the end. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @param ch character to be located. + @return the index of the last occurrence of the character in the + character sequence represented by the string, or + <code>-1</code> if the character does not occur. + The return value is always lower as the string len. +*/ +sal_Int32 SAL_CALL rtl_ustr_lastIndexOfChar( const sal_Unicode * str, sal_Unicode ch ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the last occurrence of the + specified character, searching backward starting at the specified + index (excluding the character at the specified index). + + @param str a substring. + @param len the starting index. The string length + must be greater or equal than this value. + @param ch character to be located. + @return the index of the last occurrence of the character in the + character sequence represented by the string, or + <code>-1</code> if the character does not occur. + The return value is always lower as the len param. +*/ +sal_Int32 SAL_CALL rtl_ustr_lastIndexOfChar_WithLength( const sal_Unicode * str, sal_Int32 len, sal_Unicode ch ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the first occurrence of the + specified substring. + If subStr doesn't include any character, always <code>-1</code> is + returned. This is also the case, if both strings are empty. + Both strings must be NULL-terminated. + + @param str a NULL-terminated string. + @param subStr a NULL-terminated substring to be searched for. + @return if the string argument occurs as a substring within the + string, then the index of the first character of the first + such substring is returned; if it does not occur as a + substring, <code>-1</code> is returned. +*/ +sal_Int32 SAL_CALL rtl_ustr_indexOfStr( const sal_Unicode * str, const sal_Unicode * subStr ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the first occurrence of the + specified substring. + If subLen is zero, always <code>-1</code> is returned. This is also + the case, if str is also zero. + Both string lengths must be equal or greater as there given length. + + @param str a string. + @param len the length of the string or the number of + characters to compared. The string length + must be greater or equal than this value. + @param subStr a substring to be searched for. + @param subLen the length of the substring or the number of + characters to compared. The substring length + must be greater or equal than this value. + @return if the string argument occurs as a substring within the + string, then the index of the first character of the first + such substring is returned; if it does not occur as a + substring, <code>-1</code> is returned. +*/ +sal_Int32 SAL_CALL rtl_ustr_indexOfStr_WithLength( const sal_Unicode * str, sal_Int32 len, const sal_Unicode * subStr, sal_Int32 subLen ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the last occurrence of + the specified substring, searching backward. + The returned index indicates the starting index of the substring. + If subStr doesn't include any character, always <code>-1</code> is + returned. This is also the case, if both strings are empty. + Both strings must be NULL-terminated. + + @param str a NULL-terminated string. + @param subStr a NULL-terminated substring to be searched for. + @return if the string argument occurs as a substring within the + string, then the index of the first character of the last + such substring is returned; if it does not occur as a + substring, <code>-1</code> is returned. The return value is + always lower as the string len. +*/ +sal_Int32 SAL_CALL rtl_ustr_lastIndexOfStr( const sal_Unicode * str, const sal_Unicode * subStr ) SAL_THROW_EXTERN_C(); + +/** + Returns the index within the string of the last occurrence of + the specified substring, searching backward starting at the specified + index (excluding the character at the specified index). + The returned index indicates the starting index of the substring. + If subLen is zero, always <code>-1</code> is returned. This is also + the case, if str is also zero. + Both string lengths must be equal or greater as there given length. + + @param str a string. + @param len the length of the string or the number of + characters to compared. The string length + must be greater or equal than this value. + @param subStr a substring to be searched for. + @param subLen the length of the substring or the number of + characters to compared. The substring length + must be greater or equal than this value. + @return If the string argument occurs one or more times as a substring + within the string, then the index of the first character of + the last such substring is returned. If it does not occur as a + substring <code>-1</code> is returned. The return value is + always lower as the len param. +*/ +sal_Int32 SAL_CALL rtl_ustr_lastIndexOfStr_WithLength( const sal_Unicode * str, sal_Int32 len, const sal_Unicode * subStr, sal_Int32 subLen ) SAL_THROW_EXTERN_C(); + +/** + Replaces all occurrences of oldChar in the string with newChar. + If the character oldChar does not occur in the character sequence + represented by the string, then the string is not modified. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @param oldChar the old character. + @param newChar the new character. +*/ +void SAL_CALL rtl_ustr_replaceChar( sal_Unicode * str, sal_Unicode oldChar, sal_Unicode newChar ) SAL_THROW_EXTERN_C(); + +/** + Replaces all occurrences of oldChar in the string with newChar. + If the character oldChar does not occur in the character sequence + represented by the string, then the string is not modified. + The string length must be greater or equal as the given len. + + @param str a string. + @param len the length of the string or the number of + characters to replaced. The string length + must be greater or equal than this value. + @param oldChar the old character. + @param newChar the new character. +*/ +void SAL_CALL rtl_ustr_replaceChar_WithLength( sal_Unicode * str, sal_Int32 len, sal_Unicode oldChar, sal_Unicode newChar ) SAL_THROW_EXTERN_C(); + +/** + Returns the string representation of the sal_Bool argument. + If the sal_Bool is true, the buffer is filled with the + string "True" and 5 is returned. + If the sal_Bool is false, the buffer is filled with the + string "False" and 6 is returned. + This function can't be used for language specific conversion. + + @param str a buffer, which is big enough to hold the result + and the terminating NULL-character. + You should use the RTL_USTR_MAX_VALUEOFBOOLEAN + define to create a buffer, which is big enough. + It defines the maximum number of characters + with the terminating NULL-character. + @param b a sal_Bool. + @return the length of the string. +*/ +sal_Int32 SAL_CALL rtl_ustr_valueOfBoolean( sal_Unicode * str, sal_Bool b ) SAL_THROW_EXTERN_C(); +#define RTL_USTR_MAX_VALUEOFBOOLEAN RTL_STR_MAX_VALUEOFBOOLEAN + +/** + Returns the string representation of the char argument. + This function can't be used for language specific conversion. + + @param str a buffer, which is big enough to hold the result + and the terminating NULL-character. + You should use the RTL_USTR_MAX_VALUEOFCHAR + define to create a buffer, which is big enough. + It defines the maximum number of characters + with the terminating NULL-character. + @param ch a char. + @return the length of the string. +*/ +sal_Int32 SAL_CALL rtl_ustr_valueOfChar( sal_Unicode * str, sal_Unicode ch ) SAL_THROW_EXTERN_C(); +#define RTL_USTR_MAX_VALUEOFCHAR RTL_STR_MAX_VALUEOFCHAR + +/** + Returns the string representation of the int argument. + This function can't be used for language specific conversion. + + @param str a buffer, which is big enough to hold the result + and the terminating NULL-character. + You should use the RTL_USTR_MAX_VALUEOFINT32 + define to create a buffer, which is big enough. + It defines the maximum number of characters + with the terminating NULL-character. + @param i a int32. + @param radix the radix (between 2 and 36) + @return the length of the string. +*/ +sal_Int32 SAL_CALL rtl_ustr_valueOfInt32( sal_Unicode * str, sal_Int32 i, sal_Int16 radix ) SAL_THROW_EXTERN_C(); +#define RTL_USTR_MIN_RADIX RTL_STR_MIN_RADIX +#define RTL_USTR_MAX_RADIX RTL_STR_MAX_RADIX +#define RTL_USTR_MAX_VALUEOFINT32 RTL_STR_MAX_VALUEOFINT32 + +/** + Returns the string representation of the long argument. + This function can't be used for language specific conversion. + + @param str a buffer, which is big enough to hold the result + and the terminating NULL-character. + You should use the RTL_USTR_MAX_VALUEOFINT64 + define to create a buffer, which is big enough. + It defines the maximum number of characters + with the terminating NULL-character. + @param l a int64. + @param radix the radix (between 2 and 36) + @return the length of the string. +*/ +sal_Int32 SAL_CALL rtl_ustr_valueOfInt64( sal_Unicode * str, sal_Int64 l, sal_Int16 radix ) SAL_THROW_EXTERN_C(); +#define RTL_USTR_MAX_VALUEOFINT64 RTL_STR_MAX_VALUEOFINT64 + +/** + Returns the string representation of the float argument. + This function can't be used for language specific conversion. + + @param str a buffer, which is big enough to hold the result + and the terminating NULL-character. + You should use the RTL_USTR_MAX_VALUEOFFLOAT + define to create a buffer, which is big enough. + It defines the maximum number of characters + with the terminating NULL-character. + @param f a float. + @return the length of the string. +*/ +sal_Int32 SAL_CALL rtl_ustr_valueOfFloat( sal_Unicode * str, float f ) SAL_THROW_EXTERN_C(); +#define RTL_USTR_MAX_VALUEOFFLOAT RTL_STR_MAX_VALUEOFFLOAT + +/** + Returns the string representation of the double argument. + This function can't be used for language specific conversion. + + @param str a buffer, which is big enough to hold the result + and the terminating NULL-character. + You should use the RTL_USTR_MAX_VALUEOFDOUBLE + define to create a buffer, which is big enough. + It defines the maximum number of characters + with the terminating NULL-character. + @param d a double. + @return the length of the string. +*/ +sal_Int32 SAL_CALL rtl_ustr_valueOfDouble( sal_Unicode * str, double d ) SAL_THROW_EXTERN_C(); +#define RTL_USTR_MAX_VALUEOFDOUBLE RTL_STR_MAX_VALUEOFDOUBLE + +/** + Returns the Boolean value from the given string. + This function can't be used for language specific conversion. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @return sal_True, if the string is 1 or "True" in any ASCII case. + sal_False in any other case. +*/ +sal_Bool SAL_CALL rtl_ustr_toBoolean( const sal_Unicode * str ) SAL_THROW_EXTERN_C(); + +/** + Returns the int32 value from the given string. + This function can't be used for language specific conversion. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @param radix the radix (between 2 and 36) + @return the int32 represented by the string. + 0 if the string represents no number. +*/ +sal_Int32 SAL_CALL rtl_ustr_toInt32( const sal_Unicode * str, sal_Int16 radix ) SAL_THROW_EXTERN_C(); + +/** + Returns the int64 value from the given string. + This function can't be used for language specific conversion. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @param radix the radix (between 2 and 36) + @return the int64 represented by the string. + 0 if the string represents no number. +*/ +sal_Int64 SAL_CALL rtl_ustr_toInt64( const sal_Unicode * str, sal_Int16 radix ) SAL_THROW_EXTERN_C(); + +/** + Returns the float value from the given string. + This function can't be used for language specific conversion. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @return the float represented by the string. + 0.0 if the string represents no number. +*/ +float SAL_CALL rtl_ustr_toFloat( const sal_Unicode * str ) SAL_THROW_EXTERN_C(); + +/** + Returns the double value from the given string. + This function can't be used for language specific conversion. + The string must be NULL-terminated. + + @param str a NULL-terminated string. + @return the double represented by the string. + 0.0 if the string represents no number. +*/ +double SAL_CALL rtl_ustr_toDouble( const sal_Unicode * str ) SAL_THROW_EXTERN_C(); + +/* ======================================================================= */ + +#ifdef SAL_W32 +#pragma pack(push, 4) +#elif defined(SAL_OS2) +#pragma pack(1) +#endif + /** - * Returns the length of this string. - * The length is equal to the number of 16-bit - * Unicode characters in the string. - * - * @param str must be a NULL-terminated string. - * @return the length of the sequence of characters represented by this - * string. - */ -sal_Int32 SAL_CALL rtl_ustr_getLength( const sal_Unicode * str ); + The implementation structure of a unicode string. +*/ +typedef struct _rtl_uString +{ + sal_Int32 refCount; + sal_Int32 length; + sal_Unicode buffer[1]; +} rtl_uString; + +#ifdef SAL_W32 +#pragma pack(pop) +#elif defined(SAL_OS2) +#pragma pack() +#endif + +/* ----------------------------------------------------------------------- */ + +/** + Increment the reference count of the string. + + @param str the string. +*/ +void SAL_CALL rtl_uString_acquire( rtl_uString * str ) SAL_THROW_EXTERN_C(); + +/** + Decrement the reference count of the string. If the count goes + to zero than the string data is deleted. + + @param str the string. +*/ +void SAL_CALL rtl_uString_release( rtl_uString * str ) SAL_THROW_EXTERN_C(); + +/** + Allocates a new string containing no characters. + + @param newStr pointer to the new string. The data must be 0 or + a valid string. +*/ +void SAL_CALL rtl_uString_new( rtl_uString ** newStr ) SAL_THROW_EXTERN_C(); + +/** + Allocates a new string containing space for the given + numbers of characters. + The reference count of the new string is 1 or an empty string. + The values of all characters are set to 0 and the length of the + string is 0, only data is allocated for holding characters. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param len number of characters. +*/ +void SAL_CALL rtl_uString_new_WithLength( rtl_uString ** newStr, sal_Int32 nLen ) SAL_THROW_EXTERN_C(); + +/** + Allocates a new string that contains the same sequence of + characters as the string argument. + The reference count of the new string is 1 or an empty string. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param value a valid string. +*/ +void SAL_CALL rtl_uString_newFromString( rtl_uString ** newStr, const rtl_uString * value ) SAL_THROW_EXTERN_C(); + +/** + Allocates a new string that contains the same sequence of + characters contained in the character array argument. + The reference count of the new string is 1 or an empty string. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param value a NULL-terminated character array. +*/ +void SAL_CALL rtl_uString_newFromStr( rtl_uString ** newStr, const sal_Unicode * value ) SAL_THROW_EXTERN_C(); + +/** + Allocates a new string that contains characters from + the character array argument. + The reference count of the new string is 1 or an empty string. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param value a character array. + @param len the number of character which should be copied. + The character array length must be greater or + equal than this value. +*/ +void SAL_CALL rtl_uString_newFromStr_WithLength( rtl_uString ** newStr, const sal_Unicode * value, sal_Int32 len ) SAL_THROW_EXTERN_C(); + +/** + Assign rightValue to *str. Release *str and aquire rightValue! + + @param str pointer to the string. The data must be 0 or + a valid string. + @param rightValue a valid string. +*/ +void SAL_CALL rtl_uString_assign( rtl_uString ** str, rtl_uString * rightValue ) SAL_THROW_EXTERN_C(); + +/** + Returns the length of this string. + The length is equal to the number of characters in the string. + + @param str a valid string. + @return the length of the sequence of characters represented by the + string. +*/ +sal_Int32 SAL_CALL rtl_uString_getLength( const rtl_uString * str ) SAL_THROW_EXTERN_C(); + +/** + Returns the pointer to the character array of the string. + + @param str pointer to the string. The data must be + a valid string. + @return a null terminated character array. +*/ +sal_Unicode * SAL_CALL rtl_uString_getStr( rtl_uString * str ) SAL_THROW_EXTERN_C(); + +/** + Concatenates the right string to the end of the left string and + returns the result in a new instance. + The new instance isn't in every case a new instance (for example, + if one or both strings are empty). The new string object could + be a shared instance and can't be modified without checking the + refercence count. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param left a valid string. + @param right a valid string. +*/ +void SAL_CALL rtl_uString_newConcat( rtl_uString ** newStr, rtl_uString * left, rtl_uString * right ) SAL_THROW_EXTERN_C(); + +/** + Returns a new string resulting from replacing a number of characters (count) + from the specified position (index) in the string (str) and inserting + the string (subStr) at the specified position (index). + If subStr is 0, than only a number of characters (count) are deleted + at the specified position (index). + The new instance isn't in every case a new instance. The new string + object could be a shared instance and can't be modified without + checking the refercence count. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param str a valid string. + @param index the index for beginning. + The index must be greater or equal as 0 and + less or equal as the length of the string. + @param count the count of charcters that will replaced + The count must be greater or equal as 0 and + less or equal as the length of the string minus index. + @param subStr 0 or a valid string, which is inserted at nIndex. + If subStr is 0, only a number of characters (count) + are deleted at the specified position (index). +*/ +void SAL_CALL rtl_uString_newReplaceStrAt( rtl_uString ** newStr, rtl_uString * str, sal_Int32 index, sal_Int32 count, rtl_uString * subStr ) SAL_THROW_EXTERN_C(); + +/* ======================================================================= */ + +/* predefined constants for String-Conversion */ +#define OSTRING_TO_OUSTRING_CVTFLAGS (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_MAPTOPRIVATE |\ + RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_DEFAULT |\ + RTL_TEXTTOUNICODE_FLAGS_INVALID_DEFAULT) + +/* ----------------------------------------------------------------------- */ + +/** + Allocates a new Unicode string from a seequence of bytes and convert + the byte sequence to Unicode with the specified text encoding. + The string length could be a different one as the specified length, + because not all text conversions result in the same unicode length + (for example double byte encodings, UTF-7, UTF-8, ...). + The reference count of the new string is 1 or an empty string. + This function doesn't handle "Out of Memory" or other + "bad memory allocations". + + @param newStr pointer to the new string. The data must be 0 or + a valid string. + @param str a byte array. + @param len the number of character which should be converted. + The byte array length must be greater or + equal than this value. + @param encoding the text encoding from the byte array. + @param convertFlags flags which controls the conversion. + see RTL_TEXTTOUNICODE_FLAGS_... +*/ +void SAL_CALL rtl_string2UString( rtl_uString ** newStr, const sal_Char * str, sal_Int32 len, rtl_TextEncoding encoding, sal_uInt32 convertFlags ) SAL_THROW_EXTERN_C(); + +/* ======================================================================= */ + +/* constAsciiStr must be a "..." or char const aFoo[] = "..." */ +#define RTL_CONSTASCII_USTRINGPARAM( constAsciiStr ) constAsciiStr, sizeof( constAsciiStr )-1, RTL_TEXTENCODING_ASCII_US + +/* ======================================================================= */ +/* ======================================================================= */ + /** * Compares first string to second string object. Both @@ -128,24 +735,6 @@ sal_Bool SAL_CALL rtl_ustr_equalsIgnoreCase( const sal_Unicode * first, const sa * @param first the <code>String</code> to be compared. * @param second the <code>String</code> to compare first * <code>String</code> against. - * @return the value <code>0</code> if the argument string is equal to - * this string; a value less than <code>0</code> if first string - * is lexicographically less than the second string; and a - * value greater than <code>0</code> if first string is - * lexicographically greater than the second string. - */ -sal_Int32 SAL_CALL rtl_ustr_compare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ); -sal_Int32 SAL_CALL rtl_ustr_compare( const sal_Unicode * first, const sal_Unicode * second ); - -/** - * Compares two strings lexicographically. Both - * strings must be NULL-terminated. - * The comparison is based on the Unicode value of each character in - * the strings. - * - * @param first the <code>String</code> to be compared. - * @param second the <code>String</code> to compare first - * <code>String</code> against. * @param shortenedLength the number of characters which should be compared. * This length can be longer, shorter or equal than the both other strings. * @@ -231,86 +820,6 @@ sal_Int32 SAL_CALL rtl_ustr_ascii_shortenedCompare_WithLength( const sal_Unicode const sal_Char * second, sal_Int32 shortenedLength ); /** - * Returns a hashcode for the string. - * - * @param str a NULL-terminated string. - * @return a hash code value for str. - */ -sal_Int32 SAL_CALL rtl_ustr_hashCode_WithLength( const sal_Unicode * str, sal_Int32 len ); -sal_Int32 SAL_CALL rtl_ustr_hashCode( const sal_Unicode * str ); - -/** - * Returns the index within the string of the first occurrence of the - * specified character. - * - * @param str a NULL-terminated string. - * @param ch a character. - * @return the index of the first occurrence of the character in the - * character sequence represented by the string, or - * <code>-1</code> if the character does not occur. - */ -sal_Int32 SAL_CALL rtl_ustr_indexOfChar_WithLength( const sal_Unicode * str, sal_Int32 len, sal_Unicode ch ); -sal_Int32 SAL_CALL rtl_ustr_indexOfChar( const sal_Unicode * str, sal_Unicode ch ); - -/** - * Returns the index within the string of the last occurrence of the - * specified character, searching backward starting at the specified index. - * - * @param str a NULL-terminated string. - * @param ch a character. - * @return the index of the last occurrence of the character in the - * character sequence represented by the string, or - * <code>-1</code> if the character does not occur. - */ -sal_Int32 SAL_CALL rtl_ustr_lastIndexOfChar_WithLength( const sal_Unicode * str, sal_Int32 len, sal_Unicode ch ); -sal_Int32 SAL_CALL rtl_ustr_lastIndexOfChar( const sal_Unicode * str, sal_Unicode ch ); - -/** - * Returns the index within the string of the first occurrence of the - * specified substring. - * - * @param str a NULL-terminated string. - * @param subStr a NULL-terminated substring to be searched for. - * @return if the string argument occurs as a substring within the - * string, then the index of the first character of the first - * such substring is returned; if it does not occur as a - * substring, <code>-1</code> is returned. - */ -sal_Int32 SAL_CALL rtl_ustr_indexOfStr_WithLength( const sal_Unicode * str, sal_Int32 len, const sal_Unicode * subStr, sal_Int32 subLen ); -sal_Int32 SAL_CALL rtl_ustr_indexOfStr( const sal_Unicode * str, const sal_Unicode * subStr ); - -/** - * Returns the index within this string of the last occurrence of - * the specified substring. - * The returned index indicates the start of the substring, and it - * must be equal to or less than <code>fromIndex</code>. - * - * @param str a NULL-terminated string. - * @param subStr a NULL-terminated substring to be searched for. - * @return If the string argument occurs one or more times as a substring - * within the string, then the index of the first character of - * the last such substring is returned. If it does not occur as a - * substring <code>-1</code> is returned. - */ -sal_Int32 SAL_CALL rtl_ustr_lastIndexOfStr_WithLength( const sal_Unicode * str, sal_Int32 len, const sal_Unicode * subStr, sal_Int32 subLen ); -sal_Int32 SAL_CALL rtl_ustr_lastIndexOfStr( const sal_Unicode * ggstr, const sal_Unicode * subStr ); - -/** - * Replaces all occurrences of <code>oldChar</code> in the string with - * <code>newChar</code>. - * <p> - * If the character <code>oldChar</code> does not occur in the - * character sequence represented by this object, then the string is - *not modified. - * - * @param str a NULL-terminated string. - * @param oldChar the old character. - * @param newChar the new character. - */ -void SAL_CALL rtl_ustr_replaceChar_WithLength( sal_Unicode * str, sal_Int32 len, sal_Unicode oldChar, sal_Unicode newChar); -void SAL_CALL rtl_ustr_replaceChar( sal_Unicode * str, sal_Unicode oldChar, sal_Unicode newChar); - -/** * Converts all of the characters in the <code>string</code> to lower case. * @param str a NULL-terminated string. */ @@ -339,213 +848,28 @@ sal_Int32 SAL_CALL rtl_ustr_trim_WithLength( sal_Unicode * str, sal_Int32 len ); sal_Int32 SAL_CALL rtl_ustr_trim( sal_Unicode * str ); /** - * Returns the string representation of the <code>sal_Bool</code> argument. - * - * @param str a newly allocated string with the length <code>RTL_USTR_MAX_VALUEOFBOOLEAN</code>. - * @param b a <code>sal_Bool</code>. - * @return if the argument is <code>true</code>, a string equal to - * <code>"true"</code> is returned; otherwise, a string equal to - * <code>"false"</code> is returned. - */ -#define RTL_USTR_MAX_VALUEOFBOOLEAN 6 -sal_Int32 SAL_CALL rtl_ustr_valueOfBoolean( sal_Unicode * str, sal_Bool b ); - -/** - * Returns the string representation of the <code>char</code> argument. - * - * @param str a newly allocated string with the length <code>RTL_USTR_MAX_VALUEOFCHAR</code>. - * @param ch a <code>char</code>. - * @return a newly allocated string of length <code>1</code> containing - * as its single character the argument <code>ch</code>. - */ -#define RTL_USTR_MAX_VALUEOFCHAR 2 -sal_Int32 SAL_CALL rtl_ustr_valueOfChar( sal_Unicode * str, sal_Unicode ch ); - -/** - * Returns the string representation of the <code>int</code> argument. - * <p> - * The representation is exactly the one returned by the - * <code>Integer.toString</code> method of one argument. - * - * @param str a newly allocated string with the length <code>RTL_USTR_MAX_VALUEOFINT32</code>. - * @param i an <code>sal_Int32</code>. - * @return a newly allocated string containing a string representation of - * the <code>int</code> argument. - * @see java.lang.Integer#toString(int, int) - */ -#define RTL_USTR_MIN_RADIX 2 -#define RTL_USTR_MAX_RADIX 36 -#define RTL_USTR_MAX_VALUEOFINT32 33 -sal_Int32 SAL_CALL rtl_ustr_valueOfInt32(sal_Unicode * str, sal_Int32 i, sal_Int16 radix ); - -/** - * Returns the string representation of the <code>long</code> argument. - * <p> - * The representation is exactly the one returned by the - * <code>Long.toString</code> method of one argument. - * - * @param str a newly allocated string with the length <code>RTL_USTR_MAX_VALUEOFINT64</code>. - * @param l a <code>sal_Int64</code>. - * @return a newly allocated string containing a string representation of - * the <code>long</code> argument. - * @see java.lang.Long#toString(long) - */ -#define RTL_USTR_MAX_VALUEOFINT64 65 -sal_Int32 SAL_CALL rtl_ustr_valueOfInt64(sal_Unicode * str, sal_Int64 l, sal_Int16 radix ); - -/** - * Returns the string representation of the <code>float</code> argument. - * <p> - * The representation is exactly the one returned by the - * <code>Float.toString</code> method of one argument. - * - * @param f a <code>float</code>. - * @return a newly allocated string containing a string representation of - * the <code>float</code> argument. - * @see java.lang.Float#toString(float) - */ -#define RTL_USTR_MAX_VALUEOFFLOAT 15 -sal_Int32 SAL_CALL rtl_ustr_valueOfFloat(sal_Unicode * str, float f); - -/** - * Returns the string representation of the <code>double</code> argument. - * <p> - * The representation is exactly the one returned by the - * <code>Double.toString</code> method of one argument. - * - * @param d a <code>double</code>. - * @return a newly allocated string containing a string representation of - * the <code>double</code> argument. - * @see java.lang.Double#toString(double) - */ -#define RTL_USTR_MAX_VALUEOFDOUBLE 25 -sal_Int32 SAL_CALL rtl_ustr_valueOfDouble(sal_Unicode * str, double d); - -/** - * Returns the int32 value represented <code>str</code> argument. - * <p> - * - * @param str a string representing a number - * @return the int32 represented by the string - * 0 if the string represents no number. - */ -sal_Int32 SAL_CALL rtl_ustr_toInt32( sal_Unicode * str, sal_Int16 radix ); - -/** - * Returns the int64 value represented <code>str</code> argument. - * <p> - * - * @param str a string representing a number - * @return the int64 represented by the string - * 0 if the string represents no number. - */ -sal_Int64 SAL_CALL rtl_ustr_toInt64( sal_Unicode * str, sal_Int16 radix ); - - /** - * Returns the float value represented <code>str</code> argument. - * <p> - * - * @param str a string representing a number - * @return the float represented by the string - * 0.0 if the string represents no number. - */ -float SAL_CALL rtl_ustr_toFloat( sal_Unicode * str ); - -/** - * Returns the double value represented <code>str</code> argument. - * <p> - * - * @param str a string representing a number - * @return the double represented by the string - * 0.0 if the string represents no number. - */ -double SAL_CALL rtl_ustr_toDouble( sal_Unicode * str ); - -/** * A string with this reference count is static und must not deleted. * It is also not allowed to modifiy the reference count. */ #define RTL_STATIC_STRING_REF ((sal_Int32)0x80000000) #ifdef SAL_W32 -# pragma pack(push, 4) +#pragma pack(push, 4) #elif defined(SAL_OS2) -# pragma pack(1) +#pragma pack(1) #endif struct _rtl_Locale; -/** - * The implementation structure of a string. - */ -typedef struct _rtl_uString -{ - sal_Int32 refCount; - sal_Int32 length; - sal_Unicode buffer[1]; -} rtl_uString; - #ifdef SAL_W32 -# pragma pack(pop) +#pragma pack(pop) #elif defined(SAL_OS2) -# pragma pack() +#pragma pack() #endif -/** - * Increment the reference count of the string. - */ -void SAL_CALL rtl_uString_acquire( rtl_uString * value ); - -/** - * Decrement the reference count of the string. If the count goes to zero than the string is - * deleted. - */ -void SAL_CALL rtl_uString_release( rtl_uString * value ); - -/** - * Allocates a new <code>string</code> containing no characters. - * Use the macro RTL_NEWDEFAULTSTRING() which optimize platform dependend - * the access to the default string. - */ -void SAL_CALL rtl_uString_new( rtl_uString ** newStr); #define RTL_USTRING_NEW(newStr) rtl_uString_new(newStr) /** - * Allocates a new <code>string</code> containing nLen characters. - * The values of the characters are '\u0000' defined. - */ -void SAL_CALL rtl_uString_new_WithLength( rtl_uString ** newStr, sal_Int32 nLen ); - -/** - * Allocates a new string that contains the same sequence of - * characters as the string argument.<BR> - * - * @param value a <code>string</code>. - * @return the new string. The reference count is 1. - */ -void SAL_CALL rtl_uString_newFromString( rtl_uString ** newStr, rtl_uString * value); - -/** - * Allocates a new <code>string</code> so that it represents the - * sequence of characters currently contained in the character array - * argument. - * - * @param value the initial value of the string. - * @return the new string. The reference count is 1. - */ -void SAL_CALL rtl_uString_newFromStr( rtl_uString ** newStr, const sal_Unicode * value ); - -/** - * Allocates a new <code>String</code> that contains characters from - * the character array argument. - * - * @param value array that is the source of characters. - * @param len the length of the array. - * @return the new string. The reference count is 1. - */ -void SAL_CALL rtl_uString_newFromStr_WithLength( rtl_uString ** newStr, const sal_Unicode * value, sal_Int32 Len); - -/** * Allocates a new <code>string</code> so that it represents the * sequence of characters currently contained in the character array * argument. @@ -579,37 +903,6 @@ void SAL_CALL rtl_uString_newFromWStr_WithLength( rtl_uString ** newStr, const w void SAL_CALL rtl_uString_newFromAscii( rtl_uString ** newStr, const sal_Char * value ); /** - * Assign rightValue to *str. Release *str and aquire rightValue! - */ -void SAL_CALL rtl_uString_assign( rtl_uString ** str, rtl_uString * rightValue ); - -/** - * Returns the length of this string. - * The length is equal to the number of 16-bit - * Unicode characters in the string. - * - * @return the length of the sequence of characters represented by the - * string. - */ -sal_Int32 SAL_CALL rtl_uString_getLength( rtl_uString * str ); - -/** - * Return the pointer to the sal_Unicode array of the <code>string</code>. - * - * @return a null terminated sal_Unicode *. - */ -sal_Unicode * SAL_CALL rtl_uString_getStr( rtl_uString * str ); - -/** - * Concatenates the right string to the end of the left string. Left and - * right must be NULL-terminated strings. - * <p> - * - * @return a string that represents the concatenation of the strings. - */ -void SAL_CALL rtl_uString_newConcat( rtl_uString ** newStr, rtl_uString * left, rtl_uString * right ); - -/** * Returns a new string resulting from replacing all occurrences of * <code>oldChar</code> in this string with <code>newChar</code>. * <p> @@ -627,22 +920,6 @@ void SAL_CALL rtl_uString_newReplace( rtl_uString ** newStr, sal_Unicode newChar); /** - * Returns a new string resulting from replacing n = count characters - * from position index in this string with <code>newStr</code>. - * <p> - * - * @param index the index for beginning. - * @param count the count of charcters that will replaced - * @param newStr the new substring. - * @return the new string. The reference count is 1. - */ -void SAL_CALL rtl_uString_newReplaceStrAt( rtl_uString ** newStr, - rtl_uString * str, - sal_Int32 index, - sal_Int32 count, - rtl_uString * newSub); - -/** * Converts all of the characters in this <code>String</code> to lower * case using the rules of the given locale. * @param locale use the case transformation rules for this locale @@ -692,22 +969,6 @@ sal_Int32 SAL_CALL rtl_uString_getTokenCount( rtl_uString * str , sal_Unicode cT */ void SAL_CALL rtl_uString_getToken( rtl_uString ** newStr , rtl_uString * str, sal_Int32 nToken, sal_Unicode cTok); - -void SAL_CALL rtl_string2UString( rtl_uString** newStr, const sal_Char* pStr, sal_Int32 nLen, - rtl_TextEncoding encoding, sal_uInt32 nCvtFlags ); - -void SAL_CALL rtl_uString2String( rtl_String** newStr, const sal_Unicode* pWStr, sal_Int32 nWLen, - rtl_TextEncoding encoding, sal_uInt32 nCvtFlags ); - -/* constAsciiStr must be a "..." or char const aFoo[] = "..." */ -#define RTL_CONSTASCII_USTRINGPARAM( constAsciiStr ) constAsciiStr, sizeof( constAsciiStr )-1, RTL_TEXTENCODING_ASCII_US -#ifndef RTL_CONSTASCII_STRINGPARAM -#define RTL_CONSTASCII_STRINGPARAM( constAsciiStr ) constAsciiStr, sizeof( constAsciiStr )-1 -#endif -#ifndef RTL_CONSTASCII_LENGTH -#define RTL_CONSTASCII_LENGTH( constAsciiStr ) (sizeof( constAsciiStr )-1) -#endif - #ifdef __cplusplus } #endif |