about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorMatthias Krüger <matthias.krueger@famsik.de>2023-03-29 21:19:51 +0200
committerGitHub <noreply@github.com>2023-03-29 21:19:51 +0200
commit02cb4da8969ba2d9f2879df33fc13fce83012ed7 (patch)
tree849ae1690d5419ee5faa565738f7a5285013778f /src
parent85c38454c0044d727e68cc123ff93376da62abfc (diff)
parentcdc4fa45896c2b086646c8c9c91adb8d9dc5e45f (diff)
downloadrust-02cb4da8969ba2d9f2879df33fc13fce83012ed7.tar.gz
rust-02cb4da8969ba2d9f2879df33fc13fce83012ed7.zip
Rollup merge of #109726 - GuillaumeGomez:doc-hidden-crate, r=notriddle
rustdoc: Don't strip crate module

Until we decide something for https://github.com/rust-lang/rust/issues/109695, rustdoc won't crash anymore because the crate folder doesn't exist.

r? `@notriddle`
Diffstat (limited to 'src')
-rw-r--r--src/librustdoc/passes/strip_hidden.rs9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/librustdoc/passes/strip_hidden.rs b/src/librustdoc/passes/strip_hidden.rs
index 890b3e8d67f..a688aa14863 100644
--- a/src/librustdoc/passes/strip_hidden.rs
+++ b/src/librustdoc/passes/strip_hidden.rs
@@ -121,9 +121,14 @@ impl<'a, 'tcx> DocFolder for Stripper<'a, 'tcx> {
                 // strip things like impl methods but when doing so
                 // we must not add any items to the `retained` set.
                 let old = mem::replace(&mut self.update_retained, false);
-                let ret = strip_item(self.set_is_in_hidden_item_and_fold(true, i));
+                let ret = self.set_is_in_hidden_item_and_fold(true, i);
                 self.update_retained = old;
-                Some(ret)
+                if ret.is_crate() {
+                    // We don't strip the crate, even if it has `#[doc(hidden)]`.
+                    Some(ret)
+                } else {
+                    Some(strip_item(ret))
+                }
             }
             _ => {
                 let ret = self.set_is_in_hidden_item_and_fold(true, i);