Struct qm_mongodb::bson::RawArray  
source · pub struct RawArray { /* private fields */ }Expand description
A slice of a BSON document containing a BSON array value (akin to std::str). This can be
retrieved from a RawDocument via RawDocument::get.
This is an unsized type, meaning that it must always be used behind a pointer like &.
Accessing elements within a RawArray is similar to element access in crate::Document,
but because the contents are parsed during iteration instead of at creation time, format errors
can happen at any time during use.
Iterating over a RawArray yields either an error or a value that borrows from the
original document without making any additional allocations.
use bson::{doc, raw::RawDocument};
let doc = doc! {
    "x": [1, true, "two", 5.5]
};
let bytes = bson::to_vec(&doc)?;
let rawdoc = RawDocument::from_bytes(bytes.as_slice())?;
let rawarray = rawdoc.get_array("x")?;
for v in rawarray {
    println!("{:?}", v?);
}Individual elements can be accessed using RawArray::get or any of
the type-specific getters, such as RawArray::get_object_id or
RawArray::get_str. Note that accessing elements is an O(N) operation, as it
requires iterating through the array from the beginning to find the requested index.
use bson::{doc, raw::RawDocument};
let doc = doc! {
    "x": [1, true, "two", 5.5]
};
let bytes = bson::to_vec(&doc)?;
let rawdoc = RawDocument::from_bytes(bytes.as_slice())?;
let rawarray = rawdoc.get_array("x")?;
assert_eq!(rawarray.get_bool(1)?, true);Implementations§
source§impl RawArray
 
impl RawArray
sourcepub fn to_raw_array_buf(&self) -> RawArrayBuf
 
pub fn to_raw_array_buf(&self) -> RawArrayBuf
Convert this borrowed RawArray into an owned RawArrayBuf.
This involves a traversal of the array to count the values.
sourcepub fn get(&self, index: usize) -> Result<Option<RawBsonRef<'_>>, Error>
 
pub fn get(&self, index: usize) -> Result<Option<RawBsonRef<'_>>, Error>
Gets a reference to the value at the given index.
sourcepub fn get_f64(&self, index: usize) -> Result<f64, ValueAccessError>
 
pub fn get_f64(&self, index: usize) -> Result<f64, ValueAccessError>
Gets the BSON double at the given index or returns an error if the value at that index isn’t a double.
sourcepub fn get_str(&self, index: usize) -> Result<&str, ValueAccessError>
 
pub fn get_str(&self, index: usize) -> Result<&str, ValueAccessError>
Gets a reference to the string at the given index or returns an error if the value at that index isn’t a string.
sourcepub fn get_document(
    &self,
    index: usize,
) -> Result<&RawDocument, ValueAccessError>
 
pub fn get_document( &self, index: usize, ) -> Result<&RawDocument, ValueAccessError>
Gets a reference to the document at the given index or returns an error if the value at that index isn’t a document.
sourcepub fn get_array(&self, index: usize) -> Result<&RawArray, ValueAccessError>
 
pub fn get_array(&self, index: usize) -> Result<&RawArray, ValueAccessError>
Gets a reference to the array at the given index or returns an error if the value at that index isn’t a array.
sourcepub fn get_binary(
    &self,
    index: usize,
) -> Result<RawBinaryRef<'_>, ValueAccessError>
 
pub fn get_binary( &self, index: usize, ) -> Result<RawBinaryRef<'_>, ValueAccessError>
Gets a reference to the BSON binary value at the given index or returns an error if the value at that index isn’t a binary.
sourcepub fn get_object_id(&self, index: usize) -> Result<ObjectId, ValueAccessError>
 
pub fn get_object_id(&self, index: usize) -> Result<ObjectId, ValueAccessError>
Gets the ObjectId at the given index or returns an error if the value at that index isn’t an ObjectId.
sourcepub fn get_bool(&self, index: usize) -> Result<bool, ValueAccessError>
 
pub fn get_bool(&self, index: usize) -> Result<bool, ValueAccessError>
Gets the boolean at the given index or returns an error if the value at that index isn’t a boolean.
sourcepub fn get_datetime(&self, index: usize) -> Result<DateTime, ValueAccessError>
 
