Remove some unnecessary hash truncations
This commit is contained in:
parent
fd57c6b407
commit
84facac97a
4 changed files with 9 additions and 33 deletions
|
@ -5,40 +5,30 @@
|
||||||
//! mismatches where we have two versions of the same crate that were
|
//! mismatches where we have two versions of the same crate that were
|
||||||
//! compiled from distinct sources.
|
//! compiled from distinct sources.
|
||||||
|
|
||||||
use rustc_serialize::{Decodable, Decoder, Encodable, Encoder};
|
use crate::fingerprint::Fingerprint;
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
use std::hash::{Hash, Hasher};
|
|
||||||
|
|
||||||
use crate::stable_hasher;
|
use crate::stable_hasher;
|
||||||
|
|
||||||
#[derive(Copy, Clone, PartialEq, Eq, Debug)]
|
#[derive(Copy, Clone, PartialEq, Eq, Debug, Encodable, Decodable, Hash)]
|
||||||
pub struct Svh {
|
pub struct Svh {
|
||||||
hash: u64,
|
hash: Fingerprint,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Svh {
|
impl Svh {
|
||||||
/// Creates a new `Svh` given the hash. If you actually want to
|
/// Creates a new `Svh` given the hash. If you actually want to
|
||||||
/// compute the SVH from some HIR, you want the `calculate_svh`
|
/// compute the SVH from some HIR, you want the `calculate_svh`
|
||||||
/// function found in `rustc_incremental`.
|
/// function found in `rustc_incremental`.
|
||||||
pub fn new(hash: u64) -> Svh {
|
pub fn new(hash: Fingerprint) -> Svh {
|
||||||
Svh { hash }
|
Svh { hash }
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn as_u64(&self) -> u64 {
|
pub fn as_u64(&self) -> u64 {
|
||||||
self.hash
|
self.hash.to_smaller_hash()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn to_string(&self) -> String {
|
pub fn to_string(&self) -> String {
|
||||||
format!("{:016x}", self.hash)
|
format!("{:016x}", self.hash.to_smaller_hash())
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Hash for Svh {
|
|
||||||
fn hash<H>(&self, state: &mut H)
|
|
||||||
where
|
|
||||||
H: Hasher,
|
|
||||||
{
|
|
||||||
self.hash.to_le().hash(state);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,18 +38,6 @@ impl fmt::Display for Svh {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<S: Encoder> Encodable<S> for Svh {
|
|
||||||
fn encode(&self, s: &mut S) {
|
|
||||||
s.emit_u64(self.as_u64().to_le());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<D: Decoder> Decodable<D> for Svh {
|
|
||||||
fn decode(d: &mut D) -> Svh {
|
|
||||||
Svh::new(u64::from_le(d.read_u64()))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T> stable_hasher::HashStable<T> for Svh {
|
impl<T> stable_hasher::HashStable<T> for Svh {
|
||||||
#[inline]
|
#[inline]
|
||||||
fn hash_stable(&self, ctx: &mut T, hasher: &mut stable_hasher::StableHasher) {
|
fn hash_stable(&self, ctx: &mut T, hasher: &mut stable_hasher::StableHasher) {
|
||||||
|
|
|
@ -1199,7 +1199,7 @@ pub(super) fn crate_hash(tcx: TyCtxt<'_>, _: LocalCrate) -> Svh {
|
||||||
stable_hasher.finish()
|
stable_hasher.finish()
|
||||||
});
|
});
|
||||||
|
|
||||||
Svh::new(crate_hash.to_smaller_hash())
|
Svh::new(crate_hash)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn upstream_crates(tcx: TyCtxt<'_>) -> Vec<(StableCrateId, Svh)> {
|
fn upstream_crates(tcx: TyCtxt<'_>) -> Vec<(StableCrateId, Svh)> {
|
||||||
|
|
|
@ -75,7 +75,7 @@ impl<'a> HashStable<StableHashingContext<'a>> for SourceFile {
|
||||||
ref normalized_pos,
|
ref normalized_pos,
|
||||||
} = *self;
|
} = *self;
|
||||||
|
|
||||||
(name_hash as u64).hash_stable(hcx, hasher);
|
name_hash.hash_stable(hcx, hasher);
|
||||||
|
|
||||||
src_hash.hash_stable(hcx, hasher);
|
src_hash.hash_stable(hcx, hasher);
|
||||||
|
|
||||||
|
|
|
@ -2159,9 +2159,7 @@ where
|
||||||
};
|
};
|
||||||
|
|
||||||
Hash::hash(&TAG_VALID_SPAN, hasher);
|
Hash::hash(&TAG_VALID_SPAN, hasher);
|
||||||
// We truncate the stable ID hash and line and column numbers. The chances
|
Hash::hash(&file.name_hash, hasher);
|
||||||
// of causing a collision this way should be minimal.
|
|
||||||
Hash::hash(&(file.name_hash as u64), hasher);
|
|
||||||
|
|
||||||
// Hash both the length and the end location (line/column) of a span. If we
|
// Hash both the length and the end location (line/column) of a span. If we
|
||||||
// hash only the length, for example, then two otherwise equal spans with
|
// hash only the length, for example, then two otherwise equal spans with
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue