public class KeywordMap extends Object
KeywordMap
is similar to a hashtable in that it maps keys
to values. However, the `keys' are Swing segments. This allows lookups of
text substrings without the overhead of creating a new string object.
This class is used by CTokenMarker
to map keywords to ids.
Modifier and Type | Field and Description |
---|---|
protected int |
mapLength |
Constructor and Description |
---|
KeywordMap(boolean ignoreCase)
Creates a new
KeywordMap . |
KeywordMap(boolean ignoreCase,
int mapLength)
Creates a new
KeywordMap . |
Modifier and Type | Method and Description |
---|---|
void |
add(String keyword,
byte id)
Adds a key-value mapping.
|
boolean |
getIgnoreCase()
Returns true if the keyword map is set to be case insensitive,
false otherwise.
|
protected int |
getSegmentMapKey(Segment s,
int off,
int len) |
protected int |
getStringMapKey(String s) |
byte |
lookup(Segment text,
int offset,
int length)
Looks up a key.
|
void |
setIgnoreCase(boolean ignoreCase)
Sets if the keyword map should be case insensitive.
|
public KeywordMap(boolean ignoreCase)
KeywordMap
.ignoreCase
- True if keys are case insensitivepublic KeywordMap(boolean ignoreCase, int mapLength)
KeywordMap
.ignoreCase
- True if the keys are case insensitivemapLength
- The number of `buckets' to create.
A value of 52 will give good performance for most maps.public byte lookup(Segment text, int offset, int length)
text
- The text segmentoffset
- The offset of the substring within the text segmentlength
- The length of the substringpublic void add(String keyword, byte id)
keyword
- The keypublic boolean getIgnoreCase()
public void setIgnoreCase(boolean ignoreCase)
ignoreCase
- True if the keyword map should be case
insensitive, false otherwiseprotected int getStringMapKey(String s)
protected int getSegmentMapKey(Segment s, int off, int len)