blob: d232c76f2ce9a43aa0c79b01fef7211e70913a90 [file] [log] [blame]
/*
* Copyright (C) 1996-2001, International Business Machines Corporation and
* others. All Rights Reserved.
*
* $Source: /xsrl/Nsvn/icu/icu4j/src/com/ibm/icu/text/UnicodeNameTransliterator.java,v $
* $Date: 2002/03/27 19:11:37 $
* $Revision: 1.8 $
*/
package com.ibm.icu.text;
import java.util.*;
import com.ibm.icu.lang.*;
/**
* A transliterator that performs character to name mapping.
* @author Alan Liu
*/
class UnicodeNameTransliterator extends Transliterator {
char openDelimiter;
char closeDelimiter;
static final String _ID = "Any-Name";
/**
* System registration hook.
*/
static void register() {
Transliterator.registerFactory(_ID, new Transliterator.Factory() {
public Transliterator getInstance(String ID) {
return new UnicodeNameTransliterator(null);
}
});
}
/**
* Constructs a transliterator.
*/
public UnicodeNameTransliterator(char openDelimiter, char closeDelimiter,
UnicodeFilter filter) {
super(_ID, filter);
this.openDelimiter = openDelimiter;
this.closeDelimiter = closeDelimiter;
}
/**
* Constructs a transliterator with the default delimiters '{' and
* '}'.
*/
public UnicodeNameTransliterator(UnicodeFilter filter) {
this('{', '}', filter);
}
/**
* Implements {@link Transliterator#handleTransliterate}.
*/
protected void handleTransliterate(Replaceable text,
Position offsets, boolean isIncremental) {
int cursor = offsets.start;
int limit = offsets.limit;
StringBuffer str = new StringBuffer();
str.append(openDelimiter);
int len;
String name;
while (cursor < limit) {
int c = text.char32At(cursor);
if ((name=UCharacter.getExtendedName(c)) != null) {
str.setLength(1);
str.append(name).append(closeDelimiter);
int clen = UTF16.getCharCount(c);
text.replace(cursor, cursor+clen, str.toString());
len = str.length();
cursor += len; // advance cursor by 1 and adjust for new text
limit += len-clen; // change in length
} else {
++cursor;
}
}
offsets.contextLimit += limit - offsets.limit;
offsets.limit = limit;
offsets.start = cursor;
}
}