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