nix::fcntl

Function copy_file_range

Source
pub fn copy_file_range(
    fd_in: RawFd,
    off_in: Option<&mut loff_t>,
    fd_out: RawFd,
    off_out: Option<&mut loff_t>,
    len: usize,
) -> Result<usize>
Expand description

Copy a range of data from one file to another

The copy_file_range system call performs an in-kernel copy between file descriptors fd_in and fd_out without the additional cost of transferring data from the kernel to user space and then back into the kernel. It copies up to len bytes of data from file descriptor fd_in to file descriptor fd_out, overwriting any data that exists within the requested range of the target file.

If the off_in and/or off_out arguments are used, the values will be mutated to reflect the new position within the file after copying. If they are not used, the relevant filedescriptors will be seeked to the new position.

On successful completion the number of bytes actually copied will be returned.