mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2024-09-27 06:20:05 +00:00
ea25c9262b
This commit adds `_if_some()` variants for builder field setters. The variants aim at improving usability when setting optional fields. E.g. currently, we need to write something like: ```rust let opt_value = ...; let mut sb = gst::Structure::builder("test") .field("mandatory_field", "mandatory"); if let Some(value) = opt_value sb = sb.field("optional_field", value); } let s = sb.build(); ``` With `_if_some()`, this can be written like this: ```rust let opt_value = ...; let s = gst::Structure::builder("test") .field("mandatory_field", "mandatory") .field_if_some("optional_field", opt_value) .build(); ``` Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/-/merge_requests/1424>
126 lines
3.3 KiB
Rust
126 lines
3.3 KiB
Rust
// Take a look at the license at the top of the repository in the LICENSE file.
|
|
|
|
use std::fmt;
|
|
|
|
use glib::{translate::*, SendValue};
|
|
|
|
gst::mini_object_wrapper!(RTSPToken, RTSPTokenRef, ffi::GstRTSPToken, || {
|
|
ffi::gst_rtsp_token_get_type()
|
|
});
|
|
|
|
impl RTSPToken {
|
|
#[doc(alias = "gst_rtsp_token_new_empty")]
|
|
pub fn new_empty() -> Self {
|
|
assert_initialized_main_thread!();
|
|
unsafe { from_glib_full(ffi::gst_rtsp_token_new_empty()) }
|
|
}
|
|
|
|
#[doc(alias = "gst_rtsp_token_new")]
|
|
pub fn builder() -> Builder {
|
|
skip_assert_initialized!();
|
|
Builder::new()
|
|
}
|
|
|
|
#[allow(clippy::should_implement_trait)]
|
|
pub fn from_iter(iter: impl IntoIterator<Item = (impl IntoGStr, SendValue)>) -> RTSPToken {
|
|
skip_assert_initialized!();
|
|
let mut token = RTSPToken::new_empty();
|
|
|
|
let s = token.get_mut().unwrap().structure_mut();
|
|
iter.into_iter().for_each(|(f, v)| s.set_value(f, v));
|
|
|
|
token
|
|
}
|
|
}
|
|
|
|
impl RTSPTokenRef {
|
|
#[doc(alias = "get_string")]
|
|
#[doc(alias = "gst_rtsp_token_get_string")]
|
|
pub fn string(&self, field: &str) -> Option<String> {
|
|
unsafe {
|
|
from_glib_none(ffi::gst_rtsp_token_get_string(
|
|
self.as_mut_ptr(),
|
|
field.to_glib_none().0,
|
|
))
|
|
}
|
|
}
|
|
|
|
#[doc(alias = "get_structure")]
|
|
#[doc(alias = "gst_rtsp_token_get_structure")]
|
|
pub fn structure(&self) -> Option<gst::Structure> {
|
|
unsafe { from_glib_none(ffi::gst_rtsp_token_get_structure(self.as_mut_ptr())) }
|
|
}
|
|
|
|
#[doc(alias = "gst_rtsp_token_is_allowed")]
|
|
pub fn is_allowed(&self, field: &str) -> bool {
|
|
unsafe {
|
|
from_glib(ffi::gst_rtsp_token_is_allowed(
|
|
self.as_mut_ptr(),
|
|
field.to_glib_none().0,
|
|
))
|
|
}
|
|
}
|
|
|
|
#[doc(alias = "get_mut_structure")]
|
|
pub fn structure_mut(&mut self) -> &mut gst::StructureRef {
|
|
unsafe {
|
|
let structure = ffi::gst_rtsp_token_writable_structure(self.as_mut_ptr());
|
|
gst::StructureRef::from_glib_borrow_mut(structure)
|
|
}
|
|
}
|
|
}
|
|
|
|
impl fmt::Debug for RTSPToken {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
RTSPTokenRef::fmt(self, f)
|
|
}
|
|
}
|
|
|
|
impl fmt::Debug for RTSPTokenRef {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
f.debug_struct("RTSPToken")
|
|
.field("structure", &self.structure())
|
|
.finish()
|
|
}
|
|
}
|
|
|
|
#[derive(Debug)]
|
|
#[must_use = "The builder must be built to be used"]
|
|
pub struct Builder {
|
|
token: RTSPToken,
|
|
}
|
|
|
|
impl Builder {
|
|
fn new() -> Self {
|
|
skip_assert_initialized!();
|
|
Builder {
|
|
token: RTSPToken::new_empty(),
|
|
}
|
|
}
|
|
|
|
pub fn field(mut self, name: impl IntoGStr, value: impl Into<glib::Value> + Send) -> Self {
|
|
self.token
|
|
.get_mut()
|
|
.unwrap()
|
|
.structure_mut()
|
|
.set(name, value);
|
|
self
|
|
}
|
|
|
|
pub fn field_if_some(
|
|
self,
|
|
name: impl IntoGStr,
|
|
value: Option<impl Into<glib::Value> + Send>,
|
|
) -> Self {
|
|
if let Some(value) = value {
|
|
self.field(name, value)
|
|
} else {
|
|
self
|
|
}
|
|
}
|
|
|
|
#[must_use = "Building the structure without using it has no effect"]
|
|
pub fn build(self) -> RTSPToken {
|
|
self.token
|
|
}
|
|
}
|