pub trait Interner:
Sized
+ Copy
+ IrPrint<AliasTy<Self>>
+ IrPrint<AliasTerm<Self>>
+ IrPrint<TraitRef<Self>>
+ IrPrint<TraitPredicate<Self>>
+ IrPrint<HostEffectPredicate<Self>>
+ IrPrint<ExistentialTraitRef<Self>>
+ IrPrint<ExistentialProjection<Self>>
+ IrPrint<ProjectionPredicate<Self>>
+ IrPrint<NormalizesTo<Self>>
+ IrPrint<SubtypePredicate<Self>>
+ IrPrint<CoercePredicate<Self>>
+ IrPrint<FnSig<Self>>
+ IrPrint<PatternKind<Self>> {
Show 148 associated items
type DefId: DefId<Self>;
type LocalDefId: Copy + Debug + Hash + Eq + Into<Self::DefId> + TypeFoldable<Self>;
type TraitId: SpecificDefId<Self>;
type ForeignId: SpecificDefId<Self>;
type FunctionId: SpecificDefId<Self>;
type ClosureId: SpecificDefId<Self>;
type CoroutineClosureId: SpecificDefId<Self>;
type CoroutineId: SpecificDefId<Self>;
type AdtId: SpecificDefId<Self>;
type ImplId: SpecificDefId<Self>;
type UnevaluatedConstId: SpecificDefId<Self>;
type Span: Span<Self>;
type GenericArgs: GenericArgs<Self>;
type GenericArgsSlice: Copy + Debug + Hash + Eq + SliceLike<Item = Self::GenericArg>;
type GenericArg: GenericArg<Self>;
type Term: Term<Self>;
type BoundVarKinds: Copy + Debug + Hash + Eq + SliceLike<Item = Self::BoundVarKind> + Default;
type BoundVarKind: Copy + Debug + Hash + Eq;
type PredefinedOpaques: Copy + Debug + Hash + Eq + TypeFoldable<Self> + SliceLike<Item = (OpaqueTypeKey<Self>, Self::Ty)>;
type LocalDefIds: Copy + Debug + Hash + Default + Eq + TypeVisitable<Self> + SliceLike<Item = Self::LocalDefId>;
type CanonicalVarKinds: Copy + Debug + Hash + Eq + SliceLike<Item = CanonicalVarKind<Self>> + Default;
type ExternalConstraints: Copy + Debug + Hash + Eq + TypeFoldable<Self> + Deref<Target = ExternalConstraintsData<Self>>;
type DepNodeIndex;
type Tracked<T: Debug + Clone>: Debug;
type Ty: Ty<Self>;
type Tys: Tys<Self>;
type FnInputTys: Copy + Debug + Hash + Eq + SliceLike<Item = Self::Ty> + TypeVisitable<Self>;
type ParamTy: ParamLike;
type BoundTy: BoundVarLike<Self>;
type PlaceholderTy: PlaceholderLike<Self, Bound = Self::BoundTy>;
type Symbol: Copy + Hash + PartialEq + Eq + Debug;
type ErrorGuaranteed: Copy + Debug + Hash + Eq;
type BoundExistentialPredicates: BoundExistentialPredicates<Self>;
type AllocId: Copy + Debug + Hash + Eq;
type Pat: Copy + Debug + Hash + Eq + Relate<Self> + Flags + IntoKind<Kind = PatternKind<Self>>;
type PatList: Copy + Debug + Hash + Default + Eq + TypeVisitable<Self> + SliceLike<Item = Self::Pat>;
type Safety: Safety<Self>;
type Abi: Abi<Self>;
type Const: Const<Self>;
type ParamConst: Copy + Debug + Hash + Eq + ParamLike;
type BoundConst: BoundVarLike<Self>;
type PlaceholderConst: PlaceholderConst<Self>;
type ValueConst: ValueConst<Self>;
type ExprConst: ExprConst<Self>;
type ValTree: Copy + Debug + Hash + Eq;
type Region: Region<Self>;
type EarlyParamRegion: ParamLike;
type LateParamRegion: Copy + Debug + Hash + Eq;
type BoundRegion: BoundVarLike<Self>;
type PlaceholderRegion: PlaceholderLike<Self, Bound = Self::BoundRegion>;
type RegionAssumptions: Copy + Debug + Hash + Eq + SliceLike<Item = OutlivesPredicate<Self, Self::GenericArg>> + TypeFoldable<Self>;
type ParamEnv: ParamEnv<Self>;
type Predicate: Predicate<Self>;
type Clause: Clause<Self>;
type Clauses: Clauses<Self>;
type GenericsOf: GenericsOf<Self>;
type VariancesOf: Copy + Debug + SliceLike<Item = Variance>;
type AdtDef: AdtDef<Self>;
type Features: Features<Self>;
type UnsizingParams: Deref<Target = DenseBitSet<u32>>;
type Probe: Debug + Hash + Eq + Borrow<Probe<Self>>;
// Required methods
fn mk_predefined_opaques_in_body(
self,
data: &[(OpaqueTypeKey<Self>, Self::Ty)],
) -> Self::PredefinedOpaques;
fn mk_canonical_var_kinds(
self,
kinds: &[CanonicalVarKind<Self>],
) -> Self::CanonicalVarKinds;
fn mk_external_constraints(
self,
data: ExternalConstraintsData<Self>,
) -> Self::ExternalConstraints;
fn mk_tracked<T: Debug + Clone>(
self,
data: T,
dep_node: Self::DepNodeIndex,
) -> Self::Tracked<T>;
fn get_tracked<T: Debug + Clone>(self, tracked: &Self::Tracked<T>) -> T;
fn with_cached_task<T>(
self,
task: impl FnOnce() -> T,
) -> (T, Self::DepNodeIndex);
fn with_global_cache<R>(
self,
f: impl FnOnce(&mut GlobalCache<Self>) -> R,
) -> R;
fn canonical_param_env_cache_get_or_insert<R>(
self,
param_env: Self::ParamEnv,
f: impl FnOnce() -> CanonicalParamEnvCacheEntry<Self>,
from_entry: impl FnOnce(&CanonicalParamEnvCacheEntry<Self>) -> R,
) -> R;
fn assert_evaluation_is_concurrent(&self);
fn expand_abstract_consts<T: TypeFoldable<Self>>(self, t: T) -> T;
fn generics_of(self, def_id: Self::DefId) -> Self::GenericsOf;
fn variances_of(self, def_id: Self::DefId) -> Self::VariancesOf;
fn opt_alias_variances(
self,
kind: impl Into<AliasTermKind>,
def_id: Self::DefId,
) -> Option<Self::VariancesOf>;
fn type_of(self, def_id: Self::DefId) -> EarlyBinder<Self, Self::Ty>;
fn type_of_opaque_hir_typeck(
self,
def_id: Self::LocalDefId,
) -> EarlyBinder<Self, Self::Ty>;
fn adt_def(self, adt_def_id: Self::AdtId) -> Self::AdtDef;
fn alias_ty_kind(self, alias: AliasTy<Self>) -> AliasTyKind;
fn alias_term_kind(self, alias: AliasTerm<Self>) -> AliasTermKind;
fn trait_ref_and_own_args_for_alias(
self,
def_id: Self::DefId,
args: Self::GenericArgs,
) -> (TraitRef<Self>, Self::GenericArgsSlice);
fn mk_args(self, args: &[Self::GenericArg]) -> Self::GenericArgs;
fn mk_args_from_iter<I, T>(self, args: I) -> T::Output
where I: Iterator<Item = T>,
T: CollectAndApply<Self::GenericArg, Self::GenericArgs>;
fn check_args_compatible(
self,
def_id: Self::DefId,
args: Self::GenericArgs,
) -> bool;
fn debug_assert_args_compatible(
self,
def_id: Self::DefId,
args: Self::GenericArgs,
);
fn debug_assert_existential_args_compatible(
self,
def_id: Self::DefId,
args: Self::GenericArgs,
);
fn mk_type_list_from_iter<I, T>(self, args: I) -> T::Output
where I: Iterator<Item = T>,
T: CollectAndApply<Self::Ty, Self::Tys>;
fn parent(self, def_id: Self::DefId) -> Self::DefId;
fn recursion_limit(self) -> usize;
fn features(self) -> Self::Features;
fn coroutine_hidden_types(
self,
def_id: Self::CoroutineId,
) -> EarlyBinder<Self, Binder<Self, CoroutineWitnessTypes<Self>>>;
fn fn_sig(
self,
def_id: Self::FunctionId,
) -> EarlyBinder<Self, Binder<Self, FnSig<Self>>>;
fn coroutine_movability(self, def_id: Self::CoroutineId) -> Movability;
fn coroutine_for_closure(
self,
def_id: Self::CoroutineClosureId,
) -> Self::CoroutineId;
fn generics_require_sized_self(self, def_id: Self::DefId) -> bool;
fn item_bounds(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>;
fn item_self_bounds(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>;
fn item_non_self_bounds(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>;
fn predicates_of(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>;
fn own_predicates_of(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>;
fn explicit_super_predicates_of(
self,
def_id: Self::TraitId,
) -> EarlyBinder<Self, impl IntoIterator<Item = (Self::Clause, Self::Span)>>;
fn explicit_implied_predicates_of(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = (Self::Clause, Self::Span)>>;
fn impl_super_outlives(
self,
impl_def_id: Self::ImplId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>;
fn impl_is_const(self, def_id: Self::ImplId) -> bool;
fn fn_is_const(self, def_id: Self::FunctionId) -> bool;
fn alias_has_const_conditions(self, def_id: Self::DefId) -> bool;
fn const_conditions(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Binder<Self, TraitRef<Self>>>>;
fn explicit_implied_const_bounds(
self,
def_id: Self::DefId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Binder<Self, TraitRef<Self>>>>;
fn impl_self_is_guaranteed_unsized(self, def_id: Self::ImplId) -> bool;
fn has_target_features(self, def_id: Self::FunctionId) -> bool;
fn require_lang_item(self, lang_item: SolverLangItem) -> Self::DefId;
fn require_trait_lang_item(
self,
lang_item: SolverTraitLangItem,
) -> Self::TraitId;
fn require_adt_lang_item(self, lang_item: SolverAdtLangItem) -> Self::AdtId;
fn is_lang_item(
self,
def_id: Self::DefId,
lang_item: SolverLangItem,
) -> bool;
fn is_trait_lang_item(
self,
def_id: Self::TraitId,
lang_item: SolverTraitLangItem,
) -> bool;
fn is_adt_lang_item(
self,
def_id: Self::AdtId,
lang_item: SolverAdtLangItem,
) -> bool;
fn is_default_trait(self, def_id: Self::TraitId) -> bool;
fn is_sizedness_trait(self, def_id: Self::TraitId) -> bool;
fn as_lang_item(self, def_id: Self::DefId) -> Option<SolverLangItem>;
fn as_trait_lang_item(
self,
def_id: Self::TraitId,
) -> Option<SolverTraitLangItem>;
fn as_adt_lang_item(self, def_id: Self::AdtId) -> Option<SolverAdtLangItem>;
fn associated_type_def_ids(
self,
def_id: Self::TraitId,
) -> impl IntoIterator<Item = Self::DefId>;
fn for_each_relevant_impl(
self,
trait_def_id: Self::TraitId,
self_ty: Self::Ty,
f: impl FnMut(Self::ImplId),
);
fn for_each_blanket_impl(
self,
trait_def_id: Self::TraitId,
f: impl FnMut(Self::ImplId),
);
fn has_item_definition(self, def_id: Self::DefId) -> bool;
fn impl_specializes(
self,
impl_def_id: Self::ImplId,
victim_def_id: Self::ImplId,
) -> bool;
fn impl_is_default(self, impl_def_id: Self::ImplId) -> bool;
fn impl_trait_ref(
self,
impl_def_id: Self::ImplId,
) -> EarlyBinder<Self, TraitRef<Self>>;
fn impl_polarity(self, impl_def_id: Self::ImplId) -> ImplPolarity;
fn trait_is_auto(self, trait_def_id: Self::TraitId) -> bool;
fn trait_is_coinductive(self, trait_def_id: Self::TraitId) -> bool;
fn trait_is_alias(self, trait_def_id: Self::TraitId) -> bool;
fn trait_is_dyn_compatible(self, trait_def_id: Self::TraitId) -> bool;
fn trait_is_fundamental(self, def_id: Self::TraitId) -> bool;
fn trait_may_be_implemented_via_object(
self,
trait_def_id: Self::TraitId,
) -> bool;
fn trait_is_unsafe(self, trait_def_id: Self::TraitId) -> bool;
fn is_impl_trait_in_trait(self, def_id: Self::DefId) -> bool;
fn delay_bug(self, msg: impl ToString) -> Self::ErrorGuaranteed;
fn is_general_coroutine(self, coroutine_def_id: Self::CoroutineId) -> bool;
fn coroutine_is_async(self, coroutine_def_id: Self::CoroutineId) -> bool;
fn coroutine_is_gen(self, coroutine_def_id: Self::CoroutineId) -> bool;
fn coroutine_is_async_gen(self, coroutine_def_id: Self::CoroutineId) -> bool;
fn unsizing_params_for_adt(
self,
adt_def_id: Self::AdtId,
) -> Self::UnsizingParams;
fn anonymize_bound_vars<T: TypeFoldable<Self>>(
self,
binder: Binder<Self, T>,
) -> Binder<Self, T>;
fn opaque_types_defined_by(
self,
defining_anchor: Self::LocalDefId,
) -> Self::LocalDefIds;
fn opaque_types_and_coroutines_defined_by(
self,
defining_anchor: Self::LocalDefId,
) -> Self::LocalDefIds;
fn mk_probe(self, probe: Probe<Self>) -> Self::Probe;
fn evaluate_root_goal_for_proof_tree_raw(
self,
canonical_goal: CanonicalInput<Self>,
) -> (QueryResult<Self>, Self::Probe);
// Provided method
fn next_trait_solver_globally(self) -> bool { ... }
}
Required Associated Types§
type DefId: DefId<Self>
type LocalDefId: Copy + Debug + Hash + Eq + Into<Self::DefId> + TypeFoldable<Self>
type TraitId: SpecificDefId<Self>
type ForeignId: SpecificDefId<Self>
type FunctionId: SpecificDefId<Self>
type ClosureId: SpecificDefId<Self>
type CoroutineClosureId: SpecificDefId<Self>
type CoroutineId: SpecificDefId<Self>
type AdtId: SpecificDefId<Self>
type ImplId: SpecificDefId<Self>
type UnevaluatedConstId: SpecificDefId<Self>
type Span: Span<Self>
type GenericArgs: GenericArgs<Self>
type GenericArgsSlice: Copy + Debug + Hash + Eq + SliceLike<Item = Self::GenericArg>
type GenericArg: GenericArg<Self>
type Term: Term<Self>
type BoundVarKinds: Copy + Debug + Hash + Eq + SliceLike<Item = Self::BoundVarKind> + Default
type BoundVarKind: Copy + Debug + Hash + Eq
type PredefinedOpaques: Copy + Debug + Hash + Eq + TypeFoldable<Self> + SliceLike<Item = (OpaqueTypeKey<Self>, Self::Ty)>
type LocalDefIds: Copy + Debug + Hash + Default + Eq + TypeVisitable<Self> + SliceLike<Item = Self::LocalDefId>
type CanonicalVarKinds: Copy + Debug + Hash + Eq + SliceLike<Item = CanonicalVarKind<Self>> + Default
type ExternalConstraints: Copy + Debug + Hash + Eq + TypeFoldable<Self> + Deref<Target = ExternalConstraintsData<Self>>
type DepNodeIndex
type Tracked<T: Debug + Clone>: Debug
type Ty: Ty<Self>
type Tys: Tys<Self>
type FnInputTys: Copy + Debug + Hash + Eq + SliceLike<Item = Self::Ty> + TypeVisitable<Self>
type ParamTy: ParamLike
type BoundTy: BoundVarLike<Self>
type PlaceholderTy: PlaceholderLike<Self, Bound = Self::BoundTy>
type Symbol: Copy + Hash + PartialEq + Eq + Debug
type ErrorGuaranteed: Copy + Debug + Hash + Eq
type BoundExistentialPredicates: BoundExistentialPredicates<Self>
type AllocId: Copy + Debug + Hash + Eq
type Pat: Copy + Debug + Hash + Eq + Relate<Self> + Flags + IntoKind<Kind = PatternKind<Self>>
type PatList: Copy + Debug + Hash + Default + Eq + TypeVisitable<Self> + SliceLike<Item = Self::Pat>
type Safety: Safety<Self>
type Abi: Abi<Self>
type Const: Const<Self>
type ParamConst: Copy + Debug + Hash + Eq + ParamLike
type BoundConst: BoundVarLike<Self>
type PlaceholderConst: PlaceholderConst<Self>
type ValueConst: ValueConst<Self>
type ExprConst: ExprConst<Self>
type ValTree: Copy + Debug + Hash + Eq
type Region: Region<Self>
type EarlyParamRegion: ParamLike
type LateParamRegion: Copy + Debug + Hash + Eq
type BoundRegion: BoundVarLike<Self>
type PlaceholderRegion: PlaceholderLike<Self, Bound = Self::BoundRegion>
type RegionAssumptions: Copy + Debug + Hash + Eq + SliceLike<Item = OutlivesPredicate<Self, Self::GenericArg>> + TypeFoldable<Self>
type ParamEnv: ParamEnv<Self>
type Predicate: Predicate<Self>
type Clause: Clause<Self>
type Clauses: Clauses<Self>
type GenericsOf: GenericsOf<Self>
type VariancesOf: Copy + Debug + SliceLike<Item = Variance>
type AdtDef: AdtDef<Self>
type Features: Features<Self>
type UnsizingParams: Deref<Target = DenseBitSet<u32>>
type Probe: Debug + Hash + Eq + Borrow<Probe<Self>>
Required Methods§
fn mk_predefined_opaques_in_body( self, data: &[(OpaqueTypeKey<Self>, Self::Ty)], ) -> Self::PredefinedOpaques
fn mk_canonical_var_kinds( self, kinds: &[CanonicalVarKind<Self>], ) -> Self::CanonicalVarKinds
fn mk_external_constraints( self, data: ExternalConstraintsData<Self>, ) -> Self::ExternalConstraints
fn mk_tracked<T: Debug + Clone>( self, data: T, dep_node: Self::DepNodeIndex, ) -> Self::Tracked<T>
fn get_tracked<T: Debug + Clone>(self, tracked: &Self::Tracked<T>) -> T
fn with_cached_task<T>( self, task: impl FnOnce() -> T, ) -> (T, Self::DepNodeIndex)
fn with_global_cache<R>(self, f: impl FnOnce(&mut GlobalCache<Self>) -> R) -> R
fn canonical_param_env_cache_get_or_insert<R>( self, param_env: Self::ParamEnv, f: impl FnOnce() -> CanonicalParamEnvCacheEntry<Self>, from_entry: impl FnOnce(&CanonicalParamEnvCacheEntry<Self>) -> R, ) -> R
Sourcefn assert_evaluation_is_concurrent(&self)
fn assert_evaluation_is_concurrent(&self)
Useful for testing. If a cache entry is replaced, this should (in theory) only happen when concurrent.
fn expand_abstract_consts<T: TypeFoldable<Self>>(self, t: T) -> T
fn generics_of(self, def_id: Self::DefId) -> Self::GenericsOf
fn variances_of(self, def_id: Self::DefId) -> Self::VariancesOf
fn opt_alias_variances( self, kind: impl Into<AliasTermKind>, def_id: Self::DefId, ) -> Option<Self::VariancesOf>
fn type_of(self, def_id: Self::DefId) -> EarlyBinder<Self, Self::Ty>
fn type_of_opaque_hir_typeck( self, def_id: Self::LocalDefId, ) -> EarlyBinder<Self, Self::Ty>
fn adt_def(self, adt_def_id: Self::AdtId) -> Self::AdtDef
fn alias_ty_kind(self, alias: AliasTy<Self>) -> AliasTyKind
fn alias_term_kind(self, alias: AliasTerm<Self>) -> AliasTermKind
fn trait_ref_and_own_args_for_alias( self, def_id: Self::DefId, args: Self::GenericArgs, ) -> (TraitRef<Self>, Self::GenericArgsSlice)
fn mk_args(self, args: &[Self::GenericArg]) -> Self::GenericArgs
fn mk_args_from_iter<I, T>(self, args: I) -> T::Output
fn check_args_compatible( self, def_id: Self::DefId, args: Self::GenericArgs, ) -> bool
fn debug_assert_args_compatible( self, def_id: Self::DefId, args: Self::GenericArgs, )
Sourcefn debug_assert_existential_args_compatible(
self,
def_id: Self::DefId,
args: Self::GenericArgs,
)
fn debug_assert_existential_args_compatible( self, def_id: Self::DefId, args: Self::GenericArgs, )
Assert that the args from an ExistentialTraitRef
or ExistentialProjection
are compatible with the DefId
.
fn mk_type_list_from_iter<I, T>(self, args: I) -> T::Output
fn parent(self, def_id: Self::DefId) -> Self::DefId
fn recursion_limit(self) -> usize
fn features(self) -> Self::Features
fn fn_sig( self, def_id: Self::FunctionId, ) -> EarlyBinder<Self, Binder<Self, FnSig<Self>>>
fn coroutine_movability(self, def_id: Self::CoroutineId) -> Movability
fn coroutine_for_closure( self, def_id: Self::CoroutineClosureId, ) -> Self::CoroutineId
fn generics_require_sized_self(self, def_id: Self::DefId) -> bool
fn item_bounds( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
fn item_self_bounds( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
fn item_non_self_bounds( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
fn predicates_of( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
fn own_predicates_of( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
fn explicit_super_predicates_of( self, def_id: Self::TraitId, ) -> EarlyBinder<Self, impl IntoIterator<Item = (Self::Clause, Self::Span)>>
fn explicit_implied_predicates_of( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = (Self::Clause, Self::Span)>>
Sourcefn impl_super_outlives(
self,
impl_def_id: Self::ImplId,
) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
fn impl_super_outlives( self, impl_def_id: Self::ImplId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Self::Clause>>
This is equivalent to computing the super-predicates of the trait for this impl and filtering them to the outlives predicates. This is purely for performance.
fn impl_is_const(self, def_id: Self::ImplId) -> bool
fn fn_is_const(self, def_id: Self::FunctionId) -> bool
fn alias_has_const_conditions(self, def_id: Self::DefId) -> bool
fn const_conditions( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Binder<Self, TraitRef<Self>>>>
fn explicit_implied_const_bounds( self, def_id: Self::DefId, ) -> EarlyBinder<Self, impl IntoIterator<Item = Binder<Self, TraitRef<Self>>>>
fn impl_self_is_guaranteed_unsized(self, def_id: Self::ImplId) -> bool
fn has_target_features(self, def_id: Self::FunctionId) -> bool
fn require_lang_item(self, lang_item: SolverLangItem) -> Self::DefId
fn require_trait_lang_item( self, lang_item: SolverTraitLangItem, ) -> Self::TraitId
fn require_adt_lang_item(self, lang_item: SolverAdtLangItem) -> Self::AdtId
fn is_lang_item(self, def_id: Self::DefId, lang_item: SolverLangItem) -> bool
fn is_trait_lang_item( self, def_id: Self::TraitId, lang_item: SolverTraitLangItem, ) -> bool
fn is_adt_lang_item( self, def_id: Self::AdtId, lang_item: SolverAdtLangItem, ) -> bool
fn is_default_trait(self, def_id: Self::TraitId) -> bool
fn is_sizedness_trait(self, def_id: Self::TraitId) -> bool
fn as_lang_item(self, def_id: Self::DefId) -> Option<SolverLangItem>
fn as_trait_lang_item( self, def_id: Self::TraitId, ) -> Option<SolverTraitLangItem>
fn as_adt_lang_item(self, def_id: Self::AdtId) -> Option<SolverAdtLangItem>
fn associated_type_def_ids( self, def_id: Self::TraitId, ) -> impl IntoIterator<Item = Self::DefId>
fn for_each_relevant_impl( self, trait_def_id: Self::TraitId, self_ty: Self::Ty, f: impl FnMut(Self::ImplId), )
fn for_each_blanket_impl( self, trait_def_id: Self::TraitId, f: impl FnMut(Self::ImplId), )
fn has_item_definition(self, def_id: Self::DefId) -> bool
fn impl_specializes( self, impl_def_id: Self::ImplId, victim_def_id: Self::ImplId, ) -> bool
fn impl_is_default(self, impl_def_id: Self::ImplId) -> bool
fn impl_trait_ref( self, impl_def_id: Self::ImplId, ) -> EarlyBinder<Self, TraitRef<Self>>
fn impl_polarity(self, impl_def_id: Self::ImplId) -> ImplPolarity
fn trait_is_auto(self, trait_def_id: Self::TraitId) -> bool
fn trait_is_coinductive(self, trait_def_id: Self::TraitId) -> bool
fn trait_is_alias(self, trait_def_id: Self::TraitId) -> bool
fn trait_is_dyn_compatible(self, trait_def_id: Self::TraitId) -> bool
fn trait_is_fundamental(self, def_id: Self::TraitId) -> bool
fn trait_may_be_implemented_via_object( self, trait_def_id: Self::TraitId, ) -> bool
Sourcefn trait_is_unsafe(self, trait_def_id: Self::TraitId) -> bool
fn trait_is_unsafe(self, trait_def_id: Self::TraitId) -> bool
Returns true
if this is an unsafe trait
.
fn is_impl_trait_in_trait(self, def_id: Self::DefId) -> bool
fn delay_bug(self, msg: impl ToString) -> Self::ErrorGuaranteed
fn is_general_coroutine(self, coroutine_def_id: Self::CoroutineId) -> bool
fn coroutine_is_async(self, coroutine_def_id: Self::CoroutineId) -> bool
fn coroutine_is_gen(self, coroutine_def_id: Self::CoroutineId) -> bool
fn coroutine_is_async_gen(self, coroutine_def_id: Self::CoroutineId) -> bool
fn unsizing_params_for_adt( self, adt_def_id: Self::AdtId, ) -> Self::UnsizingParams
fn anonymize_bound_vars<T: TypeFoldable<Self>>( self, binder: Binder<Self, T>, ) -> Binder<Self, T>
fn opaque_types_defined_by( self, defining_anchor: Self::LocalDefId, ) -> Self::LocalDefIds
fn opaque_types_and_coroutines_defined_by( self, defining_anchor: Self::LocalDefId, ) -> Self::LocalDefIds
fn mk_probe(self, probe: Probe<Self>) -> Self::Probe
fn evaluate_root_goal_for_proof_tree_raw( self, canonical_goal: CanonicalInput<Self>, ) -> (QueryResult<Self>, Self::Probe)
Provided Methods§
fn next_trait_solver_globally(self) -> bool
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.