Struct serde_yaml::Number[][src]

pub struct Number { /* fields omitted */ }

Represents a YAML number, whether integer or floating point.

Implementations

impl Number[src]

pub fn is_i64(&self) -> bool[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());

pub fn is_u64(&self) -> bool[src]

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());

pub fn is_f64(&self) -> bool[src]

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());

pub fn as_i64(&self) -> Option<i64>[src]

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);

pub fn as_u64(&self) -> Option<u64>[src]

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);

pub fn as_f64(&self) -> Option<f64>[src]

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());

pub fn is_nan(&self) -> bool[src]

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());

pub fn is_infinite(&self) -> bool[src]

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());

pub fn is_finite(&self) -> bool[src]

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 Clone for Number[src]

impl Debug for Number[src]

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

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

type Error = Error

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

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

type Error = Error

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

impl Display for Number[src]

impl From<f32> for Number[src]

impl From<f64> for Number[src]

impl From<i16> for Number[src]

impl From<i32> for Number[src]

impl From<i64> for Number[src]

impl From<i8> for Number[src]

impl From<isize> for Number[src]

impl From<u16> for Number[src]

impl From<u32> for Number[src]

impl From<u64> for Number[src]

impl From<u8> for Number[src]

impl From<usize> for Number[src]

impl Hash for Number[src]

impl PartialEq<Number> for Number[src]

impl PartialOrd<Number> for Number[src]

impl Serialize for Number[src]

impl StructuralPartialEq for Number[src]

Auto Trait Implementations

impl RefUnwindSafe for Number

impl Send for Number

impl Sync for Number

impl Unpin for Number

impl UnwindSafe for Number

Blanket Implementations

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

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

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

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

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

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

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

type Owned = T

The resulting type after obtaining ownership.

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

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.

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.