Auto merge of #30944 - fhahn:issue-29789-use-constant2, r=nagisa

This PR for  #29789 uses `rustc::repr::mir::Constant` in `ExprKind::Repeat`, which seems to fit quite nicely. Is there a reason for not re-using that type?
This commit is contained in:
bors 2016-01-22 00:31:29 +00:00
commit 18b851bc52
7 changed files with 26 additions and 18 deletions

View File

@ -683,7 +683,7 @@ pub enum Rvalue<'tcx> {
Use(Operand<'tcx>), Use(Operand<'tcx>),
// [x; 32] // [x; 32]
Repeat(Operand<'tcx>, Constant<'tcx>), Repeat(Operand<'tcx>, TypedConstVal<'tcx>),
// &x or &mut x // &x or &mut x
Ref(Region, BorrowKind, Lvalue<'tcx>), Ref(Region, BorrowKind, Lvalue<'tcx>),
@ -891,6 +891,20 @@ pub struct Constant<'tcx> {
pub literal: Literal<'tcx>, pub literal: Literal<'tcx>,
} }
#[derive(Clone, RustcEncodable, RustcDecodable)]
pub struct TypedConstVal<'tcx> {
pub ty: Ty<'tcx>,
pub span: Span,
pub value: ConstVal
}
impl<'tcx> Debug for TypedConstVal<'tcx> {
fn fmt(&self, fmt: &mut Formatter) -> fmt::Result {
try!(write!(fmt, "const "));
fmt_const_val(fmt, &self.value)
}
}
#[derive(Clone, Copy, Debug, PartialEq, RustcEncodable, RustcDecodable)] #[derive(Clone, Copy, Debug, PartialEq, RustcEncodable, RustcDecodable)]
pub enum ItemKind { pub enum ItemKind {
Constant, Constant,

View File

@ -213,9 +213,8 @@ macro_rules! make_mir_visitor {
} }
Rvalue::Repeat(ref $($mutability)* value, Rvalue::Repeat(ref $($mutability)* value,
ref $($mutability)* len) => { _) => {
self.visit_operand(value); self.visit_operand(value);
self.visit_constant(len);
} }
Rvalue::Ref(r, bk, ref $($mutability)* path) => { Rvalue::Ref(r, bk, ref $($mutability)* path) => {

View File

@ -44,7 +44,6 @@ impl<'a,'tcx> Builder<'a,'tcx> {
} }
ExprKind::Repeat { value, count } => { ExprKind::Repeat { value, count } => {
let value_operand = unpack!(block = this.as_operand(block, value)); let value_operand = unpack!(block = this.as_operand(block, value));
let count = this.as_constant(count);
block.and(Rvalue::Repeat(value_operand, count)) block.and(Rvalue::Repeat(value_operand, count))
} }
ExprKind::Borrow { region, borrow_kind, arg } => { ExprKind::Borrow { region, borrow_kind, arg } => {

View File

@ -15,6 +15,7 @@ use hair::cx::block;
use hair::cx::to_ref::ToRef; use hair::cx::to_ref::ToRef;
use rustc::front::map; use rustc::front::map;
use rustc::middle::def::Def; use rustc::middle::def::Def;
use rustc::middle::const_eval;
use rustc::middle::region::CodeExtent; use rustc::middle::region::CodeExtent;
use rustc::middle::pat_util; use rustc::middle::pat_util;
use rustc::middle::ty::{self, VariantDef, Ty}; use rustc::middle::ty::{self, VariantDef, Ty};
@ -325,14 +326,11 @@ impl<'tcx> Mirror<'tcx> for &'tcx hir::Expr {
hir::ExprRepeat(ref v, ref c) => ExprKind::Repeat { hir::ExprRepeat(ref v, ref c) => ExprKind::Repeat {
value: v.to_ref(), value: v.to_ref(),
count: Expr { count: TypedConstVal {
ty: cx.tcx.expr_ty(c), ty: cx.tcx.expr_ty(c),
temp_lifetime: None,
span: c.span, span: c.span,
kind: ExprKind::Literal { value: const_eval::eval_const_expr(cx.tcx, c)
literal: cx.const_eval_literal(c)
} }
}.to_ref()
}, },
hir::ExprRet(ref v) => hir::ExprRet(ref v) =>
ExprKind::Return { value: v.to_ref() }, ExprKind::Return { value: v.to_ref() },

View File

@ -14,7 +14,8 @@
//! unit-tested and separated from the Rust source and compiler data //! unit-tested and separated from the Rust source and compiler data
//! structures. //! structures.
use rustc::mir::repr::{BinOp, BorrowKind, Field, Literal, Mutability, UnOp, ItemKind}; use rustc::mir::repr::{BinOp, BorrowKind, Field, Literal, Mutability, UnOp, ItemKind,
TypedConstVal};
use rustc::middle::const_eval::ConstVal; use rustc::middle::const_eval::ConstVal;
use rustc::middle::def_id::DefId; use rustc::middle::def_id::DefId;
use rustc::middle::region::CodeExtent; use rustc::middle::region::CodeExtent;
@ -213,10 +214,7 @@ pub enum ExprKind<'tcx> {
}, },
Repeat { Repeat {
value: ExprRef<'tcx>, value: ExprRef<'tcx>,
// FIXME(#29789): Add a separate hair::Constant<'tcx> so this could be more explicit about count: TypedConstVal<'tcx>,
// its contained data. Currently this should only contain expression of ExprKind::Literal
// kind.
count: ExprRef<'tcx>,
}, },
Vec { Vec {
fields: Vec<ExprRef<'tcx>>, fields: Vec<ExprRef<'tcx>>,

View File

@ -143,9 +143,9 @@ impl<'a, 'tcx> EraseRegions<'a, 'tcx> {
Rvalue::Use(ref mut operand) => { Rvalue::Use(ref mut operand) => {
self.erase_regions_operand(operand) self.erase_regions_operand(operand)
} }
Rvalue::Repeat(ref mut operand, ref mut constant) => { Rvalue::Repeat(ref mut operand, ref mut value) => {
self.erase_regions_operand(operand); self.erase_regions_operand(operand);
self.erase_regions_constant(constant); value.ty = self.tcx.erase_regions(&value.ty);
} }
Rvalue::Ref(ref mut region, _, ref mut lvalue) => { Rvalue::Ref(ref mut region, _, ref mut lvalue) => {
*region = ty::ReStatic; *region = ty::ReStatic;

View File

@ -89,7 +89,7 @@ impl<'bcx, 'tcx> MirContext<'bcx, 'tcx> {
mir::Rvalue::Repeat(ref elem, ref count) => { mir::Rvalue::Repeat(ref elem, ref count) => {
let elem = self.trans_operand(bcx, elem); let elem = self.trans_operand(bcx, elem);
let size = self.trans_constant(bcx, count).immediate(); let size = self.trans_constval(bcx, &count.value, count.ty).immediate();
let base = expr::get_dataptr(bcx, dest.llval); let base = expr::get_dataptr(bcx, dest.llval);
tvec::iter_vec_raw(bcx, base, elem.ty, size, |bcx, llslot, _| { tvec::iter_vec_raw(bcx, base, elem.ty, size, |bcx, llslot, _| {
self.store_operand(bcx, llslot, elem); self.store_operand(bcx, llslot, elem);