2019-03-29 14:03:31 +00:00
|
|
|
// 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.
|
|
|
|
|
2019-06-12 14:56:51 +00:00
|
|
|
//@ revisions: cfail1 cfail2
|
2019-07-02 21:30:28 +00:00
|
|
|
//@ build-pass (FIXME(62277): could be check-pass?)
|
2019-03-29 14:03:31 +00:00
|
|
|
|
2019-10-25 05:19:07 +00:00
|
|
|
#![feature(rustc_attrs)]
|
2019-03-29 14:03:31 +00:00
|
|
|
#![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);
|
|
|
|
}
|