pub struct CacheConfig {
pub app_name: String,
pub cache_dir: PathBuf,
pub max_age: Duration,
pub max_entries: Option<usize>,
}Expand description
Configuration for the file cache system.
The cache directory defaults to the operating system’s cache folder
(e.g. %LOCALAPPDATA% on Windows, ~/Library/Caches on macOS,
$XDG_CACHE_HOME on Linux) joined with the application name.
On platforms where no cache directory can be determined (including
some Android configurations), std::env::temp_dir is used as
a fallback.
Fields§
§app_name: StringApplication name used to derive the manifest filename
("{app_name}.cache_manifest").
cache_dir: PathBufFilesystem directory for cache files and the manifest.
max_age: DurationMaximum age of an entry before it becomes eligible for cleanup at application exit.
max_entries: Option<usize>Maximum number of cache entries. None means unlimited.
Enforced at application exit — new entries are never rejected.
Implementations§
Source§impl CacheConfig
impl CacheConfig
Sourcepub fn new(app_name: &str) -> Self
pub fn new(app_name: &str) -> Self
Create a new config using the OS cache directory for the given app name.
Sourcepub fn manifest_file_name(&self) -> String
pub fn manifest_file_name(&self) -> String
Returns the manifest filename, e.g. "my_game.cache_manifest".
Sourcepub fn manifest_fs_path(&self) -> PathBuf
pub fn manifest_fs_path(&self) -> PathBuf
Filesystem path for the manifest, e.g.
<cache_dir>/my_game.cache_manifest.
Sourcepub fn ensure_cache_dir(&self) -> Result<(), Error>
pub fn ensure_cache_dir(&self) -> Result<(), Error>
Ensure the cache directory exists on disk.
Sourcepub fn validate_key(&self, key: &str) -> Result<(), CacheError>
pub fn validate_key(&self, key: &str) -> Result<(), CacheError>
Validate that a cache key is a safe relative path within the cache root. Forward-slash subpaths are allowed, but traversal, absolute paths, backslashes, empty segments, and manifest filename collisions are rejected.
Trait Implementations§
Source§impl Clone for CacheConfig
impl Clone for CacheConfig
Source§fn clone(&self) -> CacheConfig
fn clone(&self) -> CacheConfig
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for CacheConfig
impl Debug for CacheConfig
Source§impl Default for CacheConfig
impl Default for CacheConfig
impl Resource for CacheConfig
Auto Trait Implementations§
impl Freeze for CacheConfig
impl RefUnwindSafe for CacheConfig
impl Send for CacheConfig
impl Sync for CacheConfig
impl Unpin for CacheConfig
impl UnsafeUnpin for CacheConfig
impl UnwindSafe for CacheConfig
Blanket Implementations§
Source§impl<T, U> AsBindGroupShaderType<U> for T
impl<T, U> AsBindGroupShaderType<U> for T
Source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T ShaderType for self. When used in AsBindGroup
derives, it is safe to assume that all images in self exist.Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> FromWorld for Twhere
T: Default,
impl<T> FromWorld for Twhere
T: Default,
Source§fn from_world(_world: &mut World) -> T
fn from_world(_world: &mut World) -> T
Creates Self using default().
Source§impl<T, W> HasTypeWitness<W> for Twhere
W: MakeTypeWitness<Arg = T>,
T: ?Sized,
impl<T, W> HasTypeWitness<W> for Twhere
W: MakeTypeWitness<Arg = T>,
T: ?Sized,
Source§impl<T> Identity for Twhere
T: ?Sized,
impl<T> Identity for Twhere
T: ?Sized,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more