Struct cargo::util::Filesystem
source · [−]pub struct Filesystem { /* private fields */ }
Expand description
A “filesystem” is intended to be a globally shared, hence locked, resource in Cargo.
The Path
of a filesystem cannot be learned unless it’s done in a locked
fashion, and otherwise functions on this structure are prepared to handle
concurrent invocations across multiple instances of Cargo.
Implementations
sourceimpl Filesystem
impl Filesystem
sourcepub fn new(path: PathBuf) -> Filesystem
pub fn new(path: PathBuf) -> Filesystem
Creates a new filesystem to be rooted at the given path.
sourcepub fn join<T: AsRef<Path>>(&self, other: T) -> Filesystem
pub fn join<T: AsRef<Path>>(&self, other: T) -> Filesystem
Like Path::join
, creates a new filesystem rooted at this filesystem
joined with the given path.
sourcepub fn push<T: AsRef<Path>>(&mut self, other: T)
pub fn push<T: AsRef<Path>>(&mut self, other: T)
Like Path::push
, pushes a new path component onto this filesystem.
sourcepub fn into_path_unlocked(self) -> PathBuf
pub fn into_path_unlocked(self) -> PathBuf
Consumes this filesystem and returns the underlying PathBuf
.
Note that this is a relatively dangerous operation and should be used with great caution!.
sourcepub fn as_path_unlocked(&self) -> &Path
pub fn as_path_unlocked(&self) -> &Path
Returns the underlying Path
.
Note that this is a relatively dangerous operation and should be used with great caution!.
sourcepub fn create_dir(&self) -> CargoResult<()>
pub fn create_dir(&self) -> CargoResult<()>
Creates the directory pointed to by this filesystem.
Handles errors where other Cargo processes are also attempting to concurrently create this directory.
sourcepub fn display(&self) -> Display<'_>
pub fn display(&self) -> Display<'_>
Returns an adaptor that can be used to print the path of this filesystem.
sourcepub fn open_rw<P>(
&self,
path: P,
config: &Config,
msg: &str
) -> CargoResult<FileLock> where
P: AsRef<Path>,
pub fn open_rw<P>(
&self,
path: P,
config: &Config,
msg: &str
) -> CargoResult<FileLock> where
P: AsRef<Path>,
Opens exclusive access to a file, returning the locked version of a file.
This function will create a file at path
if it doesn’t already exist
(including intermediate directories), and then it will acquire an
exclusive lock on path
. If the process must block waiting for the
lock, the msg
is printed to config
.
The returned file can be accessed to look at the path and also has read/write access to the underlying file.
sourcepub fn open_ro<P>(
&self,
path: P,
config: &Config,
msg: &str
) -> CargoResult<FileLock> where
P: AsRef<Path>,
pub fn open_ro<P>(
&self,
path: P,
config: &Config,
msg: &str
) -> CargoResult<FileLock> where
P: AsRef<Path>,
Opens shared access to a file, returning the locked version of a file.
This function will fail if path
doesn’t already exist, but if it does
then it will acquire a shared lock on path
. If the process must block
waiting for the lock, the msg
is printed to config
.
The returned file can be accessed to look at the path and also has read access to the underlying file. Any writes to the file will return an error.
Trait Implementations
sourceimpl Clone for Filesystem
impl Clone for Filesystem
sourcefn clone(&self) -> Filesystem
fn clone(&self) -> Filesystem
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl Debug for Filesystem
impl Debug for Filesystem
sourceimpl PartialEq<Filesystem> for Path
impl PartialEq<Filesystem> for Path
Auto Trait Implementations
impl RefUnwindSafe for Filesystem
impl Send for Filesystem
impl Sync for Filesystem
impl Unpin for Filesystem
impl UnwindSafe for Filesystem
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more