Skip to content

Commit

Permalink
Regression test for incremental treatment of rustc_on_unimplemented.
Browse files Browse the repository at this point in the history
  • Loading branch information
pnkfelix committed Mar 29, 2019
1 parent ff33b27 commit 0b96697
Showing 1 changed file with 27 additions and 0 deletions.
27 changes: 27 additions & 0 deletions src/test/incremental/issue-59523-on-implemented-is-not-unused.rs
@@ -0,0 +1,27 @@
// We should not see the unused_attributes lint fire for
// rustc_on_unimplemented, but with this bug we are seeing it fire (on
// subsequent runs) if incremental compilation is enabled.

// revisions: rpass1 rpass2
// compile-pass

#![feature(on_unimplemented)]
#![deny(unused_attributes)]

#[rustc_on_unimplemented = "invalid"]
trait Index<Idx: ?Sized> {
type Output: ?Sized;
fn index(&self, index: Idx) -> &Self::Output;
}

#[rustc_on_unimplemented = "a usize is required to index into a slice"]
impl Index<usize> for [i32] {
type Output = i32;
fn index(&self, index: usize) -> &i32 {
&self[index]
}
}

fn main() {
Index::<usize>::index(&[1, 2, 3] as &[i32], 2);
}

0 comments on commit 0b96697

Please sign in to comment.