Package org.json
Class JSONTokener
- java.lang.Object
-
- org.json.JSONTokener
-
- Direct Known Subclasses:
HTTPTokener,XMLTokener
public class JSONTokener extends java.lang.ObjectA JSONTokener takes a source string and extracts characters and tokens from it. It is used by the JSONObject and JSONArray constructors to parse JSON source strings.- Version:
- 2014-05-03
-
-
Field Summary
Fields Modifier and Type Field Description private longcharactercurrent read character position on the current line.private longcharacterPreviousLinethe number of characters read in the previous line.private booleaneofflag to indicate if the end of the input has been found.private longindexcurrent read index of the input.private longlinecurrent line of the input.private charpreviousprevious character read from the input.private java.io.ReaderreaderReader for the input.private booleanusePreviousflag to indicate that a previous character was requested.
-
Constructor Summary
Constructors Constructor Description JSONTokener(java.io.InputStream inputStream)Construct a JSONTokener from an InputStream.JSONTokener(java.io.Reader reader)Construct a JSONTokener from a Reader.JSONTokener(java.lang.String s)Construct a JSONTokener from a string.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidback()Back up one character.voidclose()Closes the underlying reader, releasing any resources associated with it.private voiddecrementIndexes()Decrements the indexes for theback()method based on the previous character read.static intdehexchar(char c)Get the hex value of a character (base16).booleanend()Checks if the end of the input has been reached.protected chargetPrevious()Get the last character read from the input or '\0' if nothing has been read yet.private voidincrementIndexes(int c)Increments the internal indexes according to the previous character read and the character passed as the current character.booleanmore()Determine if the source string still contains characters that next() can consume.charnext()Get the next character in the source string.charnext(char c)Consume the next character, and check that it matches a specified character.java.lang.Stringnext(int n)Get the next n characters.charnextClean()Get the next char in the string, skipping whitespace.(package private) java.lang.ObjectnextSimpleValue(char c)java.lang.StringnextString(char quote)Return the characters up to the next close quote character.java.lang.StringnextTo(char delimiter)Get the text up but not including the specified character or the end of line, whichever comes first.java.lang.StringnextTo(java.lang.String delimiters)Get the text up but not including one of the specified delimiter characters or the end of line, whichever comes first.java.lang.ObjectnextValue()Get the next value.charskipTo(char to)Skip characters until the next character is the requested character.JSONExceptionsyntaxError(java.lang.String message)Make a JSONException to signal a syntax error.JSONExceptionsyntaxError(java.lang.String message, java.lang.Throwable causedBy)Make a JSONException to signal a syntax error.java.lang.StringtoString()Make a printable string of this JSONTokener.
-
-
-
Field Detail
-
character
private long character
current read character position on the current line.
-
eof
private boolean eof
flag to indicate if the end of the input has been found.
-
index
private long index
current read index of the input.
-
line
private long line
current line of the input.
-
previous
private char previous
previous character read from the input.
-
reader
private final java.io.Reader reader
Reader for the input.
-
usePrevious
private boolean usePrevious
flag to indicate that a previous character was requested.
-
characterPreviousLine
private long characterPreviousLine
the number of characters read in the previous line.
-
-
Constructor Detail
-
JSONTokener
public JSONTokener(java.io.Reader reader)
Construct a JSONTokener from a Reader. The caller must close the Reader.- Parameters:
reader- A reader.
-
JSONTokener
public JSONTokener(java.io.InputStream inputStream)
Construct a JSONTokener from an InputStream. The caller must close the input stream.- Parameters:
inputStream- The source.
-
JSONTokener
public JSONTokener(java.lang.String s)
Construct a JSONTokener from a string.- Parameters:
s- A source string.
-
-
Method Detail
-
back
public void back() throws JSONExceptionBack up one character. This provides a sort of lookahead capability, so that you can test for a digit or letter before attempting to parse the next number or identifier.- Throws:
JSONException- Thrown if trying to step back more than 1 step or if already at the start of the string
-
decrementIndexes
private void decrementIndexes()
Decrements the indexes for theback()method based on the previous character read.
-
dehexchar
public static int dehexchar(char c)
Get the hex value of a character (base16).- Parameters:
c- A character between '0' and '9' or between 'A' and 'F' or between 'a' and 'f'.- Returns:
- An int between 0 and 15, or -1 if c was not a hex digit.
-
end
public boolean end()
Checks if the end of the input has been reached.- Returns:
- true if at the end of the file and we didn't step back
-
more
public boolean more() throws JSONExceptionDetermine if the source string still contains characters that next() can consume.- Returns:
- true if not yet at the end of the source.
- Throws:
JSONException- thrown if there is an error stepping forward or backward while checking for more data.
-
next
public char next() throws JSONExceptionGet the next character in the source string.- Returns:
- The next character, or 0 if past the end of the source string.
- Throws:
JSONException- Thrown if there is an error reading the source string.
-
getPrevious
protected char getPrevious()
Get the last character read from the input or '\0' if nothing has been read yet.- Returns:
- the last character read from the input.
-
incrementIndexes
private void incrementIndexes(int c)
Increments the internal indexes according to the previous character read and the character passed as the current character.- Parameters:
c- the current character read.
-
next
public char next(char c) throws JSONExceptionConsume the next character, and check that it matches a specified character.- Parameters:
c- The character to match.- Returns:
- The character.
- Throws:
JSONException- if the character does not match.
-
next
public java.lang.String next(int n) throws JSONExceptionGet the next n characters.- Parameters:
n- The number of characters to take.- Returns:
- A string of n characters.
- Throws:
JSONException- Substring bounds error if there are not n characters remaining in the source string.
-
nextClean
public char nextClean() throws JSONExceptionGet the next char in the string, skipping whitespace.- Returns:
- A character, or 0 if there are no more characters.
- Throws:
JSONException- Thrown if there is an error reading the source string.
-
nextString
public java.lang.String nextString(char quote) throws JSONExceptionReturn the characters up to the next close quote character. Backslash processing is done. The formal JSON format does not allow strings in single quotes, but an implementation is allowed to accept them.- Parameters:
quote- The quoting character, either"(double quote) or'(single quote).- Returns:
- A String.
- Throws:
JSONException- Unterminated string.
-
nextTo
public java.lang.String nextTo(char delimiter) throws JSONExceptionGet the text up but not including the specified character or the end of line, whichever comes first.- Parameters:
delimiter- A delimiter character.- Returns:
- A string.
- Throws:
JSONException- Thrown if there is an error while searching for the delimiter
-
nextTo
public java.lang.String nextTo(java.lang.String delimiters) throws JSONExceptionGet the text up but not including one of the specified delimiter characters or the end of line, whichever comes first.- Parameters:
delimiters- A set of delimiter characters.- Returns:
- A string, trimmed.
- Throws:
JSONException- Thrown if there is an error while searching for the delimiter
-
nextValue
public java.lang.Object nextValue() throws JSONExceptionGet the next value. The value can be a Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONObject.NULL object.- Returns:
- An object.
- Throws:
JSONException- If syntax error.
-
nextSimpleValue
java.lang.Object nextSimpleValue(char c)
-
skipTo
public char skipTo(char to) throws JSONExceptionSkip characters until the next character is the requested character. If the requested character is not found, no characters are skipped.- Parameters:
to- A character to skip to.- Returns:
- The requested character, or zero if the requested character is not found.
- Throws:
JSONException- Thrown if there is an error while searching for the to character
-
syntaxError
public JSONException syntaxError(java.lang.String message)
Make a JSONException to signal a syntax error.- Parameters:
message- The error message.- Returns:
- A JSONException object, suitable for throwing
-
syntaxError
public JSONException syntaxError(java.lang.String message, java.lang.Throwable causedBy)
Make a JSONException to signal a syntax error.- Parameters:
message- The error message.causedBy- The throwable that caused the error.- Returns:
- A JSONException object, suitable for throwing
-
toString
public java.lang.String toString()
Make a printable string of this JSONTokener.- Overrides:
toStringin classjava.lang.Object- Returns:
- " at {index} [character {character} line {line}]"
-
close
public void close() throws java.io.IOExceptionCloses the underlying reader, releasing any resources associated with it.- Throws:
java.io.IOException- If an I/O error occurs while closing the reader.
-
-