use crate::{InputStream, PollableInputStream, Seekable};
use glib::{prelude::*, translate::*};
glib::wrapper! {
#[doc(alias = "GMemoryInputStream")]
pub struct MemoryInputStream(Object<ffi::GMemoryInputStream, ffi::GMemoryInputStreamClass>) @extends InputStream, @implements PollableInputStream, Seekable;
match fn {
type_ => || ffi::g_memory_input_stream_get_type(),
}
}
impl MemoryInputStream {
pub const NONE: Option<&'static MemoryInputStream> = None;
#[doc(alias = "g_memory_input_stream_new")]
pub fn new() -> MemoryInputStream {
unsafe { InputStream::from_glib_full(ffi::g_memory_input_stream_new()).unsafe_cast() }
}
#[doc(alias = "g_memory_input_stream_new_from_bytes")]
#[doc(alias = "new_from_bytes")]
pub fn from_bytes(bytes: &glib::Bytes) -> MemoryInputStream {
unsafe {
InputStream::from_glib_full(ffi::g_memory_input_stream_new_from_bytes(
bytes.to_glib_none().0,
))
.unsafe_cast()
}
}
}
impl Default for MemoryInputStream {
fn default() -> Self {
Self::new()
}
}
mod sealed {
pub trait Sealed {}
impl<T: super::IsA<super::MemoryInputStream>> Sealed for T {}
}
pub trait MemoryInputStreamExt: IsA<MemoryInputStream> + sealed::Sealed + 'static {
#[doc(alias = "g_memory_input_stream_add_bytes")]
fn add_bytes(&self, bytes: &glib::Bytes) {
unsafe {
ffi::g_memory_input_stream_add_bytes(
self.as_ref().to_glib_none().0,
bytes.to_glib_none().0,
);
}
}
}
impl<O: IsA<MemoryInputStream>> MemoryInputStreamExt for O {}