Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rollup of 5 pull requests #117538

Merged
merged 86 commits into from
Nov 3, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
5e17f9f
Skip if_not_else lint for '!= 0'-style checks
BenWiederhake Jun 25, 2023
438f934
suggest passing function instead of calling it in [`option_if_let_else`]
J-ZhengLi Sep 4, 2023
22ba792
Update clippy_lints/src/option_if_let_else.rs
J-ZhengLi Sep 12, 2023
fb4f603
Apply suggestions from code review
J-ZhengLi Sep 14, 2023
f4a8b12
Wrap with parenthesis if necessary
koka831 Sep 29, 2023
536114c
[`ignored_unit_patterns`]: check &(), &&(), ...
lengyijun Oct 15, 2023
4fc503e
Avoid a `track_errors` by bubbling up most errors from `check_well_fo…
oli-obk Oct 18, 2023
8e7d167
Merge commit '2b030eb03d9e5837440b1ee0b98c50b97c0c5889' into clippyup
flip1995 Oct 21, 2023
d6fc606
[`map_identity`]: recognize tuples
y21 Jun 13, 2023
56c8235
Auto merge of #10943 - y21:issue7189, r=llogiq
bors Oct 21, 2023
87d0ace
use visibility to check unused imports and delete some stmts
bvanjoi Oct 15, 2023
3c501e4
[`iter_without_into_iter`]: fix papercuts + only lint on pub types
y21 Oct 22, 2023
f942470
Auto merge of #11028 - BenWiederhake:dev-ifnotelse_neqzero, r=llogiq
bors Oct 23, 2023
350a682
Auto merge of #116849 - oli-obk:error_shenanigans, r=cjgillot
bors Oct 23, 2023
56ece10
Use `no_run` for doc-tests in new lints
Alexendoo Oct 23, 2023
9f5de66
Auto merge of #11460 - J-ZhengLi:issue11429, r=Centri3
bors Oct 23, 2023
7347c18
Set existing doc-tests to `no_run`
Alexendoo Oct 23, 2023
033c763
Auto merge of #11699 - Alexendoo:no-run-doctests, r=llogiq
bors Oct 23, 2023
e1b287c
Use multiple pushes in `vec_init_then_push` example
Alexendoo Oct 23, 2023
7ade24e
Fix stable feature names in tests
dtolnay Oct 15, 2023
4622203
Move configuration to new `clippy_config` crate
Alexendoo Oct 19, 2023
330d7fa
Auto merge of #116033 - bvanjoi:fix-116032, r=petrochenkov
bors Oct 23, 2023
f879096
Add a lint to check needless `Waker` clones
a1phyr Oct 23, 2023
7df1c8a
Hide config implementation details from public docs
Alexendoo Oct 19, 2023
4eb4192
Auto merge of #11685 - Alexendoo:clippy_config, r=flip1995
bors Oct 24, 2023
cd6ec97
Auto merge of #116773 - dtolnay:validatestable, r=compiler-errors
bors Oct 24, 2023
f4f5b05
Handle structured stable attribute 'since' version in clippy
dtolnay Oct 25, 2023
76d7af0
Expose a non-Symbol way to access current rustc version string
dtolnay Oct 25, 2023
ffc7419
Work around the fact that `check_mod_type_wf` may spuriously return `…
oli-obk Oct 25, 2023
0580080
Remove the `internal_warn` lint category
Alexendoo Oct 25, 2023
ebf6667
Apply suggestions
a1phyr Oct 25, 2023
c337899
Rename `AsyncCoroutineKind` to `CoroutineSource`
oli-obk Oct 23, 2023
7ce6e0d
Auto merge of #11670 - lengyijun:ignored_unit_pattern_ref, r=dswij
bors Oct 25, 2023
ebe63cd
Stop telling people to submit bugs for internal feature ICEs
Noratrieb Oct 16, 2023
5f19fac
Rollup merge of #117175 - oli-obk:gen_fn_split, r=compiler-errors
matthiaskrgr Oct 25, 2023
45f94c7
mention restriction to exported types as a limitation
y21 Oct 25, 2023
d914890
Auto merge of #116818 - Nilstrieb:stop-submitting-bug-reports, r=wesl…
bors Oct 26, 2023
3e05710
Auto merge of #117148 - dtolnay:sinceversion, r=cjgillot
bors Oct 26, 2023
0da4dab
Auto merge of #11584 - koka831:fix/11335, r=blyxyas
bors Oct 26, 2023
392b255
Auto merge of #11712 - Alexendoo:remove-internal-warn, r=dswij
bors Oct 26, 2023
2f0f4dd
Auto merge of #11698 - a1phyr:waker_clone_and_wake, r=y21
bors Oct 26, 2023
d736992
Parse rustc version at compile time
dtolnay Oct 27, 2023
0c8caee
Add gen blocks to ast and do some broken ast lowering
oli-obk Oct 20, 2023
f4b4e2c
Remove internal feature from clippy_utils
Alexendoo Oct 27, 2023
1ed1001
Fix missing parenthesis in suboptimal floating point help
llogiq Oct 27, 2023
58fe451
Expand docs on clippy::todo
Wilfred Oct 27, 2023
9a10d32
reword limitation section
y21 Oct 28, 2023
f8409ef
Auto merge of #11696 - y21:iter_without_into_iter_suggestion, r=xFrednet
bors Oct 28, 2023
5852ca8
Auto merge of #11724 - rust-lang:fix-11559, r=blyxyas
bors Oct 28, 2023
2fea83b
move `read_zero_byte_vec` to nursery
dswij Oct 28, 2023
f2a0776
Auto merge of #116447 - oli-obk:gen_fn, r=compiler-errors
bors Oct 29, 2023
2030c58
Fix some typos
cuishuang Oct 29, 2023
a40958a
Auto merge of #11730 - cuishuang:master, r=dswij
bors Oct 29, 2023
fa6fd8c
Auto merge of #11726 - Wilfred:todo_docs, r=dswij
bors Oct 29, 2023
c51e2a0
fix enum_variant_names depending lint depending on order
jonboh Sep 13, 2023
e6c804c
ignore lower-camel-case words in `doc_markdown`
llogiq Oct 29, 2023
739f9e2
Auto merge of #11727 - dswij:read-zero-byte-vec-nursery, r=Centri3
bors Oct 29, 2023
2e907aa
Rename Since -> StableSince in preparation for a DeprecatedSince
dtolnay Oct 26, 2023
e245f7c
Auto merge of #11735 - rust-lang:fix-11568, r=blyxyas
bors Oct 30, 2023
325e9fd
Auto merge of #11723 - Alexendoo:clippy-utils-internal, r=Jarcho
bors Oct 30, 2023
cdc4d56
Auto merge of #11701 - Alexendoo:vec-init-then-push-docs, r=Jarcho
bors Oct 30, 2023
69c3b9c
new lint: `unnecessary_fallible_conversions`
y21 Oct 14, 2023
3da80dc
Auto merge of #11498 - jonboh:issue11494_enumvariants_order_affects_l…
bors Oct 31, 2023
7d34406
Auto merge of #11669 - y21:issue11577, r=Jarcho
bors Oct 31, 2023
c872ccc
delegate box error provide
BugenZhao Oct 31, 2023
0b90f72
feat: unused_enumerate_index lint
dnbln Feb 26, 2023
14b8290
Apply suggestions from code review
dnbln Oct 12, 2023
bb9cc6d
refactor: extract common pat_is_wild to clippy_utils
dnbln Nov 1, 2023
919f698
Auto merge of #10404 - dnbln:feat/unused_enumerate_index, r=blyxyas
bors Nov 1, 2023
3b759bc
fix get_first false negative for VecDeque
matthri Nov 1, 2023
61c76dd
remove code duplication
matthri Nov 1, 2023
01a0a36
Auto merge of #11744 - matthri:get-first-deque-fix, r=Jarcho
bors Nov 2, 2023
95dc7be
Merge remote-tracking branch 'upstream/master' into rustup
flip1995 Nov 2, 2023
5eee19e
Bump nightly version -> 2023-11-02
flip1995 Nov 2, 2023
62a82b3
Format let-chains across the code base
flip1995 Nov 2, 2023
09ac14c
Auto merge of #11747 - flip1995:rustup, r=flip1995
bors Nov 2, 2023
257147a
Merge commit '09ac14c901abc43bd0d617ae4a44e8a4fed98d9c' into clippyup
flip1995 Nov 2, 2023
02562bf
Update Cargo.lock
flip1995 Nov 2, 2023
c5895c4
oli.pause()
compiler-errors Nov 2, 2023
9e7345b
Fix incorrect trait bound restriction suggestion
estebank Nov 2, 2023
fedfca7
Revert "bootstrap: do not purge docs on CI environment"
onur-ozkan Nov 3, 2023
958a6af
Rollup merge of #117434 - BugenZhao:box-error-provide, r=cuviper
matthiaskrgr Nov 3, 2023
6cb627b
Rollup merge of #117505 - estebank:issue-117501, r=TaKO8Ki
matthiaskrgr Nov 3, 2023
9028ce3
Rollup merge of #117520 - flip1995:clippyup, r=Manishearth
matthiaskrgr Nov 3, 2023
7a0df44
Rollup merge of #117523 - compiler-errors:oli-vacation, r=compiler-er…
matthiaskrgr Nov 3, 2023
c0fa97c
Rollup merge of #117533 - onur-ozkan:revert-117471, r=onur-ozkan
matthiaskrgr Nov 3, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Remove the internal_warn lint category
  • Loading branch information
