vortex_scalar/scalarvalue/
binary.rs1use std::sync::Arc;
2
3use vortex_buffer::ByteBuffer;
4use vortex_error::{VortexError, VortexExpect, VortexResult};
5
6use crate::ScalarValue;
7use crate::scalarvalue::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 }
17}
18
19impl<'a> TryFrom<&'a ScalarValue> for Option<ByteBuffer> {
20 type Error = VortexError;
21
22 fn try_from(scalar: &'a ScalarValue) -> VortexResult<Self> {
23 scalar.as_buffer()
24 }
25}
26
27impl From<&[u8]> for ScalarValue {
28 fn from(value: &[u8]) -> Self {
29 ScalarValue::from(ByteBuffer::from(value.to_vec()))
30 }
31}
32
33impl From<ByteBuffer> for ScalarValue {
34 fn from(value: ByteBuffer) -> Self {
35 ScalarValue(InnerScalarValue::Buffer(Arc::new(value)))
36 }
37}