Coverage Report

Created: 2025-10-26 06:49

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libunistring/lib/uninorm/decomposition-table.h
Line
Count
Source
1
/* Decomposition of Unicode characters.
2
   Copyright (C) 2001-2003, 2009-2025 Free Software Foundation, Inc.
3
   Written by Bruno Haible <bruno@clisp.org>, 2009.
4
5
   This file is free software: you can redistribute it and/or modify
6
   it under the terms of the GNU Lesser General Public License as
7
   published by the Free Software Foundation; either version 2.1 of the
8
   License, or (at your option) any later version.
9
10
   This file 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
13
   GNU Lesser General Public License for more details.
14
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/>.  */
17
18
19
#include "unitypes.h"
20
21
/* The decomposition table is made of two parts:
22
     - A table containing the actual arrays of decomposed equivalents.
23
       (This table is separate because the maximum length of a decomposition
24
       is 18, much larger than the average length 1.497 of a decomposition).
25
     - A 3-level table of indices into this array.  */
26
27
#include "decomposition-table1.h"
28
29
static inline unsigned short
30
decomp_index (ucs4_t uc)
31
34.1M
{
32
34.1M
  unsigned int index1 = uc >> decomp_header_0;
33
34.1M
  if (index1 < decomp_header_1)
34
34.1M
    {
35
34.1M
      int lookup1 = gl_uninorm_decomp_index_table.level1[index1];
36
34.1M
      if (lookup1 >= 0)
37
34.0M
        {
38
34.0M
          unsigned int index2 = (uc >> decomp_header_2) & decomp_header_3;
39
34.0M
          int lookup2 = gl_uninorm_decomp_index_table.level2[lookup1 + index2];
40
34.0M
          if (lookup2 >= 0)
41
11.3M
            {
42
11.3M
              unsigned int index3 = uc & decomp_header_4;
43
11.3M
              return gl_uninorm_decomp_index_table.level3[lookup2 + index3];
44
11.3M
            }
45
34.0M
        }
46
34.1M
    }
47
22.7M
  return (unsigned short)(-1);
48
34.1M
}
decomposition.c:decomp_index
Line
Count
Source
31
22.3M
{
32
22.3M
  unsigned int index1 = uc >> decomp_header_0;
33
22.3M
  if (index1 < decomp_header_1)
34
22.3M
    {
35
22.3M
      int lookup1 = gl_uninorm_decomp_index_table.level1[index1];
36
22.3M
      if (lookup1 >= 0)
37
22.3M
        {
38
22.3M
          unsigned int index2 = (uc >> decomp_header_2) & decomp_header_3;
39
22.3M
          int lookup2 = gl_uninorm_decomp_index_table.level2[lookup1 + index2];
40
22.3M
          if (lookup2 >= 0)
41
7.73M
            {
42
7.73M
              unsigned int index3 = uc & decomp_header_4;
43
7.73M
              return gl_uninorm_decomp_index_table.level3[lookup2 + index3];
44
7.73M
            }
45
22.3M
        }
46
22.3M
    }
47
14.6M
  return (unsigned short)(-1);
48
22.3M
}
Unexecuted instantiation: decomposition-table.c:decomp_index
canonical-decomposition.c:decomp_index
Line
Count
Source
31
11.8M
{
32
11.8M
  unsigned int index1 = uc >> decomp_header_0;
33
11.8M
  if (index1 < decomp_header_1)
34
11.8M
    {
35
11.8M
      int lookup1 = gl_uninorm_decomp_index_table.level1[index1];
36
11.8M
      if (lookup1 >= 0)
37
11.7M
        {
38
11.7M
          unsigned int index2 = (uc >> decomp_header_2) & decomp_header_3;
39
11.7M
          int lookup2 = gl_uninorm_decomp_index_table.level2[lookup1 + index2];
40
11.7M
          if (lookup2 >= 0)
41
3.62M
            {
42
3.62M
              unsigned int index3 = uc & decomp_header_4;
43
3.62M
              return gl_uninorm_decomp_index_table.level3[lookup2 + index3];
44
3.62M
            }
45
11.7M
        }
46
11.8M
    }
47
8.17M
  return (unsigned short)(-1);
48
11.8M
}