Sha256: 794332ee9e34cfad1e5fa03d168dfe90631423f9f3f9c9c3e634b7b0b06960b3

Contents?: true

Size: 1.75 KB

Versions: 13

Compression:

Stored size: 1.75 KB

Contents

//! A capability-based filesystem API modeled after [`std::fs`].
//!
//! This corresponds to [`std::fs`].
//!
//! Instead of [`std::fs`'s free functions] and [`std::fs::File`]'s
//! constructors which operate on bare paths, this crate has methods on [`Dir`]
//! which operate on paths which must be relative to the directory.
//!
//! Where `std` says "the filesystem", this API says "a filesystem", as
//! it doesn't assume that there's a single global filesystem namespace.
//!
//! Since all functions which expose raw file descriptors are `unsafe`,
//! I/O handles in this API are unforgeable (unsafe code notwithstanding).
//! This combined with a lack of absolute paths provides a natural
//! capability-based interface.
//!
//! This crate uses the existing `std::path::Path` rather than having its own
//! path type, however while `std::path::Path` is mostly just a pure datatype,
//! it includes aliases for several `std::fs` functions. To preserve the
//! capability-based interface, avoid using `std::path::Path`'s `canonicalize`,
//! `read_link`, `read_dir`, `metadata`, and `symlink_metadata` functions.
//!
//! [`std::fs`'s free functions]: https://doc.rust-lang.org/std/fs/#functions

mod dir;
mod dir_entry;
mod file;
mod read_dir;

pub use dir::Dir;
pub use dir_entry::DirEntry;
pub use file::File;
pub use read_dir::ReadDir;

// Re-export types from `cap_primitives`.
pub use cap_primitives::fs::{DirBuilder, FileType, Metadata, OpenOptions, Permissions};

// Re-export conditional types from `cap_primitives`.
#[cfg(any(unix, target_os = "vxworks", all(windows, windows_file_type_ext)))]
pub use cap_primitives::fs::FileTypeExt;
#[cfg(unix)]
pub use cap_primitives::fs::{DirBuilderExt, PermissionsExt};
pub use cap_primitives::fs::{FileExt, MetadataExt, OpenOptionsExt};

Version data entries

13 entries across 13 versions & 1 rubygems

Version Path
wasmtime-29.0.0 ./ext/cargo-vendor/cap-std-3.4.2/src/fs/mod.rs
wasmtime-28.0.0 ./ext/cargo-vendor/cap-std-3.4.2/src/fs/mod.rs
wasmtime-27.0.0 ./ext/cargo-vendor/cap-std-3.4.1/src/fs/mod.rs
wasmtime-26.0.0 ./ext/cargo-vendor/cap-std-3.3.0/src/fs/mod.rs
wasmtime-25.0.2 ./ext/cargo-vendor/cap-std-3.2.0/src/fs/mod.rs
wasmtime-25.0.1 ./ext/cargo-vendor/cap-std-3.2.0/src/fs/mod.rs
wasmtime-25.0.0 ./ext/cargo-vendor/cap-std-3.2.0/src/fs/mod.rs
wasmtime-24.0.0 ./ext/cargo-vendor/cap-std-3.2.0/src/fs/mod.rs
wasmtime-23.0.2 ./ext/cargo-vendor/cap-std-3.1.0/src/fs/mod.rs
wasmtime-22.0.0 ./ext/cargo-vendor/cap-std-3.1.0/src/fs/mod.rs
wasmtime-21.0.1 ./ext/cargo-vendor/cap-std-3.1.0/src/fs/mod.rs
wasmtime-20.0.2 ./ext/cargo-vendor/cap-std-3.1.0/src/fs/mod.rs
wasmtime-20.0.0 ./ext/cargo-vendor/cap-std-3.0.0/src/fs/mod.rs