File tree 1 file changed +16
-0
lines changed
1 file changed +16
-0
lines changed Original file line number Diff line number Diff line change @@ -1216,6 +1216,20 @@ impl LinkCollector<'_, '_> {
1216
1216
. emit ( ) ;
1217
1217
}
1218
1218
1219
+ fn filter_private_hidden_candidates ( & self , candidates : & mut Vec < ( Res , Option < DefId > ) > ) {
1220
+ candidates. retain ( |( candidate, _) | {
1221
+ let Res :: Def ( _, def_id) = candidate else { return true } ;
1222
+
1223
+ if !self . cx . render_options . document_private && !self . cx . tcx . visibility ( def_id) . is_public ( ) {
1224
+ false
1225
+ } else if !self . cx . render_options . document_hidden && self . cx . tcx . is_doc_hidden ( def_id) {
1226
+ false
1227
+ } else {
1228
+ true
1229
+ }
1230
+ } ) ;
1231
+ }
1232
+
1219
1233
fn resolve_with_disambiguator_cached (
1220
1234
& mut self ,
1221
1235
key : ResolutionInfo ,
@@ -1250,6 +1264,8 @@ impl LinkCollector<'_, '_> {
1250
1264
}
1251
1265
}
1252
1266
1267
+ self . filter_private_hidden_candidates ( & mut candidates) ;
1268
+
1253
1269
// If there are multiple items with the same "kind" (for example, both "associated types")
1254
1270
// and after removing duplicated kinds, only one remains, the `ambiguity_error` function
1255
1271
// won't emit an error. So at this point, we can just take the first candidate as it was
You can’t perform that action at this time.
0 commit comments