vortex_scalar/scalarvalue/
binary.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
use std::sync::Arc;

use vortex_buffer::ByteBuffer;
use vortex_error::{VortexError, VortexExpect, VortexResult};

use crate::scalarvalue::InnerScalarValue;
use crate::ScalarValue;

impl<'a> TryFrom<&'a ScalarValue> for ByteBuffer {
    type Error = VortexError;

    fn try_from(scalar: &'a ScalarValue) -> VortexResult<Self> {
        Ok(scalar
            .as_buffer()?
            .vortex_expect("Can't convert null scalar into a byte buffer"))
    }
}

impl<'a> TryFrom<&'a ScalarValue> for Option<ByteBuffer> {
    type Error = VortexError;

    fn try_from(scalar: &'a ScalarValue) -> VortexResult<Self> {
        scalar.as_buffer()
    }
}

impl From<&[u8]> for ScalarValue {
    fn from(value: &[u8]) -> Self {
        ScalarValue::from(ByteBuffer::from(value.to_vec()))
    }
}

impl From<ByteBuffer> for ScalarValue {
    fn from(value: ByteBuffer) -> Self {
        ScalarValue(InnerScalarValue::Buffer(Arc::new(value)))
    }
}