LibreOffice
LibreOffice 4.1 SDK C/C++ API Reference
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
ustring.h
Go to the documentation of this file.
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
5  * This Source Code Form is subject to the terms of the Mozilla Public
6  * License, v. 2.0. If a copy of the MPL was not distributed with this
7  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
11  * Licensed to the Apache Software Foundation (ASF) under one or more
12  * contributor license agreements. See the NOTICE file distributed
13  * with this work for additional information regarding copyright
14  * ownership. The ASF licenses this file to you under the Apache
15  * License, Version 2.0 (the "License"); you may not use this file
16  * except in compliance with the License. You may obtain a copy of
17  * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18  */
19 
20 #ifndef _RTL_USTRING_H_
21 #define _RTL_USTRING_H_
22 
23 #include "sal/config.h"
24 
25 #include "osl/interlck.h"
26 #include "rtl/string.h"
27 #include "rtl/textenc.h"
28 #include "sal/saldllapi.h"
29 #include "sal/types.h"
30 
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34 
35 /* ======================================================================= */
36 
49 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_getLength(
50  const sal_Unicode * str ) SAL_THROW_EXTERN_C();
51 
70 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_compare(
71  const sal_Unicode * first, const sal_Unicode * second ) SAL_THROW_EXTERN_C();
72 
99  const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C();
100 
131  const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen, sal_Int32 shortenedLen ) SAL_THROW_EXTERN_C();
132 
159  const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C();
160 
183  const sal_Unicode * first, const sal_Char * second, sal_Int32 len ) SAL_THROW_EXTERN_C();
184 
205  const sal_Unicode * first, const sal_Unicode * second ) SAL_THROW_EXTERN_C();
206 
235  const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C();
236 
270  const sal_Unicode * first, sal_Int32 firstLen, const sal_Unicode * second, sal_Int32 secondLen, sal_Int32 shortenedLen ) SAL_THROW_EXTERN_C();
271 
295 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_ascii_compare(
296  const sal_Unicode * first, const sal_Char * second ) SAL_THROW_EXTERN_C();
297 
325  const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second ) SAL_THROW_EXTERN_C();
326 
358  const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second, sal_Int32 shortenedLen ) SAL_THROW_EXTERN_C();
359 
390  const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second, sal_Int32 secondLen ) SAL_THROW_EXTERN_C();
391 
417  const sal_Unicode * first, const sal_Char * second ) SAL_THROW_EXTERN_C();
418 
448  const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second ) SAL_THROW_EXTERN_C();
449 
482  sal_Unicode const * first, sal_Int32 firstLen,
483  char const * second, sal_Int32 secondLen) SAL_THROW_EXTERN_C();
484 
519  const sal_Unicode * first, sal_Int32 firstLen, const sal_Char * second, sal_Int32 shortenedLen ) SAL_THROW_EXTERN_C();
520 
533 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_hashCode(
534  const sal_Unicode * str ) SAL_THROW_EXTERN_C();
535 
552  const sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C();
553 
568 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_indexOfChar(
569  const sal_Unicode * str, sal_Unicode ch ) SAL_THROW_EXTERN_C();
570 
588  const sal_Unicode * str, sal_Int32 len, sal_Unicode ch ) SAL_THROW_EXTERN_C();
589 
605 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_lastIndexOfChar(
606  const sal_Unicode * str, sal_Unicode ch ) SAL_THROW_EXTERN_C();
607 
626  const sal_Unicode * str, sal_Int32 len, sal_Unicode ch ) SAL_THROW_EXTERN_C();
627 
643 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_indexOfStr(
644  const sal_Unicode * str, const sal_Unicode * subStr ) SAL_THROW_EXTERN_C();
645 
669  const sal_Unicode * str, sal_Int32 len, const sal_Unicode * subStr, sal_Int32 subLen ) SAL_THROW_EXTERN_C();
670 
696  sal_Unicode const * str, sal_Int32 len,
697  char const * subStr, sal_Int32 subLen) SAL_THROW_EXTERN_C();
698 
714 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_lastIndexOfStr(
715  const sal_Unicode * str, const sal_Unicode * subStr ) SAL_THROW_EXTERN_C();
716 
740  const sal_Unicode * str, sal_Int32 len, const sal_Unicode * subStr, sal_Int32 subLen ) SAL_THROW_EXTERN_C();
741 
767  sal_Unicode const * str, sal_Int32 len,
768  char const * subStr, sal_Int32 subLen) SAL_THROW_EXTERN_C();
769 
784 SAL_DLLPUBLIC void SAL_CALL rtl_ustr_replaceChar(
785  sal_Unicode * str, sal_Unicode oldChar, sal_Unicode newChar ) SAL_THROW_EXTERN_C();
786 
805  sal_Unicode * str, sal_Int32 len, sal_Unicode oldChar, sal_Unicode newChar ) SAL_THROW_EXTERN_C();
806 
818 
832  sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C();
833 
845 
859  sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C();
860 
873 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_trim(
875 
892 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_trim_WithLength(
893  sal_Unicode * str, sal_Int32 len ) SAL_THROW_EXTERN_C();
894 
913 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfBoolean(
915 #define RTL_USTR_MAX_VALUEOFBOOLEAN RTL_STR_MAX_VALUEOFBOOLEAN
916 
930 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfChar(
932 #define RTL_USTR_MAX_VALUEOFCHAR RTL_STR_MAX_VALUEOFCHAR
933 
953 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfInt32(
954  sal_Unicode * str, sal_Int32 i, sal_Int16 radix ) SAL_THROW_EXTERN_C();
955 #define RTL_USTR_MIN_RADIX RTL_STR_MIN_RADIX
956 #define RTL_USTR_MAX_RADIX RTL_STR_MAX_RADIX
957 #define RTL_USTR_MAX_VALUEOFINT32 RTL_STR_MAX_VALUEOFINT32
958 
978 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfInt64(
979  sal_Unicode * str, sal_Int64 l, sal_Int16 radix ) SAL_THROW_EXTERN_C();
980 #define RTL_USTR_MAX_VALUEOFINT64 RTL_STR_MAX_VALUEOFINT64
981 
1001 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfUInt64(
1002  sal_Unicode * str, sal_uInt64 l, sal_Int16 radix ) SAL_THROW_EXTERN_C();
1003 #define RTL_USTR_MAX_VALUEOFINT64 RTL_STR_MAX_VALUEOFINT64
1004 
1020 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfFloat(
1021  sal_Unicode * str, float f ) SAL_THROW_EXTERN_C();
1022 #define RTL_USTR_MAX_VALUEOFFLOAT RTL_STR_MAX_VALUEOFFLOAT
1023 
1039 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_valueOfDouble(
1040  sal_Unicode * str, double d ) SAL_THROW_EXTERN_C();
1041 #define RTL_USTR_MAX_VALUEOFDOUBLE RTL_STR_MAX_VALUEOFDOUBLE
1042 
1055  const sal_Unicode * str ) SAL_THROW_EXTERN_C();
1056 
1073 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_ustr_toInt32(
1074  const sal_Unicode * str, sal_Int16 radix ) SAL_THROW_EXTERN_C();
1075 
1092 SAL_DLLPUBLIC sal_Int64 SAL_CALL rtl_ustr_toInt64(
1093  const sal_Unicode * str, sal_Int16 radix ) SAL_THROW_EXTERN_C();
1094 
1113 SAL_DLLPUBLIC sal_uInt64 SAL_CALL rtl_ustr_toUInt64(
1114  const sal_Unicode * str, sal_Int16 radix ) SAL_THROW_EXTERN_C();
1115 
1128 SAL_DLLPUBLIC float SAL_CALL rtl_ustr_toFloat(
1129  const sal_Unicode * str ) SAL_THROW_EXTERN_C();
1130 
1143 SAL_DLLPUBLIC double SAL_CALL rtl_ustr_toDouble(
1144  const sal_Unicode * str ) SAL_THROW_EXTERN_C();
1145 
1146 /* ======================================================================= */
1147 
1148 #if defined(SAL_W32)
1149 #pragma pack(push, 4)
1150 #endif
1151 
1155 typedef struct _rtl_uString
1156 {
1157  oslInterlockedCount refCount; /* opaque */
1158  sal_Int32 length;
1159  sal_Unicode buffer[1];
1160 } rtl_uString;
1163 #if defined(SAL_W32)
1164 #pragma pack(pop)
1165 #endif
1166 
1167 /* ----------------------------------------------------------------------- */
1168 
1174 SAL_DLLPUBLIC void SAL_CALL rtl_uString_acquire(
1175  rtl_uString * str ) SAL_THROW_EXTERN_C();
1176 
1184 SAL_DLLPUBLIC void SAL_CALL rtl_uString_release(
1185  rtl_uString * str ) SAL_THROW_EXTERN_C();
1186 
1193 SAL_DLLPUBLIC void SAL_CALL rtl_uString_new(
1194  rtl_uString ** newStr ) SAL_THROW_EXTERN_C();
1195 
1217 SAL_DLLPUBLIC rtl_uString * SAL_CALL rtl_uString_alloc(sal_Int32 nLen) SAL_THROW_EXTERN_C();
1218 
1233  rtl_uString ** newStr, sal_Int32 nLen ) SAL_THROW_EXTERN_C();
1234 
1249  rtl_uString ** newStr, const rtl_uString * value ) SAL_THROW_EXTERN_C();
1250 
1265  rtl_uString ** newStr, const sal_Unicode * value ) SAL_THROW_EXTERN_C();
1266 
1285  rtl_uString ** newStr, const sal_Unicode * value, sal_Int32 len ) SAL_THROW_EXTERN_C();
1286 
1303  rtl_uString ** newStr, const rtl_uString * from,
1304  sal_Int32 beginIndex, sal_Int32 count ) SAL_THROW_EXTERN_C();
1305 
1324  rtl_uString ** newStr, const sal_Char * value ) SAL_THROW_EXTERN_C();
1325 
1331  rtl_uString ** newStr, const sal_Char * value, sal_Int32 len,
1332  sal_Int32 allocExtra ) SAL_THROW_EXTERN_C();
1333 
1354  rtl_uString ** newString, sal_uInt32 const * codePoints,
1355  sal_Int32 codePointCount) SAL_THROW_EXTERN_C();
1356 
1369 SAL_DLLPUBLIC void SAL_CALL rtl_uString_assign(
1370  rtl_uString ** str, rtl_uString * rightValue ) SAL_THROW_EXTERN_C();
1371 
1382 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_uString_getLength(
1383  const rtl_uString * str ) SAL_THROW_EXTERN_C();
1384 
1394  rtl_uString * str ) SAL_THROW_EXTERN_C();
1395 
1413 SAL_DLLPUBLIC void SAL_CALL rtl_uString_newConcat(
1414  rtl_uString ** newStr, rtl_uString * left, rtl_uString * right ) SAL_THROW_EXTERN_C();
1415 
1446  rtl_uString ** newStr, rtl_uString * str, sal_Int32 idx, sal_Int32 count, rtl_uString * subStr ) SAL_THROW_EXTERN_C();
1447 
1473  rtl_uString ** newStr, rtl_uString * str, sal_Unicode oldChar, sal_Unicode newChar ) SAL_THROW_EXTERN_C();
1474 
1497  rtl_uString ** newStr, rtl_uString * str, rtl_uString const * from,
1498  rtl_uString const * to, sal_Int32 * index) SAL_THROW_EXTERN_C();
1499 
1525  rtl_uString ** newStr, rtl_uString * str, char const * from,
1526  sal_Int32 fromLength, rtl_uString const * to, sal_Int32 * index)
1528 
1557  rtl_uString ** newStr, rtl_uString * str, char const * from,
1558  sal_Int32 fromLength, char const * to, sal_Int32 toLength,
1559  sal_Int32 * index) SAL_THROW_EXTERN_C();
1560 
1579  rtl_uString ** newStr, rtl_uString * str, rtl_uString const * from,
1580  rtl_uString const * to) SAL_THROW_EXTERN_C();
1581 
1602  rtl_uString ** newStr, rtl_uString * str, rtl_uString const * from,
1603  rtl_uString const * to, sal_Int32 fromIndex) SAL_THROW_EXTERN_C();
1604 
1626  rtl_uString ** newStr, rtl_uString * str, char const * from,
1627  sal_Int32 fromLength, rtl_uString const * to) SAL_THROW_EXTERN_C();
1628 
1653  rtl_uString ** newStr, rtl_uString * str, char const * from,
1654  sal_Int32 fromLength, char const * to, sal_Int32 toLength)
1656 
1677  rtl_uString ** newStr, rtl_uString * str ) SAL_THROW_EXTERN_C();
1678 
1699  rtl_uString ** newStr, rtl_uString * str ) SAL_THROW_EXTERN_C();
1700 
1720 SAL_DLLPUBLIC void SAL_CALL rtl_uString_newTrim(
1721  rtl_uString ** newStr, rtl_uString * str ) SAL_THROW_EXTERN_C();
1722 
1767 SAL_DLLPUBLIC sal_Int32 SAL_CALL rtl_uString_getToken(
1768  rtl_uString ** newStr , rtl_uString * str, sal_Int32 token, sal_Unicode cTok, sal_Int32 idx ) SAL_THROW_EXTERN_C();
1769 
1770 /* ======================================================================= */
1771 
1785 // The &foo[0] trick is intentional, it makes sure the type is char* or const char*
1786 // (plain cast to const char* would not work with non-const char foo[]="a", which seems to be allowed).
1787 // This is to avoid mistaken use with functions that accept string literals
1788 // (i.e. const char (&)[N]) where usage of this macro otherwise could match
1789 // the argument and a following int argument with a default value (e.g. OUString::match()).
1790 #define RTL_CONSTASCII_USTRINGPARAM( constAsciiStr ) (&(constAsciiStr)[0]), \
1791  ((sal_Int32)(SAL_N_ELEMENTS(constAsciiStr)-1)), RTL_TEXTENCODING_ASCII_US
1792 
1793 /* ======================================================================= */
1794 
1795 /* predefined constants for String-Conversion */
1796 #define OSTRING_TO_OUSTRING_CVTFLAGS (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_MAPTOPRIVATE |\
1797  RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_DEFAULT |\
1798  RTL_TEXTTOUNICODE_FLAGS_INVALID_DEFAULT)
1799 
1800 /* ----------------------------------------------------------------------- */
1801 
1834 SAL_DLLPUBLIC void SAL_CALL rtl_string2UString(
1835  rtl_uString ** newStr, const sal_Char * str, sal_Int32 len, rtl_TextEncoding encoding, sal_uInt32 convertFlags ) SAL_THROW_EXTERN_C();
1836 
1837 /* ======================================================================= */
1838 /* Interning methods */
1839 
1859 SAL_DLLPUBLIC void SAL_CALL rtl_uString_intern(
1860  rtl_uString ** newStr, rtl_uString * str) SAL_THROW_EXTERN_C();
1861 
1898  rtl_uString ** newStr,
1899  const sal_Char * str,
1900  sal_Int32 len,
1901  rtl_TextEncoding encoding,
1902  sal_uInt32 convertFlags,
1903  sal_uInt32 *pInfo) SAL_THROW_EXTERN_C();
1904 
1957 SAL_DLLPUBLIC sal_uInt32 SAL_CALL rtl_uString_iterateCodePoints(
1958  rtl_uString const * string, sal_Int32 * indexUtf16,
1959  sal_Int32 incrementCodePoints);
1960 
1995  rtl_uString ** target, char const * source, sal_Int32 length,
1996  rtl_TextEncoding encoding, sal_uInt32 flags) SAL_THROW_EXTERN_C();
1997 
2014 SAL_DLLPUBLIC void SAL_CALL rtl_uString_ensureCapacity( rtl_uString ** str, sal_Int32 size ) SAL_THROW_EXTERN_C();
2015 
2016 #ifdef __cplusplus
2017 }
2018 #endif
2019 
2020 #endif /* _RTL_USTRING_H_ */
2021 
2022 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */