blob: 1f530f1bf713583983b7f7a6a68e8d34d25cd71f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
};
#define UNICODE_SHIFT 21
int do_precomposition(int base, int comb) {
int min = 0;
int max = sizeof(precompositions) / sizeof(precompositions[0]) - 1;
int mid;
unsigned long sought = ((unsigned) base << UNICODE_SHIFT) | (unsigned) comb;
unsigned long that;
/* binary search */
while (max >= min) {
mid = (min + max) / 2;
that = ((unsigned) precompositions[mid].base << UNICODE_SHIFT) | ((unsigned) precompositions[mid].comb);
if (that < sought) {
min = mid + 1;
} else if (that > sought) {
max = mid - 1;
} else {
return precompositions[mid].replacement;
}
}
/* no match */
return -1;
}
|