JSONTokener

public class JSONTokener

A 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.

Author:JSON.org

Constructors

JSONTokener

public JSONTokener(Reader reader)

Construct a JSONTokener from a Reader.

Parameters:
  • reader – A reader.

JSONTokener

public JSONTokener(InputStream inputStream)

Construct a JSONTokener from an InputStream.

JSONTokener

public JSONTokener(String s)

Construct a JSONTokener from a string.

Parameters:
  • s – A source string.

Methods

back

public void back()

Back 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.

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()

more

public boolean more()

Determine if the source string still contains characters that next() can consume.

Returns:true if not yet at the end of the source.

next

public char next(char c)

Consume the next character, and check that it matches a specified character.

Parameters:
  • c – The character to match.
Throws:
Returns:

The character.

next

public String next(int n)

Get the next n characters.

Parameters:
  • n – The number of characters to take.
Throws:
  • JSONException – Substring bounds error if there are not n characters remaining in the source string.
Returns:

A string of n characters.

nextClean

public char nextClean()

Get the next char in the string, skipping whitespace.

Throws:
Returns:

A character, or 0 if there are no more characters.

nextString

public String nextString(char quote)

Return 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).
Throws:
Returns:

A String.

nextTo

public String nextTo(char delimiter)

Get 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.

nextTo

public String nextTo(String delimiters)

Get 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.

nextValue

public Object nextValue()

Get the next value. The value can be a Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONObject.NULL object.

Throws:
Returns:

An object.

syntaxError

public JSONException syntaxError(String message)

Make a JSONException to signal a syntax error.

Parameters:
  • message – The error message.
Returns:

A JSONException object, suitable for throwing

toString

public String toString()

Make a printable string of this JSONTokener.

Returns:” at {index} [character {character} line {line}]”