pub struct Peek<'mem, 'facet> { /* private fields */ }reflect only.Expand description
Lets you read from a value (implements read-only ValueVTable proxies)
If the value is a struct, you can read its fields, if the value is an enum, you can find out which variant is selected, if it’s a scalar you can check against known types and get a concrete value out of it, etc.
Implementations§
Source§impl<'mem, 'facet> Peek<'mem, 'facet>
impl<'mem, 'facet> Peek<'mem, 'facet>
Sourcepub unsafe fn unchecked_new(
data: PtrConst<'mem>,
shape: &'static Shape,
) -> Peek<'mem, 'facet>
pub unsafe fn unchecked_new( data: PtrConst<'mem>, shape: &'static Shape, ) -> Peek<'mem, 'facet>
Returns a read-only view over a value (given its shape), trusting you that those two match.
§Safety
This function is unsafe because it doesn’t check if the provided data and shape are compatible. The caller must ensure that the data is valid for the given shape.
Sourcepub fn vtable(&self) -> &'static ValueVTable
pub fn vtable(&self) -> &'static ValueVTable
Returns the vtable
Sourcepub fn id(&self) -> ValueId
pub fn id(&self) -> ValueId
Returns a unique identifier for this value, usable for cycle detection
Sourcepub fn ptr_eq(&self, other: &Peek<'_, '_>) -> bool
pub fn ptr_eq(&self, other: &Peek<'_, '_>) -> bool
Returns true if the two values are pointer-equal
Sourcepub fn partial_eq(&self, other: &Peek<'_, '_>) -> Result<bool, ReflectError>
pub fn partial_eq(&self, other: &Peek<'_, '_>) -> Result<bool, ReflectError>
Returns true if this scalar is equal to the other scalar
§Returns
false if equality comparison is not supported for this scalar type
Sourcepub fn partial_cmp(
&self,
other: &Peek<'_, '_>,
) -> Result<Option<Ordering>, ReflectError>
pub fn partial_cmp( &self, other: &Peek<'_, '_>, ) -> Result<Option<Ordering>, ReflectError>
Compares this scalar with another and returns their ordering
§Returns
None if comparison is not supported for this scalar type
Sourcepub fn scalar_type(&self) -> Option<ScalarType>
pub fn scalar_type(&self) -> Option<ScalarType>
Get the scalar type if set.
Sourcepub fn get<T>(&self) -> Result<&T, ReflectError>
pub fn get<T>(&self) -> Result<&T, ReflectError>
Sourcepub fn as_str(&self) -> Option<&'mem str>
pub fn as_str(&self) -> Option<&'mem str>
Try to get the value as a string if it’s a string type Returns None if the value is not a string or couldn’t be extracted
Sourcepub fn as_bytes(&self) -> Option<&'mem [u8]>
pub fn as_bytes(&self) -> Option<&'mem [u8]>
Try to get the value as a byte slice if it’s a &u8 type Returns None if the value is not a byte slice or couldn’t be extracted
Sourcepub fn into_struct(self) -> Result<PeekStruct<'mem, 'facet>, ReflectError>
pub fn into_struct(self) -> Result<PeekStruct<'mem, 'facet>, ReflectError>
Tries to identify this value as a struct
Sourcepub fn into_enum(self) -> Result<PeekEnum<'mem, 'facet>, ReflectError>
pub fn into_enum(self) -> Result<PeekEnum<'mem, 'facet>, ReflectError>
Tries to identify this value as an enum
Sourcepub fn into_map(self) -> Result<PeekMap<'mem, 'facet>, ReflectError>
pub fn into_map(self) -> Result<PeekMap<'mem, 'facet>, ReflectError>
Tries to identify this value as a map
Sourcepub fn into_set(self) -> Result<PeekSet<'mem, 'facet>, ReflectError>
pub fn into_set(self) -> Result<PeekSet<'mem, 'facet>, ReflectError>
Tries to identify this value as a set
Sourcepub fn into_list(self) -> Result<PeekList<'mem, 'facet>, ReflectError>
pub fn into_list(self) -> Result<PeekList<'mem, 'facet>, ReflectError>
Tries to identify this value as a list
Sourcepub fn into_ndarray(self) -> Result<PeekNdArray<'mem, 'facet>, ReflectError>
pub fn into_ndarray(self) -> Result<PeekNdArray<'mem, 'facet>, ReflectError>
Tries to identify this value as a ndarray
Sourcepub fn into_list_like(self) -> Result<PeekListLike<'mem, 'facet>, ReflectError>
pub fn into_list_like(self) -> Result<PeekListLike<'mem, 'facet>, ReflectError>
Tries to identify this value as a list, array or slice
Sourcepub fn into_pointer(self) -> Result<PeekPointer<'mem, 'facet>, ReflectError>
pub fn into_pointer(self) -> Result<PeekPointer<'mem, 'facet>, ReflectError>
Tries to identify this value as a pointer
Sourcepub fn into_option(self) -> Result<PeekOption<'mem, 'facet>, ReflectError>
pub fn into_option(self) -> Result<PeekOption<'mem, 'facet>, ReflectError>
Tries to identify this value as an option
Sourcepub fn into_tuple(self) -> Result<PeekTuple<'mem, 'facet>, ReflectError>
pub fn into_tuple(self) -> Result<PeekTuple<'mem, 'facet>, ReflectError>
Tries to identify this value as a tuple
Sourcepub fn innermost_peek(self) -> Peek<'mem, 'facet>
pub fn innermost_peek(self) -> Peek<'mem, 'facet>
Tries to return the innermost value — useful for serialization. For example, we serialize a NonZero<u8> the same
as a u8. Similarly, we serialize a Utf8PathBuf the same as a `String.
Returns a Peek to the innermost value, unwrapping transparent wrappers recursively.
For example, this will peel through newtype wrappers or smart pointers that have an inner.
Sourcepub fn custom_serialization(
&self,
field: Field,
) -> Result<OwnedPeek<'mem>, ReflectError>
Available on crate feature alloc only.
pub fn custom_serialization( &self, field: Field, ) -> Result<OwnedPeek<'mem>, ReflectError>
alloc only.Performs custom serialization of the current peek using the provided field’s metadata.
Returns an OwnedPeek that points to the final type that should be serialized in place
of the current peek.