pub struct File<P: CheckedPermissions + MessageAllowed<CloseFile>> { /* private fields */ }Implementations§
Source§impl<P: CheckedPermissions + MessageAllowed<CloseFile>> File<P>
impl<P: CheckedPermissions + MessageAllowed<CloseFile>> File<P>
pub fn truncate(&mut self) -> Result<(), Error>where
P: MessageAllowed<TruncateFile>,
pub fn set_len(&mut self, len: u64) -> Result<(), Error>where
P: MessageAllowed<SetLen>,
pub fn metadata(&self) -> Result<Metadata, Error>where
P: MessageAllowed<GetMetadata>,
pub fn set_mtime(&mut self, datetime: DateTime) -> Result<(), Error>where
P: MessageAllowed<SetMtime>,
Sourcepub fn async_read(&mut self, read_len: usize) -> AsyncRead
pub fn async_read(&mut self, read_len: usize) -> AsyncRead
Prepare a message that can be sent with slint_keyos_platform::async_archive Less efficient than a regular read() May return less bytes than requested. Returns an empty buffer on EOF
Sourcepub fn async_write(&mut self, buffer: Vec<u8>) -> AsyncWrite
pub fn async_write(&mut self, buffer: Vec<u8>) -> AsyncWrite
Prepare a message that can be sent with slint_keyos_platform::async_archive Less efficient than a regular write() The actual bytes written is returned, may be less than the buffer size
Sourcepub fn async_copy_block_to(
&mut self,
to: &mut Self,
len: usize,
) -> AsyncCopyBlock
pub fn async_copy_block_to( &mut self, to: &mut Self, len: usize, ) -> AsyncCopyBlock
Prepare a message that can be sent with slint_keyos_platform::async_scalar Efficiently copies between two open files. Returns the numebr of actually copied bytes. Returns Ok(0) on EOF
pub fn copy_block_to(
&mut self,
to: &mut Self,
len: usize,
) -> Result<usize, Error>where
P: MessageAllowed<AsyncCopyBlock>,
pub fn overwrite(&mut self, buf: &[u8]) -> Result<(), Error>where
P: MessageAllowed<SeekFile> + MessageAllowed<WriteFile> + MessageAllowed<TruncateFile> + MessageAllowed<Flush>,
pub fn copy_to(&mut self, to: &mut Self) -> Result<(), Error>where
P: MessageAllowed<SeekFile> + MessageAllowed<WriteFile> + MessageAllowed<TruncateFile> + MessageAllowed<AsyncCopyBlock>,
Trait Implementations§
Source§impl<P: Debug + CheckedPermissions + MessageAllowed<CloseFile>> Debug for File<P>
impl<P: Debug + CheckedPermissions + MessageAllowed<CloseFile>> Debug for File<P>
Source§impl<P: CheckedPermissions + MessageAllowed<CloseFile>> Drop for File<P>
impl<P: CheckedPermissions + MessageAllowed<CloseFile>> Drop for File<P>
Source§impl<P> FileAdapter<P> for File<P>where
P: CheckedPermissions + MessageAllowed<CloseFile> + MessageAllowed<ReadFile> + MessageAllowed<WriteFile> + MessageAllowed<Flush> + MessageAllowed<SeekFile>,
impl<P> FileAdapter<P> for File<P>where
P: CheckedPermissions + MessageAllowed<CloseFile> + MessageAllowed<ReadFile> + MessageAllowed<WriteFile> + MessageAllowed<Flush> + MessageAllowed<SeekFile>,
fn metadata(&self) -> Result<Metadata, Error>where
P: MessageAllowed<GetMetadata>,
fn truncate(&mut self) -> Result<(), Error>where
P: MessageAllowed<TruncateFile>,
fn set_mtime(&mut self, datetime: DateTime) -> Result<(), Error>where
P: MessageAllowed<SetMtime>,
fn copy_block_to(&mut self, to: &mut Self, len: usize) -> Result<usize, Error>where
P: MessageAllowed<AsyncCopyBlock>,
Source§impl<P> Read for File<P>
impl<P> Read for File<P>
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
Pull some bytes from this source into the specified buffer, returning
how many bytes were read. Read more
1.36.0 · Source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
Like
read, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
Reads all bytes until EOF in this source, placing them into
buf. Read more1.0.0 · Source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
Reads all bytes until EOF in this source, appending them to
buf. Read more1.6.0 · Source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
Reads the exact number of bytes required to fill
buf. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf)Pull some bytes from this source into the specified buffer. Read more
Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf)Reads the exact number of bytes required to fill
cursor. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Creates a “by reference” adaptor for this instance of
Read. Read moreSource§impl<P> Seek for File<P>
impl<P> Seek for File<P>
Source§fn seek(&mut self, pos: SeekFrom) -> Result<u64>
fn seek(&mut self, pos: SeekFrom) -> Result<u64>
Seek to an offset, in bytes, in a stream. Read more
1.55.0 · Source§fn rewind(&mut self) -> Result<(), Error>
fn rewind(&mut self) -> Result<(), Error>
Rewind to the beginning of a stream. Read more
Source§fn stream_len(&mut self) -> Result<u64, Error>
fn stream_len(&mut self) -> Result<u64, Error>
🔬This is a nightly-only experimental API. (
seek_stream_len)Returns the length of this stream (in bytes). Read more
Source§impl<P> Write for File<P>where
P: MessageAllowed<WriteFile> + MessageAllowed<Flush> + CheckedPermissions + MessageAllowed<CloseFile>,
impl<P> Write for File<P>where
P: MessageAllowed<WriteFile> + MessageAllowed<Flush> + CheckedPermissions + MessageAllowed<CloseFile>,
Source§fn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Writes a buffer into this writer, returning how many bytes were written. Read more
Source§fn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Flushes this output stream, ensuring that all intermediately buffered
contents reach their destination. Read more
Source§fn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector)1.0.0 · Source§fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
Attempts to write an entire buffer into this writer. Read more
Source§fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
write_all_vectored)Attempts to write multiple buffers into this writer. Read more
Auto Trait Implementations§
impl<P> Freeze for File<P>
impl<P> RefUnwindSafe for File<P>
impl<P> Send for File<P>
impl<P> Sync for File<P>
impl<P> Unpin for File<P>
impl<P> UnwindSafe for File<P>
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.