Trait FileExt
trait FileExt
Windows-specific extensions to fs::File.
Required Methods
fn seek_read(self: &Self, buf: &mut [u8], offset: u64) -> io::Result<usize>Seeks to a given position and reads a number of bytes.
Returns the number of bytes read.
The offset is relative to the start of the file and thus independent from the current cursor. The current cursor is affected by this function, it is set to the end of the read.
Reading beyond the end of the file will always return with a length of 0.
Note that similar to
File::read, it is not an error to return with a short read. When returning from such a short read, the file pointer is still updated.Examples
use std::io; use std::fs::File; use std::os::windows::prelude::*; fn main() -> io::Result<()> { let mut file = File::open("foo.txt")?; let mut buffer = [0; 10]; // Read 10 bytes, starting 72 bytes from the // start of the file. file.seek_read(&mut buffer[..], 72)?; Ok(()) }fn seek_write(self: &Self, buf: &[u8], offset: u64) -> io::Result<usize>Seeks to a given position and writes a number of bytes.
Returns the number of bytes written.
The offset is relative to the start of the file and thus independent from the current cursor. The current cursor is affected by this function, it is set to the end of the write.
When writing beyond the end of the file, the file is appropriately extended and the intermediate bytes are set to zero.
Note that similar to
File::write, it is not an error to return a short write. When returning from such a short write, the file pointer is still updated.Examples
use std::fs::File; use std::os::windows::prelude::*; fn main() -> std::io::Result<()> { let mut buffer = File::create("foo.txt")?; // Write a byte string starting 72 bytes from // the start of the file. buffer.seek_write(b"some bytes", 72)?; Ok(()) }
Provided Methods
fn seek_read_buf(self: &Self, buf: BorrowedCursor<'_>, offset: u64) -> io::Result<()>Seeks to a given position and reads some bytes into the buffer.
This is equivalent to the
seek_readmethod, except that it is passed aBorrowedCursorrather than&mut [u8]to allow use with uninitialized buffers. The new data will be appended to any existing contents ofbuf.Reading beyond the end of the file will always succeed without reading any bytes.
Examples
#![feature(core_io_borrowed_buf)] #![feature(read_buf_at)] use std::io; use std::io::BorrowedBuf; use std::fs::File; use std::mem::MaybeUninit; use std::os::windows::prelude::*; fn main() -> io::Result<()> { let mut file = File::open("pi.txt")?; // Read some bytes starting from offset 2 let mut buf: [MaybeUninit<u8>; 10] = [MaybeUninit::uninit(); 10]; let mut buf = BorrowedBuf::from(buf.as_mut_slice()); file.seek_read_buf(buf.unfilled(), 2)?; assert!(buf.filled().starts_with(b"1")); Ok(()) }
Implementors
impl FileExt for fs::File