blob: 3b34c6ddc429d7d1f10a5e06d07e63e9c96546a2 [file] [log] [blame]
/*
**********************************************************************
* Copyright (C) 2001, International Business Machines
* Corporation and others. All Rights Reserved.
**********************************************************************
* Date Name Description
* 06/06/01 aliu Creation.
**********************************************************************
*/
#ifndef UNI2NAME_H
#define UNI2NAME_H
#include "unicode/translit.h"
U_NAMESPACE_BEGIN
/**
* A transliterator that performs character to name mapping.
* @author Alan Liu
*/
class U_I18N_API UnicodeNameTransliterator : public Transliterator {
UChar32 openDelimiter;
UChar32 closeDelimiter;
public:
/**
* Constructs a transliterator.
* @param openDelimiter the open delimiter character.
* @param closeDelimiter the close delimiter character.
* @param adoptedFilter the filter to be adopted.
*/
UnicodeNameTransliterator(UChar32 openDelimiter, UChar32 closeDelimiter,
UnicodeFilter* adoptedFilter = 0);
/**
* Constructs a transliterator with the default delimiters '{' and
* '}'.
* @param adoptedFilter the filter to be adopted.
*/
UnicodeNameTransliterator(UnicodeFilter* adoptedFilter = 0);
/**
* Destructor.
*/
virtual ~UnicodeNameTransliterator();
/**
* Copy constructor.
*/
UnicodeNameTransliterator(const UnicodeNameTransliterator&);
/**
* Assignment operator.
*/
UnicodeNameTransliterator& operator=(const UnicodeNameTransliterator&);
/**
* Transliterator API.
*/
Transliterator* clone(void) const;
/**
* ICU "poor man's RTTI", returns a UClassID for the actual class.
*
* @draft ICU 2.2
*/
virtual inline UClassID getDynamicClassID() const { return getStaticClassID(); }
/**
* ICU "poor man's RTTI", returns a UClassID for this class.
*
* @draft ICU 2.2
*/
static inline UClassID getStaticClassID() { return (UClassID)&fgClassID; }
protected:
/**
* Implements {@link Transliterator#handleTransliterate}.
* @param text the buffer holding transliterated and
* untransliterated text
* @param offset the start and limit of the text, the position
* of the cursor, and the start and limit of transliteration.
* @param incremental if true, assume more text may be coming after
* pos.contextLimit. Otherwise, assume the text is complete.
*/
virtual void handleTransliterate(Replaceable& text, UTransPosition& offset,
UBool isIncremental) const;
private:
static const char _ID[];
/**
* The address of this static class variable serves as this class's ID
* for ICU "poor man's RTTI".
*/
static const char fgClassID;
};
U_NAMESPACE_END
#endif