public class Cursor extends java.text.ParsePosition implements Reusable
This class represents a parsing cursor over characters. Cursor
allows for token iterations over any CharSequence
.
Prints the following output:
CharSequence csq = "this is a test";
Cursor cursor = Cursor.newInstance();
try {
for (CharSequence token; (token=cursor.nextToken(csq, ' '))!= null;)
System.out.println(token);
} finally {
Cursor.recycle(cursor);
}
this is a testCursors are typically used with
TextFormat
instances.
// Parses decimal number (e.g. "xxx.xxxxxExx" or "NaN")
public Decimal parse(CharSequence csq, Cursor cursor) {
if (cursor.skip("NaN", csq))
return Decimal.NaN;
LargeInteger significand = LargeInteger.TEXT_FORMAT.parse(csq, cursor);
LargeInteger fraction = cursor.skip('.', csq) ? LargeInteger.TEXT_FORMAT.parse(csq, cursor) : LargeInteger.ZERO;
int exponent = cursor.skip(CharSet.valueOf('E', 'e'), csq) ? TypeFormat.parseInt(csq, 10, cursor) : 0;
int fractionDigits = fraction.digitLength();
return Decimal.valueOf(significand.E(fractionDigits).plus(fraction), exponent - fractionDigits);
}
Constructor and Description |
---|
Cursor()
Default constructor.
|
Modifier and Type | Method and Description |
---|---|
boolean |
at(char c,
java.lang.CharSequence csq)
Indicates if this cursor points to the specified character in the
specified character sequence.
|
boolean |
at(CharSet charSet,
java.lang.CharSequence csq)
Indicates if this cursor points to any of the specified character in the
specified character sequence.
|
boolean |
at(java.lang.String str,
java.lang.CharSequence csq)
Indicates if this cursor points to the specified characters in the
specified sequence.
|
boolean |
atEnd(java.lang.CharSequence csq)
Indicates if this cursor points to the end of the specified
character sequence.
|
boolean |
equals(java.lang.Object obj)
Indicates if this cursor is equals to the specified object.
|
int |
getIndex()
Returns this cursor index.
|
int |
hashCode()
Returns the hash code for this cursor.
|
Cursor |
increment()
Increments the cursor index by one.
|
Cursor |
increment(int i)
Increments the cursor index by the specified value.
|
static Cursor |
newInstance()
Returns a factory produced instance which can be
recycled
after usage. |
char |
nextChar(java.lang.CharSequence csq)
Returns the next character at this cursor position.The cursor
position is incremented by one.
|
java.lang.CharSequence |
nextToken(java.lang.CharSequence csq,
char c)
Returns the subsequence from the specified cursor position not holding
the specified character.
|
java.lang.CharSequence |
nextToken(java.lang.CharSequence csq,
CharSet charSet)
Returns the subsequence from the specified cursor position not holding
any of the characters specified.
|
static void |
recycle(Cursor cursor)
Recycles the specified factory
produced cursor. |
void |
reset()
Resets this cursor instance.
|
void |
setIndex(int i)
Sets the cursor current index.
|
boolean |
skip(char c,
java.lang.CharSequence csq)
Moves this cursor forward only if at the specified character.
|
boolean |
skip(CharSet charSet,
java.lang.CharSequence csq)
Moves this cursor forward only if at any of the specified character.
|
boolean |
skip(java.lang.String str,
java.lang.CharSequence csq)
Moves this cursor forward only if at the specified string.
|
boolean |
skipAny(char c,
java.lang.CharSequence csq)
Moves this cursor forward until it points to a character
different from the specified character.
|
boolean |
skipAny(CharSet charSet,
java.lang.CharSequence csq)
Moves this cursor forward until it points to a character
different from any of the character in the specified set.
|
java.lang.String |
toString()
Returns the string representation of this cursor.
|
public static Cursor newInstance()
recycled
after usage.public static void recycle(Cursor cursor)
produced
cursor.cursor
- the cursor to recycle.public final int getIndex()
getIndex
in class java.text.ParsePosition
public void setIndex(int i)
setIndex
in class java.text.ParsePosition
i
- the index of the next character to parse.public final boolean atEnd(java.lang.CharSequence csq)
csq
- the character sequence iterated by this cursor.getIndex() >= csq.length()
public final boolean at(char c, java.lang.CharSequence csq)
c
- the character to test.csq
- the character sequence iterated by this cursor.csq.charAt(this.getIndex()) == c
public final boolean at(CharSet charSet, java.lang.CharSequence csq)
charSet
- any of the character to test.csq
- the character sequence iterated by this cursor.csq.charAt(this.getIndex()) == c
public final boolean at(java.lang.String str, java.lang.CharSequence csq)
str
- the characters to test.csq
- the character sequence iterated by this cursor.true
if this cursor points to the specified
characters; false
otherwise.public final char nextChar(java.lang.CharSequence csq)
csq
- the character sequence iterated by this cursor.java.lang.IndexOutOfBoundsException
- if this.atEnd(csq)
public final boolean skipAny(char c, java.lang.CharSequence csq)
c
- the character to skip.csq
- the character sequence iterated by this cursor.true
if this cursor has skipped at least one
character;false
otherwise (e.g. end of sequence
reached).public final boolean skipAny(CharSet charSet, java.lang.CharSequence csq)
// Reads numbers separated by tabulations or spaces.
FastTable<Integer> numbers = new FastTable<Integer>();
while (cursor.skipAny(CharSet.SPACE_OR_TAB, csq)) {
numbers.add(TypeFormat.parseInt(csq, cursor));
}
charSet
- the character to skip.csq
- the character sequence iterated by this cursor.true
if this cursor has skipped at least one
character;false
otherwise (e.g. end of sequence
reached).public final boolean skip(char c, java.lang.CharSequence csq)
if (at(c, csq))
increment();
c
- the character to skip.csq
- the character sequence iterated by this cursor.true
if this cursor has skipped the specified
character;false
otherwise.public final boolean skip(CharSet charSet, java.lang.CharSequence csq)
if (at(charSet, csq))
increment();
charSet
- holding the characters to skip.csq
- the character sequence iterated by this cursor.true
if this cursor has skipped any the specified
character;false
otherwise.public final boolean skip(java.lang.String str, java.lang.CharSequence csq)
if (at(str, csq))
increment(str.length());
str
- the string to skip.csq
- the character sequence iterated by this cursor.true
if this cursor has skipped the specified
string;false
otherwise (e.g. end of sequence
reached).public final java.lang.CharSequence nextToken(java.lang.CharSequence csq, char c)
CharSequence csq = "This is a test";
for (CharSequence token; (token=cursor.nextToken(csq, ' '))!= null;) {
System.out.println(token); // Prints one word at a time.
}
csq
- the character sequence iterated by this cursor.c
- the character being skipped.null
if none.public final java.lang.CharSequence nextToken(java.lang.CharSequence csq, CharSet charSet)
CharSequence csq = "This is a test";
for (CharSequence token; (token=cursor.nextToken(csq, CharSet.WHITESPACE))!= null;) {
System.out.println(token); // Prints one word at a time.
}
csq
- the character sequence iterated by this cursor.charSet
- the characters being skipped.null
if none.public final Cursor increment()
this
public final Cursor increment(int i)
i
- the increment value.this
public java.lang.String toString()
toString
in class java.text.ParsePosition
public boolean equals(java.lang.Object obj)
equals
in class java.text.ParsePosition
true
if the specified object is a cursor
at the same index; false
otherwise.public int hashCode()
hashCode
in class java.text.ParsePosition
Copyright © 2005 - 2007 Javolution.