Enum mz_avro::schema::SchemaPiece

source ·
pub enum SchemaPiece {
Show 34 variants Null, Boolean, Int, Long, Float, Double, Date, TimestampMilli, TimestampMicro, Decimal { precision: usize, scale: usize, fixed_size: Option<usize>, }, Bytes, String, Json, Uuid, Array(Box<SchemaPieceOrNamed>), Map(Box<SchemaPieceOrNamed>), Union(UnionSchema), ResolveIntTsMilli, ResolveIntTsMicro, ResolveDateTimestamp, ResolveIntLong, ResolveIntFloat, ResolveIntDouble, ResolveLongFloat, ResolveLongDouble, ResolveFloatDouble, ResolveConcreteUnion { index: usize, inner: Box<SchemaPieceOrNamed>, n_reader_variants: usize, reader_null_variant: Option<usize>, }, ResolveUnionUnion { permutation: Vec<Result<(usize, SchemaPieceOrNamed), Error>>, n_reader_variants: usize, reader_null_variant: Option<usize>, }, ResolveUnionConcrete { index: usize, inner: Box<SchemaPieceOrNamed>, }, Record { doc: Documentation, fields: Vec<RecordField>, lookup: BTreeMap<String, usize>, }, Enum { doc: Documentation, symbols: Vec<String>, default_idx: Option<usize>, }, Fixed { size: usize, }, ResolveRecord { defaults: Vec<ResolvedDefaultValueField>, fields: Vec<ResolvedRecordField>, n_reader_fields: usize, }, ResolveEnum { doc: Documentation, symbols: Vec<Result<(usize, String), String>>, default: Option<(usize, String)>, },
}

Variants§

§

Null

A null Avro schema.

§

Boolean

A boolean Avro schema.

§

Int

An int Avro schema.

§

Long

A long Avro schema.

§

Float

A float Avro schema.

§

Double

A double Avro schema.

§

Date

An Int Avro schema with a semantic type being days since the unix epoch.

§

TimestampMilli

An Int64 Avro schema with a semantic type being milliseconds since the unix epoch.

https://avro.apache.org/docs/current/spec.html#Timestamp+%28millisecond+precision%29

§

TimestampMicro

An Int64 Avro schema with a semantic type being microseconds since the unix epoch.

https://avro.apache.org/docs/current/spec.html#Timestamp+%28microsecond+precision%29

§

Decimal

A bytes or fixed Avro schema with a logical type of decimal and the specified precision and scale.

If the underlying type is fixed, the fixed_size field specifies the size.

Fields

§precision: usize
§scale: usize
§fixed_size: Option<usize>
§

Bytes

A bytes Avro schema. Bytes represents a sequence of 8-bit unsigned bytes.

§

String

A string Avro schema. String represents a unicode character sequence.

§

Json

A string Avro schema that is tagged as representing JSON data

§

Uuid

A string Avro schema with a logical type of uuid.

§

Array(Box<SchemaPieceOrNamed>)

A array Avro schema. Avro arrays are required to have the same type for each element. This variant holds the Schema for the array element type.

§

Map(Box<SchemaPieceOrNamed>)

A map Avro schema. Map holds a pointer to the Schema of its values, which must all be the same schema. Map keys are assumed to be string.

§

Union(UnionSchema)

A union Avro schema.

§

ResolveIntTsMilli

A value written as int and read as long, for the timestamp-millis logicalType.

§

ResolveIntTsMicro

A value written as int and read as long, for the timestamp-micros logicalType.

§

ResolveDateTimestamp

A value written as an int with date logical type, and read as any timestamp type

§

ResolveIntLong

A value written as int and read as long

§

ResolveIntFloat

A value written as int and read as float

§

ResolveIntDouble

A value written as int and read as double

§

ResolveLongFloat

A value written as long and read as float

§

ResolveLongDouble

A value written as long and read as double

§

ResolveFloatDouble

A value written as float and read as double

§

ResolveConcreteUnion

A concrete (i.e., non-union) type in the writer, resolved against one specific variant of a union in the reader.

Fields

§index: usize

The index of the variant in the reader

§inner: Box<SchemaPieceOrNamed>

The concrete type

§n_reader_variants: usize
§reader_null_variant: Option<usize>
§

ResolveUnionUnion

A union in the writer, resolved against a union in the reader. The two schemas may have different variants and the variants may be in a different order.

Fields

§permutation: Vec<Result<(usize, SchemaPieceOrNamed), Error>>

A mapping of the fields in the writer to those in the reader. If the ith element is Err(e), the ith field in the writer did not match any field in the reader (or even if it matched by name, resolution failed). If the ith element is Ok((j, piece)), then the ith field of the writer matched the jth field of the reader, and piece is their resolved node.

§n_reader_variants: usize
§reader_null_variant: Option<usize>
§

ResolveUnionConcrete

The inverse of ResolveConcreteUnion

Fields

§index: usize
§

Record

A record Avro schema.

The lookup table maps field names to their position in the Vec of fields.

§

Enum

An enum Avro schema.

Fields

§symbols: Vec<String>
§default_idx: Option<usize>

The index of the default value.

This is only used in schema resolution: it is the value that will be read by a reader when a writer writes a value that the reader does not expect.

§

Fixed

A fixed Avro schema.

Fields

§size: usize
§

ResolveRecord

A record in the writer, resolved against a record in the reader. The two schemas may have different fields and the fields may be in a different order.

Fields

§defaults: Vec<ResolvedDefaultValueField>

Fields that do not exist in the writer schema, but had a default value specified in the reader schema, which we use.

§fields: Vec<ResolvedRecordField>

Fields in the order of their appearance in the writer schema. Present if they could be resolved against a field in the reader schema; Absent otherwise.

§n_reader_fields: usize

The size of defaults, plus the number of Present values in fields.

§

ResolveEnum

An enum in the writer, resolved against an enum in the reader. The two schemas may have different values and the values may be in a different order.

Fields

§symbols: Vec<Result<(usize, String), String>>

Symbols in order of the writer schema along with their index in the reader schema, or Err(symbol_name) if they don’t exist in the reader schema.

§default: Option<(usize, String)>

The value to decode if the writer writes some value not expected by the reader.

Implementations§

source§

impl SchemaPiece

source

pub fn is_underlying_int(&self) -> bool

Returns whether the schema node is “underlyingly” an Int (but possibly a logicalType typedef)

source

pub fn is_underlying_long(&self) -> bool

Returns whether the schema node is “underlyingly” an Int64 (but possibly a logicalType typedef)

source

pub fn try_make_int_value( &self, int: i32, ) -> Option<Result<AvroValue, AvroError>>

Constructs an avro::Value if this is of underlying int type. Guaranteed to be Some when is_underlying_int is true.

source

pub fn try_make_long_value( &self, long: i64, ) -> Option<Result<AvroValue, AvroError>>

Constructs an avro::Value if this is of underlying long type. Guaranteed to be Some when is_underlying_long is true.

Trait Implementations§

source§

impl Clone for SchemaPiece

source§

fn clone(&self) -> SchemaPiece

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for SchemaPiece

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'a> From<&'a SchemaPiece> for SchemaKind

source§

fn from(piece: &'a SchemaPiece) -> SchemaKind

Converts to this type from the input type.
source§

impl From<SchemaPiece> for SchemaPieceOrNamed

source§

fn from(piece: SchemaPiece) -> Self

Converts to this type from the input type.
source§

impl PartialEq for SchemaPiece

source§

fn eq(&self, other: &SchemaPiece) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl StructuralPartialEq for SchemaPiece

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T, U> CastInto<U> for T
where U: CastFrom<T>,

source§

fn cast_into(self) -> U

Performs the cast.
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FromRef<T> for T
where T: Clone,

source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,