Enum amadeus::data::Decimal[][src]

pub enum Decimal {
    Int32 {
        value: [u8; 4],
        precision: i32,
        scale: i32,
    },
    Int64 {
        value: [u8; 8],
        precision: i32,
        scale: i32,
    },
    Bytes {
        value: Vec<u8, Global>,
        precision: i32,
        scale: i32,
    },
}
Expand description

Rust representation for Decimal values.

This is not a representation of Parquet physical type, but rather a wrapper for DECIMAL logical type, and serves as container for raw parts of decimal values: unscaled value in bytes, precision and scale.

Variants

Int32

Decimal backed by i32.

Show fields

Fields of Int32

value: [u8; 4]precision: i32scale: i32
Int64

Decimal backed by i64.

Show fields

Fields of Int64

value: [u8; 8]precision: i32scale: i32
Bytes

Decimal backed by byte array.

Show fields

Fields of Bytes

value: Vec<u8, Global>precision: i32scale: i32

Implementations

impl Decimal[src]

pub fn from_bytes(value: Vec<u8, Global>, precision: i32, scale: i32) -> Decimal[src]

Creates new decimal value from Vec<u8>.

pub fn data(&self) -> &[u8]

Notable traits for &'_ [u8]

impl<'_> Read for &'_ [u8]impl<'_> Write for &'_ mut [u8]
[src]

Returns bytes of unscaled value.

pub fn precision(&self) -> i32[src]

Returns decimal precision.

pub fn scale(&self) -> i32[src]

Returns decimal scale.

Trait Implementations

impl AmadeusOrd for Decimal[src]

pub fn amadeus_cmp(&self, other: &Decimal) -> Ordering[src]

impl Clone for Decimal[src]

