Skip to content

Commit

Permalink
gio: fix UnixSocketAddress constructor with a path
Browse files Browse the repository at this point in the history
as_os_str().len() does not return the number of bytes in the string, but
the full allocation size. Just pass -1 and let glib calculate the len.
  • Loading branch information
pbor committed Nov 2, 2023
1 parent 2cb10ec commit beda594
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 6 deletions.
39 changes: 35 additions & 4 deletions gio/src/unix_socket_address.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,16 +47,26 @@ impl UnixSocketAddress {

let type_ = address_type.to_type();
let (path, len) = match address_type {
Path(path) => (path.to_glib_none().0, path.as_os_str().len()),
Abstract(path) | AbstractPadded(path) => {
(path.to_glib_none().0 as *mut libc::c_char, path.len())
Path(path) => {
unsafe {
let p = std::ffi::CStr::from_ptr(path.to_glib_none().0);
panic!("{address_type:?} {p:?}");
}
(path.to_glib_none().0, -1)
}
Abstract(path) | AbstractPadded(path) => (
path.to_glib_none().0 as *mut libc::c_char,
path.len() as i32,
),
Anonymous => (ptr::null_mut(), 0),
};
unsafe {
let p = std::ffi::CStr::from_ptr(path);
panic!("{address_type:?} {p:?} {len}");

SocketAddress::from_glib_full(ffi::g_unix_socket_address_new_with_type(
path,
len as i32,
len,
type_.into_glib(),
))
.unsafe_cast()
Expand Down Expand Up @@ -97,3 +107,24 @@ pub trait UnixSocketAddressExtManual: sealed::Sealed + IsA<UnixSocketAddress> +
}

impl<O: IsA<UnixSocketAddress>> UnixSocketAddressExtManual for O {}

#[cfg(test)]
mod test {
use super::*;

// Check the actual path and len are correct and are not the underlying OsString
#[test]
fn check_path() {
let mut os_string = std::ffi::OsString::with_capacity(100);
os_string.push("/tmp/foo");
let path = os_string.as_ref();

let addr = UnixSocketAddress::new(path);
assert_eq!(addr.path_len(), 8);
assert_eq!(addr.path_as_array().unwrap().as_ref(), b"/tmp/foo");

let addr = UnixSocketAddress::with_type(UnixSocketAddressPath::Path(path));
assert_eq!(addr.path_len(), 8);
assert_eq!(addr.path_as_array().unwrap().as_ref(), b"/tmp/foo");
}
}
2 changes: 1 addition & 1 deletion gir
Submodule gir updated from 133ee1 to 2fd6d4

0 comments on commit beda594

Please sign in to comment.