rspack_core 0.100.1

rspack core
Documentation
use rspack_cacheable::{cacheable, cacheable_dyn};

use super::{AffectType, FactorizeInfo};
use crate::{
  AsContextDependency, AsDependencyCodeGeneration, Context, Dependency, DependencyCategory,
  DependencyId, DependencyType, ModuleDependency,
};

#[cacheable]
#[derive(Debug, Clone)]
pub struct LoaderImportDependency {
  id: DependencyId,
  context: Context,
  request: String,
  factorize_info: FactorizeInfo,
}

impl LoaderImportDependency {
  pub fn new(request: String, context: Context) -> Self {
    Self {
      request,
      context,
      id: DependencyId::new(),
      factorize_info: Default::default(),
    }
  }
}

impl PartialEq for LoaderImportDependency {
  fn eq(&self, other: &Self) -> bool {
    self.id == other.id && self.context == other.context && self.request == other.request
  }
}

impl Eq for LoaderImportDependency {}

impl std::hash::Hash for LoaderImportDependency {
  fn hash<H: std::hash::Hasher>(&self, state: &mut H) {
    self.id.hash(state);
    self.context.hash(state);
    self.request.hash(state);
  }
}

impl AsDependencyCodeGeneration for LoaderImportDependency {}
impl AsContextDependency for LoaderImportDependency {}

#[cacheable_dyn]
impl Dependency for LoaderImportDependency {
  fn id(&self) -> &DependencyId {
    &self.id
  }

  fn get_context(&self) -> Option<&Context> {
    Some(&self.context)
  }

  fn category(&self) -> &DependencyCategory {
    &DependencyCategory::LoaderImport
  }

  fn dependency_type(&self) -> &DependencyType {
    &DependencyType::LoaderImport
  }

  fn could_affect_referencing_module(&self) -> AffectType {
    AffectType::True
  }
}

#[cacheable_dyn]
impl ModuleDependency for LoaderImportDependency {
  fn request(&self) -> &str {
    &self.request
  }

  fn user_request(&self) -> &str {
    &self.request
  }

  fn factorize_info(&self) -> &FactorizeInfo {
    &self.factorize_info
  }

  fn factorize_info_mut(&mut self) -> &mut FactorizeInfo {
    &mut self.factorize_info
  }
}