# `wasmer-cache` [data:image/s3,"s3://crabby-images/b9a00/b9a00e4ff67b36cdf0d8ce3e56fbc354cbbafb71" alt="Build Status"](https://github.com/wasmerio/wasmer/actions?query=workflow%3Abuild) [data:image/s3,"s3://crabby-images/fac6e/fac6e80368bc57d18716a45e4bff9ae8448ac9e7" alt="Join Wasmer Slack"](https://slack.wasmer.io) [data:image/s3,"s3://crabby-images/66425/664254495411fb09cd3a62a0c3e88fe1107f3a3d" alt="MIT License"](https://github.com/wasmerio/wasmer/blob/main/LICENSE)
The `wasmer-cache` crate allows to cache WebAssembly modules (of kind
`wasmer::Module`) in your system, so that next uses of the module does
imply a compilation time.
## Usage
The `Cache` trait represents a generic cache for storing and loading
compiled WebAssembly modules. The `FileSystemCache` type implements
`Cache` to store cache on the file system.
```rust
use wasmer::{DeserializeError, Module, SerializeError};
use wasmer_cache::{Cache, FileSystemCache, Hash};
fn store_module(module: &Module, bytes: &[u8]) -> Result<(), SerializeError> {
// Create a new file system cache.
let mut fs_cache = FileSystemCache::new("some/directory/goes/here")?;
// Compute a key for a given WebAssembly binary
let hash = Hash::generate(bytes);
// Store a module into the cache given a key
fs_cache.store(hash, module.clone())?;
Ok(())
}
```