Skip to content

Commit 33bb269

Browse files
committed
Refactor away a use of ast_map.span_if_local()
1 parent 3bcf818 commit 33bb269

File tree

1 file changed

+13
-3
lines changed

1 file changed

+13
-3
lines changed

src/librustc_resolve/lib.rs

Lines changed: 13 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1819,11 +1819,21 @@ impl<'a, 'tcx> Resolver<'a, 'tcx> {
18191819
path_depth)));
18201820

18211821
// If it's a typedef, give a note
1822-
if let Def::TyAlias(did) = path_res.base_def {
1822+
if let Def::TyAlias(..) = path_res.base_def {
18231823
err.fileline_note(trait_path.span,
18241824
"`type` aliases cannot be used for traits");
1825-
if let Some(sp) = self.ast_map.span_if_local(did) {
1826-
err.span_note(sp, "type defined here");
1825+
1826+
let definition_site = {
1827+
let segments = &trait_path.segments;
1828+
if trait_path.global {
1829+
self.resolve_crate_relative_path(trait_path.span, segments, TypeNS)
1830+
} else {
1831+
self.resolve_module_relative_path(trait_path.span, segments, TypeNS)
1832+
}.map(|binding| binding.span).unwrap_or(codemap::DUMMY_SP)
1833+
};
1834+
1835+
if definition_site != codemap::DUMMY_SP {
1836+
err.span_note(definition_site, "type defined here");
18271837
}
18281838
}
18291839
err.emit();

0 commit comments

Comments
 (0)