Enum yaml_rust2::yaml::Yaml
source · pub enum Yaml {
Real(String),
Integer(i64),
String(String),
Boolean(bool),
Array(Array),
Hash(Hash),
Alias(usize),
Null,
BadValue,
}
Expand description
A YAML node is stored as this Yaml
enumeration, which provides an easy way to
access your YAML document.
§Examples
use yaml_rust2::Yaml;
let foo = Yaml::from_str("-123"); // convert the string to the appropriate YAML type
assert_eq!(foo.as_i64().unwrap(), -123);
// iterate over an Array
let vec = Yaml::Array(vec![Yaml::Integer(1), Yaml::Integer(2)]);
for v in vec.as_vec().unwrap() {
assert!(v.as_i64().is_some());
}
Variants§
Real(String)
Float types are stored as String and parsed on demand.
Note that f64
does NOT implement Eq trait and can NOT be stored in BTreeMap
.
Integer(i64)
YAML int is stored as i64.
String(String)
YAML scalar.
Boolean(bool)
YAML bool, e.g. true
or false
.
Array(Array)
YAML array, can be accessed as a Vec
.
Hash(Hash)
YAML hash, can be accessed as a LinkedHashMap
.
Insertion order will match the order of insertion into the map.
Alias(usize)
Alias, not fully supported yet.
Null
YAML null, e.g. null
or ~
.
BadValue
Accessing a nonexistent node via the Index trait returns BadValue
. This
simplifies error handling in the calling code. Invalid type conversion also
returns BadValue
.
Implementations§
source§impl Yaml
impl Yaml
sourcepub fn as_bool(&self) -> Option<bool>
pub fn as_bool(&self) -> Option<bool>
Get a copy of the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with a copy of the $t
contained.
Otherwise, return None
.
sourcepub fn as_i64(&self) -> Option<i64>
pub fn as_i64(&self) -> Option<i64>
Get a copy of the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with a copy of the $t
contained.
Otherwise, return None
.
sourcepub fn as_str(&self) -> Option<&str>
pub fn as_str(&self) -> Option<&str>
Get a reference to the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some(&$t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn as_hash(&self) -> Option<&Hash>
pub fn as_hash(&self) -> Option<&Hash>
Get a reference to the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some(&$t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn as_vec(&self) -> Option<&Array>
pub fn as_vec(&self) -> Option<&Array>
Get a reference to the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some(&$t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn as_mut_hash(&mut self) -> Option<&mut Hash>
pub fn as_mut_hash(&mut self) -> Option<&mut Hash>
Get a mutable reference to the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some(&mut $t)
with the $t
contained.
Otherwise, return None
.
sourcepub fn as_mut_vec(&mut self) -> Option<&mut Array>
pub fn as_mut_vec(&mut self) -> Option<&mut Array>
Get a mutable reference to the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some(&mut $t)
with the $t
contained.
Otherwise, return None
.
sourcepub fn into_bool(self) -> Option<bool>
pub fn into_bool(self) -> Option<bool>
Get the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn into_i64(self) -> Option<i64>
pub fn into_i64(self) -> Option<i64>
Get the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn into_string(self) -> Option<String>
pub fn into_string(self) -> Option<String>
Get the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn into_hash(self) -> Option<Hash>
pub fn into_hash(self) -> Option<Hash>
Get the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn into_vec(self) -> Option<Array>
pub fn into_vec(self) -> Option<Array>
Get the inner object in the YAML enum if it is a $t
.
§Return
If the variant of self
is Yaml::$yt
, return Some($t)
with the $t
contained. Otherwise,
return None
.
sourcepub fn is_null(&self) -> bool
pub fn is_null(&self) -> bool
Return whether self
is a Yaml::Null
node.
sourcepub fn is_badvalue(&self) -> bool
pub fn is_badvalue(&self) -> bool
Return whether self
is a Yaml::BadValue
node.
sourcepub fn is_array(&self) -> bool
pub fn is_array(&self) -> bool
Return whether self
is a Yaml::Array
node.
sourcepub fn as_f64(&self) -> Option<f64>
pub fn as_f64(&self) -> Option<f64>
Return the f64
value contained in this YAML node.
If the node is not a Yaml::Real
YAML node or its contents is not a valid f64
string,
None
is returned.
sourcepub fn into_f64(self) -> Option<f64>
pub fn into_f64(self) -> Option<f64>
Return the f64
value contained in this YAML node.
If the node is not a Yaml::Real
YAML node or its contents is not a valid f64
string,
None
is returned.
sourcepub fn or(self, other: Self) -> Self
pub fn or(self, other: Self) -> Self
If a value is null or otherwise bad (see variants), consume it and
replace it with a given value other
. Otherwise, return self unchanged.
use yaml_rust2::yaml::Yaml;
assert_eq!(Yaml::BadValue.or(Yaml::Integer(3)), Yaml::Integer(3));
assert_eq!(Yaml::Integer(3).or(Yaml::BadValue), Yaml::Integer(3));
sourcepub fn borrowed_or<'a>(&'a self, other: &'a Self) -> &'a Self
pub fn borrowed_or<'a>(&'a self, other: &'a Self) -> &'a Self
See or
for behavior. This performs the same operations, but with
borrowed values for less linear pipelines.
source§impl Yaml
impl Yaml
sourcepub fn from_str(v: &str) -> Yaml
pub fn from_str(v: &str) -> Yaml
Convert a string to a Yaml
node.
Yaml
does not implement std::str::FromStr
since conversion may not fail. This
function falls back to Yaml::String
if nothing else matches.
§Examples
assert!(matches!(Yaml::from_str("42"), Yaml::Integer(42)));
assert!(matches!(Yaml::from_str("0x2A"), Yaml::Integer(42)));
assert!(matches!(Yaml::from_str("0o52"), Yaml::Integer(42)));
assert!(matches!(Yaml::from_str("~"), Yaml::Null));
assert!(matches!(Yaml::from_str("null"), Yaml::Null));
assert!(matches!(Yaml::from_str("true"), Yaml::Boolean(true)));
assert!(matches!(Yaml::from_str("3.14"), Yaml::Real(_)));
assert!(matches!(Yaml::from_str("foo"), Yaml::String(_)));
Trait Implementations§
source§impl IndexMut<usize> for Yaml
impl IndexMut<usize> for Yaml
source§fn index_mut(&mut self, idx: usize) -> &mut Yaml
fn index_mut(&mut self, idx: usize) -> &mut Yaml
Perform indexing if self
is a sequence or a mapping.
§Panics
This function panics if the index given is out of range (as per IndexMut
). If self
i
a Yaml::Array
, this is when the index is bigger or equal to the length of the
underlying Vec
. If self
is a Yaml::Hash
, this is when the mapping sequence does no
contain Yaml::Integer
(idx)
as a key.
This function also panics if self
is not a Yaml::Array
nor a Yaml::Hash
.
source§impl IntoIterator for Yaml
impl IntoIterator for Yaml
source§impl Ord for Yaml
impl Ord for Yaml
source§impl PartialEq for Yaml
impl PartialEq for Yaml
source§impl PartialOrd for Yaml
impl PartialOrd for Yaml
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read more