From 908a9d4aad61f4b8108ff91ae42f76e67dec5148 Mon Sep 17 00:00:00 2001 From: Noah Lev Date: Tue, 28 Dec 2021 13:15:02 -0800 Subject: [PATCH] Add regression test for #59502 This issue was fixed using a hacky recursion "fuel" argument, but the issue was never minimized nor was a regression test added. The underlying bug is still unfixed, so this test should help with fixing it and removing the `recurse` hack. --- src/librustdoc/html/render/search_index.rs | 2 ++ ...search-index-generics-recursion-bug-issue-59502.rs | 11 +++++++++++ 2 files changed, 13 insertions(+) create mode 100644 src/test/rustdoc-ui/search-index-generics-recursion-bug-issue-59502.rs diff --git a/src/librustdoc/html/render/search_index.rs b/src/librustdoc/html/render/search_index.rs index 038ee351545f6..0fbe090f2190a 100644 --- a/src/librustdoc/html/render/search_index.rs +++ b/src/librustdoc/html/render/search_index.rs @@ -236,6 +236,7 @@ fn get_index_type_name(clean_type: &clean::Type) -> Option { /// /// Important note: It goes through generics recursively. So if you have /// `T: Option>`, it'll go into `Option` and then into `Result`. +#[instrument(level = "trace", skip(tcx, res))] fn add_generics_and_bounds_as_types<'tcx>( generics: &Generics, arg: &Type, @@ -316,6 +317,7 @@ fn add_generics_and_bounds_as_types<'tcx>( if recurse >= 10 { // FIXME: remove this whole recurse thing when the recursion bug is fixed + // See #59502 for the original issue. return; } diff --git a/src/test/rustdoc-ui/search-index-generics-recursion-bug-issue-59502.rs b/src/test/rustdoc-ui/search-index-generics-recursion-bug-issue-59502.rs new file mode 100644 index 0000000000000..ce51556dd418b --- /dev/null +++ b/src/test/rustdoc-ui/search-index-generics-recursion-bug-issue-59502.rs @@ -0,0 +1,11 @@ +// check-pass + +// Minimization of issue #59502 + +trait MyTrait { + type Output; +} + +pub fn pow>(arg: T) -> T { + arg +}