Skip to content

Commit

Permalink
Rollup merge of rust-lang#108377 - clubby789:duplicate-diagnostic-ice…
Browse files Browse the repository at this point in the history
…, r=compiler-errors

Fix ICE in 'duplicate diagnostic item' diagnostic

Not sure how to add this in a test; I found it by mistakenly running `cargo fix --lib -p std` rather than `x fix` at the root.
  • Loading branch information
matthiaskrgr authored Feb 23, 2023
2 parents 9ebff9e + 4332a27 commit 3a3c0d5
Show file tree
Hide file tree
Showing 5 changed files with 32 additions and 1 deletion.
2 changes: 1 addition & 1 deletion compiler/rustc_passes/locales/en-US.ftl
Original file line number Diff line number Diff line change
Expand Up @@ -407,10 +407,10 @@ passes_duplicate_diagnostic_item =
passes_duplicate_diagnostic_item_in_crate =
duplicate diagnostic item in crate `{$crate_name}`: `{$name}`.
.note = the diagnostic item is first defined in crate `{$orig_crate_name}`.
passes_diagnostic_item_first_defined =
the diagnostic item is first defined here
.note = the diagnostic item is first defined in crate `{$orig_crate_name}`.
passes_abi =
abi: {$abi}
Expand Down
3 changes: 3 additions & 0 deletions tests/ui/tool-attributes/auxiliary/p1.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
#![feature(rustc_attrs)]
#[rustc_diagnostic_item = "Foo"]
pub struct Foo {}
3 changes: 3 additions & 0 deletions tests/ui/tool-attributes/auxiliary/p2.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
#![feature(rustc_attrs)]
#[rustc_diagnostic_item = "Foo"]
pub struct Foo {}
13 changes: 13 additions & 0 deletions tests/ui/tool-attributes/duplicate-diagnostic.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
// aux-build: p1.rs
// aux-build: p2.rs

// error-pattern: duplicate diagnostic item in crate `p2`
// error-pattern: note: the diagnostic item is first defined in crate `p1`

#![feature(rustc_attrs)]
extern crate p1;
extern crate p2;

#[rustc_diagnostic_item = "Foo"]
pub struct Foo {} //~ ERROR duplicate diagnostic item found
fn main() {}
12 changes: 12 additions & 0 deletions tests/ui/tool-attributes/duplicate-diagnostic.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
error: duplicate diagnostic item in crate `p2`: `Foo`.
|
= note: the diagnostic item is first defined in crate `p1`.

error: duplicate diagnostic item found: `Foo`.
--> $DIR/duplicate-diagnostic.rs:12:1
|
LL | pub struct Foo {}
| ^^^^^^^^^^^^^^

error: aborting due to 2 previous errors

0 comments on commit 3a3c0d5

Please sign in to comment.