diff options
| author | Wilco Kusee <wilcokusee@gmail.com> | 2017-12-20 23:13:15 +0100 |
|---|---|---|
| committer | Wilco Kusee <wilcokusee@gmail.com> | 2017-12-20 23:13:15 +0100 |
| commit | d5b1119b16d0592459104b1a16237d27c7d738bb (patch) | |
| tree | 00ac5b748d809ce78801b6057fd97999215e3e37 /src | |
| parent | 81622c6b02536bdcf56145beb317da0d336703c1 (diff) | |
| download | rust-d5b1119b16d0592459104b1a16237d27c7d738bb.tar.gz rust-d5b1119b16d0592459104b1a16237d27c7d738bb.zip | |
Const-eval TyArray trait implementors
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustdoc/clean/mod.rs | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/src/librustdoc/clean/mod.rs b/src/librustdoc/clean/mod.rs index 2bf701d1f4e..09792d29d36 100644 --- a/src/librustdoc/clean/mod.rs +++ b/src/librustdoc/clean/mod.rs @@ -33,7 +33,6 @@ use rustc::middle::resolve_lifetime as rl; use rustc::middle::lang_items; use rustc::hir::def::{Def, CtorKind}; use rustc::hir::def_id::{CrateNum, DefId, CRATE_DEF_INDEX, LOCAL_CRATE}; -use rustc::traits::Reveal; use rustc::ty::subst::Substs; use rustc::ty::{self, Ty, AdtKind}; use rustc::middle::stability; @@ -2044,7 +2043,7 @@ impl Clean<Type> for hir::Ty { TySlice(ref ty) => Slice(box ty.clean(cx)), TyArray(ref ty, n) => { let def_id = cx.tcx.hir.body_owner_def_id(n); - let param_env = ty::ParamEnv::empty(Reveal::UserFacing); + let param_env = cx.tcx.param_env(def_id); let substs = Substs::identity_for_item(cx.tcx, def_id); let n = cx.tcx.const_eval(param_env.and((def_id, substs))).unwrap(); let n = if let ConstVal::Integral(ConstInt::Usize(n)) = n.val { @@ -2173,6 +2172,11 @@ impl<'tcx> Clean<Type> for Ty<'tcx> { ty::TyStr => Primitive(PrimitiveType::Str), ty::TySlice(ty) => Slice(box ty.clean(cx)), ty::TyArray(ty, n) => { + let mut n = cx.tcx.lift(&n).unwrap(); + if let ConstVal::Unevaluated(def_id, substs) = n.val { + let param_env = cx.tcx.param_env(def_id); + n = cx.tcx.const_eval(param_env.and((def_id, substs))).unwrap() + }; let n = if let ConstVal::Integral(ConstInt::Usize(n)) = n.val { n.to_string() } else if let ConstVal::Unevaluated(def_id, _) = n.val { |
