From 0d295a28425f860bf6de343b5447ad835181f586 Mon Sep 17 00:00:00 2001 From: Malena Ohl Date: Sat, 7 Dec 2024 16:29:11 -0500 Subject: [PATCH 1/6] Add function_like_proc_macro_missing lint --- .../function_like_proc_macro_missing.ron | 44 +++++++++++++++++++ src/query.rs | 1 + .../new/Cargo.toml | 10 +++++ .../new/src/lib.rs | 20 +++++++++ .../old/Cargo.toml | 10 +++++ .../old/src/lib.rs | 23 ++++++++++ .../function_like_proc_macro_missing.snap | 9 ++++ 7 files changed, 117 insertions(+) create mode 100644 src/lints/function_like_proc_macro_missing.ron create mode 100644 test_crates/function_like_proc_macro_missing/new/Cargo.toml create mode 100644 test_crates/function_like_proc_macro_missing/new/src/lib.rs create mode 100644 test_crates/function_like_proc_macro_missing/old/Cargo.toml create mode 100644 test_crates/function_like_proc_macro_missing/old/src/lib.rs create mode 100644 test_outputs/query_execution/function_like_proc_macro_missing.snap diff --git a/src/lints/function_like_proc_macro_missing.ron b/src/lints/function_like_proc_macro_missing.ron new file mode 100644 index 00000000..9a2ef6d7 --- /dev/null +++ b/src/lints/function_like_proc_macro_missing.ron @@ -0,0 +1,44 @@ +SemverQuery( + id: "function_like_proc_macro_missing", + human_readable_name: "function-like proc macro removed", + description: "A function-like procedural macro that previously existed has been removed.", + required_update: Major, + lint_level: Deny, + reference_link: Some("https://doc.rust-lang.org/reference/procedural-macros.html#function-like-procedural-macros"), + query: r#" + { + CrateDiff { + baseline { + item { + ... on FunctionLikeProcMacro { + macro_name: name @output @tag + visibility_limit @filter(op: "=", value: ["$public"]) + + # Get span info from the baseline for error reporting + span_: span @optional { + filename @output + begin_line @output + } + } + } + } + + current @fold @transform(op: "count") @filter(op: "=", value: ["$zero"]) { + item { + ... on FunctionLikeProcMacro { + name @filter(op: "=", value: ["%macro_name"]) + } + } + } + } + }"#, + arguments: { + "public": "public", + "zero": 0, + }, + error_message: "A function-like procedural macro has been removed. Any code that invokes this macro will fail to compile.", + per_result_error_template: Some("macro {{macro_name}} in file {{span_filename}}:{{span_begin_line}}"), + witness: Some(( + hint_template: r#"{{macro_name}}!(...);"#, + )), +) \ No newline at end of file diff --git a/src/query.rs b/src/query.rs index 419b22d7..c20f5178 100644 --- a/src/query.rs +++ b/src/query.rs @@ -1079,6 +1079,7 @@ add_lints!( function_changed_abi, function_const_removed, function_export_name_changed, + function_like_proc_macro_missing, function_missing, function_must_use_added, function_now_doc_hidden, diff --git a/test_crates/function_like_proc_macro_missing/new/Cargo.toml b/test_crates/function_like_proc_macro_missing/new/Cargo.toml new file mode 100644 index 00000000..aab18142 --- /dev/null +++ b/test_crates/function_like_proc_macro_missing/new/Cargo.toml @@ -0,0 +1,10 @@ +[package] +publish = false +name = "function_like_proc_macro_missing" +version = "0.1.0" +edition = "2021" + +[lib] +proc-macro = true + +[dependencies] diff --git a/test_crates/function_like_proc_macro_missing/new/src/lib.rs b/test_crates/function_like_proc_macro_missing/new/src/lib.rs new file mode 100644 index 00000000..0af0b9b7 --- /dev/null +++ b/test_crates/function_like_proc_macro_missing/new/src/lib.rs @@ -0,0 +1,20 @@ +use proc_macro::TokenStream; + +// make_answer is removed + +// Keep this to verify we don't have false positives +#[proc_macro] +pub fn another_macro(_item: TokenStream) -> TokenStream { + "fn other() -> u32 { 0 }".parse().unwrap() +} + +// Keep other macro types to verify we don't detect their changes +#[proc_macro_derive(MyDerive)] +pub fn my_derive(_item: TokenStream) -> TokenStream { + TokenStream::new() +} + +#[proc_macro_attribute] +pub fn my_attribute(_attr: TokenStream, _item: TokenStream) -> TokenStream { + TokenStream::new() +} \ No newline at end of file diff --git a/test_crates/function_like_proc_macro_missing/old/Cargo.toml b/test_crates/function_like_proc_macro_missing/old/Cargo.toml new file mode 100644 index 00000000..aab18142 --- /dev/null +++ b/test_crates/function_like_proc_macro_missing/old/Cargo.toml @@ -0,0 +1,10 @@ +[package] +publish = false +name = "function_like_proc_macro_missing" +version = "0.1.0" +edition = "2021" + +[lib] +proc-macro = true + +[dependencies] diff --git a/test_crates/function_like_proc_macro_missing/old/src/lib.rs b/test_crates/function_like_proc_macro_missing/old/src/lib.rs new file mode 100644 index 00000000..f90ac24c --- /dev/null +++ b/test_crates/function_like_proc_macro_missing/old/src/lib.rs @@ -0,0 +1,23 @@ +use proc_macro::TokenStream; + +#[proc_macro] +pub fn make_answer(_item: TokenStream) -> TokenStream { + "fn answer() -> u32 { 42 }".parse().unwrap() +} + +// Will keep this one to ensure we don't have false positives +#[proc_macro] +pub fn another_macro(_item: TokenStream) -> TokenStream { + "fn other() -> u32 { 0 }".parse().unwrap() +} + +// Other kinds of proc macros that should not trigger this lint +#[proc_macro_derive(MyDerive)] +pub fn my_derive(_item: TokenStream) -> TokenStream { + TokenStream::new() +} + +#[proc_macro_attribute] +pub fn my_attribute(_attr: TokenStream, _item: TokenStream) -> TokenStream { + TokenStream::new() +} \ No newline at end of file diff --git a/test_outputs/query_execution/function_like_proc_macro_missing.snap b/test_outputs/query_execution/function_like_proc_macro_missing.snap new file mode 100644 index 00000000..1bbeede6 --- /dev/null +++ b/test_outputs/query_execution/function_like_proc_macro_missing.snap @@ -0,0 +1,9 @@ +--- +source: src/query.rs +expression: "&query_execution_results" +--- +{ + "./test_crates/function_like_proc_macro_missing/": [ + // TODO + ] +} From c9a418240d0feaf778b093b14e995fe17f6f9b5d Mon Sep 17 00:00:00 2001 From: Predrag Gruevski <2348618+obi1kenobi@users.noreply.github.com> Date: Sat, 7 Dec 2024 16:34:45 -0500 Subject: [PATCH 2/6] Update src/lints/function_like_proc_macro_missing.ron --- src/lints/function_like_proc_macro_missing.ron | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/lints/function_like_proc_macro_missing.ron b/src/lints/function_like_proc_macro_missing.ron index 9a2ef6d7..09688b6a 100644 --- a/src/lints/function_like_proc_macro_missing.ron +++ b/src/lints/function_like_proc_macro_missing.ron @@ -41,4 +41,4 @@ SemverQuery( witness: Some(( hint_template: r#"{{macro_name}}!(...);"#, )), -) \ No newline at end of file +) From efa35d67f965d408417362d637775340d1570337 Mon Sep 17 00:00:00 2001 From: Predrag Gruevski <2348618+obi1kenobi@users.noreply.github.com> Date: Sat, 7 Dec 2024 16:35:01 -0500 Subject: [PATCH 3/6] Update test_crates/function_like_proc_macro_missing/new/src/lib.rs --- test_crates/function_like_proc_macro_missing/new/src/lib.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test_crates/function_like_proc_macro_missing/new/src/lib.rs b/test_crates/function_like_proc_macro_missing/new/src/lib.rs index 0af0b9b7..bb139345 100644 --- a/test_crates/function_like_proc_macro_missing/new/src/lib.rs +++ b/test_crates/function_like_proc_macro_missing/new/src/lib.rs @@ -17,4 +17,4 @@ pub fn my_derive(_item: TokenStream) -> TokenStream { #[proc_macro_attribute] pub fn my_attribute(_attr: TokenStream, _item: TokenStream) -> TokenStream { TokenStream::new() -} \ No newline at end of file +} From 122968d6198e76ae3849c0edddeb4c8a1ebca654 Mon Sep 17 00:00:00 2001 From: Predrag Gruevski <2348618+obi1kenobi@users.noreply.github.com> Date: Sat, 7 Dec 2024 16:35:40 -0500 Subject: [PATCH 4/6] Update test_crates/function_like_proc_macro_missing/old/src/lib.rs --- test_crates/function_like_proc_macro_missing/old/src/lib.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test_crates/function_like_proc_macro_missing/old/src/lib.rs b/test_crates/function_like_proc_macro_missing/old/src/lib.rs index f90ac24c..943a22ea 100644 --- a/test_crates/function_like_proc_macro_missing/old/src/lib.rs +++ b/test_crates/function_like_proc_macro_missing/old/src/lib.rs @@ -20,4 +20,4 @@ pub fn my_derive(_item: TokenStream) -> TokenStream { #[proc_macro_attribute] pub fn my_attribute(_attr: TokenStream, _item: TokenStream) -> TokenStream { TokenStream::new() -} \ No newline at end of file +} From 5acecf241f8afffb0a6d89e73e98b3df10b54a2a Mon Sep 17 00:00:00 2001 From: Malena Ohl Date: Sat, 7 Dec 2024 17:08:11 -0500 Subject: [PATCH 5/6] Update snapshot file --- .../function_like_proc_macro_missing.snap | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/test_outputs/query_execution/function_like_proc_macro_missing.snap b/test_outputs/query_execution/function_like_proc_macro_missing.snap index 1bbeede6..49b3d242 100644 --- a/test_outputs/query_execution/function_like_proc_macro_missing.snap +++ b/test_outputs/query_execution/function_like_proc_macro_missing.snap @@ -1,9 +1,14 @@ --- source: src/query.rs expression: "&query_execution_results" +snapshot_kind: text --- { - "./test_crates/function_like_proc_macro_missing/": [ - // TODO - ] + "./test_crates/function_like_proc_macro_missing/": [ + { + "macro_name": String("make_answer"), + "span_begin_line": Uint64(4), + "span_filename": String("src/lib.rs"), + }, + ], } From 3514620b364b2d03444e76858bca038ccd849e2b Mon Sep 17 00:00:00 2001 From: Predrag Gruevski <2348618+obi1kenobi@users.noreply.github.com> Date: Sat, 7 Dec 2024 17:29:57 -0500 Subject: [PATCH 6/6] Update src/lints/function_like_proc_macro_missing.ron --- src/lints/function_like_proc_macro_missing.ron | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/lints/function_like_proc_macro_missing.ron b/src/lints/function_like_proc_macro_missing.ron index 09688b6a..19bc61b6 100644 --- a/src/lints/function_like_proc_macro_missing.ron +++ b/src/lints/function_like_proc_macro_missing.ron @@ -38,7 +38,5 @@ SemverQuery( }, error_message: "A function-like procedural macro has been removed. Any code that invokes this macro will fail to compile.", per_result_error_template: Some("macro {{macro_name}} in file {{span_filename}}:{{span_begin_line}}"), - witness: Some(( - hint_template: r#"{{macro_name}}!(...);"#, - )), + witness: None, )