diff options
author | Stephan Bergmann <sb@openoffice.org> | 2001-10-30 12:41:07 +0000 |
---|---|---|
committer | Stephan Bergmann <sb@openoffice.org> | 2001-10-30 12:41:07 +0000 |
commit | 51e5f01dc701e87929634ac4455c1fa537b472e9 (patch) | |
tree | e212112bad37d7ec1e9b95618d98e27c0e9a021d /sal/inc/rtl/ustring.h | |
parent | 9481c4dac68408b0a5f98e870baa87b469e9b7db (diff) |
#88337# Documentation.
Diffstat (limited to 'sal/inc/rtl/ustring.h')
-rw-r--r-- | sal/inc/rtl/ustring.h | 2033 |
1 files changed, 1120 insertions, 913 deletions
diff --git a/sal/inc/rtl/ustring.h b/sal/inc/rtl/ustring.h index 72e0999a0ef1..0865db145c7e 100644 --- a/sal/inc/rtl/ustring.h +++ b/sal/inc/rtl/ustring.h @@ -2,9 +2,9 @@ * * $RCSfile: ustring.h,v $ * - * $Revision: 1.5 $ + * $Revision: 1.6 $ * - * last change: $Author: th $ $Date: 2001-07-27 13:21:46 $ + * last change: $Author: sb $ $Date: 2001-10-30 13:41:07 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -78,760 +78,910 @@ extern "C" { /* ======================================================================= */ -/** - 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. +/** Return the length of a string. - @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. -*/ + The length is equal to the number of 16-bit Unicode characters in the + string, without the terminating NUL character. + + @param str + a null-terminated string. + + @return + the length of the sequence of characters represented by this string, + excluding the terminating NUL 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 -*/ +/** Compare two strings. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot 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 one. + + @return + 0 if both strings are equal, a value less than 0 if the first string is + less than the second string, and a value greater than 0 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 -*/ +/** Compare two strings. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second string which is compared with the first one. Need not be + null-terminated, but must be at least as long as the specified secondLen. + + @param secondLen + the length of the second string. + + @return + 0 if both strings are equal, a value less than 0 if the first string is + less than the second string, and a value greater than 0 if the first + string is 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_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. - @param shortenedLen the number of characters which should be compared. - This length can be longer, shorter or equal than - the both other strings. - @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 -*/ +/** Compare two strings with a maximum count of characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second string which is compared with the first one. Need not be + null-terminated, but must be at least as long as the specified secondLen. + + @param secondLen + the length of the second string. + + @param shortenedLen + the maximum number of characters to compare. This length can be greater + or smaller than the lengths of the two strings. + + @return + 0 if both substrings are equal, a value less than 0 if the first substring + is less than the second substring, and a value greater than 0 if the first + substring is greater than the second substring. + */ sal_Int32 SAL_CALL rtl_ustr_shortenedCompare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen, sal_Int32 shortenedLen ) SAL_THROW_EXTERN_C(); -/** - Compares two strings in reverse order. - 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. - The string length 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 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 -*/ +/** Compare two strings from back to front. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second string which is compared with the first one. Need not be + null-terminated, but must be at least as long as the specified secondLen. + + @param secondLen + the length of the second string. + + @return + 0 if both strings are equal, a value less than 0 if the first string + compares less than the second string, and a value greater than 0 if the + first string compares greater than the second string. + */ sal_Int32 SAL_CALL rtl_ustr_reverseCompare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C(); -/** - Perform a ASCII lowercase comparison of two strings. - The comparison is based on the numeric value of each character in - the strings and return a value indicating their relationship. - Character values between 65 and 90 (ASCII A-Z) are interpreted as - values between 97 and 122 (ASCII a-z). - 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 -*/ +/** Compare two strings, ignoring the case of ASCII characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. Character + values between 65 and 90 (ASCII A--Z) are interpreted as values between 97 + and 122 (ASCII a--z). This function cannot 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 one. + + @return + 0 if both strings are equal, a value less than 0 if the first string is + less than the second string, and a value greater than 0 if the first + string is greater than the second string. + */ sal_Int32 SAL_CALL rtl_ustr_compareIgnoreAsciiCase( const sal_Unicode * first, const sal_Unicode * second ) SAL_THROW_EXTERN_C(); -/** - Perform a ASCII lowercase comparison of 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. - Character values between 65 and 90 (ASCII A-Z) are interpreted as - values between 97 and 122 (ASCII a-z). - 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 -*/ +/** Compare two strings, ignoring the case of ASCII characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. Character + values between 65 and 90 (ASCII A--Z) are interpreted as values between 97 + and 122 (ASCII a--z). This function cannot be used for language-specific + sorting. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second string which is compared with the first one. Need not be + null-terminated, but must be at least as long as the specified secondLen. + + @param secondLen + the length of the second string. + + @return + 0 if both strings are equal, a value less than 0 if the first string is + less than the second string, and a value greater than 0 if the first + string is greater than the second string. + */ sal_Int32 SAL_CALL rtl_ustr_compareIgnoreAsciiCase_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C(); -/** - Perform a ASCII lowercase comparison of 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. - Character values between 65 and 90 (ASCII A-Z) are interpreted as - values between 97 and 122 (ASCII a-z). - 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. - @param shortenedLen the number of characters which should be compared. - This length can be longer, shorter or equal than - the both other strings. - @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 -*/ +/** Compare two strings with a maximum count of characters, ignoring the case + of ASCII characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. Character + values between 65 and 90 (ASCII A--Z) are interpreted as values between 97 + and 122 (ASCII a--z). This function cannot be used for language-specific + sorting. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second string which is compared with the first one. Need not be + null-terminated, but must be at least as long as the specified secondLen. + + @param secondLen + the length of the second string. + + @param shortenedLen + the maximum number of characters to compare. This length can be greater + or smaller than the lengths of the two strings. + + @return + 0 if both substrings are equal, a value less than 0 if the first substring + is less than the second substring, and a value greater than 0 if the first + substring is greater than the second substring. + */ sal_Int32 SAL_CALL rtl_ustr_shortenedCompareIgnoreAsciiCase_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen, sal_Int32 shortenedLen ) 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. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @param first the first NULL-terminated string to be compared. - @param second the second NULL-terminated ASCII 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 -*/ +/** Compare two strings. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. Both strings must be + null-terminated. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first null-terminated string to be compared. + + @param second + the second null-terminated ASCII string which is compared with the first + one. + + @return + 0 if both substrings are equal, a value less than 0 if the first substring + is less than the second substring, and a value greater than 0 if the first + substring is greater than the second substring. + */ sal_Int32 SAL_CALL rtl_ustr_ascii_compare( const sal_Unicode * first, const sal_Char * 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. - The string length must be equal or greater as there given length. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @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 ASCII string which is compared with - the first param. - @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 -*/ +/** Compare two strings. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second null-terminated ASCII string which is compared with the first + one. + + @return + 0 if both substrings are equal, a value less than 0 if the first substring + is less than the second substring, and a value greater than 0 if the first + substring is greater than the second substring. + */ sal_Int32 SAL_CALL rtl_ustr_ascii_compare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * 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. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @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 ASCII string which is compared with - the first param. - @param shortenedLen the number of characters which should be compared. - This length can be longer, shorter or equal than - the both other strings. - @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 -*/ +/** Compare two strings with a maximum count of characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second null-terminated ASCII string which is compared with the first + one. + + @param shortenedLen + the maximum number of characters to compare. This length can be greater + or smaller than the lengths of the two strings. + + @return + 0 if both substrings are equal, a value less than 0 if the first substring + is less than the second substring, and a value greater than 0 if the first + substring is greater than the second substring. + */ sal_Int32 SAL_CALL rtl_ustr_ascii_shortenedCompare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second, sal_Int32 shortenedLen ) SAL_THROW_EXTERN_C(); -/** - Compares two strings in reverse order. - 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. - The string length must be equal or greater as there given length. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @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 ASCII 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 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 -*/ +/** Compare two strings from back to front. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. This function + cannot be used for language-specific sorting. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second ASCII string which is compared with the first one. Need not be + null-terminated, but must be at least as long as the specified secondLen. + + @param secondLen + the length of the second string. + + @return + 0 if both strings are equal, a value less than 0 if the first string + compares less than the second string, and a value greater than 0 if the + first string compares greater than the second string. + */ sal_Int32 SAL_CALL rtl_ustr_asciil_reverseCompare_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C(); -/** - Perform a ASCII lowercase comparison of two strings. - The comparison is based on the numeric value of each character in - the strings and return a value indicating their relationship. - Character values between 65 and 90 (ASCII A-Z) are interpreted as - values between 97 and 122 (ASCII a-z). - This function can't be used for language specific sorting. - Both strings must be NULL-terminated. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @param first the first NULL-terminated string to be compared. - @param second the second NULL-terminated ASCII 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 -*/ +/** Compare two strings, ignoring the case of ASCII characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. Character + values between 65 and 90 (ASCII A--Z) are interpreted as values between 97 + and 122 (ASCII a--z). This function cannot be used for language-specific + sorting. Both strings must be null-terminated. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first null-terminated string to be compared. + + @param second + the second null-terminated ASCII string which is compared with the first + one. + + @return + 0 if both strings are equal, a value less than 0 if the first string is + less than the second string, and a value greater than 0 if the first + string is greater than the second string. + */ sal_Int32 SAL_CALL rtl_ustr_ascii_compareIgnoreAsciiCase( const sal_Unicode * first, const sal_Char * second ) SAL_THROW_EXTERN_C(); -/** - Perform a ASCII lowercase comparison of two strings. - The comparison is based on the numeric value of each character in - the strings and return a value indicating their relationship. - Character values between 65 and 90 (ASCII A-Z) are interpreted as - values between 97 and 122 (ASCII a-z). - This function can't be used for language specific sorting. - The string length must be equal or greater as there given length. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @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 ASCII string which is compared with - the first param. - @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 -*/ +/** Compare two strings, ignoring the case of ASCII characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. Character + values between 65 and 90 (ASCII A--Z) are interpreted as values between 97 + and 122 (ASCII a--z). This function cannot be used for language-specific + sorting. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second null-terminated ASCII string which is compared with the first + one. + + @return + 0 if both strings are equal, a value less than 0 if the first string is + less than the second string, and a value greater than 0 if the first + string is greater than the second string. + */ sal_Int32 SAL_CALL rtl_ustr_ascii_compareIgnoreAsciiCase_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second ) SAL_THROW_EXTERN_C(); -/** - Perform a ASCII lowercase comparison of 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. - Character values between 65 and 90 (ASCII A-Z) are interpreted as - values between 97 and 122 (ASCII a-z). - This function can't be used for language specific sorting. - Both string lengths must be equal or greater as there given length. - Since this method is optimized for performance, the ASCII character - values are not converted in any way. The caller has to make sure that - all ASCII characters are in the allowed range between 0 and - 127. - - @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 ASCII string which is compared with - the first param. - @param shortenedLen the number of characters which should be compared. - This length can be longer, shorter or equal than - the both other strings. - @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 -*/ +/** Compare two strings with a maximum count of characters, ignoring the case + of ASCII characters. + + The comparison is based on the numeric value of each character in the + strings and returns a value indicating their relationship. Character + values between 65 and 90 (ASCII A--Z) are interpreted as values between 97 + and 122 (ASCII a--z). This function cannot be used for language-specific + sorting. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param first + the first string to be compared. Need not be null-terminated, but must be + at least as long as the specified firstLen. + + @param firstLen + the length of the first string. + + @param second + the second null-terminated ASCII string which is compared with the first + one. + + @param shortenedLen + the maximum number of characters to compare. This length can be greater + or smaller than the lengths of the two strings. + + @return + 0 if both substrings are equal, a value less than 0 if the first substring + is less than the second substring, and a value greater than 0 if the first + substring is greater than the second substring. + */ sal_Int32 SAL_CALL rtl_ustr_ascii_shortenedCompareIgnoreAsciiCase_WithLength( const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second, sal_Int32 shortenedLen ) 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. +/** Return a hash code for a string. - @param str a NULL-terminated string. - @return a hash code value for str. -*/ + It is not allowed to store the hash code persistently, because later + versions could return other hash codes. The string must be + null-terminated. + + @param str + a null-terminated string. + + @return + a hash code for the given string. + */ 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. +/** Return a hash code for a string. - @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. -*/ + It is not allowed to store the hash code persistently, because later + versions could return other hash codes. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + + @return + a hash code for the given string. + */ 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. +/** Search for the first occurrence of a character within a string. - @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. -*/ + The string must be null-terminated. + + @param str + a null-terminated string. + + @param ch + the character to be searched for. + + @return + the index (starting at 0) of the first occurrence of the character in the + string, or -1 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. -*/ +/** Search for the first occurrence of a character within a string. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + + @param ch + the character to be searched for. + + @return + the index (starting at 0) of the first occurrence of the character in the + string, or -1 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. -*/ +/** Search for the last occurrence of a character within a string. + + The string must be null-terminated. + + @param str + a null-terminated string. + + @param ch + the character to be searched for. + + @return + the index (starting at 0) of the last occurrence of the character in the + string, or -1 if the character does not occur. The returned value is + always smaller than the string length. + */ 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. -*/ +/** Search for the last occurrence of a character within a string. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + + @param ch + the character to be searched for. + + @return + the index (starting at 0) of the last occurrence of the character in the + string, or -1 if the character does not occur. The returned value is + always smaller than the string length. + */ 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. -*/ +/** Search for the first occurrence of a substring within a string. + + If subStr is empty, or both str and subStr are empty, -1 is returned. + Both strings must be null-terminated. + + @param str + a null-terminated string. + + @param subStr + the null-terminated substring to be searched for. + + @return + the index (starting at 0) of the first character of the first occurrence + of the substring within the string, or -1 if the substring does not occur. + */ 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. -*/ +/** Search for the first occurrence of a substring within a string. + + If subStr is empty, or both str and subStr are empty, -1 is returned. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + + @param subStr + the substring to be searched for. Need not be null-terminated, but must + be at least as long as the specified subLen. + + @param subLen + the length of the substring. + + @return + the index (starting at 0) of the first character of the first occurrence + of the substring within the string, or -1 if the substring does not occur. + */ 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. -*/ +/** Search for the last occurrence of a substring within a string. + + If subStr is empty, or both str and subStr are empty, -1 is returned. + Both strings must be null-terminated. + + @param str + a null-terminated string. + + @param subStr + the null-terminated substring to be searched for. + + @return + the index (starting at 0) of the first character of the last occurrence + of the substring within the string, or -1 if the substring does not occur. + */ 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. -*/ +/** Search for the last occurrence of a substring within a string. + + If subStr is empty, or both str and subStr are empty, -1 is returned. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + + @param subStr + the substring to be searched for. Need not be null-terminated, but must + be at least as long as the specified subLen. + + @param subLen + the length of the substring. + + @return + the index (starting at 0) of the first character of the first occurrence + of the substring within the string, or -1 if the substring does not occur. + */ 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. +/** Replace all occurrences of a single character within a string. - @param str a NULL-terminated string. - @param oldChar the old character. - @param newChar the new character. -*/ + If oldChar does not occur within str, 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. -*/ +/** Replace all occurrences of a single character within a string. + + If oldChar does not occur within str, then the string is not modified. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the 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 ) SAL_THROW_EXTERN_C(); -/** - Converts all ASCII uppercase characters (65-90) in the string to - ASCII lowercase characters (97-122). - This function can't be used for language specific conversion. - The string length must be greater or equal as the given len. +/** Convert all ASCII uppercase letters to lowercase within a string. - @param str a string. - @param len the length of the string or the number of - characters to converted. The string length - must be greater or equal than this value. -*/ + The characters with values between 65 and 90 (ASCII A--Z) are replaced + with values between 97 and 122 (ASCII a--z). The string must be + null-terminated. + + @param str + a null-terminated string. + */ +void SAL_CALL rtl_ustr_toAsciiLowerCase( sal_Unicode * str ) SAL_THROW_EXTERN_C(); + +/** Convert all ASCII uppercase letters to lowercase within a string. + + The characters with values between 65 and 90 (ASCII A--Z) are replaced + with values between 97 and 122 (ASCII a--z). + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + */ void SAL_CALL rtl_ustr_toAsciiLowerCase_WithLength( sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C(); -/** - Converts all ASCII lowercase characters (97-122) in the string to - ASCII uppercase characters (65-90). - This function can't be used for language specific conversion. - The string must be NULL-terminated. +/** Convert all ASCII lowercase letters to uppercase within a string. - @param str a NULL-terminated string. -*/ + The characters with values between 97 and 122 (ASCII a--z) are replaced + with values between 65 and 90 (ASCII A--Z). The string must be + null-terminated. + + @param str + a null-terminated string. + */ void SAL_CALL rtl_ustr_toAsciiUpperCase( sal_Unicode * str ) SAL_THROW_EXTERN_C(); -/** - Converts all ASCII lowercase characters (97-122) in the string to - ASCII uppercase characters (65-90). - This function can't be used for language specific conversion. - The string length must be greater or equal as the given len. +/** Convert all ASCII lowercase letters to uppercase within a string. - @param str a string. - @param len the length of the string or the number of - characters to converted. The string length - must be greater or equal than this value. -*/ + The characters with values between 97 and 122 (ASCII a--z) are replaced + with values between 65 and 90 (ASCII A--Z). + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the length of the string. + */ void SAL_CALL rtl_ustr_toAsciiUpperCase_WithLength( sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C(); -/** - Removes white space from both ends of the string. - All characters that have codes less than or equal to - 32 (the space character) are considered to be white space. - Also the Unicode space characters between 0x2000 and 0x200B, - 0x2028 (LINE SEPARATOR) and 0x2029 (PARAGRAPH SEPARATOR) are - considered to be white space. - The string must be NULL-terminated. - - @param str a NULL-terminated string. - @return new length of the string. -*/ +/** Remove white space from both ends of a string. + + All characters with values less than or equal to 32 (the space character) + are considered to be white space. This function cannot be used for + language-specific operations. The string must be null-terminated. + + @param str + a null-terminated string. + + @return + the new length of the string. + */ sal_Int32 SAL_CALL rtl_ustr_trim( sal_Unicode * str ) SAL_THROW_EXTERN_C(); -/** - Removes white space from both ends of the string. - All characters that have codes less than or equal to - 32 (the space character) are considered to be white space. - Also the Unicode space characters between 0x2000 and 0x200B, - 0x2028 (LINE SEPARATOR) and 0x2029 (PARAGRAPH SEPARATOR) are - considered to be white space. - 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 converted. The string length - must be greater or equal than this value. - @return new length of the string. -*/ +/** Remove white space from both ends of the string. + + All characters with values less than or equal to 32 (the space character) + are considered to be white space. This function cannot be used for + language-specific operations. The string must be null-terminated. + + @param str + a string. Need not be null-terminated, but must be at least as long as + the specified len. + + @param len + the original length of the string. + + @return + the new length of the string. + */ sal_Int32 SAL_CALL rtl_ustr_trim_WithLength( sal_Unicode * str, sal_Int32 len ) 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. -*/ +/** Create the string representation of a boolean. + + If b is true, the buffer is filled with the string "true" and 5 is + returned. If b is false, the buffer is filled with the string "false" and + 6 is returned. This function cannot be used for language-specific + operations. + + @param str + a buffer that is big enough to hold the result and the terminating NUL + character. You should use the RTL_USTR_MAX_VALUEOFBOOLEAN define to + create a buffer that is big enough. + + @param b + a boolean value. + + @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. -*/ +/** Create the string representation of a character. + + @param str + a buffer that is big enough to hold the result and the terminating NUL + character. You should use the RTL_USTR_MAX_VALUEOFCHAR define to create a + buffer that is big enough. + + @param ch + a character value. + + @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. -*/ +/** Create the string representation of an integer. + + This function cannot be used for language-specific operations. + + @param str + a buffer that is big enough to hold the result and the terminating NUL + character. You should use the RTL_USTR_MAX_VALUEOFINT32 define to create + a buffer that is big enough. + + @param i + an integer value. + + @param radix + the radix. Must be between RTL_USTR_MIN_RADIX (2) and RTL_USTR_MAX_RADIX + (36), inclusive. + + @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. -*/ +/** Create the string representation of a long integer. + + This function cannot be used for language-specific operations. + + @param str + a buffer that is big enough to hold the result and the terminating NUL + character. You should use the RTL_USTR_MAX_VALUEOFINT64 define to create + a buffer that is big enough. + + @param l + a long integer value. + + @param radix + the radix. Must be between RTL_USTR_MIN_RADIX (2) and RTL_USTR_MAX_RADIX + (36), inclusive. + + @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. -*/ +/** Create the string representation of a float. + + This function cannot be used for language-specific conversion. + + @param str + a buffer that is big enough to hold the result and the terminating NUL + character. You should use the RTL_USTR_MAX_VALUEOFFLOAT define to create + a buffer that is big enough. + + @param f + a float value. + + @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. -*/ +/** Create the string representation of a double. + + This function cannot be used for language-specific conversion. + + @param str + a buffer that is big enough to hold the result and the terminating NUL + character. You should use the RTL_USTR_MAX_VALUEOFDOUBLE define to create + a buffer that is big enough. + + @param d + a double value. + + @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. +/** Interpret a string as a boolean. - @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. -*/ + This function cannot be used for language-specific conversion. The string + must be null-terminated. + + @param str + a null-terminated string. + + @return + true if the string is "1" or "true" in any ASCII case, false otherwise. + */ 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. +/** Interpret a string as an integer. - @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. -*/ + This function cannot be used for language-specific conversion. The string + must be null-terminated. + + @param str + a null-terminated string. + + @param radix + the radix. Must be between RTL_USTR_MIN_RADIX (2) and RTL_USTR_MAX_RADIX + (36), inclusive. + + @return + the integer value represented by the string, or 0 if the string does not + represent an integer. + */ 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. +/** Interpret a string as a long integer. - @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. -*/ + This function cannot be used for language-specific conversion. The string + must be null-terminated. + + @param str + a null-terminated string. + + @param radix + the radix. Must be between RTL_USTR_MIN_RADIX (2) and RTL_USTR_MAX_RADIX + (36), inclusive. + + @return + the long integer value represented by the string, or 0 if the string does + not represent a long integer. + */ 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. +/** Interpret a string as a float. - @param str a NULL-terminated string. - @return the float represented by the string. - 0.0 if the string represents no number. -*/ + This function cannot be used for language-specific conversion. The string + must be null-terminated. + + @param str + a null-terminated string. + + @return + the float value represented by the string, or 0.0 if the string does not + represent a float. + */ 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. +/** Interpret a string as a double. - @param str a NULL-terminated string. - @return the double represented by the string. - 0.0 if the string represents no number. -*/ + This function cannot be used for language-specific conversion. The string + must be null-terminated. + + @param str + a null-terminated string. + + @return + the float value represented by the string, or 0.0 if the string does not + represent a double. + */ double SAL_CALL rtl_ustr_toDouble( const sal_Unicode * str ) SAL_THROW_EXTERN_C(); /* ======================================================================= */ @@ -842,8 +992,9 @@ double SAL_CALL rtl_ustr_toDouble( const sal_Unicode * str ) SAL_THROW_EXTERN_C( #pragma pack(1) #endif -/** - The implementation structure of a unicode string. +/** The implementation of a Unicode string. + + @internal */ typedef struct _rtl_uString { @@ -860,286 +1011,341 @@ typedef struct _rtl_uString /* ----------------------------------------------------------------------- */ -/** - Increment the reference count of the string. +/** Increment the reference count of a string. - @param str the string. -*/ + @param str + a 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. +/** Decrement the reference count of a string. - @param str the string. -*/ + If the count goes to zero than the string data is deleted. + + @param str + a string. + */ void SAL_CALL rtl_uString_release( rtl_uString * str ) SAL_THROW_EXTERN_C(); -/** - Allocates a new string containing no characters. +/** Allocate a new string containing no characters. - @param newStr pointer to the new string. The data must be 0 or - a valid string. -*/ + @param newStr + pointer to the new string. The pointed-to data must be null 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. -*/ +/** Allocate a new string containing space for a given number of characters. + + If len is greater than zero, the reference count of the new string will be + 1. The values of all characters are set to 0 and the length of the string + is 0. This function does not handle out-of-memory conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param len + the 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". +/** Allocate a new string that contains a copy of another string. - @param newStr pointer to the new string. The data must be 0 or - a valid string. - @param value a valid string. -*/ + If the length of value is greater than zero, the reference count of the + new string will be 1. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null 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". +/** Allocate a new string that contains a copy of a character array. - @param newStr pointer to the new string. The data must be 0 or - a valid string. - @param value a NULL-terminated character array. -*/ + If the length of value is greater than zero, the reference count of the + new string will be 1. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null 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. -*/ +/** Allocate a new string that contains a copy of a character array. + + If the length of value is greater than zero, the reference count of the + new string will be 1. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param value + a character array. Need not be null-terminated, but must be at least as + long as the specified len. + + @param len + the length of the character array. + */ void SAL_CALL rtl_uString_newFromStr_WithLength( rtl_uString ** newStr, const sal_Unicode * value, sal_Int32 len ) SAL_THROW_EXTERN_C(); -/** - Allocates a new string that contains the same sequence of - characters contained in the character array argument without - conversion. - 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 ASCII character array. -*/ +/** Allocate a new string that contains a copy of a character array. + + If the length of value is greater than zero, the reference count of the + new string will be 1. This function does not handle out-of-memory + conditions. + + Since this function is optimized for performance, the ASCII character + values are not converted in any way. The caller has to make sure that + all ASCII characters are in the allowed range of 0 and 127, inclusive. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param value + a null-terminated ASCII character array. + */ void SAL_CALL rtl_uString_newFromAscii( rtl_uString ** newStr, const sal_Char * value ) SAL_THROW_EXTERN_C(); -/** - Assign rightValue to *str. Release *str and aquire rightValue! +/** Assign a new value to a string. - @param str pointer to the string. The data must be 0 or - a valid string. - @param rightValue a valid string. -*/ + First releases any value str might currently hold, then acquires + rightValue. + + @param str + pointer to the string. The pointed-to data must be null 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. +/** Return the length of a string. - @param str a valid string. - @return the length of the sequence of characters represented by the - string. -*/ + The length is equal to the number of characters in the string. + + @param str + a valid string. + + @return + the length of 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. +/** Return a pointer to the underlying character array of a string. - @param str pointer to the string. The data must be - a valid string. - @return a null terminated character array. -*/ + @param str + a valid string. + + @return + a pointer to the 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. -*/ +/** Create a new string that is the concatenation of two other strings. + + The new string does not necessarily have a reference count of 1 (in cases + where one of the two other strings is empty), so it must not be modified + without checking the reference count. This function does not handle + out-of-memory conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null 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 replacing index in str. - 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). -*/ +/** Create a new string by replacing a substring of another string. + + The new string results from replacing a number of characters (count), + starting at the specified position (index) in the original string (str), + with some new substring (subStr). If subStr is null, than only a number + of characters is deleted. + + The new string does not necessarily have a reference count of 1, so it + must not be modified without checking the reference count. This function + does not handle out-of-memory conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a valid string. + + @param index + the index into str at which to start replacement. Must be between 0 and + the length of str, inclusive. + + @param count + the number of charcters to remove. Must not be negative, and the sum of + index and count must not exceed the length of str. + + @param subStr + either null or a valid string to be inserted. + */ 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(); -/** - Returns a new string resulting from replacing all occurrences of - oldChar in this string with newChar. - If the character oldChar does not occur in the character sequence - represented by this object, then the string is assigned with - str. 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 oldChar the old character. - @param newChar the new character. -*/ +/** Create a new string by replacing all occurrences of a single character + within another string. + + The new string results from replacing all occurrences of oldChar in str + with newChar. + + The new string does not necessarily have a reference count of 1 (in cases + where oldChar does not occur in str), so it must not be modified without + checking the reference count. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a valid string. + + @param oldChar + the old character. + + @param newChar + the new character. + */ void SAL_CALL rtl_uString_newReplace( rtl_uString ** newStr, rtl_uString * str, sal_Unicode oldChar, sal_Unicode newChar ) SAL_THROW_EXTERN_C(); -/** - Returns a new string resulting from converting all - ASCII uppercase characters (65-90) in the string to - ASCII lowercase characters (97-122). - This function can't be used for language specific conversion. - If the string doesn't contain characters which must be converted, - then the new string is assigned with str. 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. -*/ +/** Create a new string by converting all ASCII uppercase letters to lowercase + within another string. + + The new string results from replacing all characters with values between + 65 and 90 (ASCII A--Z) by values between 97 and 122 (ASCII a--z). + + This function cannot be used for language-specific conversion. The new + string does not necessarily have a reference count of 1 (in cases where + no characters need to be converted), so it must not be modified without + checking the reference count. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a valid string. + */ void SAL_CALL rtl_uString_newToAsciiLowerCase( rtl_uString ** newStr, rtl_uString * str ) SAL_THROW_EXTERN_C(); -/** - Returns a new string resulting from converting all - ASCII lowercase characters (97-122) in the string to - ASCII uppercase characters (65-90). - This function can't be used for language specific conversion. - If the string doesn't contain characters which must be converted, - then the new string is assigned with str. 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. +/** Create a new string by converting all ASCII lowercase letters to uppercase + within another string. + + The new string results from replacing all characters with values between + 97 and 122 (ASCII a--z) by values between 65 and 90 (ASCII A--Z). + + This function cannot be used for language-specific conversion. The new + string does not necessarily have a reference count of 1 (in cases where + no characters need to be converted), so it must not be modified without + checking the reference count. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a valid string. */ void SAL_CALL rtl_uString_newToAsciiUpperCase( rtl_uString ** newStr, rtl_uString * str ) SAL_THROW_EXTERN_C(); -/** - Returns a new string resulting from removing white space from both ends - of the string. - All characters that have codes less than or equal to - 32 (the space character) are considered to be white space. - Also the Unicode space characters between 0x2000 and 0x200B, - 0x2028 (LINE SEPARATOR) and 0x2029 (PARAGRAPH SEPARATOR) are - considered to be white space. - If the string doesn't contain white spaces at both ends, - then the new string is assigned with str. 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. -*/ +/** Create a new string by removing white space from both ends of another + string. + + The new string results from removing all characters with values less than + or equal to 32 (the space character) form both ends of str. + + This function cannot be used for language-specific conversion. The new + string does not necessarily have a reference count of 1 (in cases where + no characters need to be removed), so it must not be modified without + checking the reference count. This function does not handle out-of-memory + conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a valid string. + */ void SAL_CALL rtl_uString_newTrim( rtl_uString ** newStr, rtl_uString * str ) SAL_THROW_EXTERN_C(); -/** - Returns a new string for the token specified by nToken. If nToken is - greater than the last possible Token then the result is an empty string. - The return value is the position of the next token or -1, if the queried - token is the last one. - Example: - rtl_uString* pToken = 0; - sal_Int32 nIndex = 0; - do - { - ... - nIndex = rtl_uString_getToken( &pToken, pStr, 0, ';', nIndex ); - ... - } - while ( nIndex >= 0 ); - 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 token the number of the token to return. The number - must be greater or equal as 0. - @param cTok the character which seperate the tokens. - @param index the position at which the token is searched in the - string. - The index must be greater or equal as 0 and - less or equal as the length of the string. - @return the index of the next token or -1, if the current token is - the last one -*/ +/** Create a new string by extracting a single token from another string. + + Starting at index, the token's next token is searched for. If there is no + such token, the result is an empty string. Otherwise, all characters from + the start of that token and up to, but not including the next occurrence + of cTok make up the resulting token. The return value is the position of + the next token, or -1 if no more tokens follow. + + Example code could look like + rtl_uString * pToken = NULL; + sal_Int32 nIndex = 0; + do + { + ... + nIndex = rtl_uString_getToken(&pToken, pStr, 0, ';', nIndex); + ... + } + while (nIndex >= 0); + + The new string does not necessarily have a reference count of 1, so it + must not be modified without checking the reference count. This function + does not handle out-of-memory conditions. + + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a valid string. + + @param token + the number of the token to return, starting at index. Must be + non-negative. + + @param cTok + the character that seperates the tokens. + + @param index + the position at which searching for the token starts. Must be between 0 + and the length of str, inclusive. + + @return + the index of the next token, or -1 if no more tokens follow. + */ sal_Int32 SAL_CALL rtl_uString_getToken( rtl_uString ** newStr , rtl_uString * str, sal_Int32 token, sal_Unicode cTok, sal_Int32 index ) 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 + +/* ======================================================================= */ + /* predefined constants for String-Conversion */ #define OSTRING_TO_OUSTRING_CVTFLAGS (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_MAPTOPRIVATE |\ RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_DEFAULT |\ @@ -1147,39 +1353,40 @@ sal_Int32 SAL_CALL rtl_uString_getToken( rtl_uString ** newStr , rtl_uString * s /* ----------------------------------------------------------------------- */ -/** - 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(); +/** Create a new Unicode string by converting a byte string, using a specific + text encoding. -/* ======================================================================= */ + The lengths of the byte string and the Unicode string may differ (e.g., + for double-byte encodings, UTF-7, UTF-8). -/* constAsciiStr must be a "..." or char const aFoo[] = "..." */ -#define RTL_CONSTASCII_USTRINGPARAM( constAsciiStr ) constAsciiStr, sizeof( constAsciiStr )-1, RTL_TEXTENCODING_ASCII_US + If the length of the byte string is greater than zero, the reference count + of the new string will be 1. This function does not handle out-of-memory + conditions. -/* ======================================================================= */ + @param newStr + pointer to the new string. The pointed-to data must be null or a valid + string. + + @param str + a byte character array. Need not be null-terminated, but must be at + least as long as the specified len. + + @param len + the length of the byte character array. + + @param encoding + the text encoding to use for conversion. + + @param convertFlags + flags which control the conversion. Either use + OSTRING_TO_OUSTRING_CVTFLAGS, or see + <http://udk.openoffice.org/cpp/man/spec/textconversion.html> for more + details. + */ +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(); #ifdef __cplusplus } #endif #endif /* _RTL_USTRING_H_ */ - - |