diff options
| author | bors <bors@rust-lang.org> | 2018-03-19 05:07:27 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2018-03-19 05:07:27 +0000 |
| commit | 15add366faac554db51244d1e27e4d10a08ab6e8 (patch) | |
| tree | 1a8018ebe0c906980d6c8fc5f0f739368cd05389 | |
| parent | 152217d29cc842d9a7577e9361f5960f87dcdf5c (diff) | |
| parent | f02dc74c2cf1afb049f8978c885589a26fb6676b (diff) | |
| download | rust-15add366faac554db51244d1e27e4d10a08ab6e8.tar.gz rust-15add366faac554db51244d1e27e4d10a08ab6e8.zip | |
Auto merge of #49091 - nikomatsakis:issue-49043-ty-infer-hash, r=michaelwoerister
extend stable hasher to support `CanonicalTy` Fixes #49043 r? @michaelwoerister
| -rw-r--r-- | src/librustc/ich/impls_ty.rs | 50 | ||||
| -rw-r--r-- | src/librustc/macros.rs | 2 | ||||
| -rw-r--r-- | src/librustc/traits/query/dropck_outlives.rs | 1 | ||||
| -rw-r--r-- | src/test/incremental/issue-49043.rs | 22 |
4 files changed, 72 insertions, 3 deletions
diff --git a/src/librustc/ich/impls_ty.rs b/src/librustc/ich/impls_ty.rs index 7f91bbd6ea2..9a442e05299 100644 --- a/src/librustc/ich/impls_ty.rs +++ b/src/librustc/ich/impls_ty.rs @@ -902,13 +902,59 @@ for ty::TypeVariants<'gcx> TyForeign(def_id) => { def_id.hash_stable(hcx, hasher); } - TyInfer(..) => { - bug!("ty::TypeVariants::hash_stable() - Unexpected variant {:?}.", *self) + TyInfer(infer_ty) => { + infer_ty.hash_stable(hcx, hasher); } } } } +impl_stable_hash_for!(enum ty::InferTy { + TyVar(a), + IntVar(a), + FloatVar(a), + FreshTy(a), + FreshIntTy(a), + FreshFloatTy(a), + CanonicalTy(a), +}); + +impl<'a, 'gcx> HashStable<StableHashingContext<'a>> +for ty::TyVid +{ + fn hash_stable<W: StableHasherResult>(&self, + _hcx: &mut StableHashingContext<'a>, + _hasher: &mut StableHasher<W>) { + // TyVid values are confined to an inference context and hence + // should not be hashed. + bug!("ty::TypeVariants::hash_stable() - can't hash a TyVid {:?}.", *self) + } +} + +impl<'a, 'gcx> HashStable<StableHashingContext<'a>> +for ty::IntVid +{ + fn hash_stable<W: StableHasherResult>(&self, + _hcx: &mut StableHashingContext<'a>, + _hasher: &mut StableHasher<W>) { + // IntVid values are confined to an inference context and hence + // should not be hashed. + bug!("ty::TypeVariants::hash_stable() - can't hash an IntVid {:?}.", *self) + } +} + +impl<'a, 'gcx> HashStable<StableHashingContext<'a>> +for ty::FloatVid +{ + fn hash_stable<W: StableHasherResult>(&self, + _hcx: &mut StableHashingContext<'a>, + _hasher: &mut StableHasher<W>) { + // FloatVid values are confined to an inference context and hence + // should not be hashed. + bug!("ty::TypeVariants::hash_stable() - can't hash a FloatVid {:?}.", *self) + } +} + impl_stable_hash_for!(struct ty::ParamTy { idx, name diff --git a/src/librustc/macros.rs b/src/librustc/macros.rs index d8a723e184d..7dc84b9ca29 100644 --- a/src/librustc/macros.rs +++ b/src/librustc/macros.rs @@ -72,7 +72,7 @@ macro_rules! __impl_stable_hash_field { #[macro_export] macro_rules! impl_stable_hash_for { - (enum $enum_name:path { $( $variant:ident $( ( $($arg:ident),* ) )* ),* }) => { + (enum $enum_name:path { $( $variant:ident $( ( $($arg:ident),* ) )* ),* $(,)* }) => { impl<'a, 'tcx> ::rustc_data_structures::stable_hasher::HashStable<$crate::ich::StableHashingContext<'a>> for $enum_name { #[inline] fn hash_stable<W: ::rustc_data_structures::stable_hasher::StableHasherResult>(&self, diff --git a/src/librustc/traits/query/dropck_outlives.rs b/src/librustc/traits/query/dropck_outlives.rs index 1caab6fd89e..017c4f5262e 100644 --- a/src/librustc/traits/query/dropck_outlives.rs +++ b/src/librustc/traits/query/dropck_outlives.rs @@ -51,6 +51,7 @@ impl<'cx, 'gcx, 'tcx> At<'cx, 'gcx, 'tcx> { let gcx = tcx.global_tcx(); let (c_ty, orig_values) = self.infcx.canonicalize_query(&self.param_env.and(ty)); let span = self.cause.span; + debug!("c_ty = {:?}", c_ty); match &gcx.dropck_outlives(c_ty) { Ok(result) if result.is_proven() => { match self.infcx.instantiate_query_result( diff --git a/src/test/incremental/issue-49043.rs b/src/test/incremental/issue-49043.rs new file mode 100644 index 00000000000..118027b190e --- /dev/null +++ b/src/test/incremental/issue-49043.rs @@ -0,0 +1,22 @@ +// Copyright 2016 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// Regression test for hashing involving canonical variables. In this +// test -- which has an intensional error -- the type of the value +// being dropped winds up including a type variable. Canonicalization +// would then produce a `?0` which -- in turn -- triggered an ICE in +// hashing. + +// revisions:cfail1 + +fn main() { + println!("Hello, world! {}",*thread_rng().choose(&[0, 1, 2, 3]).unwrap()); + //[cfail1]~^ ERROR cannot find function `thread_rng` +} |
