fs_management::filesystem

Struct ServingMultiVolumeFilesystem

Source
pub struct ServingMultiVolumeFilesystem { /* private fields */ }
Expand description

Asynchronously manages a serving multivolume filesystem. Created from Filesystem::serve_multi_volume().

Implementations§

Source§

impl ServingMultiVolumeFilesystem

Source

pub fn volume(&self, volume: &str) -> Option<&ServingVolume>

Gets a reference to the given volume, if it’s already open.

Source

pub fn volume_mut(&mut self, volume: &str) -> Option<&mut ServingVolume>

Gets a mutable reference to the given volume, if it’s already open.

Source

pub fn close_volume(&mut self, volume: &str)

Source

pub async fn shutdown_volume(&mut self, volume: &str) -> Result<(), Error>

Attempts to shutdown the filesystem using the fidl_fuchsia_fs::AdminProxy::shutdown() FIDL method. Fails if the volume is not already open.

Source

pub async fn has_volume(&mut self, volume: &str) -> Result<bool, Error>

Returns whether the given volume exists.

Source

pub async fn create_volume( &mut self, volume: &str, create_options: CreateOptions, options: MountOptions, ) -> Result<&mut ServingVolume, Error>

Creates and mounts the volume. Fails if the volume already exists. If options.crypt is set, the volume will be encrypted using the provided Crypt instance. If options.as_blob is set, creates a blob volume that is mounted as a blob filesystem.

Source

pub async fn remove_volume(&mut self, volume: &str) -> Result<(), Error>

Deletes the volume. Fails if the volume is already mounted.

Source

pub async fn open_volume( &mut self, volume: &str, options: MountOptions, ) -> Result<&mut ServingVolume, Error>

Mounts an existing volume. Fails if the volume is already mounted or doesn’t exist. If crypt is set, the volume will be decrypted using the provided Crypt instance.

Source

pub async fn set_byte_limit( &self, volume: &str, byte_limit: u64, ) -> Result<(), Error>

Sets the max byte limit for a volume. Fails if the volume is not mounted.

Source

pub async fn check_volume( &mut self, volume: &str, crypt: Option<ClientEnd<CryptMarker>>, ) -> Result<(), Error>

Source

pub fn exposed_dir(&self) -> &DirectoryProxy

Provides access to the internal |exposed_dir| for use in testing callsites which need directory access.

Source

pub async fn shutdown(self) -> Result<(), ShutdownError>

Attempts to shutdown the filesystem using the fidl_fuchsia_fs::AdminProxy::shutdown() FIDL method.

§Errors

Returns Err if the shutdown failed.

Source

pub fn take_exposed_dir(self) -> DirectoryProxy

Take the exposed dir from this filesystem instance, dropping the management struct without shutting the filesystem down. This leaves the caller with the responsibility of shutting down the filesystem, and the filesystem component if necessary.

Trait Implementations§

Source§

impl Drop for ServingMultiVolumeFilesystem

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

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, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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.

§

impl<T> IntoAny for T
where T: 'static + Send + Sync,

§

fn into_any(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Cast the given object into a dyn std::any::Any.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
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