1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
4 **********************************************************************
5 * Copyright (C) 2001-2007, International Business Machines
6 * Corporation and others. All Rights Reserved.
7 **********************************************************************
8 * Date Name Description
9 * 06/06/01 aliu Creation.
10 **********************************************************************
15 #include "unicode/utypes.h"
17 #if !UCONFIG_NO_TRANSLITERATION
19 #include "unicode/translit.h"
24 * A transliterator that performs character to name mapping.
25 * It generates the Perl syntax \N{name}.
28 class UnicodeNameTransliterator
: public Transliterator
{
33 * Constructs a transliterator.
34 * @param adoptedFilter the filter to be adopted.
36 UnicodeNameTransliterator(UnicodeFilter
* adoptedFilter
= 0);
41 virtual ~UnicodeNameTransliterator();
46 UnicodeNameTransliterator(const UnicodeNameTransliterator
&);
51 virtual Transliterator
* clone(void) const;
54 * ICU "poor man's RTTI", returns a UClassID for the actual class.
56 virtual UClassID
getDynamicClassID() const;
59 * ICU "poor man's RTTI", returns a UClassID for this class.
61 U_I18N_API
static UClassID U_EXPORT2
getStaticClassID();
66 * Implements {@link Transliterator#handleTransliterate}.
67 * @param text the buffer holding transliterated and
68 * untransliterated text
69 * @param offset the start and limit of the text, the position
70 * of the cursor, and the start and limit of transliteration.
71 * @param incremental if true, assume more text may be coming after
72 * pos.contextLimit. Otherwise, assume the text is complete.
74 virtual void handleTransliterate(Replaceable
& text
, UTransPosition
& offset
,
75 UBool isIncremental
) const;
79 * Assignment operator.
81 UnicodeNameTransliterator
& operator=(const UnicodeNameTransliterator
&);
87 #endif /* #if !UCONFIG_NO_TRANSLITERATION */