[][src]Struct serde_yaml::Number

pub struct Number { /* fields omitted */ }
[]

Represents a YAML number, whether integer or floating point.

Methods

impl Number
[src]
[]

[]

Returns true if the Number is an integer between i64::MIN and i64::MAX.

For any Number on which is_i64 returns true, as_i64 is guaranteed to return the integer value.

let big = i64::MAX as u64 + 10;
let v = yaml(r#"
a: 64
b: 9223372036854775817
c: 256.0
"#);

assert!(v["a"].is_i64());

// Greater than i64::MAX.
assert!(!v["b"].is_i64());

// Numbers with a decimal point are not considered integers.
assert!(!v["c"].is_i64());

[]

Returns true if the Number is an integer between zero and u64::MAX.

For any Number on which is_u64 returns true, as_u64 is guaranteed to return the integer value.

let v = yaml(r#"
a: 64
b: -64
c: 256.0
"#);

assert!(v["a"].is_u64());

// Negative integer.
assert!(!v["b"].is_u64());

// Numbers with a decimal point are not considered integers.
assert!(!v["c"].is_u64());

[]

Returns true if the Number can be represented by f64.

For any Number on which is_f64 returns true, as_f64 is guaranteed to return the floating point value.

Currently this function returns true if and only if both is_i64 and is_u64 return false but this is not a guarantee in the future.

let v = yaml(r#"
---
a: 256.0
b: 64
c: -64
"#);

assert!(v["a"].is_f64());

// Integers.
assert!(!v["b"].is_f64());
assert!(!v["c"].is_f64());

[]

If the Number is an integer, represent it as i64 if possible. Returns None otherwise.

let big = i64::MAX as u64 + 10;
let v = yaml(r#"
---
a: 64
b: 9223372036854775817
c: 256.0
"#);

assert_eq!(v["a"].as_i64(), Some(64));
assert_eq!(v["b"].as_i64(), None);
assert_eq!(v["c"].as_i64(), None);

[]

If the Number is an integer, represent it as u64 if possible. Returns None otherwise.

let v = yaml(r#"
---
a: 64
b: -64
c: 256.0
"#);

assert_eq!(v["a"].as_u64(), Some(64));
assert_eq!(v["b"].as_u64(), None);
assert_eq!(v["c"].as_u64(), None);

[]

Represents the number as f64 if possible. Returns None otherwise.

let v = yaml(r#"
---
a: 256.0
b: 64
c: -64
"#);

assert_eq!(v["a"].as_f64(), Some(256.0));
assert_eq!(v["b"].as_f64(), Some(64.0));
assert_eq!(v["c"].as_f64(), Some(-64.0));
assert_eq!(yaml("inf").as_f64(), Some(f64::INFINITY));
assert_eq!(yaml("-inf").as_f64(), Some(f64::NEG_INFINITY));
assert!(yaml("NaN").as_f64().unwrap().is_nan());

[]

Returns true if this value is NaN and false otherwise.

assert!(!Number::from(256.0).is_nan());

assert!(Number::from(f64::NAN).is_nan());

assert!(!Number::from(f64::INFINITY).is_nan());

assert!(!Number::from(f64::NEG_INFINITY).is_nan());

assert!(!Number::from(1).is_nan());

[]

Returns true if this value is positive infinity or negative infinity and false otherwise.

assert!(!Number::from(256.0).is_infinite());

assert!(!Number::from(f64::NAN).is_infinite());

assert!(Number::from(f64::INFINITY).is_infinite());

assert!(Number::from(f64::NEG_INFINITY).is_infinite());

assert!(!Number::from(1).is_infinite());

[]

Returns true if this number is neither infinite nor NaN.

assert!(Number::from(256.0).is_finite());

assert!(!Number::from(f64::NAN).is_finite());

assert!(!Number::from(f64::INFINITY).is_finite());

assert!(!Number::from(f64::NEG_INFINITY).is_finite());

assert!(Number::from(1).is_finite());

Trait Implementations

impl PartialOrd<Number> for Number
[src]
[+]

[]

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

[]

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

[]

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

[]

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

[]

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

impl PartialEq<Number> for Number
[src]
[+]

[]

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

[]

This method tests for !=.

impl Clone for Number
[src]
[+]

[]

Returns a copy of the value. Read more

[]

Performs copy-assignment from source. Read more

impl From<i8> for Number
[src]
[+]

[]

Performs the conversion.

impl From<i16> for Number
[src]
[+]

[]

Performs the conversion.

impl From<i32> for Number
[src]
[+]

[]

Performs the conversion.

impl From<i64> for Number
[src]
[+]

[]

Performs the conversion.

impl From<isize> for Number
[src]
[+]

[]

Performs the conversion.

impl From<u8> for Number
[src]
[+]

[]

Performs the conversion.

impl From<u16> for Number
[src]
[+]

[]

Performs the conversion.

impl From<u32> for Number
[src]
[+]

[]

Performs the conversion.

impl From<u64> for Number
[src]
[+]

[]

Performs the conversion.

impl From<usize> for Number
[src]
[+]

[]

Performs the conversion.

impl From<f32> for Number
[src]
[+]

[]

Performs the conversion.

impl From<f64> for Number
[src]
[+]

[]

Performs the conversion.

impl Display for Number
[src]
[+]

[]

Formats the value using the given formatter. Read more

impl Debug for Number
[src]
[+]

[]

Formats the value using the given formatter. Read more

impl Hash for Number
[src]
[+]

[]

Feeds this value into the given [Hasher]. Read more

[]

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

impl Serialize for Number
[src]
[+]

[]

Serialize this value into the given Serde serializer. Read more

impl<'de> Deserializer<'de> for Number
[src]
[+]

The error type that can be returned if some error occurs during deserialization. Read more

[]

Require the Deserializer to figure out how to drive the visitor based on what data type is in the input. Read more

[]

Hint that the Deserialize type is expecting a bool value.

[]

Hint that the Deserialize type is expecting an i8 value.

[]

Hint that the Deserialize type is expecting an i16 value.

[]

Hint that the Deserialize type is expecting an i32 value.

[]

Hint that the Deserialize type is expecting an i64 value.

[]

Hint that the Deserialize type is expecting a u8 value.

[]

Hint that the Deserialize type is expecting a u16 value.

[]

Hint that the Deserialize type is expecting a u32 value.

[]

Hint that the Deserialize type is expecting a u64 value.

[]

Hint that the Deserialize type is expecting a f32 value.

[]

Hint that the Deserialize type is expecting a f64 value.

[]

Hint that the Deserialize type is expecting a char value.

[]

Hint that the Deserialize type is expecting a string value and does not benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting a string value and would benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting a byte array and does not benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting a byte array and would benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting an optional value. Read more

[]

Hint that the Deserialize type is expecting a unit value.

[]

Hint that the Deserialize type is expecting a unit struct with a particular name. Read more

[]

Hint that the Deserialize type is expecting a newtype struct with a particular name. Read more

[]

Hint that the Deserialize type is expecting a sequence of values.

[]

Hint that the Deserialize type is expecting a sequence of values and knows how many values there are without looking at the serialized data. Read more

[]

Hint that the Deserialize type is expecting a tuple struct with a particular name and number of fields. Read more

[]

Hint that the Deserialize type is expecting a map of key-value pairs.

[]

Hint that the Deserialize type is expecting a struct with a particular name and fields. Read more

[]

Hint that the Deserialize type is expecting an enum value with a particular name and possible variants. Read more

[]

Hint that the Deserialize type is expecting the name of a struct field or the discriminant of an enum variant. Read more

[]

Hint that the Deserialize type needs to deserialize a value whose type doesn't matter because it is ignored. Read more

[]

Hint that the Deserialize type is expecting an i128 value. Read more

[]

Hint that the Deserialize type is expecting an u128 value. Read more

[]

Determine whether Deserialize implementations should expect to deserialize their human-readable form. Read more

impl<'de, 'a> Deserializer<'de> for &'a Number
[src]
[+]

The error type that can be returned if some error occurs during deserialization. Read more

[]

Require the Deserializer to figure out how to drive the visitor based on what data type is in the input. Read more

[]

Hint that the Deserialize type is expecting a bool value.

[]

Hint that the Deserialize type is expecting an i8 value.

[]

Hint that the Deserialize type is expecting an i16 value.

[]

Hint that the Deserialize type is expecting an i32 value.

[]

Hint that the Deserialize type is expecting an i64 value.

[]

Hint that the Deserialize type is expecting a u8 value.

[]

Hint that the Deserialize type is expecting a u16 value.

[]

Hint that the Deserialize type is expecting a u32 value.

[]

Hint that the Deserialize type is expecting a u64 value.

[]

Hint that the Deserialize type is expecting a f32 value.

[]

Hint that the Deserialize type is expecting a f64 value.

[]

Hint that the Deserialize type is expecting a char value.

[]

Hint that the Deserialize type is expecting a string value and does not benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting a string value and would benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting a byte array and does not benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting a byte array and would benefit from taking ownership of buffered data owned by the Deserializer. Read more

[]

Hint that the Deserialize type is expecting an optional value. Read more

[]

Hint that the Deserialize type is expecting a unit value.

[]

Hint that the Deserialize type is expecting a unit struct with a particular name. Read more

[]

Hint that the Deserialize type is expecting a newtype struct with a particular name. Read more

[]

Hint that the Deserialize type is expecting a sequence of values.

[]

Hint that the Deserialize type is expecting a sequence of values and knows how many values there are without looking at the serialized data. Read more

[]

Hint that the Deserialize type is expecting a tuple struct with a particular name and number of fields. Read more

[]

Hint that the Deserialize type is expecting a map of key-value pairs.

[]

Hint that the Deserialize type is expecting a struct with a particular name and fields. Read more

[]

Hint that the Deserialize type is expecting an enum value with a particular name and possible variants. Read more

[]

Hint that the Deserialize type is expecting the name of a struct field or the discriminant of an enum variant. Read more

[]

Hint that the Deserialize type needs to deserialize a value whose type doesn't matter because it is ignored. Read more

[]

Hint that the Deserialize type is expecting an i128 value. Read more

[]

Hint that the Deserialize type is expecting an u128 value. Read more

[]

Determine whether Deserialize implementations should expect to deserialize their human-readable form. Read more

impl<'de> Deserialize<'de> for Number
[src]
[+]

[]

Deserialize this value from the given Serde deserializer. Read more

Auto Trait Implementations

impl Send for Number

impl Sync for Number

Blanket Implementations

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

[]

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

[]

🔬 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]
[]

[]

Converts the given value to a String. Read more

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

[]

Performs the conversion.

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

[]

Performs the conversion.

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

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

The type returned in the event of a conversion error.

[]

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

Performs the conversion.

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

[]

Immutably borrows from an owned value. Read more

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

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

The type returned in the event of a conversion error.

[]

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

Performs the conversion.

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

[]

Mutably borrows from an owned value. Read more

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

[]

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

this method will likely be replaced by an associated static

Gets the TypeId of self. Read more

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