Struct miri::shims::unix::fs::DirTable

source ·
pub struct DirTable {
    streams: FxHashMap<u64, OpenDir>,
    next_id: u64,
}
Expand description

The table of open directories. Curiously, Unix/POSIX does not unify this into the “file descriptor” concept… everything is a file, except a directory is not?

Fields§

§streams: FxHashMap<u64, OpenDir>

Directory iterators used to emulate libc “directory streams”, as used in opendir, readdir, and closedir.

When opendir is called, a directory iterator is created on the host for the target directory, and an entry is stored in this hash map, indexed by an ID which represents the directory stream. When readdir is called, the directory stream ID is used to look up the corresponding ReadDir iterator from this map, and information from the next directory entry is returned. When closedir is called, the ReadDir iterator is removed from the map.

§next_id: u64

ID number to be used by the next call to opendir

Implementations§

source§

impl DirTable

source

fn insert_new(&mut self, read_dir: ReadDir) -> u64

Trait Implementations§

source§

impl Debug for DirTable

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for DirTable

source§

fn default() -> DirTable

Returns the “default value” for a type. Read more
source§

impl VisitProvenance for DirTable

source§

fn visit_provenance(&self, visit: &mut VisitWith<'_>)

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 40 bytes