asset_resolver/
chain.rs

1use std::path::PathBuf;
2
3use crate::AssetResolver;
4
5/// An asset resolver that chains sub-resolvers together to
6/// attempt to resolve a path using multiple ordered methods.
7pub struct ResolverChain {
8    resolvers: Vec<Box<dyn AssetResolver>>,
9}
10
11impl ResolverChain {
12    /// Construct a new resolver chain.
13    ///
14    /// # Example
15    /// ```
16    /// # use asset_resolver::*;
17    /// let resolver = ResolverChain::new(vec![
18    ///   Box::new(NullResolver),
19    ///   Box::new(DefaultResolver),
20    /// ]);
21    /// ```
22    pub fn new(resolvers: Vec<Box<dyn AssetResolver>>) -> Self {
23        Self { resolvers }
24    }
25}
26
27impl AssetResolver for ResolverChain {
28
29    /// Attempt to resolve a path using the resolvers in the chain.
30    /// 
31    /// # Example
32    /// ```
33    /// # use asset_resolver::*;
34    /// let resolver = ResolverChain::new(vec![
35    ///   Box::new(NullResolver),
36    ///   Box::new(DefaultResolver),
37    /// ]);
38    /// 
39    /// let path = resolver.resolve("/home/user/assets/test.png").unwrap();
40    /// assert_eq!(path.to_str().unwrap(), "/home/user/assets/test.png");
41    /// ```
42    fn resolve(&self, path: &str) -> Option<PathBuf> {
43        for resolver in &self.resolvers {
44            if let Some(path) = resolver.resolve(path) {
45                return Some(path);
46            }
47        }
48        None
49    }
50}
51