mirror of
https://github.com/astral-sh/uv.git
synced 2025-07-16 17:55:01 +00:00

## Summary Brings more consistency to the repo and ensures that all crates automatically show up in `--verbose` logging.
379 lines
8.1 KiB
Rust
379 lines
8.1 KiB
Rust
use std::borrow::Cow;
|
|
use std::collections::{BTreeMap, BTreeSet};
|
|
use std::hash::{Hash, Hasher};
|
|
use std::num::{
|
|
NonZeroI128, NonZeroI16, NonZeroI32, NonZeroI64, NonZeroI8, NonZeroU128, NonZeroU16,
|
|
NonZeroU32, NonZeroU64, NonZeroU8,
|
|
};
|
|
use std::path::{Path, PathBuf};
|
|
|
|
use seahash::SeaHasher;
|
|
use url::Url;
|
|
|
|
/// A trait for types that can be hashed in a stable way across versions and platforms. Equivalent
|
|
/// to Ruff's [`CacheKey`] trait.
|
|
pub trait CacheKey {
|
|
fn cache_key(&self, state: &mut CacheKeyHasher);
|
|
|
|
fn cache_key_slice(data: &[Self], state: &mut CacheKeyHasher)
|
|
where
|
|
Self: Sized,
|
|
{
|
|
for piece in data {
|
|
piece.cache_key(state);
|
|
}
|
|
}
|
|
}
|
|
|
|
impl CacheKey for bool {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u8(u8::from(*self));
|
|
}
|
|
}
|
|
|
|
impl CacheKey for char {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u32(*self as u32);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for usize {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_usize(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for u128 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u128(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for u64 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u64(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for u32 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u32(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for u16 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u16(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for u8 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_u8(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for isize {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_isize(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for i128 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_i128(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for i64 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_i64(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for i32 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_i32(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for i16 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_i16(*self);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for i8 {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_i8(*self);
|
|
}
|
|
}
|
|
macro_rules! impl_cache_key_non_zero {
|
|
($name:ident) => {
|
|
impl CacheKey for $name {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
self.get().cache_key(state)
|
|
}
|
|
}
|
|
};
|
|
}
|
|
|
|
impl_cache_key_non_zero!(NonZeroU8);
|
|
impl_cache_key_non_zero!(NonZeroU16);
|
|
impl_cache_key_non_zero!(NonZeroU32);
|
|
impl_cache_key_non_zero!(NonZeroU64);
|
|
impl_cache_key_non_zero!(NonZeroU128);
|
|
|
|
impl_cache_key_non_zero!(NonZeroI8);
|
|
impl_cache_key_non_zero!(NonZeroI16);
|
|
impl_cache_key_non_zero!(NonZeroI32);
|
|
impl_cache_key_non_zero!(NonZeroI64);
|
|
impl_cache_key_non_zero!(NonZeroI128);
|
|
|
|
macro_rules! impl_cache_key_tuple {
|
|
() => (
|
|
impl CacheKey for () {
|
|
#[inline]
|
|
fn cache_key(&self, _state: &mut CacheKeyHasher) {}
|
|
}
|
|
);
|
|
|
|
( $($name:ident)+) => (
|
|
impl<$($name: CacheKey),+> CacheKey for ($($name,)+) where last_type!($($name,)+): ?Sized {
|
|
#[allow(non_snake_case)]
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
let ($(ref $name,)+) = *self;
|
|
$($name.cache_key(state);)+
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
macro_rules! last_type {
|
|
($a:ident,) => { $a };
|
|
($a:ident, $($rest_a:ident,)+) => { last_type!($($rest_a,)+) };
|
|
}
|
|
|
|
impl_cache_key_tuple! {}
|
|
impl_cache_key_tuple! { T }
|
|
impl_cache_key_tuple! { T B }
|
|
impl_cache_key_tuple! { T B C }
|
|
impl_cache_key_tuple! { T B C D }
|
|
impl_cache_key_tuple! { T B C D E }
|
|
impl_cache_key_tuple! { T B C D E F }
|
|
impl_cache_key_tuple! { T B C D E F G }
|
|
impl_cache_key_tuple! { T B C D E F G H }
|
|
impl_cache_key_tuple! { T B C D E F G H I }
|
|
impl_cache_key_tuple! { T B C D E F G H I J }
|
|
impl_cache_key_tuple! { T B C D E F G H I J K }
|
|
impl_cache_key_tuple! { T B C D E F G H I J K L }
|
|
|
|
impl CacheKey for str {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
self.hash(&mut *state);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for String {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
self.hash(&mut *state);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for Path {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
self.hash(&mut *state);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for PathBuf {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
self.as_path().cache_key(state);
|
|
}
|
|
}
|
|
|
|
impl CacheKey for Url {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
self.as_str().cache_key(state);
|
|
}
|
|
}
|
|
|
|
impl<T: CacheKey> CacheKey for Option<T> {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
match self {
|
|
None => state.write_usize(0),
|
|
Some(value) => {
|
|
state.write_usize(1);
|
|
value.cache_key(state);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
impl<T: CacheKey> CacheKey for [T] {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_usize(self.len());
|
|
CacheKey::cache_key_slice(self, state);
|
|
}
|
|
}
|
|
|
|
impl<T: ?Sized + CacheKey> CacheKey for &T {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
(**self).cache_key(state);
|
|
}
|
|
}
|
|
|
|
impl<T: ?Sized + CacheKey> CacheKey for &mut T {
|
|
#[inline]
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
(**self).cache_key(state);
|
|
}
|
|
}
|
|
|
|
impl<T> CacheKey for Vec<T>
|
|
where
|
|
T: CacheKey,
|
|
{
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_usize(self.len());
|
|
CacheKey::cache_key_slice(self, state);
|
|
}
|
|
}
|
|
|
|
impl<V: CacheKey> CacheKey for BTreeSet<V> {
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_usize(self.len());
|
|
for item in self {
|
|
item.cache_key(state);
|
|
}
|
|
}
|
|
}
|
|
|
|
impl<K: CacheKey + Ord, V: CacheKey> CacheKey for BTreeMap<K, V> {
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
state.write_usize(self.len());
|
|
|
|
for (key, value) in self {
|
|
key.cache_key(state);
|
|
value.cache_key(state);
|
|
}
|
|
}
|
|
}
|
|
|
|
impl<V: ?Sized> CacheKey for Cow<'_, V>
|
|
where
|
|
V: CacheKey + ToOwned,
|
|
{
|
|
fn cache_key(&self, state: &mut CacheKeyHasher) {
|
|
(**self).cache_key(state);
|
|
}
|
|
}
|
|
|
|
#[derive(Clone, Default)]
|
|
pub struct CacheKeyHasher {
|
|
inner: SeaHasher,
|
|
}
|
|
|
|
impl CacheKeyHasher {
|
|
pub fn new() -> Self {
|
|
Self {
|
|
inner: SeaHasher::new(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Hasher for CacheKeyHasher {
|
|
#[inline]
|
|
fn finish(&self) -> u64 {
|
|
self.inner.finish()
|
|
}
|
|
|
|
#[inline]
|
|
fn write(&mut self, bytes: &[u8]) {
|
|
self.inner.write(bytes);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_u8(&mut self, i: u8) {
|
|
self.inner.write_u8(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_u16(&mut self, i: u16) {
|
|
self.inner.write_u16(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_u32(&mut self, i: u32) {
|
|
self.inner.write_u32(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_u64(&mut self, i: u64) {
|
|
self.inner.write_u64(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_u128(&mut self, i: u128) {
|
|
self.inner.write_u128(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_usize(&mut self, i: usize) {
|
|
self.inner.write_usize(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_i8(&mut self, i: i8) {
|
|
self.inner.write_i8(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_i16(&mut self, i: i16) {
|
|
self.inner.write_i16(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_i32(&mut self, i: i32) {
|
|
self.inner.write_i32(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_i64(&mut self, i: i64) {
|
|
self.inner.write_i64(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_i128(&mut self, i: i128) {
|
|
self.inner.write_i128(i);
|
|
}
|
|
|
|
#[inline]
|
|
fn write_isize(&mut self, i: isize) {
|
|
self.inner.write_isize(i);
|
|
}
|
|
}
|