Skip to main content

ValueKey

Struct ValueKey 

Source
pub struct ValueKey<'a>(/* private fields */);
Expand description

A key for looking up elements in Value arrays and maps.

ValueKey is the parameter type of Value::get, Value::get_mut, Value::remove, and the Index/IndexMut implementations on Value. You rarely name it directly: every type that implements Into<ValueKey> can be passed in, including:

  • integers, floats, bool, SimpleValue, ()
  • &str, &String
  • &[u8]
  • &Value
  • &[Value], &Vec<Value>, &[Value; N], &Array (array-valued keys)
  • &Map, &BTreeMap<Value, Value> (map-valued keys)

Lookups are zero-copy for the borrowed forms: passing &str, &[u8], &[Value], or &BTreeMap<Value, Value> does not allocate a full Value to compare against map keys.

§Examples

use cbor_core::{Value, array, map};

let a = array![10, 20, 30];
assert_eq!(a[1].to_u32(), Ok(20));

let m = map! { "x" => 10, 2 => 20 };
assert_eq!(m["x"].to_u32(), Ok(10));
assert_eq!(m[2].to_u32(), Ok(20));

let k: [Value; _] = [1,2,3].map(Value::from);
let m = map! { k.clone() => "array as key" };
assert_eq!(m[&k].as_str(), Ok("array as key") );

let mut v = array![1, 2, 3];
v.remove(0);
assert_eq!(v.len(), Some(2));

Trait Implementations§

Source§

impl<'a> Debug for ValueKey<'a>

Source§

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

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

impl<'a, T, const N: usize> From<&'a [T; N]> for ValueKey<'a>
where ValueKey<'a>: From<&'a [T]>,

Source§

fn from(value: &'a [T; N]) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a [Value]> for ValueKey<'a>

Source§

fn from(value: &'a [Value]) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a [u8]> for ValueKey<'a>

Source§

fn from(value: &'a [u8]) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a Array> for ValueKey<'a>

Source§

fn from(value: &'a Array) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a BTreeMap<Value, Value>> for ValueKey<'a>

Source§

fn from(value: &'a BTreeMap<Value, Value>) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a Map> for ValueKey<'a>

Source§

fn from(value: &'a Map) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a String> for ValueKey<'a>

Source§

fn from(value: &'a String) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a Value> for ValueKey<'a>

Source§

fn from(value: &'a Value) -> Self

Converts to this type from the input type.
Source§

impl<'a, T> From<&'a Vec<T>> for ValueKey<'a>
where ValueKey<'a>: From<&'a [T]>,

Source§

fn from(value: &'a Vec<T>) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a str> for ValueKey<'a>

Source§

fn from(value: &'a str) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<()> for ValueKey<'a>

Source§

fn from(value: ()) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<Float> for ValueKey<'a>

Source§

fn from(value: Float) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<SimpleValue> for ValueKey<'a>

Source§

fn from(value: SimpleValue) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<bool> for ValueKey<'a>

Source§

fn from(value: bool) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl From<f16> for ValueKey<'_>

Available on crate feature half only.
Source§

fn from(value: f16) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<f32> for ValueKey<'a>

Source§

fn from(value: f32) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<f64> for ValueKey<'a>

Source§

fn from(value: f64) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<i128> for ValueKey<'a>

Source§

fn from(value: i128) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<i16> for ValueKey<'a>

Source§

fn from(value: i16) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<i32> for ValueKey<'a>

Source§

fn from(value: i32) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<i64> for ValueKey<'a>

Source§

fn from(value: i64) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<i8> for ValueKey<'a>

Source§

fn from(value: i8) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<isize> for ValueKey<'a>

Source§

fn from(value: isize) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<u128> for ValueKey<'a>

Source§

fn from(value: u128) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<u16> for ValueKey<'a>

Source§

fn from(value: u16) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<u32> for ValueKey<'a>

Source§

fn from(value: u32) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<u64> for ValueKey<'a>

Source§

fn from(value: u64) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<u8> for ValueKey<'a>

Source§

fn from(value: u8) -> ValueKey<'a>

Converts to this type from the input type.
Source§

impl<'a> From<usize> for ValueKey<'a>

Source§

fn from(value: usize) -> ValueKey<'a>

Converts to this type from the input type.

Auto Trait Implementations§

§

impl<'a> Freeze for ValueKey<'a>

§

impl<'a> RefUnwindSafe for ValueKey<'a>

§

impl<'a> Send for ValueKey<'a>

§

impl<'a> Sync for ValueKey<'a>

§

impl<'a> Unpin for ValueKey<'a>

§

impl<'a> UnsafeUnpin for ValueKey<'a>

§

impl<'a> UnwindSafe for ValueKey<'a>

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> Az for T

Source§

fn az<Dst>(self) -> Dst
where T: Cast<Dst>,

Casts the value.
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<Src, Dst> CastFrom<Src> for Dst
where Src: Cast<Dst>,

Source§

fn cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> CheckedAs for T

Source§

fn checked_as<Dst>(self) -> Option<Dst>
where T: CheckedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> CheckedCastFrom<Src> for Dst
where Src: CheckedCast<Dst>,

Source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> OverflowingAs for T

Source§

fn overflowing_as<Dst>(self) -> (Dst, bool)
where T: OverflowingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dst
where Src: OverflowingCast<Dst>,

Source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
Source§

impl<T> SaturatingAs for T

Source§

fn saturating_as<Dst>(self) -> Dst
where T: SaturatingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dst
where Src: SaturatingCast<Dst>,

Source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> StrictAs for T

Source§

fn strict_as<Dst>(self) -> Dst
where T: StrictCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> StrictCastFrom<Src> for Dst
where Src: StrictCast<Dst>,

Source§

fn strict_cast_from(src: Src) -> Dst

Casts the value.
Source§

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

Source§

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>,

Source§

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<T> UnwrappedAs for T

Source§

fn unwrapped_as<Dst>(self) -> Dst
where T: UnwrappedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dst
where Src: UnwrappedCast<Dst>,

Source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> WrappingAs for T

Source§

fn wrapping_as<Dst>(self) -> Dst
where T: WrappingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> WrappingCastFrom<Src> for Dst
where Src: WrappingCast<Dst>,

Source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.