From d3f5ea435f06d889d986f21526273644241c9b87 Mon Sep 17 00:00:00 2001 From: Ben Sidhom Date: Sun, 3 Mar 2024 07:23:14 -0800 Subject: [PATCH] Pass byte slice as `root` to tree walk callback Fixes https://github.com/rust-lang/git2-rs/issues/1033. --- src/tree.rs | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/src/tree.rs b/src/tree.rs index ae8fe3b4c5..d22fadab35 100644 --- a/src/tree.rs +++ b/src/tree.rs @@ -119,7 +119,7 @@ impl<'repo> Tree<'repo> { /// [1]: https://libgit2.org/libgit2/#HEAD/group/tree/git_tree_walk pub fn walk(&self, mode: TreeWalkMode, mut callback: C) -> Result<(), Error> where - C: FnMut(&str, &TreeEntry<'_>) -> T, + C: FnMut(&[u8], &TreeEntry<'_>) -> T, T: Into, { unsafe { @@ -203,7 +203,7 @@ impl<'repo> Tree<'repo> { } } -type TreeWalkCb<'a, T> = dyn FnMut(&str, &TreeEntry<'_>) -> T + 'a; +type TreeWalkCb<'a, T> = dyn FnMut(&[u8], &TreeEntry<'_>) -> T + 'a; struct TreeWalkCbData<'a, T> { callback: &'a mut TreeWalkCb<'a, T>, @@ -215,10 +215,7 @@ extern "C" fn treewalk_cb>( payload: *mut c_void, ) -> c_int { match panic::wrap(|| unsafe { - let root = match CStr::from_ptr(root).to_str() { - Ok(value) => value, - _ => return -1, - }; + let root = CStr::from_ptr(root).to_bytes(); let entry = entry_from_raw_const(entry); let payload = &mut *(payload as *mut TreeWalkCbData<'_, T>); let callback = &mut payload.callback;