Struct rustc_hir_analysis::check::intrinsicck::InlineAsmCtxt
source · pub struct InlineAsmCtxt<'a, 'tcx> {
tcx: TyCtxt<'tcx>,
param_env: ParamEnv<'tcx>,
get_operand_ty: Box<dyn Fn(&'tcx Expr<'tcx>) -> Ty<'tcx> + 'a>,
}
Fields§
§tcx: TyCtxt<'tcx>
§param_env: ParamEnv<'tcx>
§get_operand_ty: Box<dyn Fn(&'tcx Expr<'tcx>) -> Ty<'tcx> + 'a>
Implementations§
source§impl<'a, 'tcx> InlineAsmCtxt<'a, 'tcx>
impl<'a, 'tcx> InlineAsmCtxt<'a, 'tcx>
pub fn new_global_asm(tcx: TyCtxt<'tcx>) -> Self
pub fn new_in_fn( tcx: TyCtxt<'tcx>, param_env: ParamEnv<'tcx>, get_operand_ty: impl Fn(&'tcx Expr<'tcx>) -> Ty<'tcx> + 'a ) -> Self
fn is_thin_ptr_ty(&self, ty: Ty<'tcx>) -> bool
fn get_asm_ty(&self, ty: Ty<'tcx>) -> Option<InlineAsmType>
fn check_asm_operand_type( &self, idx: usize, reg: InlineAsmRegOrRegClass, expr: &'tcx Expr<'tcx>, template: &[InlineAsmTemplatePiece], is_input: bool, tied_input: Option<(&'tcx Expr<'tcx>, Option<InlineAsmType>)>, target_features: &FxIndexSet<Symbol> ) -> Option<InlineAsmType>
pub fn check_asm(&self, asm: &InlineAsm<'tcx>, enclosing_id: LocalDefId)
Auto Trait Implementations§
impl<'a, 'tcx> !RefUnwindSafe for InlineAsmCtxt<'a, 'tcx>
impl<'a, 'tcx> !Send for InlineAsmCtxt<'a, 'tcx>
impl<'a, 'tcx> !Sync for InlineAsmCtxt<'a, 'tcx>
impl<'a, 'tcx> Unpin for InlineAsmCtxt<'a, 'tcx>
impl<'a, 'tcx> !UnwindSafe for InlineAsmCtxt<'a, '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
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: 32 bytes