fe6ad097c6
Because of type inference, duplicate obligations exist and cause duplicate errors. To avoid this, only display the first error for each (predicate,span). The inclusion of the span is somewhat bikesheddy, but *is* the more conservative option (it does not remove some instability, as duplicate obligations are ignored by `duplicate_set` under some inference conditions). Fixes #28098 cc #21528 (is it a dupe?)
23 lines
897 B
Rust
23 lines
897 B
Rust
// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
fn bot<T>() -> T { loop {} }
|
|
|
|
fn mutate(s: &mut str) {
|
|
s[1..2] = bot();
|
|
//~^ ERROR `core::marker::Sized` is not implemented for the type `str`
|
|
//~| ERROR `core::marker::Sized` is not implemented for the type `str`
|
|
s[1usize] = bot();
|
|
//~^ ERROR `core::ops::Index<usize>` is not implemented for the type `str`
|
|
//~| ERROR `core::ops::IndexMut<usize>` is not implemented for the type `str`
|
|
}
|
|
|
|
pub fn main() {}
|