Struct rustc_mir_transform::shim::CloneShimBuilder
source · struct CloneShimBuilder<'tcx> {
tcx: TyCtxt<'tcx>,
def_id: DefId,
local_decls: IndexVec<Local, LocalDecl<'tcx>>,
blocks: IndexVec<BasicBlock, BasicBlockData<'tcx>>,
span: Span,
sig: FnSig<'tcx>,
}
Fields§
§tcx: TyCtxt<'tcx>
§def_id: DefId
§local_decls: IndexVec<Local, LocalDecl<'tcx>>
§blocks: IndexVec<BasicBlock, BasicBlockData<'tcx>>
§span: Span
§sig: FnSig<'tcx>
Implementations§
source§impl<'tcx> CloneShimBuilder<'tcx>
impl<'tcx> CloneShimBuilder<'tcx>
fn new(tcx: TyCtxt<'tcx>, def_id: DefId, self_ty: Ty<'tcx>) -> Self
fn into_mir(self) -> Body<'tcx>
fn source_info(&self) -> SourceInfo
fn block( &mut self, statements: Vec<Statement<'tcx>>, kind: TerminatorKind<'tcx>, is_cleanup: bool ) -> BasicBlock
sourcefn block_index_offset(&self, offset: usize) -> BasicBlock
fn block_index_offset(&self, offset: usize) -> BasicBlock
Gives the index of an upcoming BasicBlock, with an offset. offset=0 will give you the index of the next BasicBlock, offset=1 will give the index of the next-to-next block, offset=-1 will give you the index of the last-created block
fn make_statement(&self, kind: StatementKind<'tcx>) -> Statement<'tcx>
fn copy_shim(&mut self)
fn make_place(&mut self, mutability: Mutability, ty: Ty<'tcx>) -> Place<'tcx>
fn make_clone_call( &mut self, dest: Place<'tcx>, src: Place<'tcx>, ty: Ty<'tcx>, next: BasicBlock, cleanup: BasicBlock )
fn clone_fields<I>(
&mut self,
dest: Place<'tcx>,
src: Place<'tcx>,
target: BasicBlock,
unwind: BasicBlock,
tys: I
) -> BasicBlockwhere
I: IntoIterator<Item = Ty<'tcx>>,
fn tuple_like_shim<I>(&mut self, dest: Place<'tcx>, src: Place<'tcx>, tys: I)where
I: IntoIterator<Item = Ty<'tcx>>,
fn coroutine_shim( &mut self, dest: Place<'tcx>, src: Place<'tcx>, coroutine_def_id: DefId, args: CoroutineArgs<'tcx> )
Auto Trait Implementations§
impl<'tcx> DynSend for CloneShimBuilder<'tcx>
impl<'tcx> DynSync for CloneShimBuilder<'tcx>
impl<'tcx> Freeze for CloneShimBuilder<'tcx>
impl<'tcx> !RefUnwindSafe for CloneShimBuilder<'tcx>
impl<'tcx> !Send for CloneShimBuilder<'tcx>
impl<'tcx> !Sync for CloneShimBuilder<'tcx>
impl<'tcx> Unpin for CloneShimBuilder<'tcx>
impl<'tcx> !UnwindSafe for CloneShimBuilder<'tcx>
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
source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
§impl<T> Filterable for T
impl<T> Filterable for T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<P> IntoQueryParam<P> for P
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<'tcx, T> ToPredicate<'tcx, T> for T
impl<'tcx, T> ToPredicate<'tcx, T> for T
fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> T
source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed ) -> T
source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
impl<T> ErasedDestructor for Twhere
T: 'static,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 88 bytes