mirror of
https://github.com/ostreedev/ostree.git
synced 2025-02-27 01:57:49 +03:00
lib: clean up types for RepoCheckoutFilter
This commit is contained in:
parent
94b524b21f
commit
903bd86e52
@ -1,8 +1,7 @@
|
||||
use self::repo_checkout_filter::filter_trampoline;
|
||||
use glib::translate::{Stash, ToGlib, ToGlibPtr};
|
||||
use glib_sys::gpointer;
|
||||
use libc::c_char;
|
||||
use ostree_sys::{OstreeRepo, OstreeRepoCheckoutAtOptions, OstreeRepoCheckoutFilterResult};
|
||||
use ostree_sys::OstreeRepoCheckoutAtOptions;
|
||||
use std::path::{Path, PathBuf};
|
||||
use {Repo, RepoCheckoutFilterResult};
|
||||
use {RepoCheckoutMode, RepoCheckoutOverwriteMode};
|
||||
@ -24,7 +23,7 @@ pub struct RepoCheckoutAtOptions {
|
||||
pub force_copy_zerosized: bool,
|
||||
pub subpath: Option<PathBuf>,
|
||||
pub devino_to_csum_cache: Option<RepoDevInoCache>,
|
||||
pub filter: RepoCheckoutFilter,
|
||||
pub filter: Option<RepoCheckoutFilter>,
|
||||
pub sepolicy: Option<SePolicy>,
|
||||
pub sepolicy_prefix: Option<String>,
|
||||
}
|
||||
@ -81,18 +80,8 @@ impl<'a> ToGlibPtr<'a, *const OstreeRepoCheckoutAtOptions> for RepoCheckoutAtOpt
|
||||
options.sepolicy = sepolicy.0;
|
||||
|
||||
if let Some(filter) = &self.filter {
|
||||
options.filter_user_data = filter
|
||||
as *const Box<dyn Fn(&Repo, &Path, &libc::stat) -> RepoCheckoutFilterResult>
|
||||
as gpointer;
|
||||
options.filter = Some(
|
||||
filter_trampoline
|
||||
as unsafe extern "C" fn(
|
||||
*mut OstreeRepo,
|
||||
*const c_char,
|
||||
*mut libc::stat,
|
||||
gpointer,
|
||||
) -> OstreeRepoCheckoutFilterResult,
|
||||
);
|
||||
options.filter_user_data = filter as *const RepoCheckoutFilter as gpointer;
|
||||
options.filter = repo_checkout_filter::trampoline();
|
||||
}
|
||||
|
||||
Stash(options.as_ref(), (options, subpath, sepolicy_prefix))
|
||||
@ -184,24 +173,10 @@ mod tests {
|
||||
);
|
||||
assert_eq!((*ptr).unused_ints, [0; 6]);
|
||||
assert_eq!((*ptr).unused_ptrs, [ptr::null_mut(); 3]);
|
||||
assert_eq!(
|
||||
(*ptr).filter,
|
||||
Some(
|
||||
filter_trampoline
|
||||
as unsafe extern "C" fn(
|
||||
*mut OstreeRepo,
|
||||
*const c_char,
|
||||
*mut libc::stat,
|
||||
gpointer,
|
||||
)
|
||||
-> OstreeRepoCheckoutFilterResult
|
||||
)
|
||||
);
|
||||
assert_eq!((*ptr).filter, repo_checkout_filter::trampoline());
|
||||
assert_eq!(
|
||||
(*ptr).filter_user_data,
|
||||
options.filter.as_ref().unwrap()
|
||||
as *const Box<dyn Fn(&Repo, &Path, &libc::stat) -> RepoCheckoutFilterResult>
|
||||
as gpointer
|
||||
options.filter.as_ref().unwrap() as *const RepoCheckoutFilter as gpointer
|
||||
);
|
||||
assert_eq!((*ptr).sepolicy, options.sepolicy.to_glib_none().0);
|
||||
assert_eq!(
|
||||
|
@ -5,20 +5,29 @@ use libc::c_char;
|
||||
use ostree_sys::{OstreeRepo, OstreeRepoCheckoutFilterResult};
|
||||
use std::path::{Path, PathBuf};
|
||||
|
||||
pub type RepoCheckoutFilter =
|
||||
Option<Box<dyn Fn(&Repo, &Path, &libc::stat) -> RepoCheckoutFilterResult>>;
|
||||
pub type RepoCheckoutFilter = Box<dyn Fn(&Repo, &Path, &libc::stat) -> RepoCheckoutFilterResult>;
|
||||
|
||||
pub(super) unsafe extern "C" fn filter_trampoline(
|
||||
unsafe extern "C" fn filter_trampoline(
|
||||
repo: *mut OstreeRepo,
|
||||
path: *const c_char,
|
||||
stat: *mut libc::stat,
|
||||
user_data: gpointer,
|
||||
) -> OstreeRepoCheckoutFilterResult {
|
||||
// TODO: handle unwinding
|
||||
let closure =
|
||||
user_data as *const Box<dyn Fn(&Repo, &Path, &libc::stat) -> RepoCheckoutFilterResult>;
|
||||
let closure = user_data as *const RepoCheckoutFilter;
|
||||
let repo = FromGlibPtrNone::from_glib_none(repo);
|
||||
let path: PathBuf = FromGlibPtrNone::from_glib_none(path);
|
||||
let result = (*closure)(&repo, &path, &*stat);
|
||||
result.to_glib()
|
||||
}
|
||||
|
||||
pub(super) fn trampoline() -> Option<
|
||||
unsafe extern "C" fn(
|
||||
*mut OstreeRepo,
|
||||
*const c_char,
|
||||
*mut libc::stat,
|
||||
gpointer,
|
||||
) -> OstreeRepoCheckoutFilterResult,
|
||||
> {
|
||||
Some(filter_trampoline)
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user