use std::{borrow::Cow, cmp::min, io};
use saturating::Saturating as S;
use crate::{
binlog::{
consts::{BinlogVersion, EventType},
BinlogCtx, BinlogEvent, BinlogStruct,
},
io::ParseBuf,
misc::raw::{bytes::EofBytes, RawBytes, Skip},
proto::{MyDeserialize, MySerialize},
};
use super::BinlogEventHeader;
#[derive(Debug, Clone, Eq, PartialEq, Hash)]
pub struct RowsQueryEvent<'a> {
length: Skip<1>,
query: RawBytes<'a, EofBytes>,
}
impl<'a> RowsQueryEvent<'a> {
pub fn new(query: impl Into<Cow<'a, [u8]>>) -> Self {
Self {
length: Default::default(),
query: RawBytes::new(query),
}
}
pub fn query_raw(&'a self) -> &'a [u8] {
self.query.as_bytes()
}
pub fn query(&'a self) -> Cow<'a, str> {
self.query.as_str()
}
pub fn into_owned(self) -> RowsQueryEvent<'static> {
RowsQueryEvent {
length: self.length,
query: self.query.into_owned(),
}
}
}
impl<'de> MyDeserialize<'de> for RowsQueryEvent<'de> {
const SIZE: Option<usize> = None;
type Ctx = BinlogCtx<'de>;
fn deserialize(_ctx: Self::Ctx, buf: &mut ParseBuf<'de>) -> io::Result<Self> {
Ok(Self {
length: buf.parse(())?,
query: buf.parse(())?,
})
}
}
impl MySerialize for RowsQueryEvent<'_> {
fn serialize(&self, buf: &mut Vec<u8>) {
self.length.serialize(&mut *buf);
self.query.serialize(&mut *buf);
}
}
impl<'a> BinlogEvent<'a> for RowsQueryEvent<'a> {
const EVENT_TYPE: EventType = EventType::ROWS_QUERY_EVENT;
}
impl<'a> BinlogStruct<'a> for RowsQueryEvent<'a> {
fn len(&self, _version: BinlogVersion) -> usize {
let mut len = S(0);
len += S(1);
len += S(self.query.0.len());
min(len.0, u32::MAX as usize - BinlogEventHeader::LEN)
}
}