bevy_asset::io

Trait 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§