rspack_core 0.7.11

rspack core
Documentation
use std::sync::atomic::AtomicU32;

use rspack_collections::{Ukey, impl_item_ukey};
#[cfg(allocative)]
use rspack_util::allocative;

use crate::{Chunk, ChunkGroup};

static NEXT_CHUNK_UKEY: AtomicU32 = AtomicU32::new(0);

#[rspack_cacheable::cacheable]
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
pub struct ChunkUkey(Ukey, std::marker::PhantomData<Chunk>);

impl_item_ukey!(ChunkUkey);

impl Default for ChunkUkey {
  fn default() -> Self {
    Self::new()
  }
}

impl ChunkUkey {
  pub fn new() -> Self {
    Self(
      NEXT_CHUNK_UKEY
        .fetch_add(1, std::sync::atomic::Ordering::Relaxed)
        .into(),
      std::marker::PhantomData,
    )
  }

  pub fn as_u32(&self) -> u32 {
    self.0.as_u32()
  }
}

impl From<u32> for ChunkUkey {
  fn from(value: u32) -> Self {
    Self(value.into(), std::marker::PhantomData)
  }
}

static NEXT_CHUNK_GROUP_UKEY: AtomicU32 = AtomicU32::new(0);

#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(allocative, derive(allocative::Allocative))]
pub struct ChunkGroupUkey(Ukey, std::marker::PhantomData<ChunkGroup>);

impl_item_ukey!(ChunkGroupUkey);

impl Default for ChunkGroupUkey {
  fn default() -> Self {
    Self::new()
  }
}

impl ChunkGroupUkey {
  pub fn new() -> Self {
    Self(
      NEXT_CHUNK_GROUP_UKEY
        .fetch_add(1, std::sync::atomic::Ordering::Relaxed)
        .into(),
      std::marker::PhantomData::default(),
    )
  }

  pub fn as_u32(&self) -> u32 {
    self.0.as_u32()
  }
}

impl From<u32> for ChunkGroupUkey {
  fn from(value: u32) -> Self {
    Self(value.into(), std::marker::PhantomData)
  }
}