src/pxar/fuse.rs: Refactor run_in_context and remove inode_to_offset and offset_to_inode
as their functionality is used only once so it makes more sense to keep them inline. Signed-off-by: Christian Ebner <c.ebner@proxmox.com>
This commit is contained in:
parent
8413083fc5
commit
ec04ea81f2
@ -27,6 +27,7 @@ use super::format_definition::PxarGoodbyeItem;
|
||||
/// required.
|
||||
const FUSE_ROOT_ID: u64 = 1;
|
||||
|
||||
const GOODBYE_ITEM_SIZE: u64 = std::mem::size_of::<PxarGoodbyeItem>() as u64;
|
||||
/// Callback function for `super::decoder::Decoder`.
|
||||
///
|
||||
/// At the moment, this is only needed to satisfy the `SequentialDecoder`.
|
||||
@ -252,47 +253,19 @@ impl Drop for Session {
|
||||
}
|
||||
}
|
||||
|
||||
const GOODBYE_ITEM_SIZE: u64 = std::mem::size_of::<PxarGoodbyeItem>() as u64;
|
||||
|
||||
/// Converts the inode to the file offset
|
||||
///
|
||||
/// Since the inodes are defined as the file offset,
|
||||
/// this simply returns the inode value.
|
||||
/// The only exception to this is the inode of root,
|
||||
/// which is defined as `FUSE_ROOT_ID` by libfuse and therefore mapped
|
||||
/// to the roots goodbye table tail.
|
||||
fn inode_to_offset(inode: u64, root_end: u64) -> u64 {
|
||||
if inode == FUSE_ROOT_ID {
|
||||
root_end - GOODBYE_ITEM_SIZE
|
||||
} else {
|
||||
inode
|
||||
}
|
||||
}
|
||||
|
||||
/// Converts the file offset to an inode
|
||||
///
|
||||
/// Since the inodes are defined as the file offset,
|
||||
/// this simply returns the offset value.
|
||||
/// The only exception to this is the inode of root,
|
||||
/// which is defined as `FUSE_ROOT_ID` by libfuse, so the roots goodbye tail
|
||||
/// offset gets mapped to `FUSE_ROOT_ID`.
|
||||
pub(crate) fn offset_to_inode(offset: u64, root_end: u64) -> u64 {
|
||||
if offset == root_end - GOODBYE_ITEM_SIZE {
|
||||
FUSE_ROOT_ID
|
||||
} else {
|
||||
offset
|
||||
}
|
||||
}
|
||||
|
||||
/// Creates a context providing an exclusive mutable reference to the decoder.
|
||||
///
|
||||
/// Each callback function needing access to the decoder can easily get an
|
||||
/// exclusive handle by running the code inside this context.
|
||||
/// Responses with error code can easily be generated by returning with the
|
||||
/// error code.
|
||||
fn run_in_context<F>(req: Request, code: F)
|
||||
/// The error code will be used to reply to libfuse.
|
||||
fn run_in_context<F>(req: Request, inode: u64, code: F)
|
||||
where
|
||||
F: FnOnce(&mut Decoder<BufReader<File>, fn(&Path) -> Result<(), Error>>) -> Result<(), i32>,
|
||||
F: FnOnce(
|
||||
&mut Decoder<BufReader<File>, fn(&Path) -> Result<(), Error>>,
|
||||
u64,
|
||||
) -> Result<(), i32>,
|
||||
{
|
||||
let ptr = unsafe {
|
||||
fuse_req_userdata(req)
|
||||
@ -301,8 +274,14 @@ where
|
||||
let boxed_decoder = unsafe { Box::from_raw(ptr) };
|
||||
let result = boxed_decoder
|
||||
.lock()
|
||||
.map(|mut decoder| code(&mut decoder))
|
||||
.unwrap_or(Err(libc::ENOENT));
|
||||
.map(|mut decoder| {
|
||||
let ino_offset = match inode {
|
||||
FUSE_ROOT_ID => decoder.root_end_offset() - GOODBYE_ITEM_SIZE,
|
||||
_ => inode,
|
||||
};
|
||||
code(&mut decoder, ino_offset)
|
||||
})
|
||||
.unwrap_or(Err(libc::EIO));
|
||||
|
||||
if let Err(err) = result {
|
||||
unsafe {
|
||||
@ -327,48 +306,48 @@ extern "C" fn destroy(decoder: MutPtr) {
|
||||
}
|
||||
}
|
||||
|
||||
extern "C" fn lookup(req: Request, _parent: u64, _name: StrPtr) {
|
||||
run_in_context(req, |_decoder| {
|
||||
extern "C" fn lookup(req: Request, parent: u64, _name: StrPtr) {
|
||||
run_in_context(req, parent, |_decoder, _ino_offset| {
|
||||
// code goes here
|
||||
|
||||
Err(libc::ENOENT)
|
||||
});
|
||||
}
|
||||
|
||||
extern "C" fn getattr(req: Request, _inode: u64, _fileinfo: MutPtr) {
|
||||
run_in_context(req, |_decoder| {
|
||||
extern "C" fn getattr(req: Request, inode: u64, _fileinfo: MutPtr) {
|
||||
run_in_context(req, inode, |_decoder, _ino_offset| {
|
||||
// code goes here
|
||||
|
||||
Err(libc::ENOENT)
|
||||
});
|
||||
}
|
||||
|
||||
extern "C" fn open(req: Request, _inode: u64, _fileinfo: MutPtr) {
|
||||
run_in_context(req, |_decoder| {
|
||||
extern "C" fn open(req: Request, inode: u64, _fileinfo: MutPtr) {
|
||||
run_in_context(req, inode, |_decoder, _ino_offset| {
|
||||
// code goes here
|
||||
|
||||
Err(libc::ENOENT)
|
||||
});
|
||||
}
|
||||
|
||||
extern "C" fn read(req: Request, _inode: u64, _size: size_t, _offset: c_int, _fileinfo: MutPtr) {
|
||||
run_in_context(req, |_decoder| {
|
||||
extern "C" fn read(req: Request, inode: u64, _size: size_t, _offset: c_int, _fileinfo: MutPtr) {
|
||||
run_in_context(req, inode, |_decoder, _ino_offset| {
|
||||
// code goes here
|
||||
|
||||
Err(libc::ENOENT)
|
||||
});
|
||||
}
|
||||
|
||||
extern "C" fn opendir(req: Request, _inode: u64, _fileinfo: MutPtr) {
|
||||
run_in_context(req, |_decoder| {
|
||||
extern "C" fn opendir(req: Request, inode: u64, _fileinfo: MutPtr) {
|
||||
run_in_context(req, inode, |_decoder, _ino_offset| {
|
||||
// code goes here
|
||||
|
||||
Err(libc::ENOENT)
|
||||
});
|
||||
}
|
||||
|
||||
extern "C" fn readdir(req: Request, _inode: u64, _size: size_t, _offset: c_int, _fileinfo: MutPtr) {
|
||||
run_in_context(req, |_decoder| {
|
||||
extern "C" fn readdir(req: Request, inode: u64, _size: size_t, _offset: c_int, _fileinfo: MutPtr) {
|
||||
run_in_context(req, inode, |_decoder, _ino_offset| {
|
||||
// code goes here
|
||||
|
||||
Err(libc::ENOENT)
|
||||
|
Loading…
Reference in New Issue
Block a user