public class KeywordMap
extends java.lang.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(java.lang.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(javax.swing.text.Segment s,
int off,
int len) |
protected int |
getStringMapKey(java.lang.String s) |
byte |
lookup(javax.swing.text.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(javax.swing.text.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(java.lang.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(java.lang.String s)
protected int getSegmentMapKey(javax.swing.text.Segment s,
int off,
int len)