Skip to content

Commit

Permalink
don't try to get a DefId for a Def that doesn't have one
Browse files Browse the repository at this point in the history
  • Loading branch information
QuietMisdreavus committed Feb 1, 2019
1 parent 1aa2506 commit c955f17
Show file tree
Hide file tree
Showing 4 changed files with 18 additions and 6 deletions.
7 changes: 5 additions & 2 deletions src/librustdoc/clean/inline.rs
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,11 @@ use super::Clean;
/// and `Some` of a vector of items if it was successfully expanded.
pub fn try_inline(cx: &DocContext, def: Def, name: ast::Name, visited: &mut FxHashSet<DefId>)
-> Option<Vec<clean::Item>> {
if def == Def::Err { return None }
let did = def.def_id();
let did = if let Some(did) = def.opt_def_id() {
did
} else {
return None;
};
if did.is_local() { return None }
let mut ret = Vec::new();
let inner = match def {
Expand Down
2 changes: 1 addition & 1 deletion src/librustdoc/clean/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3818,7 +3818,7 @@ pub fn register_def(cx: &DocContext, def: Def) -> DefId {

fn resolve_use_source(cx: &DocContext, path: Path) -> ImportSource {
ImportSource {
did: if path.def == Def::Err {
did: if path.def.opt_def_id().is_none() {
None
} else {
Some(register_def(cx, path.def))
Expand Down
7 changes: 4 additions & 3 deletions src/librustdoc/visit_ast.rs
Original file line number Diff line number Diff line change
Expand Up @@ -284,10 +284,11 @@ impl<'a, 'tcx, 'rcx> RustdocVisitor<'a, 'tcx, 'rcx> {
debug!("maybe_inline_local def: {:?}", def);

let tcx = self.cx.tcx;
if def == Def::Err {
let def_did = if let Some(did) = def.opt_def_id() {
did
} else {
return false;
}
let def_did = def.def_id();
};

let use_attrs = tcx.hir().attrs(id);
// Don't inline `doc(hidden)` imports so they can be stripped at a later stage.
Expand Down
8 changes: 8 additions & 0 deletions src/test/rustdoc/use-attr.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// edition:2018

// ICE when rustdoc encountered a use statement of a non-macro attribute (see #58054)

// @has use_attr/index.html
// @has - '//code' 'pub use proc_macro_attribute'
pub use proc_macro_attribute;
use proc_macro_derive;

0 comments on commit c955f17

Please sign in to comment.