Skip to content

Commit

Permalink
implement struct_now_doc_hidden lint
Browse files Browse the repository at this point in the history
  • Loading branch information
u9g committed Nov 25, 2023
1 parent ae14962 commit b7d1ec5
Show file tree
Hide file tree
Showing 8 changed files with 129 additions and 0 deletions.
11 changes: 11 additions & 0 deletions out.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
Documenting function_changed_abi v0.1.0 (/Users/jasonlernerman/code/cargo-semver-checks/test_crates/function_changed_abi/new)
Finished dev [unoptimized + debuginfo] target(s) in 0.13s
Documenting function_changed_abi v0.1.0 (/Users/jasonlernerman/code/cargo-semver-checks/test_crates/function_changed_abi/old)
Finished dev [unoptimized ~/code/cargo-semver-checks
Gener Documenting features_no_default v0.1.0 (/Users/jasonlernerman/code/cargo-semver-checks/test_crates/features_no_default/ne~/code/cargo-semver-checks
Generating: /features_no_default/old
~ Documenting features_no_default v0.1.0 (/Users/jasonlernerman/code/cargo-semver-checks/t~/code/cargo-semver-checks
Generating: /struct_now_doc_hidden/new
~/code/cargo-semver-checks/test_ Documenting template v0.1.0 (/Users/jasonlernerman/code/cargo-semver-checks/test_crates/struct_now_doc_hidden/new)
Finished dev [unoptimized + debuginfo] target(s) in 0.13s
mv: rename /tmp/test_crates/doc//struct_now_doc_hidden.json to /Users/jasonlernerman/code/cargo-semver-checks/localdata/test_data//struct_now_doc_hidden/new/rustdoc.json: No such file or directory
50 changes: 50 additions & 0 deletions src/lints/struct_now_doc_hidden.ron
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
SemverQuery(
id: "struct_now_doc_hidden",
human_readable_name: "pub struct is now #[doc(hidden)]",
description: "A pub struct is now hidden from documentation effectively removing it from the crate's public api.",
required_update: Major,
reference_link: Some("https://doc.rust-lang.org/rustdoc/write-documentation/the-doc-attribute.html#hidden"),
query: r#"
{
CrateDiff {
baseline {
item {
... on Struct {
visibility_limit @filter(op: "=", value: ["$public"])
struct_type @output @tag
importable_path {
path @output @tag
public_api @filter(op: "=", value: ["$true"])
}
}
}
}
current {
item {
... on Struct {
visibility_limit @filter(op: "=", value: ["$public"])
struct_name: name @output
struct_type @filter(op: "=", value: ["%struct_type"])
importable_path {
path @filter(op: "=", value: ["%path"])
public_api @filter(op: "!=", value: ["$true"])
}
span_: span @optional {
filename @output
begin_line @output
}
}
}
}
}
}"#,
arguments: {
"public": "public",
"true": true,
},
error_message: "A publicly visible struct is now hidden via #[doc(hidden)].",
per_result_error_template: Some("Struct {{struct_name}} in file {{span_filename}}:{{span_begin_line}}"),
)
1 change: 1 addition & 0 deletions src/query.rs
Original file line number Diff line number Diff line change
Expand Up @@ -495,6 +495,7 @@ add_lints!(
struct_marked_non_exhaustive,
struct_missing,
struct_must_use_added,
struct_now_doc_hidden,
struct_pub_field_missing,
struct_repr_c_removed,
struct_repr_transparent_removed,
Expand Down
7 changes: 7 additions & 0 deletions test_crates/struct_now_doc_hidden/new/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[package]
publish = false
name = "struct_now_doc_hidden"
version = "0.1.0"
edition = "2021"

[dependencies]
4 changes: 4 additions & 0 deletions test_crates/struct_now_doc_hidden/new/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
struct StayingKnown;

#[doc(hidden)]
pub struct Example;
7 changes: 7 additions & 0 deletions test_crates/struct_now_doc_hidden/old/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[package]
publish = false
name = "struct_now_doc_hidden"
version = "0.1.0"
edition = "2021"

[dependencies]
3 changes: 3 additions & 0 deletions test_crates/struct_now_doc_hidden/old/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
struct StayingKnown;

pub struct Example;
46 changes: 46 additions & 0 deletions test_outputs/struct_now_doc_hidden.output.ron
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
{
"./test_crates/struct_now_doc_hidden/": [
{
"path": List([
String("struct_now_doc_hidden"),
String("Example"),
]),
"span_begin_line": Uint64(2),
"span_filename": String("src/lib.rs"),
"struct_name": String("Example"),
"struct_type": String("unit"),
},
],
"./test_crates/type_hidden_from_public_api/": [
{
"path": List([
String("type_hidden_from_public_api"),
String("ExamplePlainStruct"),
]),
"span_begin_line": Uint64(2),
"span_filename": String("src/lib.rs"),
"struct_name": String("ExamplePlainStruct"),
"struct_type": String("plain"),
},
{
"path": List([
String("type_hidden_from_public_api"),
String("ExampleTupleStruct"),
]),
"span_begin_line": Uint64(7),
"span_filename": String("src/lib.rs"),
"struct_name": String("ExampleTupleStruct"),
"struct_type": String("tuple"),
},
{
"path": List([
String("type_hidden_from_public_api"),
String("ExampleUnitStruct"),
]),
"span_begin_line": Uint64(10),
"span_filename": String("src/lib.rs"),
"struct_name": String("ExampleUnitStruct"),
"struct_type": String("unit"),
},
],
}

0 comments on commit b7d1ec5

Please sign in to comment.