Skip to content

Commit

Permalink
Add lint declarative_macro_missing (#966)
Browse files Browse the repository at this point in the history
* Add lint `declarative_macro_missing`

* Apply suggestions from code review

---------

Co-authored-by: Predrag Gruevski <[email protected]>
  • Loading branch information
miikka and obi1kenobi authored Oct 16, 2024
1 parent 98f4a09 commit 931628b
Show file tree
Hide file tree
Showing 9 changed files with 132 additions and 1 deletion.
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ exclude = [".github/", "brand/", "scripts/", "test_crates/", "test_outputs/", "t

[dependencies]
trustfall = "0.7.1"
trustfall_rustdoc = { version = "0.16.2", default-features = false, features = ["v28", "v29", "v30", "v32", "v33", "v34", "rayon", "rustc-hash"] }
trustfall_rustdoc = { version = "0.16.2", default-features = false, features = ["v28", "v29", "v30", "v32", "v33", "v34", "v35", "rayon", "rustc-hash"] }
clap = { version = "4.5.17", features = ["derive", "cargo"] }
serde_json = "1.0.128"
anyhow = "1.0.89"
Expand Down
45 changes: 45 additions & 0 deletions src/lints/declarative_macro_missing.ron
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
SemverQuery(
id: "declarative_macro_missing",
human_readable_name: "macro_rules declaration removed or renamed",
description: "A declarative macro marked with #[macro_export] can no longer imported by its prior name.",
required_update: Major,
lint_level: Deny,
reference_link: Some("https://doc.rust-lang.org/reference/macros-by-example.html#path-based-scope"),
query: r#"
{
CrateDiff {
baseline {
item {
... on Macro {
visibility_limit @filter(op: "=", value: ["$public"])
public_api_eligible @filter(op: "=", value: ["$true"])
name @output @tag
span_: span @optional {
filename @output
begin_line @output
}
}
}
}
current @fold @transform(op: "count") @filter(op: "=", value: ["$zero"]) {
item {
... on Macro {
visibility_limit @filter(op: "=", value: ["$public"])
name @filter(op: "=", value: ["%name"])
}
}
}
}
}"#,
arguments: {
"public": "public",
"zero": 0,
"true": true,
},
error_message: "A publicly-visible `macro_rules` declarative macro cannot be imported by its prior name. A `#[macro_export]` may have been removed, or the macro itself may have been renamed or removed entirely.",
per_result_error_template: Some("macro_rules! {{name}}, previously in file {{span_filename}}:{{span_begin_line}}"),
witness: (
hint_template: r#"{{name}}!(...);"#
),
)
1 change: 1 addition & 0 deletions src/query.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1009,6 +1009,7 @@ add_lints!(
constructible_struct_adds_field,
constructible_struct_adds_private_field,
constructible_struct_changed_type,
declarative_macro_missing,
derive_trait_impl_removed,
enum_marked_non_exhaustive,
enum_missing,
Expand Down
7 changes: 7 additions & 0 deletions test_crates/declarative_macro_missing/new/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[package]
publish = false
name = "declarative_macro_missing"
version = "0.1.0"
edition = "2021"

[dependencies]
15 changes: 15 additions & 0 deletions test_crates/declarative_macro_missing/new/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
macro_rules! will_no_longer_be_exported {
() => {};
}

#[doc(hidden)]
#[macro_export]
macro_rules! became_doc_hidden {
() => {};
}

#[doc(hidden)]
#[macro_export]
macro_rules! always_doc_hidden {
() => {};
}
7 changes: 7 additions & 0 deletions test_crates/declarative_macro_missing/old/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[package]
publish = false
name = "declarative_macro_missing"
version = "0.1.0"
edition = "2021"

[dependencies]
24 changes: 24 additions & 0 deletions test_crates/declarative_macro_missing/old/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#[macro_export]
macro_rules! will_be_removed {
() => {};
}

#[macro_export]
macro_rules! will_no_longer_be_exported {
() => {};
}

macro_rules! textual_scope_macro_removed {
() => {};
}

#[macro_export]
macro_rules! became_doc_hidden {
() => {};
}

#[doc(hidden)]
#[macro_export]
macro_rules! always_doc_hidden {
() => {};
}
18 changes: 18 additions & 0 deletions test_outputs/query_execution/declarative_macro_missing.snap
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
---
source: src/query.rs
expression: "&query_execution_results"
---
{
"./test_crates/declarative_macro_missing/": [
{
"name": String("will_be_removed"),
"span_begin_line": Uint64(2),
"span_filename": String("src/lib.rs"),
},
{
"name": String("will_no_longer_be_exported"),
"span_begin_line": Uint64(7),
"span_filename": String("src/lib.rs"),
},
],
}
14 changes: 14 additions & 0 deletions test_outputs/witnesses/declarative_macro_missing.snap
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
---
source: src/query.rs
description: "Lint `declarative_macro_missing` did not have the expected witness output.\nSee https://github.com/obi1kenobi/cargo-semver-checks/blob/main/CONTRIBUTING.md#testing-witnesses\nfor more information."
expression: "&actual_witnesses"
---
[["./test_crates/declarative_macro_missing/"]]
filename = 'src/lib.rs'
begin_line = 2
hint = 'will_be_removed!(...);'

[["./test_crates/declarative_macro_missing/"]]
filename = 'src/lib.rs'
begin_line = 7
hint = 'will_no_longer_be_exported!(...);'

0 comments on commit 931628b

Please sign in to comment.