Interface IJsonStreamReader
Reads values and objects from a JSON stream asynchronously.
Namespace: Couchbase.Core.IO.Serializers
Assembly: Couchbase.NetClient.dll
Syntax
public interface IJsonStreamReader : IDisposable
Properties
| Improve this Doc View SourceDepth
The current depth of the reader. Zero indicates ready to read the root object, one indicates an attribute on the root object, etc.
Declaration
int Depth { get; }
Property Value
Type | Description |
---|---|
System.Int32 |
Remarks
Example paths: "metrics" == 1, "metrics.count" == 2, "results[0].abv" == 3.
Value
If the reader is stopped on a simple value attribute, returns the value.
Declaration
object? Value { get; }
Property Value
Type | Description |
---|---|
System.Nullable<System.Object> |
ValueType
If the reader is stopped on a simple value attribute, returns the .NET type of the value. Otherwise, returns null.
Declaration
Type? ValueType { get; }
Property Value
Type | Description |
---|---|
System.Nullable<Type> |
Methods
| Improve this Doc View SourceInitializeAsync(CancellationToken)
Initializes the reader
Declaration
Task<bool> InitializeAsync(CancellationToken cancellationToken = null)
Parameters
Type | Name | Description |
---|---|---|
CancellationToken | cancellationToken | Cancellation token. |
Returns
Type | Description |
---|---|
Task<System.Boolean> |
ReadArrayAsync<T>(Func<IJsonStreamReader, CancellationToken, Task<T>>, CancellationToken)
Reads an array of tokens at the current point in the stream.
Declaration
IAsyncEnumerable<T> ReadArrayAsync<T>(Func<IJsonStreamReader, CancellationToken, Task<T>> readElement, CancellationToken cancellationToken = null)
Parameters
Type | Name | Description |
---|---|---|
Func<IJsonStreamReader, CancellationToken, Task<T>> | readElement | Function which reads each element of the array. |
CancellationToken | cancellationToken | Cancellation token. |
Returns
Type | Description |
---|---|
IAsyncEnumerable<T> | An |
Type Parameters
Name | Description |
---|---|
T | Type of elements returned. |
ReadObjectAsync<T>(CancellationToken)
Reads an object at the current point in the stream.
Declaration
Task<T> ReadObjectAsync<T>(CancellationToken cancellationToken = null)
Parameters
Type | Name | Description |
---|---|---|
CancellationToken | cancellationToken | Cancellation token. |
Returns
Type | Description |
---|---|
Task<T> | The object read. |
Type Parameters
Name | Description |
---|---|
T | Type of the object to read. |
Remarks
This method also supports reading literals such as strings, numbers, nulls, etc,
given the correct type for T
.
ReadTokenAsync(CancellationToken)
Reads a dynamic token at the current point in the stream.
Declaration
Task<IJsonToken> ReadTokenAsync(CancellationToken cancellationToken = null)
Parameters
Type | Name | Description |
---|---|---|
CancellationToken | cancellationToken | Cancellation token. |
Returns
Type | Description |
---|---|
Task<IJsonToken> | The dynamic object. |
ReadToNextAttributeAsync(CancellationToken)
Reads until the next attribute is found in the stream. Returns the path to the attribute,
or
Declaration
Task<string?> ReadToNextAttributeAsync(CancellationToken cancellationToken = null)
Parameters
Type | Name | Description |
---|---|---|
CancellationToken | cancellationToken | Cancellation token. |
Returns
Type | Description |
---|---|
Task<System.Nullable<System.String>> | Path to the attribute relative to the overall stream,
or |
Remarks
The returned path is "." separated, and relative to the overall stream. For example, if the attribute "metrics" is on the root object, returns "metrics". If the attribute reached is "count" on the "metrics" object, the returned value is "metrics.count". Arrays are indicated with square brackets, for example "results[0].abv".