1 /* Blocks of Unicode characters.
2 Copyright (C) 2007, 2009-2021 Free Software Foundation, Inc.
3 Written by Bruno Haible <bruno@clisp.org>, 2007.
5 This program is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Lesser General Public License as published
7 by the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License
16 along with this program. If not, see <https://www.gnu.org/licenses/>. */
28 unsigned int first_index
;
29 unsigned int last_index
;
31 if (uc
< blocks_level1_threshold
)
33 unsigned int index1
= uc
>> blocks_level1_shift
;
34 first_index
= blocks_level1
[2 * index1
];
35 last_index
= blocks_level1
[2 * index1
+ 1];
39 first_index
= blocks_upper_first_index
;
40 last_index
= blocks_upper_last_index
;
42 /* We know that the relevant blocks are blocks[i] with
43 first_index <= i < last_index. Now perform a binary search. */
44 while (first_index
< last_index
)
46 unsigned int mid_index
= (first_index
+ last_index
) / 2;
47 if (blocks
[mid_index
].end
< uc
)
48 first_index
= mid_index
+ 1;
49 else if (uc
< blocks
[mid_index
].start
)
50 last_index
= mid_index
;
52 return &blocks
[mid_index
];
58 uc_all_blocks (const uc_block_t
**blocksp
, size_t *countp
)
61 *countp
= sizeof (blocks
) / sizeof (blocks
[0]);