pub fn clone(&self) -> Decimal[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Data for Decimal[src]

type Vec = Vec<Decimal, Global>

type DynamicType = ()

pub fn new_vec(_type: <Decimal as Data>::DynamicType) -> <Decimal as Data>::Vec[src]

impl Data for Decimal[src]

fn heap(&self) -> usize[src]

fn size(&self) -> usize[src]

fn cast<D: Data>(self) -> Result<D, CastError>[src]

fn eq<D: Data>(self, other: D) -> bool[src]

fn partial_cmp<D: Data>(self, other: D) -> Option<Ordering>[src]

fn hash<H: Hasher>(self, state: &mut H)[src]

impl Debug for Decimal[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

Formats the value using the given formatter. Read more

impl<'de> Deserialize<'de> for Decimal[src]

pub fn deserialize<__D>(
    __deserializer: __D
) -> Result<Decimal, <__D as Deserializer<'de>>::Error> where
    __D: Deserializer<'de>, 
[src]

Deserialize this value from the given Serde deserializer. Read more

impl Display for Decimal[src]

pub fn fmt(&self, _f: &mut Formatter<'_>) -> Result<(), Error>[src]

Formats the value using the given formatter. Read more

impl DowncastFrom<Value> for Decimal[src]

impl From<Decimal> for Value[src]

pub fn from(value: Decimal) -> Value[src]

Performs the conversion.

impl FromStr for Decimal[src]

type Err = ParseDecimalError

The associated error which can be returned from parsing.

pub fn from_str(_s: &str) -> Result<Decimal, <Decimal as FromStr>::Err>[src]

Parses a string s to return a value of this type. Read more

impl Hash for Decimal[src]

pub fn hash<__H>(&self, state: &mut __H) where
    __H: Hasher
[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl Ord for Decimal[src]

pub fn cmp(&self, other: &Decimal) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl ParquetData for Decimal[src]

type Schema = DecimalSchema

type Reader = impl Reader<Item = Decimal>

type Predicate = Predicate

pub fn parse(
    schema: &Type,
    _predicate: Option<&<Decimal as ParquetData>::Predicate>,
    repetition: Option<Repetition>
) -> Result<(String, <Decimal as ParquetData>::Schema), ParquetError>
[src]

Parse a [Type] into Self::Schema, using repetition instead of Type::get_basic_info().repetition(). A repetition of None denotes a root schema. Read more

pub fn reader(
    schema: &<Decimal as ParquetData>::Schema,
    path: &mut Vec<String, Global>,
    def_level: i16,
    rep_level: i16,
    paths: &mut HashMap<ColumnPath, ColumnReader, RandomState>,
    batch_size: usize
) -> <Decimal as ParquetData>::Reader
[src]

Builds tree of [Reader]s for the specified [Schema] recursively.

impl PartialEq<Decimal> for Decimal[src]

pub fn eq(&self, other: &Decimal) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

pub fn ne(&self, other: &Decimal) -> bool[src]

This method tests for !=.

impl PartialEq<Decimal> for Value[src]

pub fn eq(&self, other: &Decimal) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

#[must_use]
fn ne(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests for !=.

impl PartialOrd<Decimal> for Decimal[src]

pub fn partial_cmp(&self, other: &Decimal) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl PostgresData for Decimal[src]

pub fn query(
    f: &mut Formatter<'_>,
    name: Option<&Names<'_>>
) -> Result<(), Error>
[src]

pub fn decode(
    _type_: &Type,
    _buf: Option<&[u8]>
) -> Result<Decimal, Box<dyn Error + 'static + Sync + Send, Global>>
[src]

impl SerdeData for Decimal[src]

pub fn serialize<S>(
    &self,
    serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
    S: Serializer
[src]

pub fn deserialize<'de, D>(
    deserializer: D,
    _schema: Option<SchemaIncomplete>
) -> Result<Decimal, <D as Deserializer<'de>>::Error> where
    D: Deserializer<'de>, 
[src]

impl Serialize for Decimal[src]

pub fn serialize<__S>(
    &self,
    __serializer: __S
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error> where
    __S: Serializer
[src]

Serialize this value into the given Serde serializer. Read more

impl Eq for Decimal[src]

impl StructuralEq for Decimal[src]

impl StructuralPartialEq for Decimal[src]

Auto Trait Implementations

impl RefUnwindSafe for Decimal

impl Send for Decimal

impl Sync for Decimal

impl Unpin for Decimal

impl UnwindSafe for Decimal

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Any for T where
    T: Any + Serialize + Deserialize
[src]

pub fn as_any(&self) -> &(dyn Any + 'static)[src]

Convert to a &std::any::Any.

pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)[src]

Convert to a &mut std::any::Any.

pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>[src]

Convert to a std::boxed::Box<dyn std::any::Any>.

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<A, B> Downcast<A> for B where
    A: DowncastFrom<B>, 
[src]

pub fn downcast(self) -> Result<A, DowncastError>[src]

impl<Q, K> Equivalent<K> for Q where
    K: Borrow<Q> + ?Sized,
    Q: Eq + ?Sized
[src]

pub fn equivalent(&self, key: &K) -> bool[src]

Compare self to key and return true if they are equal.

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T> Instrument for T[src]

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

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

fn in_current_span(self) -> Instrumented<Self>[src]

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

impl<T> Instrument for T[src]

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

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

fn in_current_span(self) -> Instrumented<Self>[src]

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

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T> Serialize for T where
    T: Serialize + ?Sized
[src]

pub fn erased_serialize(
    &self,
    serializer: &mut dyn Serializer
) -> Result<Ok, Error>
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

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

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

impl<T> ToString for T where
    T: Display + ?Sized
[src]

pub default fn to_string(&self) -> String[src]

Converts the given value to a String. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T> Type for T where
    T: ?Sized
[src]

pub default fn meta(self: *const T) -> <T as Type>::Meta[src]

Retrieve TraitObject, Slice or Concrete meta data respectively for a type

pub default fn data(self: *const T) -> *const ()[src]

Retrieve pointer to the data

pub default fn data_mut(self: *mut T) -> *mut ()[src]

Retrieve mut pointer to the data

pub default fn dangling(t: <T as Type>::Meta) -> NonNull<T>[src]

Create a dangling non-null *const Self with the provided Self::Meta.

pub default fn fatten(thin: *mut (), t: <T as Type>::Meta) -> *mut T[src]

Create a *mut Self with the provided Self::Meta.

const METATYPE: MetaType[src]

Enum describing whether a type is TraitObject, Slice or Concrete.

type Meta: 'static

Type of metadata for type.

fn meta_type(self: *const Self) -> MetaType[src]

Helper method describing whether a type is TraitObject, Slice or Concrete.

impl<T> Type for T[src]

pub const METATYPE: MetaType[src]

Enum describing whether a type is TraitObject, Slice or Concrete.

type Meta = Concrete

Type of metadata for type.

pub fn meta(self: *const T) -> <T as Type>::Meta[src]

Retrieve TraitObject, Slice or Concrete meta data respectively for a type

pub fn data(self: *const T) -> *const ()[src]

Retrieve pointer to the data

pub fn data_mut(self: *mut T) -> *mut ()[src]

Retrieve mut pointer to the data

pub fn dangling(_t: <T as Type>::Meta) -> NonNull<T>[src]

Create a dangling non-null *const Self with the provided Self::Meta.

pub fn fatten(thin: *mut (), _t: <T as Type>::Meta) -> *mut T[src]

Create a *mut Self with the provided Self::Meta.

fn meta_type(self: *const Self) -> MetaType[src]

Helper method describing whether a type is TraitObject, Slice or Concrete.

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

pub fn vzip(self) -> V

impl<T> Debug for T where
    T: Debug + Serialize + Deserialize + ?Sized
[src]

impl<T> Deserialize for T where
    T: DeserializeOwned
[src]

impl<T> DeserializeOwned for T where
    T: for<'de> Deserialize<'de>, 
[src]

impl<T> Display for T where
    T: Display + Serialize + Deserialize + ?Sized
[src]

impl<T> ProcessSend for T where
    T: Send + Serialize + for<'de> Deserialize<'de> + ?Sized
[src]

impl<T> Serialize for T where
    T: Serialize + ?Sized
[src]