vortex_scalar/scalar_value/
binary.rs

1use std::sync::Arc;
2
3use vortex_buffer::ByteBuffer;
4use vortex_error::{VortexError, VortexExpect, VortexResult};
5
6use crate::ScalarValue;
7use crate::scalar_value::InnerScalarValue;
8
9impl<'a> TryFrom<&'a ScalarValue> for ByteBuffer {
10    type Error = VortexError;
11
12    fn try_from(scalar: &'a ScalarValue) -> VortexResult<Self> {
13        Ok(scalar
14            .as_buffer()?
15            .vortex_expect("Can't convert null scalar into a byte buffer")
16            .as_ref()
17            .clone())
18    }
19}
20
21impl<'a> TryFrom<&'a ScalarValue> for Option<ByteBuffer> {
22    type Error = VortexError;
23
24    fn try_from(scalar: &'a ScalarValue) -> VortexResult<Self> {
25        Ok(scalar.as_buffer()?.as_ref().map(|b| b.as_ref().clone()))
26    }
27}
28
29impl From<&[u8]> for ScalarValue {
30    fn from(value: &[u8]) -> Self {
31        ScalarValue::from(ByteBuffer::from(value.to_vec()))
32    }
33}
34
35impl From<ByteBuffer> for ScalarValue {
36    fn from(value: ByteBuffer) -> Self {
37        ScalarValue(InnerScalarValue::Buffer(Arc::new(value)))
38    }
39}