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 #include <i18nutil/oneToOneMapping.hxx>
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski namespace com { namespace sun { namespace star { namespace i18n {
27*b1cdbd2cSJim Jagielski 
oneToOneMapping(OneToOneMappingTable_t * rpTable,const size_t rnBytes,const size_t rnUnitSize)28*b1cdbd2cSJim Jagielski oneToOneMapping::oneToOneMapping( OneToOneMappingTable_t *rpTable, const size_t rnBytes, const size_t rnUnitSize )
29*b1cdbd2cSJim Jagielski     : mpTable( rpTable ),
30*b1cdbd2cSJim Jagielski       mnSize( rnBytes / rnUnitSize )
31*b1cdbd2cSJim Jagielski {
32*b1cdbd2cSJim Jagielski }
33*b1cdbd2cSJim Jagielski 
~oneToOneMapping()34*b1cdbd2cSJim Jagielski oneToOneMapping::~oneToOneMapping()
35*b1cdbd2cSJim Jagielski {
36*b1cdbd2cSJim Jagielski }
37*b1cdbd2cSJim Jagielski 
find(const sal_Unicode nKey) const38*b1cdbd2cSJim Jagielski sal_Unicode oneToOneMapping::find(const sal_Unicode nKey) const
39*b1cdbd2cSJim Jagielski {
40*b1cdbd2cSJim Jagielski     if( mpTable )
41*b1cdbd2cSJim Jagielski     {
42*b1cdbd2cSJim Jagielski         // binary search
43*b1cdbd2cSJim Jagielski 	    int bottom = 0;
44*b1cdbd2cSJim Jagielski 	    int top = mnSize - 1;
45*b1cdbd2cSJim Jagielski 	    int current;
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski 	    for (;;) {
48*b1cdbd2cSJim Jagielski             current = (top + bottom) / 2;
49*b1cdbd2cSJim Jagielski             if( nKey < mpTable[current].first )
50*b1cdbd2cSJim Jagielski                 top = current - 1;
51*b1cdbd2cSJim Jagielski             else if( nKey > mpTable[current].first )
52*b1cdbd2cSJim Jagielski                 bottom = current + 1;
53*b1cdbd2cSJim Jagielski             else
54*b1cdbd2cSJim Jagielski                 return mpTable[current].second;
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski             if( bottom > top )
57*b1cdbd2cSJim Jagielski                 return sal_Unicode( nKey );
58*b1cdbd2cSJim Jagielski 	    }
59*b1cdbd2cSJim Jagielski     }
60*b1cdbd2cSJim Jagielski     else
61*b1cdbd2cSJim Jagielski         return sal_Unicode( nKey );
62*b1cdbd2cSJim Jagielski }
63*b1cdbd2cSJim Jagielski 
oneToOneMappingWithFlag(UnicodePairWithFlag * rpTableWF,const size_t rnSize,const UnicodePairFlag rnFlag)64*b1cdbd2cSJim Jagielski oneToOneMappingWithFlag::oneToOneMappingWithFlag( UnicodePairWithFlag *rpTableWF, const size_t rnSize, const UnicodePairFlag rnFlag )
65*b1cdbd2cSJim Jagielski     : oneToOneMapping( NULL, rnSize, sizeof(UnicodePairWithFlag) ),
66*b1cdbd2cSJim Jagielski       mpTableWF ( rpTableWF ),
67*b1cdbd2cSJim Jagielski       mnFlag    ( rnFlag ),
68*b1cdbd2cSJim Jagielski       mbHasIndex( sal_False )
69*b1cdbd2cSJim Jagielski {
70*b1cdbd2cSJim Jagielski }
71*b1cdbd2cSJim Jagielski 
~oneToOneMappingWithFlag()72*b1cdbd2cSJim Jagielski oneToOneMappingWithFlag::~oneToOneMappingWithFlag()
73*b1cdbd2cSJim Jagielski {
74*b1cdbd2cSJim Jagielski 	if( mbHasIndex )
75*b1cdbd2cSJim Jagielski         for( int i = 0; i < 256; i++ )
76*b1cdbd2cSJim Jagielski             if( mpIndex[i] )
77*b1cdbd2cSJim Jagielski                 delete [] mpIndex[i];
78*b1cdbd2cSJim Jagielski }
79*b1cdbd2cSJim Jagielski 
80*b1cdbd2cSJim Jagielski 
makeIndex()81*b1cdbd2cSJim Jagielski void oneToOneMappingWithFlag::makeIndex()
82*b1cdbd2cSJim Jagielski {
83*b1cdbd2cSJim Jagielski     if( !mbHasIndex && mpTableWF )
84*b1cdbd2cSJim Jagielski     {
85*b1cdbd2cSJim Jagielski         int i, j, high, low, current = -1;
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski         for( i = 0; i < 256; i++ )
88*b1cdbd2cSJim Jagielski             mpIndex[i] = NULL;
89*b1cdbd2cSJim Jagielski 
90*b1cdbd2cSJim Jagielski         for( size_t k = 0; k < mnSize; k++ )
91*b1cdbd2cSJim Jagielski         {
92*b1cdbd2cSJim Jagielski             high = (mpTableWF[k].first >> 8) & 0xFF;
93*b1cdbd2cSJim Jagielski             low  = (mpTableWF[k].first)      & 0xFF;
94*b1cdbd2cSJim Jagielski             if( high != current )
95*b1cdbd2cSJim Jagielski             {
96*b1cdbd2cSJim Jagielski                 current = high;
97*b1cdbd2cSJim Jagielski                 mpIndex[high] = new UnicodePairWithFlag*[256];
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski                 for( j = 0; j < 256; j++ )
100*b1cdbd2cSJim Jagielski                     mpIndex[high][j] = NULL;
101*b1cdbd2cSJim Jagielski             }
102*b1cdbd2cSJim Jagielski             mpIndex[high][low] = &mpTableWF[k];
103*b1cdbd2cSJim Jagielski         }
104*b1cdbd2cSJim Jagielski 
105*b1cdbd2cSJim Jagielski         mbHasIndex = sal_True;
106*b1cdbd2cSJim Jagielski     }
107*b1cdbd2cSJim Jagielski }
108*b1cdbd2cSJim Jagielski 
find(const sal_Unicode nKey) const109*b1cdbd2cSJim Jagielski sal_Unicode oneToOneMappingWithFlag::find( const sal_Unicode nKey ) const
110*b1cdbd2cSJim Jagielski {
111*b1cdbd2cSJim Jagielski     if( mpTableWF )
112*b1cdbd2cSJim Jagielski     {
113*b1cdbd2cSJim Jagielski         if( mbHasIndex )
114*b1cdbd2cSJim Jagielski         {
115*b1cdbd2cSJim Jagielski             // index search
116*b1cdbd2cSJim Jagielski             int high, low;
117*b1cdbd2cSJim Jagielski             high = (nKey >> 8) & 0xFF;
118*b1cdbd2cSJim Jagielski             low = nKey & 0xFF;
119*b1cdbd2cSJim Jagielski             if( mpIndex[high] != NULL &&
120*b1cdbd2cSJim Jagielski                 mpIndex[high][low] != NULL &&
121*b1cdbd2cSJim Jagielski                 mpIndex[high][low]->flag & mnFlag )
122*b1cdbd2cSJim Jagielski                 return mpIndex[high][low]->second;
123*b1cdbd2cSJim Jagielski             else
124*b1cdbd2cSJim Jagielski                 return sal_Unicode( nKey );
125*b1cdbd2cSJim Jagielski         }
126*b1cdbd2cSJim Jagielski         else
127*b1cdbd2cSJim Jagielski         {
128*b1cdbd2cSJim Jagielski             // binary search
129*b1cdbd2cSJim Jagielski             int bottom = 0;
130*b1cdbd2cSJim Jagielski             int top = mnSize - 1;
131*b1cdbd2cSJim Jagielski             int current;
132*b1cdbd2cSJim Jagielski 
133*b1cdbd2cSJim Jagielski             for (;;) {
134*b1cdbd2cSJim Jagielski                 current = (top + bottom) / 2;
135*b1cdbd2cSJim Jagielski                 if( nKey < mpTableWF[current].first )
136*b1cdbd2cSJim Jagielski                     top = current - 1;
137*b1cdbd2cSJim Jagielski                 else if( nKey > mpTableWF[current].first )
138*b1cdbd2cSJim Jagielski                     bottom = current + 1;
139*b1cdbd2cSJim Jagielski                 else
140*b1cdbd2cSJim Jagielski                 {
141*b1cdbd2cSJim Jagielski                     if( mpTableWF[current].flag & mnFlag )
142*b1cdbd2cSJim Jagielski                         return mpTableWF[current].second;
143*b1cdbd2cSJim Jagielski                     else
144*b1cdbd2cSJim Jagielski                         return sal_Unicode( nKey );
145*b1cdbd2cSJim Jagielski                 }
146*b1cdbd2cSJim Jagielski 
147*b1cdbd2cSJim Jagielski                 if( bottom > top )
148*b1cdbd2cSJim Jagielski                     return sal_Unicode( nKey );
149*b1cdbd2cSJim Jagielski             }
150*b1cdbd2cSJim Jagielski 	    }
151*b1cdbd2cSJim Jagielski 	}
152*b1cdbd2cSJim Jagielski     else
153*b1cdbd2cSJim Jagielski         return sal_Unicode( nKey );
154*b1cdbd2cSJim Jagielski }
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski 
157*b1cdbd2cSJim Jagielski } } } }
158