summaryrefslogtreecommitdiff
path: root/lib/unilbrk/lbrktables.h
blob: 60121ea81f48ba0cf335c6c4db1a746b25d9f1ec (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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/* Line breaking auxiliary tables.
   Copyright (C) 2001-2003, 2006-2022 Free Software Foundation, Inc.
   Written by Bruno Haible <bruno@clisp.org>, 2001.

   This file is free software.
   It is dual-licensed under "the GNU LGPLv3+ or the GNU GPLv2+".
   You can redistribute it and/or modify it under either
     - the terms of the GNU Lesser General Public License as published
       by the Free Software Foundation; either version 3, or (at your
       option) any later version, or
     - the terms of the GNU General Public License as published by the
       Free Software Foundation; either version 2, or (at your option)
       any later version, or
     - the same dual license "the GNU LGPLv3+ or the GNU GPLv2+".

   This file is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License and the GNU General Public License
   for more details.

   You should have received a copy of the GNU Lesser General Public
   License and of the GNU General Public License along with this
   program.  If not, see <https://www.gnu.org/licenses/>.  */

#include "unitypes.h"

/* Line breaking classification.  */

enum
{
  /* Values >= 33 are resolved at run time. */
  LBP_BK  = 33, /* mandatory break */
  LBP_CR  = 34, /* carriage return */
  LBP_LF  = 35, /* line feed */
  LBP_CM  = 36, /* attached characters and combining marks */
/*LBP_NL,          next line - not used here because it's equivalent to LBP_BK */
/*LBP_SG,          surrogates - not used here because they are not characters */
  LBP_WJ  =  0, /* word joiner */
  LBP_ZW  = 37, /* zero width space */
  LBP_GL  =  1, /* non-breaking (glue) */
  LBP_SP  = 38, /* space */
  LBP_B2  =  2, /* break opportunity before and after */
  LBP_BA  =  3, /* break opportunity after */
  LBP_BB  =  4, /* break opportunity before */
  LBP_HY  =  5, /* hyphen */
  LBP_CB  = 39, /* contingent break opportunity */
  LBP_CL  =  6, /* closing punctuation */
  LBP_CP1 =  7, /* closing parenthesis, non-EastAsian character */
  LBP_CP2 =  8, /* closing parenthesis, EastAsian character */
  LBP_EX  =  9, /* exclamation/interrogation */
  LBP_IN  = 10, /* inseparable */
  LBP_NS  = 11, /* non starter */
  LBP_OP1 = 12, /* opening punctuation, non-EastAsian character */
  LBP_OP2 = 13, /* opening punctuation, EastAsian character */
  LBP_QU  = 14, /* ambiguous quotation */
  LBP_IS  = 15, /* infix separator (numeric) */
  LBP_NU  = 16, /* numeric */
  LBP_PO  = 17, /* postfix (numeric) */
  LBP_PR  = 18, /* prefix (numeric) */
  LBP_SY  = 19, /* symbols allowing breaks */
  LBP_AI  = 40, /* ambiguous (alphabetic or ideograph) */
  LBP_AL  = 20, /* ordinary alphabetic and symbol characters */
/*LBP_CJ,          conditional Japanese starter, resolved to NS */
  LBP_H2  = 21, /* Hangul LV syllable */
  LBP_H3  = 22, /* Hangul LVT syllable */
  LBP_HL  = 28, /* Hebrew letter */
  LBP_ID1 = 23, /* ideographic */
  LBP_ID2 = 24, /* ideographic and potential future emoji */
  LBP_JL  = 25, /* Hangul L Jamo */
  LBP_JV  = 26, /* Hangul V Jamo */
  LBP_JT  = 27, /* Hangul T Jamo */
  LBP_RI  = 29, /* regional indicator */
  LBP_SA  = 41, /* complex context (South East Asian) */
  LBP_ZWJ = 30, /* zero width joiner */
  LBP_EB  = 31, /* emoji base */
  LBP_EM  = 32, /* emoji modifier */
  LBP_XX  = 42, /* unknown */
  /* Artificial values that exist only at runtime, not in the tables. */
  LBP_HL_BA = 100
};

#include "lbrkprop1.h"

static inline unsigned char
unilbrkprop_lookup (ucs4_t uc)
{
  unsigned int index1 = uc >> lbrkprop_header_0;
  if (index1 < lbrkprop_header_1)
    {
      int lookup1 = unilbrkprop.level1[index1];
      if (lookup1 >= 0)
        {
          unsigned int index2 = (uc >> lbrkprop_header_2) & lbrkprop_header_3;
          int lookup2 = unilbrkprop.level2[lookup1 + index2];
          if (lookup2 >= 0)
            {
              unsigned int index3 = uc & lbrkprop_header_4;
              return unilbrkprop.level3[lookup2 + index3];
            }
        }
    }
  return LBP_XX;
}

/* Table indexed by two line breaking classifications.  */
#define D 1  /* direct break opportunity, empty in table 7.3 of UTR #14 */
#define I 2  /* indirect break opportunity, '%' in table 7.3 of UTR #14 */
#define P 3  /* prohibited break,           '^' in table 7.3 of UTR #14 */

extern const unsigned char unilbrk_table[33][33];

/* We don't support line breaking of complex-context dependent characters
   (Thai, Lao, Myanmar, Khmer) yet, because it requires dictionary lookup. */