pub struct Transform;
Trait Implementations§
source§impl LlbcPass for Transform
impl LlbcPass for Transform
We do the following.
If p
is a projection (for instance: var
, *var
, var.f
, etc.), we
detect:
- whether it operates on a slice or an array (we keep track of the types)
- whether the access might mutate the value or not (it is
the case if it is in a
move
,&mut
or at the lhs of an assignment), and do the following transformations
// If array and mutable access:
... p[i] ...
~~>
tmp0 = &mut p
tmp1 = ArrayIndexMut(move p, i)
... *tmp1 ...
// If array and non-mutable access:
... p[i] ...
~~>
tmp0 := & p
tmp1 := ArrayIndexShared(move tmp0, i)
... *tmp1 ...
// Omitting the slice cases, which are similar
For instance, it leads to the following transformations:
// x : [u32; N]
y : u32 = copy x[i]
~~>
tmp0 : & [u32; N] := &x
tmp1 : &u32 = ArrayIndexShared(move tmp0, i)
y : u32 = copy (*tmp1)
// x : &[T; N]
y : &T = & (*x)[i]
~~>
tmp0 : & [T; N] := & (*x)
tmp1 : &T = ArrayIndexShared(move tmp0, i)
y : &T = & (*tmp1)
// x : [u32; N]
y = &mut x[i]
~~>
tmp0 : &mut [u32; N] := &mut x
tmp1 : &mut u32 := ArrayIndexMut(move tmp0, i)
y = &mut (*tmp)
// When using an index on the lhs:
// y : [T; N]
y[i] = x
~~>
tmp0 : &mut [T; N] := &mut y;
tmp1 : &mut T = ArrayIndexMut(move y, i)
*tmp1 = x
source§fn transform_body(&self, _ctx: &mut TransformCtx<'_>, b: &mut ExprBody)
fn transform_body(&self, _ctx: &mut TransformCtx<'_>, b: &mut ExprBody)
Transform a body.
source§fn transform_function(
&self,
ctx: &mut TransformCtx<'_>,
_decl: &mut FunDecl,
body: Result<&mut ExprBody, Opaque>,
)
fn transform_function( &self, ctx: &mut TransformCtx<'_>, _decl: &mut FunDecl, body: Result<&mut ExprBody, Opaque>, )
Transform a function declaration. This forwards to
transform_body
by default.source§fn transform_ctx(&self, ctx: &mut TransformCtx<'_>)
fn transform_ctx(&self, ctx: &mut TransformCtx<'_>)
Transform the given context. This forwards to the other methods by default.
source§fn name(&self) -> &str
fn name(&self) -> &str
The name of the pass, used for debug logging. The default implementation uses the type
name.
source§fn log_before_body(
&self,
ctx: &TransformCtx<'_>,
name: &Name,
body: Result<&ExprBody, &Opaque>,
)
fn log_before_body( &self, ctx: &TransformCtx<'_>, name: &Name, body: Result<&ExprBody, &Opaque>, )
Log that the pass is about to be run on this body.
Auto Trait Implementations§
impl Freeze for Transform
impl RefUnwindSafe for Transform
impl Send for Transform
impl Sync for Transform
impl Unpin for Transform
impl UnwindSafe for Transform
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<I, T> ExtractContext<I, ()> for T
impl<I, T> ExtractContext<I, ()> for T
§fn extract_context(self, _original_input: I)
fn extract_context(self, _original_input: I)
Given the context attached to a nom error, and given the original
input to the nom parser, extract more the useful context information. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<I> RecreateContext<I> for I
impl<I> RecreateContext<I> for I
§fn recreate_context(_original_input: I, tail: I) -> I
fn recreate_context(_original_input: I, tail: I) -> I
Given the original input, as well as the context reported by nom,
recreate a context in the original string where the error occurred. Read more