]> git.lizzy.rs Git - rust.git/commitdiff
rustdoc: Allow linking from private items to private types
authorDennis Hamester <dennis.hamester@gmail.com>
Wed, 8 Jul 2020 05:39:49 +0000 (07:39 +0200)
committerDennis Hamester <dennis.hamester@gmail.com>
Wed, 8 Jul 2020 06:15:34 +0000 (08:15 +0200)
Fixes #74134

After PR #72771 this would trigger an intra_doc_link_resolution_failure warning
when rustdoc is invoked without --document-private-items. Links from private
items to private types are however never actually generated in that case and
thus shouldn't produce a warning. These links are in fact a very useful tool to
document crate internals.

Tests are added for all 4 combinations of public/private items and link
targets. Test 1 is the case mentioned above and fails without this commit. Tests
2 - 4 passed before already but are added nonetheless to prevent regressions.

src/librustdoc/passes/collect_intra_doc_links.rs
src/test/rustdoc/issue-74134-1.rs [new file with mode: 0644]
src/test/rustdoc/issue-74134-2.rs [new file with mode: 0644]
src/test/rustdoc/issue-74134-3.rs [new file with mode: 0644]
src/test/rustdoc/issue-74134-4.rs [new file with mode: 0644]

index f1d1bf439f17133e1eac0d11f1d14d2f29bd33f5..86f94af0c6e313d6b0ff2156b6ebcd0eca28ea16 100644 (file)
@@ -796,6 +796,7 @@ fn fold_item(&mut self, mut item: Item) -> Option<Item> {
 
                     let hir_id = self.cx.tcx.hir().as_local_hir_id(local);
                     if !self.cx.tcx.privacy_access_levels(LOCAL_CRATE).is_exported(hir_id)
+                        && (item.visibility == Visibility::Public)
                         && !self.cx.render_options.document_private
                     {
                         let item_name = item.name.as_deref().unwrap_or("<unknown>");
diff --git a/src/test/rustdoc/issue-74134-1.rs b/src/test/rustdoc/issue-74134-1.rs
new file mode 100644 (file)
index 0000000..72d3863
--- /dev/null
@@ -0,0 +1,10 @@
+#![deny(intra_doc_link_resolution_failure)]
+
+// Linking from a private item to a private type is fine without --document-private-items.
+
+struct Private;
+
+pub struct Public {
+    /// [`Private`]
+    private: Private,
+}
diff --git a/src/test/rustdoc/issue-74134-2.rs b/src/test/rustdoc/issue-74134-2.rs
new file mode 100644 (file)
index 0000000..f665e36
--- /dev/null
@@ -0,0 +1,11 @@
+// compile-flags: --document-private-items
+#![deny(intra_doc_link_resolution_failure)]
+
+// Linking from a private item to a private type is fine with --document-private-items.
+
+struct Private;
+
+pub struct Public {
+    /// [`Private`]
+    private: Private,
+}
diff --git a/src/test/rustdoc/issue-74134-3.rs b/src/test/rustdoc/issue-74134-3.rs
new file mode 100644 (file)
index 0000000..b2709ec
--- /dev/null
@@ -0,0 +1,11 @@
+// should-fail
+#![deny(intra_doc_link_resolution_failure)]
+
+// Linking from a public item to a private type fails without --document-private-items.
+
+struct Private;
+
+pub struct Public {
+    /// [`Private`]
+    pub public: u32,
+}
diff --git a/src/test/rustdoc/issue-74134-4.rs b/src/test/rustdoc/issue-74134-4.rs
new file mode 100644 (file)
index 0000000..efff74f
--- /dev/null
@@ -0,0 +1,11 @@
+// compile-flags: --document-private-items
+#![deny(intra_doc_link_resolution_failure)]
+
+// Linking from a public item to a private type is fine with --document-private-items.
+
+struct Private;
+
+pub struct Public {
+    /// [`Private`]
+    pub public: u32,
+}