commonMain.com.apollographql.apollo3.api.json.JsonReader.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of apollo-api-jvm Show documentation
Show all versions of apollo-api-jvm Show documentation
Apollo GraphQL API classes
/*
* Copyright (C) 2010 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.apollographql.apollo3.api.json
import com.apollographql.apollo3.exception.JsonDataException
import okio.Closeable
import okio.IOException
/**
* Reads a JSON [RFC 7159](http://www.ietf.org/rfc/rfc7159.txt) encoded value as a stream of tokens.
*
* This stream includes both literal values (strings, numbers, booleans, and nulls) as well as the begin and end delimiters of objects
* and arrays.
*
* The tokens are traversed in depth-first order, the same order that they appear in the JSON document.
* Within JSON objects, name/value pairs are represented by a single token.
*
* Each {@code JsonReader} may be used to read a single JSON stream. Instances of this class are not thread safe.
*
* Json doesn't have int, long, double values. Only string and number. That means nextInt(), nextDouble(), nextLong() and nextNumber() will
* coerce the Json value into the expected type or throw if the conversion is not possible or loses precision.
*
* [BufferedSourceJsonReader] can parse longs without having to buffer so when possible, prefer nextLong() over nextInt()
*
* **Note**: This interface was originally from Moshi and has been tweaked to better match the GraphQL use cases
*/
interface JsonReader : Closeable {
/**
* Returns the type of the next token without consuming it.
*/
@Throws(IOException::class)
fun peek(): Token
/**
* Consumes the next token from the JSON stream and asserts that it is the beginning of a new array.
*/
@Throws(IOException::class)
fun beginArray(): JsonReader
/**
* Consumes the next token from the JSON stream and asserts that it is the end of the current array.
*/
@Throws(IOException::class)
fun endArray(): JsonReader
/**
* Consumes the next token from the JSON stream and asserts that it is the beginning of a new object.
*/
@Throws(IOException::class)
fun beginObject(): JsonReader
/**
* Consumes the next token from the JSON stream and asserts that it is the end of the current object.
*/
@Throws(IOException::class)
fun endObject(): JsonReader
/**
* Returns true if the current array or object has another element.
*/
@Throws(IOException::class)
fun hasNext(): Boolean
/**
* Returns the next token [Token.NAME], and consumes it.
*
* @throws JsonDataException if the next token in the stream is not a property name.
*/
@Throws(IOException::class)
fun nextName(): String
/**
* Returns the [Token.STRING] value of the next token, consuming it.
*
* If the next token is a number, this method will return its string form.
*
* @throws JsonDataException if the next token is not a string or if this reader is closed.
*/
@Throws(IOException::class)
fun nextString(): String?
/**
* Returns the [Token.BOOLEAN] value of the next token, consuming it.
*
* @throws JsonDataException if the next token is not a boolean or if this reader is closed.
*/
@Throws(IOException::class)
fun nextBoolean(): Boolean
/**
* Consumes the next token from the JSON stream and asserts that it is a literal null. Returns null.
*
* @throws JsonDataException if the next token is not null or if this reader is closed.
*/
@Throws(IOException::class)
fun nextNull(): Nothing?
/**
* Returns the [Token.NUMBER] value of the next token, consuming it.
*
* If the next token is a string, this method will attempt to parse it as an int. If the next token's numeric value cannot be exactly
* represented by a [Int], this method throws.
*
* @throws JsonDataException if the next token is not a literal value, if the next literal value cannot be parsed as a number, or
* exactly represented as an int.
*/
@Throws(IOException::class)
fun nextInt(): Int
/**
* Returns the [Token.NUMBER] value of the next token, consuming it.
*
* If the next token is a string, this method will attempt to parse it as a double.
*
* @throws JsonDataException if the next token is not a literal value, or if the next literal value cannot be parsed as a double,
* or is non-finite.
*/
@Throws(IOException::class)
fun nextDouble(): Double
/**
* Returns the [Token.NUMBER] value of the next token, consuming it.
*
* If the next token is a string, this method will attempt to parse it as an long. If the next token's numeric value cannot be exactly
* represented by a [Long], this method throws.
*
* @throws JsonDataException if the next token is not a literal value, if the next literal value cannot be parsed as a number, or
* exactly represented as a Long.
*/
@Throws(IOException::class)
fun nextLong(): Long
/**
* Returns the [Token.NUMBER] value of the next token, consuming it.
*/
@Throws(IOException::class)
fun nextNumber(): JsonNumber
/**
* Skips the next value recursively. If it is an object or array, all nested elements are skipped.
*
* This method is intended for use when the JSON token stream contains unrecognized or unhandled values.
*/
@Throws(IOException::class)
fun skipValue()
/**
* An optimized way to retrieve the nextName when the candidates and their order is known. [selectName] maintains the current index in
* the list and saves having to string compare [nextName] to every candidate.
*
* @return the index of the next name or -1 if there is no next name
*/
@Throws(IOException::class)
fun selectName(names: List): Int
/**
* Reset the current object so that [selectName] start returning names again
*/
fun rewind()
/**
* Returns the current path of the JSON being read, as a List. The elements can either be Strings (names) or Integers (array indices).
*/
fun getPath(): List
/**
* A structure, name, or value type in a JSON-encoded string.
*/
enum class Token {
/**
* The opening of a JSON array. Written using [JsonWriter.beginArray] and read using [JsonReader.beginArray].
*/
BEGIN_ARRAY,
/**
* The closing of a JSON array. Written using [JsonWriter.endArray] and read using [JsonReader.endArray].
*/
END_ARRAY,
/**
* The opening of a JSON object. Written using [JsonWriter.beginObject] and read using [JsonReader.beginObject].
*/
BEGIN_OBJECT,
/**
* The closing of a JSON object. Written using [JsonWriter.endObject] and read using [JsonReader.endObject].
*/
END_OBJECT,
/**
* A JSON property name. Within objects, tokens alternate between names and their values. Written using [JsonWriter.name] and read
* using [JsonReader.nextName]
*/
NAME,
/**
* A JSON string.
*/
STRING,
/**
* A JSON number represented in this API by a Java `double`, `long`, or `int`.
*/
NUMBER,
/**
* A JSON number represented in this API by a `long`.
*/
LONG,
/**
* A JSON `true` or `false`.
*/
BOOLEAN,
/**
* A JSON `null`.
*/
NULL,
/**
* The end of the JSON stream. This sentinel value is returned by [JsonReader.peek] to signal that the JSON-encoded value has no
* more tokens.
*/
END_DOCUMENT,
/**
* A reference to an in-memory value that is reader-specific. Not all readers may support this
*/
ANY
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy