rspack_core 0.7.11

rspack core
Documentation
// TODO add #[cfg(test)]
mod memory;

use std::{path::PathBuf, sync::Arc};

pub use memory::MemoryStorage;
use rspack_cacheable::{cacheable, utils::PortablePath, with::As};
use rspack_fs::IntermediateFileSystem;
pub use rspack_storage::Storage;
use rspack_storage::{BridgeFileSystem, PackStorage, PackStorageOptions};

/// Storage Options
///
/// This enum contains all of supported storage options.
/// Since MemoryStorage is only used in unit test, there is no need to add it here.
#[cacheable]
#[derive(Debug, Clone, Hash)]
pub enum StorageOptions {
  FileSystem {
    #[cacheable(with=As<PortablePath>)]
    directory: PathBuf,
  },
}

pub fn create_storage(
  options: StorageOptions,
  version: String,
  fs: Arc<dyn IntermediateFileSystem>,
) -> Arc<dyn Storage> {
  match options {
    StorageOptions::FileSystem { directory } => {
      let option = PackStorageOptions {
        temp_root: directory.join(".temp"),
        root: directory,
        clean: true,
        bucket_size: 20,
        pack_size: 500 * 1024,
        expire: 7 * 24 * 60 * 60 * 1000,
        fs: Arc::new(BridgeFileSystem(fs)),
        fresh_generation: Some(1),
        release_generation: Some(2),
        version,
      };
      Arc::new(PackStorage::new(option))
    }
  }
}