Trait bevy_asset::io::ErasedAssetWriter

source ·
pub trait ErasedAssetWriter: Send + Sync + 'static {
    // Required methods
    fn write<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<Box<Writer>, AssetWriterError>>;
    fn write_meta<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<Box<Writer>, AssetWriterError>>;
    fn remove<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn remove_meta<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn rename<'a>(
        &'a self,
        old_path: &'a Path,
        new_path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn rename_meta<'a>(
        &'a self,
        old_path: &'a Path,
        new_path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn remove_directory<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn remove_empty_directory<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn remove_assets_in_directory<'a>(
        &'a self,
        path: &'a Path
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn write_bytes<'a>(
        &'a self,
        path: &'a Path,
        bytes: &'a [u8]
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
    fn write_meta_bytes<'a>(
        &'a self,
        path: &'a Path,
        bytes: &'a [u8]
    ) -> BoxedFuture<'_, Result<(), AssetWriterError>>;
}
Expand description

Equivalent to an AssetWriter but using boxed futures, necessary eg. when using a dyn AssetWriter, as AssetWriter isn’t currently object safe.

Required Methods§

source

fn write<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<Box<Writer>, AssetWriterError>>

Writes the full asset bytes at the provided path.

source

fn write_meta<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<Box<Writer>, AssetWriterError>>

Writes the full asset meta bytes at the provided path. This should not include storage specific extensions like .meta.

source

fn remove<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Removes the asset stored at the given path.

source

fn remove_meta<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Removes the asset meta stored at the given path. This should not include storage specific extensions like .meta.

source

fn rename<'a>( &'a self, old_path: &'a Path, new_path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Renames the asset at old_path to new_path

source

fn rename_meta<'a>( &'a self, old_path: &'a Path, new_path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Renames the asset meta for the asset at old_path to new_path. This should not include storage specific extensions like .meta.

source

fn remove_directory<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Removes the directory at the given path, including all assets and directories in that directory.

source

fn remove_empty_directory<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Removes the directory at the given path, but only if it is completely empty. This will return an error if the directory is not empty.

source

fn remove_assets_in_directory<'a>( &'a self, path: &'a Path ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Removes all assets (and directories) in this directory, resulting in an empty directory.

source

fn write_bytes<'a>( &'a self, path: &'a Path, bytes: &'a [u8] ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Writes the asset bytes to the given path.

source

fn write_meta_bytes<'a>( &'a self, path: &'a Path, bytes: &'a [u8] ) -> BoxedFuture<'_, Result<(), AssetWriterError>>

Writes the asset meta bytes to the given path.

Implementors§