gstreamer-rs/gstreamer-sdp/src/sdp_connection.rs
Sebastian Dröge 37bfb78fdc Change some assertions to debug assertions
These assertions can only trigger because of bugs in the bindings
implementation or in the C code and not because of bugs in calling code,
so using debug assertions is perfectly fine for them and reduces the
number of assertions inlined everywhere in release builds.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/-/merge_requests/1188>
2023-01-14 17:13:46 +02:00

107 lines
2.7 KiB
Rust

// Take a look at the license at the top of the repository in the LICENSE file.
use std::{ffi::CStr, fmt, mem};
use glib::translate::*;
#[repr(transparent)]
#[doc(alias = "GstSDPConnection")]
pub struct SDPConnection(pub(crate) ffi::GstSDPConnection);
unsafe impl Send for SDPConnection {}
unsafe impl Sync for SDPConnection {}
impl SDPConnection {
pub fn new(nettype: &str, addrtype: &str, address: &str, ttl: u32, addr_number: u32) -> Self {
assert_initialized_main_thread!();
unsafe {
let mut conn = mem::MaybeUninit::uninit();
ffi::gst_sdp_connection_set(
conn.as_mut_ptr(),
nettype.to_glib_none().0,
addrtype.to_glib_none().0,
address.to_glib_none().0,
ttl,
addr_number,
);
SDPConnection(conn.assume_init())
}
}
pub fn nettype(&self) -> Option<&str> {
unsafe {
if self.0.nettype.is_null() {
None
} else {
Some(CStr::from_ptr(self.0.nettype).to_str().unwrap())
}
}
}
pub fn addrtype(&self) -> Option<&str> {
unsafe {
if self.0.addrtype.is_null() {
None
} else {
Some(CStr::from_ptr(self.0.addrtype).to_str().unwrap())
}
}
}
pub fn address(&self) -> Option<&str> {
unsafe {
if self.0.address.is_null() {
None
} else {
Some(CStr::from_ptr(self.0.address).to_str().unwrap())
}
}
}
pub fn ttl(&self) -> u32 {
self.0.ttl
}
pub fn addr_number(&self) -> u32 {
self.0.addr_number
}
}
impl Clone for SDPConnection {
fn clone(&self) -> Self {
skip_assert_initialized!();
unsafe {
let mut conn = mem::MaybeUninit::uninit();
ffi::gst_sdp_connection_set(
conn.as_mut_ptr(),
self.0.nettype,
self.0.addrtype,
self.0.address,
self.0.ttl,
self.0.addr_number,
);
SDPConnection(conn.assume_init())
}
}
}
impl Drop for SDPConnection {
fn drop(&mut self) {
unsafe {
ffi::gst_sdp_connection_clear(&mut self.0);
}
}
}
impl fmt::Debug for SDPConnection {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
f.debug_struct("SDPConnection")
.field("nettype", &self.nettype())
.field("addrtype", &self.addrtype())
.field("address", &self.address())
.field("ttl", &self.ttl())
.field("addr_number", &self.addr_number())
.finish()
}
}