pub struct LintLevelsBuilder<'s, P> {
sess: &'s Session,
features: &'s Features,
provider: P,
lint_added_lints: bool,
store: &'s LintStore,
registered_tools: &'s RegisteredTools,
}
Fields§
§sess: &'s Session
§features: &'s Features
§provider: P
§lint_added_lints: bool
§store: &'s LintStore
§registered_tools: &'s RegisteredTools
Implementations§
Source§impl<'tcx> LintLevelsBuilder<'_, LintLevelQueryMap<'tcx>>
impl<'tcx> LintLevelsBuilder<'_, LintLevelQueryMap<'tcx>>
Source§impl<'s> LintLevelsBuilder<'s, TopDown>
impl<'s> LintLevelsBuilder<'s, TopDown>
pub(crate) fn new( sess: &'s Session, features: &'s Features, lint_added_lints: bool, store: &'s LintStore, registered_tools: &'s RegisteredTools, ) -> Self
fn process_command_line(&mut self)
Sourcepub(crate) fn push(
&mut self,
attrs: &[Attribute],
is_crate_node: bool,
source_hir_id: Option<HirId>,
) -> BuilderPush
pub(crate) fn push( &mut self, attrs: &[Attribute], is_crate_node: bool, source_hir_id: Option<HirId>, ) -> BuilderPush
Pushes a list of AST lint attributes onto this context.
This function will return a BuilderPush
object which should be passed
to pop
when this scope for the attributes provided is exited.
This function will perform a number of tasks:
- It’ll validate all lint-related attributes in
attrs
- It’ll mark all lint-related attributes as used
- Lint levels will be updated based on the attributes provided
- Lint attributes are validated, e.g., a
#[forbid]
can’t be switched to#[allow]
Don’t forget to call pop
!
Sourcepub(crate) fn pop(&mut self, push: BuilderPush)
pub(crate) fn pop(&mut self, push: BuilderPush)
Called after push
when the scope of a set of attributes are exited.
Source§impl<'s, P: LintLevelsProvider> LintLevelsBuilder<'s, P>
impl<'s, P: LintLevelsProvider> LintLevelsBuilder<'s, P>
pub(crate) fn sess(&self) -> &Session
pub(crate) fn features(&self) -> &Features
fn current_specs(&self) -> &FxIndexMap<LintId, LevelAndSource>
fn insert(&mut self, id: LintId, lvl: LevelAndSource)
fn add_command_line(&mut self)
Sourcefn insert_spec(&mut self, id: LintId, (level, src): LevelAndSource)
fn insert_spec(&mut self, id: LintId, (level, src): LevelAndSource)
Attempts to insert the id
to level_src
map entry. If unsuccessful
(e.g. if a forbid was already inserted on the same scope), then emits a
diagnostic with no change to specs
.
fn add( &mut self, attrs: &[impl AttributeExt], is_crate_node: bool, source_hir_id: Option<HirId>, )
Sourcefn check_gated_lint(
&self,
lint_id: LintId,
span: Span,
lint_from_cli: bool,
) -> bool
fn check_gated_lint( &self, lint_id: LintId, span: Span, lint_from_cli: bool, ) -> bool
Checks if the lint is gated on a feature that is not enabled.
Returns true
if the lint’s feature is enabled.
Sourcepub fn lint_level(&self, lint: &'static Lint) -> LevelAndSource
pub fn lint_level(&self, lint: &'static Lint) -> LevelAndSource
Find the lint level for a lint.
Sourcepub(crate) fn opt_span_lint(
&self,
lint: &'static Lint,
span: Option<MultiSpan>,
decorate: impl for<'a, 'b> FnOnce(&'b mut Diag<'a, ()>),
)
pub(crate) fn opt_span_lint( &self, lint: &'static Lint, span: Option<MultiSpan>, decorate: impl for<'a, 'b> FnOnce(&'b mut Diag<'a, ()>), )
Used to emit a lint-related diagnostic based on the current state of this lint context.
pub fn emit_span_lint( &self, lint: &'static Lint, span: MultiSpan, decorate: impl for<'a> LintDiagnostic<'a, ()>, )
pub fn emit_lint( &self, lint: &'static Lint, decorate: impl for<'a> LintDiagnostic<'a, ()>, )
Trait Implementations§
Source§impl<'tcx> Visitor<'tcx> for LintLevelsBuilder<'_, LintLevelQueryMap<'tcx>>
impl<'tcx> Visitor<'tcx> for LintLevelsBuilder<'_, LintLevelQueryMap<'tcx>>
Source§type NestedFilter = OnlyBodies
type NestedFilter = OnlyBodies
NestedFilter
for details. If you override this type, you
must also override nested_visit_map
. Read moreSource§fn nested_visit_map(&mut self) -> Self::Map
fn nested_visit_map(&mut self) -> Self::Map
type NestedFilter
is set to visit nested items, this method
must also be overridden to provide a map to retrieve nested items.fn visit_param(&mut self, param: &'tcx Param<'tcx>)
Source§fn visit_item(&mut self, it: &'tcx Item<'tcx>)
fn visit_item(&mut self, it: &'tcx Item<'tcx>)
visit_nested_item
for details.fn visit_foreign_item(&mut self, it: &'tcx ForeignItem<'tcx>)
fn visit_stmt(&mut self, s: &'tcx Stmt<'tcx>)
fn visit_expr(&mut self, e: &'tcx Expr<'tcx>)
fn visit_expr_field(&mut self, f: &'tcx ExprField<'tcx>)
fn visit_field_def(&mut self, s: &'tcx FieldDef<'tcx>)
fn visit_variant(&mut self, v: &'tcx Variant<'tcx>)
fn visit_local(&mut self, l: &'tcx LetStmt<'tcx>)
fn visit_arm(&mut self, a: &'tcx Arm<'tcx>)
fn visit_trait_item(&mut self, trait_item: &'tcx TraitItem<'tcx>)
fn visit_impl_item(&mut self, impl_item: &'tcx ImplItem<'tcx>)
type Map = <Self::NestedFilter as NestedFilter<'v>>::Map
Source§fn visit_nested_item(&mut self, id: ItemId) -> Self::Result
fn visit_nested_item(&mut self, id: ItemId) -> Self::Result
Self::NestedFilter
is nested_filter::None
, this method does
nothing. You probably don’t want to override this method –
instead, override Self::NestedFilter
or use the “shallow” or
“deep” visit patterns described at
rustc_hir::intravisit
. The only reason to override
this method is if you want a nested pattern but cannot supply a
Map
; see nested_visit_map
for advice.Source§fn visit_nested_trait_item(&mut self, id: TraitItemId) -> Self::Result
fn visit_nested_trait_item(&mut self, id: TraitItemId) -> Self::Result
visit_nested_item()
, but for trait items. See
visit_nested_item()
for advice on when to override this
method.Source§fn visit_nested_impl_item(&mut self, id: ImplItemId) -> Self::Result
fn visit_nested_impl_item(&mut self, id: ImplItemId) -> Self::Result
visit_nested_item()
, but for impl items. See
visit_nested_item()
for advice on when to override this
method.Source§fn visit_nested_foreign_item(&mut self, id: ForeignItemId) -> Self::Result
fn visit_nested_foreign_item(&mut self, id: ForeignItemId) -> Self::Result
visit_nested_item()
, but for foreign items. See
visit_nested_item()
for advice on when to override this
method.Source§fn visit_nested_body(&mut self, id: BodyId) -> Self::Result
fn visit_nested_body(&mut self, id: BodyId) -> Self::Result
visit_nested_item
, does nothing by default unless you override
Self::NestedFilter
.fn visit_body(&mut self, b: &Body<'v>) -> Self::Result
fn visit_id(&mut self, _hir_id: HirId) -> Self::Result
fn visit_name(&mut self, _name: Symbol) -> Self::Result
fn visit_ident(&mut self, ident: Ident) -> Self::Result
fn visit_mod(&mut self, m: &'v Mod<'v>, _s: Span, n: HirId) -> Self::Result
fn visit_block(&mut self, b: &'v Block<'v>) -> Self::Result
fn visit_pat(&mut self, p: &'v Pat<'v>) -> Self::Result
fn visit_pat_field(&mut self, f: &'v PatField<'v>) -> Self::Result
fn visit_anon_const(&mut self, c: &'v AnonConst) -> Self::Result
fn visit_inline_const(&mut self, c: &'v ConstBlock) -> Self::Result
fn visit_const_arg(&mut self, c: &'v ConstArg<'v>) -> Self::Result
fn visit_ty(&mut self, t: &'v Ty<'v>) -> Self::Result
fn visit_pattern_type_pattern(&mut self, _p: &'v Pat<'v>)
fn visit_generic_param(&mut self, p: &'v GenericParam<'v>) -> Self::Result
fn visit_const_param_default( &mut self, _param: HirId, ct: &'v ConstArg<'v>, ) -> Self::Result
fn visit_generics(&mut self, g: &'v Generics<'v>) -> Self::Result
fn visit_where_predicate( &mut self, predicate: &'v WherePredicate<'v>, ) -> Self::Result
fn visit_fn_ret_ty(&mut self, ret_ty: &'v FnRetTy<'v>) -> Self::Result
fn visit_fn_decl(&mut self, fd: &'v FnDecl<'v>) -> Self::Result
fn visit_fn( &mut self, fk: FnKind<'v>, fd: &'v FnDecl<'v>, b: BodyId, _: Span, id: LocalDefId, ) -> Self::Result
fn visit_use( &mut self, path: &'v Path<'v, SmallVec<[Res; 3]>>, hir_id: HirId, ) -> Self::Result
fn visit_trait_item_ref(&mut self, ii: &'v TraitItemRef) -> Self::Result
fn visit_foreign_item_ref(&mut self, ii: &'v ForeignItemRef) -> Self::Result
fn visit_impl_item_ref(&mut self, ii: &'v ImplItemRef) -> Self::Result
fn visit_trait_ref(&mut self, t: &'v TraitRef<'v>) -> Self::Result
fn visit_param_bound(&mut self, bounds: &'v GenericBound<'v>) -> Self::Result
fn visit_precise_capturing_arg( &mut self, arg: &'v PreciseCapturingArg<'v>, ) -> Self::Result
fn visit_poly_trait_ref(&mut self, t: &'v PolyTraitRef<'v>) -> Self::Result
fn visit_opaque_ty(&mut self, opaque: &'v OpaqueTy<'v>) -> Self::Result
fn visit_variant_data(&mut self, s: &'v VariantData<'v>) -> Self::Result
fn visit_enum_def( &mut self, enum_definition: &'v EnumDef<'v>, item_id: HirId, ) -> Self::Result
fn visit_label(&mut self, label: &'v Label) -> Self::Result
fn visit_infer(&mut self, inf: &'v InferArg) -> Self::Result
fn visit_generic_arg(&mut self, generic_arg: &'v GenericArg<'v>) -> Self::Result
fn visit_lifetime(&mut self, lifetime: &'v Lifetime) -> Self::Result
fn visit_qpath( &mut self, qpath: &'v QPath<'v>, id: HirId, _span: Span, ) -> Self::Result
fn visit_path(&mut self, path: &Path<'v>, _id: HirId) -> Self::Result
fn visit_path_segment( &mut self, path_segment: &'v PathSegment<'v>, ) -> Self::Result
fn visit_generic_args( &mut self, generic_args: &'v GenericArgs<'v>, ) -> Self::Result
fn visit_assoc_item_constraint( &mut self, constraint: &'v AssocItemConstraint<'v>, ) -> Self::Result
fn visit_attribute(&mut self, _attr: &'v Attribute) -> Self::Result
fn visit_associated_item_kind( &mut self, kind: &'v AssocItemKind, ) -> Self::Result
fn visit_defaultness(&mut self, defaultness: &'v Defaultness) -> Self::Result
fn visit_inline_asm( &mut self, asm: &'v InlineAsm<'v>, id: HirId, ) -> Self::Result
Auto Trait Implementations§
impl<'s, P> DynSend for LintLevelsBuilder<'s, P>where
P: DynSend,
impl<'s, P> DynSync for LintLevelsBuilder<'s, P>where
P: DynSync,
impl<'s, P> Freeze for LintLevelsBuilder<'s, P>where
P: Freeze,
impl<'s, P> !RefUnwindSafe for LintLevelsBuilder<'s, P>
impl<'s, P> !Send for LintLevelsBuilder<'s, P>
impl<'s, P> !Sync for LintLevelsBuilder<'s, P>
impl<'s, P> Unpin for LintLevelsBuilder<'s, P>where
P: Unpin,
impl<'s, P> !UnwindSafe for LintLevelsBuilder<'s, P>
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
Source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
Source§impl<T> Filterable for T
impl<T> Filterable for T
Source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
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<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>
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>
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 moreSource§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
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
Source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> 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<T> ErasedDestructor for Twhere
T: 'static,
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.