diff --git a/src/librustc_mir/interpret/cast.rs b/src/librustc_mir/interpret/cast.rs index aff358f815c98..84de97488c51f 100644 --- a/src/librustc_mir/interpret/cast.rs +++ b/src/librustc_mir/interpret/cast.rs @@ -4,7 +4,7 @@ use syntax::ast::{FloatTy, IntTy, UintTy}; use error::{EvalResult, EvalError}; use eval_context::EvalContext; use value::PrimVal; -use memory::{MemoryPointer, HasDataLayout}; +use memory::{MemoryPointer, PointerArithmetic}; impl<'a, 'tcx> EvalContext<'a, 'tcx> { pub(super) fn cast_primval( diff --git a/src/librustc_mir/interpret/memory.rs b/src/librustc_mir/interpret/memory.rs index 00b29d26e974e..ad7326761a622 100644 --- a/src/librustc_mir/interpret/memory.rs +++ b/src/librustc_mir/interpret/memory.rs @@ -68,30 +68,30 @@ pub struct MemoryPointer { pub offset: u64, } -impl MemoryPointer { +impl<'tcx> MemoryPointer { pub fn new(alloc_id: AllocId, offset: u64) -> Self { MemoryPointer { alloc_id, offset } } - pub(crate) fn wrapping_signed_offset<'a, L: HasDataLayout<'a>>(self, i: i64, l: L) -> Self { + pub(crate) fn wrapping_signed_offset(self, i: i64, l: L) -> Self { MemoryPointer::new(self.alloc_id, l.wrapping_signed_offset(self.offset, i)) } - pub(crate) fn overflowing_signed_offset<'a, L: HasDataLayout<'a>>(self, i: i128, l: L) -> (Self, bool) { + pub(crate) fn overflowing_signed_offset(self, i: i128, l: L) -> (Self, bool) { let (res, over) = l.overflowing_signed_offset(self.offset, i); (MemoryPointer::new(self.alloc_id, res), over) } - pub(crate) fn signed_offset<'a, 'tcx, L: HasDataLayout<'a>>(self, i: i64, l: L) -> EvalResult<'tcx, Self> { + pub(crate) fn signed_offset(self, i: i64, l: L) -> EvalResult<'tcx, Self> { Ok(MemoryPointer::new(self.alloc_id, l.signed_offset(self.offset, i)?)) } - pub(crate) fn overflowing_offset<'a, L: HasDataLayout<'a>>(self, i: u64, l: L) -> (Self, bool) { + pub(crate) fn overflowing_offset(self, i: u64, l: L) -> (Self, bool) { let (res, over) = l.overflowing_offset(self.offset, i); (MemoryPointer::new(self.alloc_id, res), over) } - pub(crate) fn offset<'a, 'tcx, L: HasDataLayout<'a>>(self, i: u64, l: L) -> EvalResult<'tcx, Self> { + pub(crate) fn offset(self, i: u64, l: L) -> EvalResult<'tcx, Self> { Ok(MemoryPointer::new(self.alloc_id, l.offset(self.offset, i)?)) } } @@ -1183,9 +1183,7 @@ impl<'a, 'tcx> HasMemory<'a, 'tcx> for EvalContext<'a, 'tcx> { // Pointer arithmetic //////////////////////////////////////////////////////////////////////////////// -pub(crate) trait HasDataLayout<'a> : Copy { - fn data_layout(self) -> &'a TargetDataLayout; - +pub trait PointerArithmetic : layout::HasDataLayout { // These are not supposed to be overriden. //// Trunace the given value to the pointer size; also return whether there was an overflow @@ -1236,17 +1234,17 @@ pub(crate) trait HasDataLayout<'a> : Copy { } } -impl<'a> HasDataLayout<'a> for &'a TargetDataLayout { +impl PointerArithmetic for T {} + +impl<'a, 'tcx> layout::HasDataLayout for &'a Memory<'a, 'tcx> { #[inline] - fn data_layout(self) -> &'a TargetDataLayout { - self + fn data_layout(&self) -> &TargetDataLayout { + self.layout } } - -impl<'a, 'b, 'tcx, T> HasDataLayout<'a> for &'b T - where T: HasMemory<'a, 'tcx> { +impl<'a, 'tcx> layout::HasDataLayout for &'a EvalContext<'a, 'tcx> { #[inline] - fn data_layout(self) -> &'a TargetDataLayout { + fn data_layout(&self) -> &TargetDataLayout { self.memory().layout } } diff --git a/src/librustc_mir/interpret/value.rs b/src/librustc_mir/interpret/value.rs index 7420ae1256af2..10fa3394043d9 100644 --- a/src/librustc_mir/interpret/value.rs +++ b/src/librustc_mir/interpret/value.rs @@ -2,7 +2,7 @@ #![allow(float_cmp)] use error::{EvalError, EvalResult}; -use memory::{Memory, MemoryPointer, HasMemory, HasDataLayout}; +use memory::{Memory, MemoryPointer, HasMemory, PointerArithmetic}; pub(super) fn bytes_to_f32(bytes: u128) -> f32 { f32::from_bits(bytes as u32) @@ -59,7 +59,7 @@ impl<'tcx> Pointer { self.primval } - pub(crate) fn signed_offset<'a, L: HasDataLayout<'a>>(self, i: i64, layout: L) -> EvalResult<'tcx, Self> { + pub(crate) fn signed_offset(self, i: i64, layout: L) -> EvalResult<'tcx, Self> { match self.primval { PrimVal::Bytes(b) => { assert_eq!(b as u64 as u128, b); @@ -70,7 +70,7 @@ impl<'tcx> Pointer { } } - pub(crate) fn offset<'a, L: HasDataLayout<'a>>(self, i: u64, layout: L) -> EvalResult<'tcx, Self> { + pub(crate) fn offset(self, i: u64, layout: L) -> EvalResult<'tcx, Self> { match self.primval { PrimVal::Bytes(b) => { assert_eq!(b as u64 as u128, b); @@ -81,7 +81,7 @@ impl<'tcx> Pointer { } } - pub(crate) fn wrapping_signed_offset<'a, L: HasDataLayout<'a>>(self, i: i64, layout: L) -> EvalResult<'tcx, Self> { + pub(crate) fn wrapping_signed_offset(self, i: i64, layout: L) -> EvalResult<'tcx, Self> { match self.primval { PrimVal::Bytes(b) => { assert_eq!(b as u64 as u128, b);