Alexendoo committed Oct 25, 2023
commit 0580080940d3d330512edb4f192a21943523c778
1 change: 0 additions & 1 deletion clippy_dev/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -199,7 +199,6 @@ fn get_clap_config() -> ArgMatches {
"cargo",
"nursery",
"internal",
"internal_warn",
]),
Arg::new("type").long("type").help("What directory the lint belongs in"),
Arg::new("msrv")
Expand Down
2 changes: 1 addition & 1 deletion clippy_dev/src/update_lints.rs
Original file line number Diff line number Diff line change
Expand Up @@ -588,7 +588,7 @@ impl Lint {
.collect()
}

/// Returns all internal lints (not `internal_warn` lints)
/// Returns all internal lints
#[must_use]
fn internal_lints(lints: &[Self]) -> Vec<Self> {
lints.iter().filter(|l| l.group == "internal").cloned().collect()
Expand Down
6 changes: 4 additions & 2 deletions clippy_lints/src/declared_lints.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ pub(crate) static LINTS: &[&crate::LintInfo] = &[
#[cfg(feature = "internal")]
crate::utils::internal_lints::almost_standard_lint_formulation::ALMOST_STANDARD_LINT_FORMULATION_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::clippy_lints_internal::CLIPPY_LINTS_INTERNAL_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::collapsible_calls::COLLAPSIBLE_SPAN_LINT_CALLS_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::compiler_lint_functions::COMPILER_LINT_FUNCTIONS_INFO,
Expand All @@ -30,13 +28,17 @@ pub(crate) static LINTS: &[&crate::LintInfo] = &[
#[cfg(feature = "internal")]
crate::utils::internal_lints::lint_without_lint_pass::MISSING_CLIPPY_VERSION_ATTRIBUTE_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::metadata_collector::METADATA_COLLECTOR_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::msrv_attr_impl::MISSING_MSRV_ATTR_IMPL_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::outer_expn_data_pass::OUTER_EXPN_EXPN_DATA_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::produce_ice::PRODUCE_ICE_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::unnecessary_def_path::UNNECESSARY_DEF_PATH_INFO,
#[cfg(feature = "internal")]
crate::utils::internal_lints::unsorted_clippy_utils_paths::UNSORTED_CLIPPY_UTILS_PATHS_INFO,
crate::absolute_paths::ABSOLUTE_PATHS_INFO,
crate::allow_attributes::ALLOW_ATTRIBUTES_INFO,
crate::almost_complete_range::ALMOST_COMPLETE_RANGE_INFO,
Expand Down
4 changes: 3 additions & 1 deletion clippy_lints/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -513,7 +513,9 @@ pub fn register_plugins(store: &mut rustc_lint::LintStore, sess: &Session, conf:
// all the internal lints
#[cfg(feature = "internal")]
{
store.register_early_pass(|| Box::new(utils::internal_lints::clippy_lints_internal::ClippyLintsInternal));
store.register_early_pass(|| {
Box::new(utils::internal_lints::unsorted_clippy_utils_paths::UnsortedClippyUtilsPaths)
});
store.register_early_pass(|| Box::new(utils::internal_lints::produce_ice::ProduceIce));
store.register_late_pass(|_| Box::new(utils::internal_lints::collapsible_calls::CollapsibleCalls));
store.register_late_pass(|_| {
Expand Down
12 changes: 4 additions & 8 deletions clippy_lints/src/utils/author.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,12 @@ use rustc_hir::{
ArrayLen, BindingAnnotation, Closure, ExprKind, FnRetTy, HirId, Lit, PatKind, QPath, StmtKind, TyKind,
};
use rustc_lint::{LateContext, LateLintPass, LintContext};
use rustc_session::{declare_lint_pass, declare_tool_lint};
use rustc_session::declare_lint_pass;
use rustc_span::symbol::{Ident, Symbol};
use std::cell::Cell;
use std::fmt::{Display, Formatter, Write as _};

declare_clippy_lint! {
declare_lint_pass!(
/// ### What it does
/// Generates clippy code that detects the offending pattern
///
Expand Down Expand Up @@ -47,12 +47,8 @@ declare_clippy_lint! {
/// // report your lint here
/// }
/// ```
pub LINT_AUTHOR,
internal_warn,
"helper for writing lints"
}

declare_lint_pass!(Author => [LINT_AUTHOR]);
Author => []
);

/// Writes a line of output with indentation added
macro_rules! out {
Expand Down
12 changes: 4 additions & 8 deletions clippy_lints/src/utils/dump_hir.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@ use clippy_utils::get_attr;
use hir::TraitItem;
use rustc_hir as hir;
use rustc_lint::{LateContext, LateLintPass, LintContext};
use rustc_session::{declare_lint_pass, declare_tool_lint};
use rustc_session::declare_lint_pass;

declare_clippy_lint! {
declare_lint_pass!(
/// ### What it does
/// It formats the attached node with `{:#?}` and writes the result to the
/// standard output. This is intended for debugging.
Expand All @@ -19,12 +19,8 @@ declare_clippy_lint! {
/// input as u64
/// }
/// ```
pub DUMP_HIR,
internal_warn,
"helper to dump info about code"
}

declare_lint_pass!(DumpHir => [DUMP_HIR]);
DumpHir => []
);

impl<'tcx> LateLintPass<'tcx> for DumpHir {
fn check_item(&mut self, cx: &LateContext<'tcx>, item: &'tcx hir::Item<'_>) {
Expand Down
2 changes: 1 addition & 1 deletion clippy_lints/src/utils/internal_lints.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
pub mod almost_standard_lint_formulation;
pub mod clippy_lints_internal;
pub mod collapsible_calls;
pub mod compiler_lint_functions;
pub mod if_chain_style;
Expand All @@ -11,3 +10,4 @@ pub mod msrv_attr_impl;
pub mod outer_expn_data_pass;
pub mod produce_ice;
pub mod unnecessary_def_path;
pub mod unsorted_clippy_utils_paths;
14 changes: 5 additions & 9 deletions clippy_lints/src/utils/internal_lints/metadata_collector.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,6 @@ use std::process::Command;
const JSON_OUTPUT_FILE: &str = "../util/gh-pages/lints.json";
/// This is the markdown output file of the lint collector.
const MARKDOWN_OUTPUT_FILE: &str = "../book/src/lint_configuration.md";
/// These lints are excluded from the export.
const BLACK_LISTED_LINTS: &[&str] = &["lint_author", "dump_hir", "internal_metadata_collector"];
/// These groups will be ignored by the lint group matcher. This is useful for collections like
/// `clippy::all`
const IGNORED_LINT_GROUPS: [&str; 1] = ["clippy::all"];
Expand Down Expand Up @@ -121,7 +119,7 @@ declare_clippy_lint! {
/// ### Example output
/// ```json,ignore
/// {
/// "id": "internal_metadata_collector",
/// "id": "metadata_collector",
/// "id_span": {
/// "path": "clippy_lints/src/utils/internal_lints/metadata_collector.rs",
/// "line": 1
Expand All @@ -131,12 +129,12 @@ declare_clippy_lint! {
/// }
/// ```
#[clippy::version = "1.56.0"]
pub INTERNAL_METADATA_COLLECTOR,
internal_warn,
pub METADATA_COLLECTOR,
internal,
"A busy bee collection metadata about lints"
}

impl_lint_pass!(MetadataCollector => [INTERNAL_METADATA_COLLECTOR]);
impl_lint_pass!(MetadataCollector => [METADATA_COLLECTOR]);

#[allow(clippy::module_name_repetitions)]
#[derive(Debug, Clone)]
Expand Down Expand Up @@ -550,7 +548,6 @@ impl<'hir> LateLintPass<'hir> for MetadataCollector {
if is_lint_ref_type(cx, ty);
// disallow check
let lint_name = sym_to_string(item.ident.name).to_ascii_lowercase();
if !BLACK_LISTED_LINTS.contains(&lint_name.as_str());
// metadata extraction
if let Some((group, level)) = get_lint_group_and_level_or_lint(cx, &lint_name, item);
if let Some(mut raw_docs) = extract_attr_docs_or_lint(cx, item);
Expand All @@ -575,7 +572,6 @@ impl<'hir> LateLintPass<'hir> for MetadataCollector {
if is_deprecated_lint(cx, ty);
// disallow check
let lint_name = sym_to_string(item.ident.name).to_ascii_lowercase();
if !BLACK_LISTED_LINTS.contains(&lint_name.as_str());
// Metadata the little we can get from a deprecated lint
if let Some(raw_docs) = extract_attr_docs_or_lint(cx, item);
then {
Expand Down Expand Up @@ -831,7 +827,7 @@ fn collect_renames(lints: &mut Vec<LintMetadata>) {
fn lint_collection_error_item(cx: &LateContext<'_>, item: &Item<'_>, message: &str) {
span_lint(
cx,
INTERNAL_METADATA_COLLECTOR,
METADATA_COLLECTOR,
item.ident.span,
&format!("metadata collection error for `{}`: {message}", item.ident.name),
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,21 +5,21 @@ use rustc_session::{declare_lint_pass, declare_tool_lint};

declare_clippy_lint! {
/// ### What it does
/// Checks for various things we like to keep tidy in clippy.
/// Checks that [`clippy_utils::paths`] is sorted lexically
///
/// ### Why is this bad?
/// We like to pretend we're an example of tidy code.
///
/// ### Example
/// Wrong ordering of the util::paths constants.
pub CLIPPY_LINTS_INTERNAL,
pub UNSORTED_CLIPPY_UTILS_PATHS,
internal,
"various things that will negatively affect your clippy experience"
}

declare_lint_pass!(ClippyLintsInternal => [CLIPPY_LINTS_INTERNAL]);
declare_lint_pass!(UnsortedClippyUtilsPaths => [UNSORTED_CLIPPY_UTILS_PATHS]);

impl EarlyLintPass for ClippyLintsInternal {
impl EarlyLintPass for UnsortedClippyUtilsPaths {
fn check_crate(&mut self, cx: &EarlyContext<'_>, krate: &Crate) {
if let Some(utils) = krate.items.iter().find(|item| item.ident.name.as_str() == "utils") {
if let ItemKind::Mod(_, ModKind::Loaded(ref items, ..)) = utils.kind {
Expand All @@ -32,7 +32,7 @@ impl EarlyLintPass for ClippyLintsInternal {
if *last_name > *name {
span_lint(
cx,
CLIPPY_LINTS_INTERNAL,
UNSORTED_CLIPPY_UTILS_PATHS,
item.span,
"this constant should be before the previous constant due to lexical \
ordering",
Expand Down
26 changes: 9 additions & 17 deletions declare_clippy_lint/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -136,28 +136,16 @@ pub fn declare_clippy_lint(input: TokenStream) -> TokenStream {
"{}",
match category.as_str() {
"correctness" => "Deny",
"style" | "suspicious" | "complexity" | "perf" | "internal_warn" => "Warn",
"style" | "suspicious" | "complexity" | "perf" => "Warn",
"pedantic" | "restriction" | "cargo" | "nursery" | "internal" => "Allow",
_ => panic!("unknown category {category}"),
},
);

let info = if category == "internal_warn" {
None
} else {
let info_name = format_ident!("{name}_INFO");
let info_name = format_ident!("{name}_INFO");

(&mut category[0..1]).make_ascii_uppercase();
let category_variant = format_ident!("{category}");

Some(quote! {
pub(crate) static #info_name: &'static crate::LintInfo = &crate::LintInfo {
lint: &#name,
category: crate::LintCategory::#category_variant,
explanation: #explanation,
};
})
};
(&mut category[0..1]).make_ascii_uppercase();
let category_variant = format_ident!("{category}");

let output = quote! {
declare_tool_lint! {
Expand All @@ -168,7 +156,11 @@ pub fn declare_clippy_lint(input: TokenStream) -> TokenStream {
report_in_external_macro: true
}

#info
pub(crate) static #info_name: &'static crate::LintInfo = &crate::LintInfo {
lint: &#name,
category: crate::LintCategory::#category_variant,
explanation: #explanation,
};
};

TokenStream::from(output)
Expand Down