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 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
use std::borrow::Cow; use crate::decode::Decode; use crate::encode::{Encode, IsNull}; use crate::error::BoxDynError; use crate::sqlite::type_info::DataType; use crate::sqlite::{Sqlite, SqliteArgumentValue, SqliteTypeInfo, SqliteValueRef}; use crate::types::Type; impl Type<Sqlite> for [u8] { fn type_info() -> SqliteTypeInfo { SqliteTypeInfo(DataType::Blob) } fn compatible(ty: &SqliteTypeInfo) -> bool { matches!(ty.0, DataType::Blob | DataType::Text) } } impl<'q> Encode<'q, Sqlite> for &'q [u8] { fn encode_by_ref(&self, args: &mut Vec<SqliteArgumentValue<'q>>) -> IsNull { args.push(SqliteArgumentValue::Blob(Cow::Borrowed(self))); IsNull::No } } impl<'r> Decode<'r, Sqlite> for &'r [u8] { fn decode(value: SqliteValueRef<'r>) -> Result<Self, BoxDynError> { Ok(value.blob()) } } impl Type<Sqlite> for Vec<u8> { fn type_info() -> SqliteTypeInfo { <&[u8] as Type<Sqlite>>::type_info() } fn compatible(ty: &SqliteTypeInfo) -> bool { <&[u8] as Type<Sqlite>>::compatible(ty) } } impl<'q> Encode<'q, Sqlite> for Vec<u8> { fn encode(self, args: &mut Vec<SqliteArgumentValue<'q>>) -> IsNull { args.push(SqliteArgumentValue::Blob(Cow::Owned(self))); IsNull::No } fn encode_by_ref(&self, args: &mut Vec<SqliteArgumentValue<'q>>) -> IsNull { args.push(SqliteArgumentValue::Blob(Cow::Owned(self.clone()))); IsNull::No } } impl<'r> Decode<'r, Sqlite> for Vec<u8> { fn decode(value: SqliteValueRef<'r>) -> Result<Self, BoxDynError> { Ok(value.blob().to_owned()) } }