]> git.saurik.com Git - apple/icu.git/blame - icuSources/common/dictbe.h
ICU-64232.0.1.tar.gz
[apple/icu.git] / icuSources / common / dictbe.h
CommitLineData
f3c0d7a5
A
1// © 2016 and later: Unicode, Inc. and others.
2// License & terms of use: http://www.unicode.org/copyright.html
73c04bcf
A
3/**
4 *******************************************************************************
b331163b 5 * Copyright (C) 2006-2014, International Business Machines Corporation *
4388f060 6 * and others. All Rights Reserved. *
73c04bcf
A
7 *******************************************************************************
8 */
9
10#ifndef DICTBE_H
11#define DICTBE_H
12
13#include "unicode/utypes.h"
14#include "unicode/uniset.h"
15#include "unicode/utext.h"
16
17#include "brkeng.h"
0f5d89e8 18#include "uvectr32.h"
73c04bcf
A
19
20U_NAMESPACE_BEGIN
21
51004dcb 22class DictionaryMatcher;
b331163b 23class Normalizer2;
73c04bcf
A
24
25/*******************************************************************
26 * DictionaryBreakEngine
27 */
28
29/**
30 * <p>DictionaryBreakEngine is a kind of LanguageBreakEngine that uses a
31 * dictionary to determine language-specific breaks.</p>
32 *
33 * <p>After it is constructed a DictionaryBreakEngine may be shared between
34 * threads without synchronization.</p>
35 */
36class DictionaryBreakEngine : public LanguageBreakEngine {
37 private:
38 /**
39 * The set of characters handled by this engine
40 * @internal
41 */
42
43 UnicodeSet fSet;
44
73c04bcf
A
45 public:
46
47 /**
0f5d89e8 48 * <p>Constructor </p>
73c04bcf 49 */
0f5d89e8 50 DictionaryBreakEngine();
73c04bcf
A
51
52 /**
53 * <p>Virtual destructor.</p>
54 */
55 virtual ~DictionaryBreakEngine();
56
51004dcb
A
57 /**
58 * <p>Indicate whether this engine handles a particular character for
59 * a particular kind of break.</p>
60 *
61 * @param c A character which begins a run that the engine might handle
51004dcb
A
62 * @return TRUE if this engine handles the particular character and break
63 * type.
64 */
0f5d89e8 65 virtual UBool handles(UChar32 c) const;
73c04bcf 66
51004dcb
A
67 /**
68 * <p>Find any breaks within a run in the supplied text.</p>
69 *
70 * @param text A UText representing the text. The iterator is left at
71 * the end of the run of characters which the engine is capable of handling
0f5d89e8 72 * that starts from the first character in the range.
51004dcb
A
73 * @param startPos The start of the run within the supplied text.
74 * @param endPos The end of the run within the supplied text.
0f5d89e8 75 * @param foundBreaks vector of int32_t to receive the break positions
51004dcb
A
76 * @return The number of breaks found.
77 */
73c04bcf
A
78 virtual int32_t findBreaks( UText *text,
79 int32_t startPos,
80 int32_t endPos,
0f5d89e8 81 UVector32 &foundBreaks ) const;
73c04bcf
A
82
83 protected:
84
85 /**
86 * <p>Set the character set handled by this engine.</p>
87 *
88 * @param set A UnicodeSet of the set of characters handled by the engine
89 */
46f4442e 90 virtual void setCharacters( const UnicodeSet &set );
73c04bcf 91
73c04bcf 92 /**
51004dcb 93 * <p>Divide up a range of known dictionary characters handled by this break engine.</p>
73c04bcf
A
94 *
95 * @param text A UText representing the text
96 * @param rangeStart The start of the range of dictionary characters
97 * @param rangeEnd The end of the range of dictionary characters
98 * @param foundBreaks Output of C array of int32_t break positions, or 0
99 * @return The number of breaks found
100 */
101 virtual int32_t divideUpDictionaryRange( UText *text,
102 int32_t rangeStart,
103 int32_t rangeEnd,
0f5d89e8 104 UVector32 &foundBreaks ) const = 0;
73c04bcf
A
105
106};
107
108/*******************************************************************
109 * ThaiBreakEngine
110 */
111
112/**
113 * <p>ThaiBreakEngine is a kind of DictionaryBreakEngine that uses a
51004dcb 114 * dictionary and heuristics to determine Thai-specific breaks.</p>
73c04bcf
A
115 *
116 * <p>After it is constructed a ThaiBreakEngine may be shared between
117 * threads without synchronization.</p>
118 */
119class ThaiBreakEngine : public DictionaryBreakEngine {
120 private:
121 /**
122 * The set of characters handled by this engine
123 * @internal
124 */
125
126 UnicodeSet fThaiWordSet;
127 UnicodeSet fEndWordSet;
128 UnicodeSet fBeginWordSet;
129 UnicodeSet fSuffixSet;
130 UnicodeSet fMarkSet;
51004dcb 131 DictionaryMatcher *fDictionary;
73c04bcf
A
132
133 public:
134
135 /**
136 * <p>Default constructor.</p>
137 *
51004dcb 138 * @param adoptDictionary A DictionaryMatcher to adopt. Deleted when the
73c04bcf
A
139 * engine is deleted.
140 */
51004dcb 141 ThaiBreakEngine(DictionaryMatcher *adoptDictionary, UErrorCode &status);
73c04bcf
A
142
143 /**
144 * <p>Virtual destructor.</p>
145 */
146 virtual ~ThaiBreakEngine();
147
148 protected:
149 /**
51004dcb 150 * <p>Divide up a range of known dictionary characters handled by this break engine.</p>
73c04bcf
A
151 *
152 * @param text A UText representing the text
153 * @param rangeStart The start of the range of dictionary characters
154 * @param rangeEnd The end of the range of dictionary characters
155 * @param foundBreaks Output of C array of int32_t break positions, or 0
156 * @return The number of breaks found
157 */
158 virtual int32_t divideUpDictionaryRange( UText *text,
159 int32_t rangeStart,
160 int32_t rangeEnd,
0f5d89e8 161 UVector32 &foundBreaks ) const;
73c04bcf
A
162
163};
164
51004dcb 165/*******************************************************************
57a6839d 166 * LaoBreakEngine
51004dcb
A
167 */
168
51004dcb 169/**
57a6839d
A
170 * <p>LaoBreakEngine is a kind of DictionaryBreakEngine that uses a
171 * dictionary and heuristics to determine Lao-specific breaks.</p>
172 *
173 * <p>After it is constructed a LaoBreakEngine may be shared between
174 * threads without synchronization.</p>
51004dcb 175 */
57a6839d
A
176class LaoBreakEngine : public DictionaryBreakEngine {
177 private:
51004dcb
A
178 /**
179 * The set of characters handled by this engine
180 * @internal
181 */
51004dcb 182
57a6839d
A
183 UnicodeSet fLaoWordSet;
184 UnicodeSet fEndWordSet;
185 UnicodeSet fBeginWordSet;
186 UnicodeSet fMarkSet;
51004dcb
A
187 DictionaryMatcher *fDictionary;
188
189 public:
190
57a6839d
A
191 /**
192 * <p>Default constructor.</p>
193 *
194 * @param adoptDictionary A DictionaryMatcher to adopt. Deleted when the
195 * engine is deleted.
196 */
197 LaoBreakEngine(DictionaryMatcher *adoptDictionary, UErrorCode &status);
51004dcb 198
57a6839d
A
199 /**
200 * <p>Virtual destructor.</p>
201 */
202 virtual ~LaoBreakEngine();
51004dcb
A
203
204 protected:
57a6839d
A
205 /**
206 * <p>Divide up a range of known dictionary characters handled by this break engine.</p>
207 *
208 * @param text A UText representing the text
209 * @param rangeStart The start of the range of dictionary characters
210 * @param rangeEnd The end of the range of dictionary characters
211 * @param foundBreaks Output of C array of int32_t break positions, or 0
212 * @return The number of breaks found
213 */
51004dcb 214 virtual int32_t divideUpDictionaryRange( UText *text,
57a6839d
A
215 int32_t rangeStart,
216 int32_t rangeEnd,
0f5d89e8 217 UVector32 &foundBreaks ) const;
51004dcb
A
218
219};
220
b331163b
A
221/*******************************************************************
222 * BurmeseBreakEngine
223 */
224
225/**
226 * <p>BurmeseBreakEngine is a kind of DictionaryBreakEngine that uses a
227 * DictionaryMatcher and heuristics to determine Burmese-specific breaks.</p>
228 *
229 * <p>After it is constructed a BurmeseBreakEngine may be shared between
230 * threads without synchronization.</p>
231 */
232class BurmeseBreakEngine : public DictionaryBreakEngine {
233 private:
234 /**
235 * The set of characters handled by this engine
236 * @internal
237 */
238
239 UnicodeSet fBurmeseWordSet;
240 UnicodeSet fEndWordSet;
241 UnicodeSet fBeginWordSet;
242 UnicodeSet fMarkSet;
243 DictionaryMatcher *fDictionary;
244
245 public:
246
247 /**
248 * <p>Default constructor.</p>
249 *
250 * @param adoptDictionary A DictionaryMatcher to adopt. Deleted when the
251 * engine is deleted.
252 */
253 BurmeseBreakEngine(DictionaryMatcher *adoptDictionary, UErrorCode &status);
254
255 /**
256 * <p>Virtual destructor.</p>
257 */
258 virtual ~BurmeseBreakEngine();
259
260 protected:
261 /**
262 * <p>Divide up a range of known dictionary characters.</p>
263 *
264 * @param text A UText representing the text
265 * @param rangeStart The start of the range of dictionary characters
266 * @param rangeEnd The end of the range of dictionary characters
267 * @param foundBreaks Output of C array of int32_t break positions, or 0
268 * @return The number of breaks found
269 */
270 virtual int32_t divideUpDictionaryRange( UText *text,
271 int32_t rangeStart,
272 int32_t rangeEnd,
0f5d89e8 273 UVector32 &foundBreaks ) const;
b331163b
A
274
275};
276
4388f060
A
277/*******************************************************************
278 * KhmerBreakEngine
279 */
280
281/**
282 * <p>KhmerBreakEngine is a kind of DictionaryBreakEngine that uses a
51004dcb 283 * DictionaryMatcher and heuristics to determine Khmer-specific breaks.</p>
4388f060
A
284 *
285 * <p>After it is constructed a KhmerBreakEngine may be shared between
286 * threads without synchronization.</p>
287 */
288class KhmerBreakEngine : public DictionaryBreakEngine {
289 private:
290 /**
291 * The set of characters handled by this engine
292 * @internal
293 */
294
295 UnicodeSet fKhmerWordSet;
296 UnicodeSet fEndWordSet;
297 UnicodeSet fBeginWordSet;
298 UnicodeSet fMarkSet;
51004dcb 299 DictionaryMatcher *fDictionary;
4388f060
A
300
301 public:
302
303 /**
304 * <p>Default constructor.</p>
305 *
51004dcb 306 * @param adoptDictionary A DictionaryMatcher to adopt. Deleted when the
4388f060
A
307 * engine is deleted.
308 */
51004dcb 309 KhmerBreakEngine(DictionaryMatcher *adoptDictionary, UErrorCode &status);
4388f060
A
310
311 /**
312 * <p>Virtual destructor.</p>
313 */
314 virtual ~KhmerBreakEngine();
315
316 protected:
317 /**
318 * <p>Divide up a range of known dictionary characters.</p>
319 *
320 * @param text A UText representing the text
321 * @param rangeStart The start of the range of dictionary characters
322 * @param rangeEnd The end of the range of dictionary characters
323 * @param foundBreaks Output of C array of int32_t break positions, or 0
324 * @return The number of breaks found
325 */
326 virtual int32_t divideUpDictionaryRange( UText *text,
327 int32_t rangeStart,
328 int32_t rangeEnd,
0f5d89e8 329 UVector32 &foundBreaks ) const;
4388f060
A
330
331};
332
57a6839d
A
333#if !UCONFIG_NO_NORMALIZATION
334
335/*******************************************************************
336 * CjkBreakEngine
337 */
338
339//indicates language/script that the CjkBreakEngine will handle
340enum LanguageType {
341 kKorean,
342 kChineseJapanese
343};
344
345/**
346 * <p>CjkBreakEngine is a kind of DictionaryBreakEngine that uses a
347 * dictionary with costs associated with each word and
348 * Viterbi decoding to determine CJK-specific breaks.</p>
349 */
350class CjkBreakEngine : public DictionaryBreakEngine {
351 protected:
352 /**
353 * The set of characters handled by this engine
354 * @internal
355 */
356 UnicodeSet fHangulWordSet;
357 UnicodeSet fHanWordSet;
358 UnicodeSet fKatakanaWordSet;
359 UnicodeSet fHiraganaWordSet;
360
b331163b
A
361 DictionaryMatcher *fDictionary;
362 const Normalizer2 *nfkcNorm2;
57a6839d
A
363
364 public:
365
366 /**
367 * <p>Default constructor.</p>
368 *
369 * @param adoptDictionary A DictionaryMatcher to adopt. Deleted when the
370 * engine is deleted. The DictionaryMatcher must contain costs for each word
371 * in order for the dictionary to work properly.
372 */
373 CjkBreakEngine(DictionaryMatcher *adoptDictionary, LanguageType type, UErrorCode &status);
374
375 /**
376 * <p>Virtual destructor.</p>
377 */
378 virtual ~CjkBreakEngine();
379
380 protected:
381 /**
382 * <p>Divide up a range of known dictionary characters handled by this break engine.</p>
383 *
384 * @param text A UText representing the text
385 * @param rangeStart The start of the range of dictionary characters
386 * @param rangeEnd The end of the range of dictionary characters
387 * @param foundBreaks Output of C array of int32_t break positions, or 0
388 * @return The number of breaks found
389 */
390 virtual int32_t divideUpDictionaryRange( UText *text,
391 int32_t rangeStart,
392 int32_t rangeEnd,
0f5d89e8 393 UVector32 &foundBreaks ) const;
57a6839d
A
394
395};
396
397#endif
398
73c04bcf
A
399U_NAMESPACE_END
400
401 /* DICTBE_H */
402#endif