pub fn get_datetime(&self, index: usize) -> Result<DateTime, ValueAccessError>
Gets the DateTime at the given index or returns an error if the value at that index isn’t a DateTime.
sourcepub fn get_regex(
    &self,
    index: usize,
) -> Result<RawRegexRef<'_>, ValueAccessError>
 
pub fn get_regex( &self, index: usize, ) -> Result<RawRegexRef<'_>, ValueAccessError>
Gets a reference to the BSON regex at the given index or returns an error if the value at that index isn’t a regex.
sourcepub fn get_timestamp(&self, index: usize) -> Result<Timestamp, ValueAccessError>
 
pub fn get_timestamp(&self, index: usize) -> Result<Timestamp, ValueAccessError>
Gets a reference to the BSON timestamp at the given index or returns an error if the value at that index isn’t a timestamp.
sourcepub fn get_i32(&self, index: usize) -> Result<i32, ValueAccessError>
 
pub fn get_i32(&self, index: usize) -> Result<i32, ValueAccessError>
Gets the BSON int32 at the given index or returns an error if the value at that index isn’t a 32-bit integer.
Trait Implementations§
source§impl AsRef<RawArray> for RawArrayBuf
 
impl AsRef<RawArray> for RawArrayBuf
source§impl Borrow<RawArray> for RawArrayBuf
 
impl Borrow<RawArray> for RawArrayBuf
source§impl<'de, 'a> Deserialize<'de> for &'a RawArraywhere
    'de: 'a,
 
impl<'de, 'a> Deserialize<'de> for &'a RawArraywhere
    'de: 'a,
source§fn deserialize<D>(
    deserializer: D,
) -> Result<&'a RawArray, <D as Deserializer<'de>>::Error>where
    D: Deserializer<'de>,
 
fn deserialize<D>(
    deserializer: D,
) -> Result<&'a RawArray, <D as Deserializer<'de>>::Error>where
    D: Deserializer<'de>,
source§impl<'a> From<&'a RawArray> for RawBsonRef<'a>
 
impl<'a> From<&'a RawArray> for RawBsonRef<'a>
source§fn from(a: &'a RawArray) -> RawBsonRef<'a>
 
fn from(a: &'a RawArray) -> RawBsonRef<'a>
source§impl<'a> IntoIterator for &'a RawArray
 
impl<'a> IntoIterator for &'a RawArray
§type IntoIter = RawArrayIter<'a>
 
type IntoIter = RawArrayIter<'a>
§type Item = Result<RawBsonRef<'a>, Error>
 
type Item = Result<RawBsonRef<'a>, Error>
source§impl PartialEq for RawArray
 
impl PartialEq for RawArray
source§impl<'a> Serialize for &'a RawArray
 
impl<'a> Serialize for &'a RawArray
source§fn serialize<S>(
    &self,
    serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
    S: Serializer,
 
fn serialize<S>(
    &self,
    serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
    S: Serializer,
source§impl ToOwned for RawArray
 
impl ToOwned for RawArray
§type Owned = RawArrayBuf
 
type Owned = RawArrayBuf
source§fn to_owned(&self) -> <RawArray as ToOwned>::Owned
 
fn to_owned(&self) -> <RawArray as ToOwned>::Owned
1.63.0 · source§fn clone_into(&self, target: &mut Self::Owned)
 
fn clone_into(&self, target: &mut Self::Owned)
impl StructuralPartialEq for RawArray
Auto Trait Implementations§
impl Freeze for RawArray
impl RefUnwindSafe for RawArray
impl Send for RawArray
impl !Sized for RawArray
impl Sync for RawArray
impl Unpin for RawArray
impl UnwindSafe for RawArray
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Pipe for Twhere
    T: ?Sized,
 
impl<T> Pipe for Twhere
    T: ?Sized,
source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
 
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
self and passes that borrow into the pipe function. Read moresource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
self and passes that borrow into the pipe function. Read moresource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
 
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
source§fn pipe_borrow_mut<'a, B, R>(
    &'a mut self,
    func: impl FnOnce(&'a mut B) -> R,
) -> R
 
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
 
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
 
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
 
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.