1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_i18npool.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include <transliteration_Numeric.hxx>
28*b1cdbd2cSJim Jagielski #include <nativenumbersupplier.hxx>
29*b1cdbd2cSJim Jagielski #include <defaultnumberingprovider.hxx>
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski using namespace com::sun::star::uno;
32*b1cdbd2cSJim Jagielski using namespace rtl;
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski namespace com { namespace sun { namespace star { namespace i18n {
35*b1cdbd2cSJim Jagielski 
getType()36*b1cdbd2cSJim Jagielski sal_Int16 SAL_CALL transliteration_Numeric::getType() throw(RuntimeException)
37*b1cdbd2cSJim Jagielski {
38*b1cdbd2cSJim Jagielski         return TransliterationType::NUMERIC;
39*b1cdbd2cSJim Jagielski }
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski OUString SAL_CALL
folding(const OUString &,sal_Int32,sal_Int32,Sequence<sal_Int32> &)42*b1cdbd2cSJim Jagielski transliteration_Numeric::folding( const OUString& /*inStr*/, sal_Int32 /*startPos*/, sal_Int32 /*nCount*/, Sequence< sal_Int32 >& /*offset*/ )
43*b1cdbd2cSJim Jagielski         throw(RuntimeException)
44*b1cdbd2cSJim Jagielski {
45*b1cdbd2cSJim Jagielski         throw (new RuntimeException());
46*b1cdbd2cSJim Jagielski }
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL
equals(const OUString &,sal_Int32,sal_Int32,sal_Int32 &,const OUString &,sal_Int32,sal_Int32,sal_Int32 &)49*b1cdbd2cSJim Jagielski transliteration_Numeric::equals( const OUString& /*str1*/, sal_Int32 /*pos1*/, sal_Int32 /*nCount1*/, sal_Int32& /*nMatch1*/, const OUString& /*str2*/, sal_Int32 /*pos2*/, sal_Int32 /*nCount2*/, sal_Int32& /*nMatch2*/ )
50*b1cdbd2cSJim Jagielski         throw(RuntimeException)
51*b1cdbd2cSJim Jagielski {
52*b1cdbd2cSJim Jagielski         throw (new RuntimeException());
53*b1cdbd2cSJim Jagielski }
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski Sequence< OUString > SAL_CALL
transliterateRange(const OUString &,const OUString &)56*b1cdbd2cSJim Jagielski transliteration_Numeric::transliterateRange( const OUString& /*str1*/, const OUString& /*str2*/ )
57*b1cdbd2cSJim Jagielski         throw(RuntimeException)
58*b1cdbd2cSJim Jagielski {
59*b1cdbd2cSJim Jagielski         throw (new RuntimeException());
60*b1cdbd2cSJim Jagielski }
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski 
63*b1cdbd2cSJim Jagielski #define isNumber(c) ((c) >= 0x30 && (c) <= 0x39)
64*b1cdbd2cSJim Jagielski #define NUMBER_ZERO 0x30
65*b1cdbd2cSJim Jagielski 
66*b1cdbd2cSJim Jagielski OUString SAL_CALL
transliterateBullet(const OUString & inStr,sal_Int32 startPos,sal_Int32 nCount,Sequence<sal_Int32> & offset)67*b1cdbd2cSJim Jagielski transliteration_Numeric::transliterateBullet( const OUString& inStr, sal_Int32 startPos, sal_Int32 nCount,
68*b1cdbd2cSJim Jagielski         Sequence< sal_Int32 >& offset ) throw(RuntimeException)
69*b1cdbd2cSJim Jagielski {
70*b1cdbd2cSJim Jagielski         sal_Int32 number = -1, j = 0, endPos = startPos + nCount;
71*b1cdbd2cSJim Jagielski 
72*b1cdbd2cSJim Jagielski         if (endPos >  inStr.getLength())
73*b1cdbd2cSJim Jagielski             endPos = inStr.getLength();
74*b1cdbd2cSJim Jagielski 
75*b1cdbd2cSJim Jagielski         rtl_uString* pStr = x_rtl_uString_new_WithLength( nCount );  // our x_rtl_ustring.h
76*b1cdbd2cSJim Jagielski         sal_Unicode* out = pStr->buffer;
77*b1cdbd2cSJim Jagielski 
78*b1cdbd2cSJim Jagielski         if (useOffset)
79*b1cdbd2cSJim Jagielski             offset.realloc(nCount);
80*b1cdbd2cSJim Jagielski 
81*b1cdbd2cSJim Jagielski         for (sal_Int32 i = startPos; i < endPos; i++) {
82*b1cdbd2cSJim Jagielski             if (i < endPos && isNumber(inStr[i])) {
83*b1cdbd2cSJim Jagielski                 if (number == -1) {
84*b1cdbd2cSJim Jagielski                     startPos = i;
85*b1cdbd2cSJim Jagielski                     number = (inStr[i] - NUMBER_ZERO);
86*b1cdbd2cSJim Jagielski                 } else  {
87*b1cdbd2cSJim Jagielski                     number = number * 10 + (inStr[i] - NUMBER_ZERO);
88*b1cdbd2cSJim Jagielski                 }
89*b1cdbd2cSJim Jagielski             } else {
90*b1cdbd2cSJim Jagielski                 if (number == 0) {
91*b1cdbd2cSJim Jagielski                     if (useOffset)
92*b1cdbd2cSJim Jagielski                         offset[j] = startPos;
93*b1cdbd2cSJim Jagielski                     out[j++] = NUMBER_ZERO;
94*b1cdbd2cSJim Jagielski                 } if (number > tableSize && !recycleSymbol) {
95*b1cdbd2cSJim Jagielski                     for (sal_Int32 k = startPos; k < i; k++) {
96*b1cdbd2cSJim Jagielski                         if (useOffset)
97*b1cdbd2cSJim Jagielski                             offset[j] = k;
98*b1cdbd2cSJim Jagielski                         out[j++] = inStr[k];
99*b1cdbd2cSJim Jagielski                     }
100*b1cdbd2cSJim Jagielski                 } else if (number > 0) {
101*b1cdbd2cSJim Jagielski                     if (useOffset)
102*b1cdbd2cSJim Jagielski                         offset[j] = startPos;
103*b1cdbd2cSJim Jagielski                     out[j++] = table[--number % tableSize];
104*b1cdbd2cSJim Jagielski                 } else if (i < endPos) {
105*b1cdbd2cSJim Jagielski                     if (useOffset)
106*b1cdbd2cSJim Jagielski                         offset[j] = i;
107*b1cdbd2cSJim Jagielski                     out[j++] = inStr[i];
108*b1cdbd2cSJim Jagielski                 }
109*b1cdbd2cSJim Jagielski                 number = -1;
110*b1cdbd2cSJim Jagielski             }
111*b1cdbd2cSJim Jagielski         }
112*b1cdbd2cSJim Jagielski         out[j] = 0;
113*b1cdbd2cSJim Jagielski 
114*b1cdbd2cSJim Jagielski         if (useOffset)
115*b1cdbd2cSJim Jagielski             offset.realloc(j);
116*b1cdbd2cSJim Jagielski 
117*b1cdbd2cSJim Jagielski         return OUString( pStr, SAL_NO_ACQUIRE ); // take over ownership of <pStr>
118*b1cdbd2cSJim Jagielski }
119*b1cdbd2cSJim Jagielski 
120*b1cdbd2cSJim Jagielski OUString SAL_CALL
transliterate(const OUString & inStr,sal_Int32 startPos,sal_Int32 nCount,Sequence<sal_Int32> & offset)121*b1cdbd2cSJim Jagielski transliteration_Numeric::transliterate( const OUString& inStr, sal_Int32 startPos, sal_Int32 nCount,
122*b1cdbd2cSJim Jagielski         Sequence< sal_Int32 >& offset ) throw(RuntimeException)
123*b1cdbd2cSJim Jagielski {
124*b1cdbd2cSJim Jagielski         if (tableSize)
125*b1cdbd2cSJim Jagielski             return transliterateBullet( inStr, startPos, nCount, offset);
126*b1cdbd2cSJim Jagielski         else
127*b1cdbd2cSJim Jagielski             return NativeNumberSupplier(useOffset).getNativeNumberString( inStr.copy(startPos, nCount), aLocale, nNativeNumberMode, offset );
128*b1cdbd2cSJim Jagielski }
129*b1cdbd2cSJim Jagielski 
130*b1cdbd2cSJim Jagielski sal_Unicode SAL_CALL
transliterateChar2Char(sal_Unicode inChar)131*b1cdbd2cSJim Jagielski transliteration_Numeric::transliterateChar2Char( sal_Unicode inChar ) throw(RuntimeException, MultipleCharsOutputException)
132*b1cdbd2cSJim Jagielski {
133*b1cdbd2cSJim Jagielski         if (tableSize) {
134*b1cdbd2cSJim Jagielski             if (isNumber(inChar)) {
135*b1cdbd2cSJim Jagielski                 sal_Int16 number = inChar - NUMBER_ZERO;
136*b1cdbd2cSJim Jagielski                 if (number <= tableSize || recycleSymbol)
137*b1cdbd2cSJim Jagielski                     return table[--number % tableSize];
138*b1cdbd2cSJim Jagielski             }
139*b1cdbd2cSJim Jagielski             return inChar;
140*b1cdbd2cSJim Jagielski         }
141*b1cdbd2cSJim Jagielski         else
142*b1cdbd2cSJim Jagielski             return NativeNumberSupplier().getNativeNumberChar( inChar, aLocale, nNativeNumberMode );
143*b1cdbd2cSJim Jagielski }
144*b1cdbd2cSJim Jagielski 
145*b1cdbd2cSJim Jagielski } } } }
146