sheave_core/messages/stream_begin.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 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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
use std::io::Result as IOResult;
use crate::{
ByteBuffer,
Decoder,
Encoder,
messages::{
Channel,
ChunkData,
EventType,
UserControl,
headers::MessageType,
}
};
/// The event to tell that the stream is ready to a client.
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
pub struct StreamBegin(u32);
impl StreamBegin {
/// Constructs a StreamBegin event.
pub fn new(message_id: u32) -> Self {
Self(message_id)
}
/// Gets the message ID which this event has.
pub fn get_message_id(&self) -> u32 {
self.0
}
}
impl From<StreamBegin> for u32 {
fn from(stream_begin: StreamBegin) -> Self {
stream_begin.0
}
}
impl ChunkData for StreamBegin {
const CHANNEL: Channel = Channel::Network;
const MESSAGE_TYPE: MessageType = MessageType::UserControl;
}
impl UserControl for StreamBegin {
const EVENT_TYPE: EventType = EventType::StreamBegin;
}
impl Decoder<StreamBegin> for ByteBuffer {
/// Decodes bytes into a StreamBegin event.
///
/// # Errors
///
/// * [`InsufficientBufferLength`]
///
/// When some field misses.
///
/// # Examples
///
/// ```rust
/// use sheave_core::{
/// ByteBuffer,
/// Decoder,
/// Encoder,
/// messages::{
/// EventType,
/// StreamBegin
/// }
/// };
///
/// let mut buffer = ByteBuffer::default();
/// buffer.put_u32_be(u32::default());
/// assert!(Decoder::<StreamBegin>::decode(&mut buffer).is_ok());
///
/// let mut buffer = ByteBuffer::default();
/// assert!(Decoder::<StreamBegin>::decode(&mut buffer).is_err())
/// ```
///
/// [`InsufficientBufferLength`]: crate::byte_buffer::InsufficientBufferLength
fn decode(&mut self) -> IOResult<StreamBegin> {
self.get_u32_be().map(StreamBegin)
}
}
impl Encoder<StreamBegin> for ByteBuffer {
/// Encodes a StreamBegin event into bytes.
fn encode(&mut self, stream_begin: &StreamBegin) {
self.put_u32_be(stream_begin.get_message_id());
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn decode_stream_begin() {
let mut buffer = ByteBuffer::default();
buffer.put_u32_be(u32::default());
let result: IOResult<StreamBegin> = buffer.decode();
assert!(result.is_ok());
let actual = result.unwrap();
let expected = StreamBegin::new(u32::default());
assert_eq!(expected, actual)
}
#[test]
fn encode_stream_begin() {
let mut buffer = ByteBuffer::default();
let expected_message_id = u32::default();
let expected = StreamBegin::new(expected_message_id);
buffer.encode(&expected);
let actual_message_id = buffer.get_u32_be().unwrap();
assert_eq!(expected_message_id, actual_message_id)
}
}