Auto merge of #48449 - petrochenkov:uidiff, r=nikomatsakis

Anonymize some line numbers in UI test output

New unstable flag `-Z ui-testing` is introduced. This flag changes diagnostic output of the compiler *in some way* making it more suitable for UI testing (this is intentionally vague).
At the moment this flag anonymizes line numbers at line starts thus solving the largest issue with UI test diffs. If diffs continue to be too noisy, some other tweaks could be applied (e.g. anonymizing lines/columns in `--> $DIR/file.rs:line:column`), but this needs some time and experience (we shouldn't diverge too much from the actual output in general).

If comment `// disable-ui-testing-normalization` is added to an UI test, then `-Z ui-testing` is not passed.

Closes https://github.com/rust-lang/rust/issues/46643
This commit is contained in:
bors 2018-02-27 00:29:50 +00:00
commit 29f5c699b1
1230 changed files with 6878 additions and 6708 deletions

View file

@ -1322,6 +1322,8 @@ options! {DebuggingOptions, DebuggingSetter, basic_debugging_options,
epoch). Crates compiled with different epochs can be linked together."),
run_dsymutil: Option<bool> = (None, parse_opt_bool, [TRACKED],
"run `dsymutil` and delete intermediate object files"),
ui_testing: bool = (false, parse_bool, [UNTRACKED],
"format compiler diagnostics in a way that's better suitable for UI testing"),
}
pub fn default_lib_output() -> CrateType {

View file

@ -909,21 +909,24 @@ pub fn build_session_with_codemap(sopts: config::Options,
let emitter: Box<Emitter> = match (sopts.error_format, emitter_dest) {
(config::ErrorOutputType::HumanReadable(color_config), None) => {
Box::new(EmitterWriter::stderr(color_config,
Some(codemap.clone()),
false,
sopts.debugging_opts.teach))
Box::new(EmitterWriter::stderr(color_config, Some(codemap.clone()),
false, sopts.debugging_opts.teach)
.ui_testing(sopts.debugging_opts.ui_testing))
}
(config::ErrorOutputType::HumanReadable(_), Some(dst)) => {
Box::new(EmitterWriter::new(dst, Some(codemap.clone()), false, false))
Box::new(EmitterWriter::new(dst, Some(codemap.clone()),
false, false)
.ui_testing(sopts.debugging_opts.ui_testing))
}
(config::ErrorOutputType::Json(pretty), None) => {
Box::new(JsonEmitter::stderr(Some(registry), codemap.clone(),
pretty, sopts.debugging_opts.approximate_suggestions))
pretty, sopts.debugging_opts.approximate_suggestions)
.ui_testing(sopts.debugging_opts.ui_testing))
}
(config::ErrorOutputType::Json(pretty), Some(dst)) => {
Box::new(JsonEmitter::new(dst, Some(registry), codemap.clone(),
pretty, sopts.debugging_opts.approximate_suggestions))
pretty, sopts.debugging_opts.approximate_suggestions)
.ui_testing(sopts.debugging_opts.ui_testing))
}
(config::ErrorOutputType::Short(color_config), None) => {
Box::new(EmitterWriter::stderr(color_config, Some(codemap.clone()), true, false))

View file

@ -25,6 +25,8 @@ use std::collections::{HashMap, HashSet};
use std::cmp::min;
use unicode_width;
const ANONYMIZED_LINE_NUM: &str = "LL";
/// Emitter trait for emitting errors.
pub trait Emitter {
/// Emit a structured diagnostic.
@ -108,6 +110,7 @@ pub struct EmitterWriter {
short_message: bool,
teach: bool,
error_codes: HashSet<String>,
ui_testing: bool,
}
struct FileWithAnnotatedLines {
@ -157,6 +160,7 @@ impl EmitterWriter {
short_message,
teach,
error_codes: HashSet::new(),
ui_testing: false,
}
} else {
EmitterWriter {
@ -165,6 +169,7 @@ impl EmitterWriter {
short_message,
teach,
error_codes: HashSet::new(),
ui_testing: false,
}
}
}
@ -180,6 +185,20 @@ impl EmitterWriter {
short_message,
teach,
error_codes: HashSet::new(),
ui_testing: false,
}
}
pub fn ui_testing(mut self, ui_testing: bool) -> Self {
self.ui_testing = ui_testing;
self
}
fn maybe_anonymized(&self, line_num: usize) -> String {
if self.ui_testing {
ANONYMIZED_LINE_NUM.to_string()
} else {
line_num.to_string()
}
}
@ -336,7 +355,7 @@ impl EmitterWriter {
buffer.puts(line_offset, code_offset, &source_string, Style::Quotation);
buffer.puts(line_offset,
0,
&(line.line_index.to_string()),
&self.maybe_anonymized(line.line_index),
Style::LineNumber);
draw_col_separator(buffer, line_offset, width_offset - 2);
@ -1159,8 +1178,8 @@ impl EmitterWriter {
buffer.puts(last_buffer_line_num,
0,
&(annotated_file.lines[line_idx + 1].line_index - 1)
.to_string(),
&self.maybe_anonymized(annotated_file.lines[line_idx + 1]
.line_index - 1),
Style::LineNumber);
draw_col_separator(&mut buffer,
last_buffer_line_num,
@ -1235,7 +1254,7 @@ impl EmitterWriter {
// Print the span column to avoid confusion
buffer.puts(row_num,
0,
&((line_start + line_pos).to_string()),
&self.maybe_anonymized(line_start + line_pos),
Style::LineNumber);
// print the suggestion
draw_col_separator(&mut buffer, row_num, max_line_num_len + 1);
@ -1288,8 +1307,11 @@ impl EmitterWriter {
span: &MultiSpan,
children: &Vec<SubDiagnostic>,
suggestions: &[CodeSuggestion]) {
let max_line_num = self.get_max_line_num(span, children);
let max_line_num_len = max_line_num.to_string().len();
let max_line_num_len = if self.ui_testing {
ANONYMIZED_LINE_NUM.len()
} else {
self.get_max_line_num(span, children).to_string().len()
};
match self.emit_message_default(span,
message,

View file

@ -40,6 +40,7 @@ pub struct JsonEmitter {
pretty: bool,
/// Whether "approximate suggestions" are enabled in the config
approximate_suggestions: bool,
ui_testing: bool,
}
impl JsonEmitter {
@ -53,6 +54,7 @@ impl JsonEmitter {
cm: code_map,
pretty,
approximate_suggestions,
ui_testing: false,
}
}
@ -73,8 +75,13 @@ impl JsonEmitter {
cm: code_map,
pretty,
approximate_suggestions,
ui_testing: false,
}
}
pub fn ui_testing(self, ui_testing: bool) -> Self {
Self { ui_testing, ..self }
}
}
impl Emitter for JsonEmitter {
@ -199,7 +206,8 @@ impl Diagnostic {
}
let buf = BufWriter::default();
let output = buf.clone();
EmitterWriter::new(Box::new(buf), Some(je.cm.clone()), false, false).emit(db);
EmitterWriter::new(Box::new(buf), Some(je.cm.clone()), false, false)
.ui_testing(je.ui_testing).emit(db);
let output = Arc::try_unwrap(output.0).unwrap().into_inner().unwrap();
let output = String::from_utf8(output).unwrap();

View file

@ -1,7 +1,7 @@
error: proc-macro derive panicked
--> $DIR/issue-36935.rs:18:15
|
18 | #[derive(Foo, Bar)] //~ ERROR proc-macro derive panicked
LL | #[derive(Foo, Bar)] //~ ERROR proc-macro derive panicked
| ^^^
|
= help: message: lolnope

View file

@ -1,6 +1,6 @@
warning: derive(Encodable) is deprecated in favor of derive(RustcEncodable)
--> $DIR/deprecated-derive.rs:18:10
|
18 | #[derive(Encodable)]
LL | #[derive(Encodable)]
| ^^^^^^^^^

View file

@ -1,7 +1,7 @@
warning: item is named 'lintme'
--> $DIR/lint-group-plugin.rs:18:1
|
18 | fn lintme() { } //~ WARNING item is named 'lintme'
LL | fn lintme() { } //~ WARNING item is named 'lintme'
| ^^^^^^^^^^^^^^^
|
= note: #[warn(test_lint)] on by default
@ -9,7 +9,7 @@ warning: item is named 'lintme'
warning: item is named 'pleaselintme'
--> $DIR/lint-group-plugin.rs:19:1
|
19 | fn pleaselintme() { } //~ WARNING item is named 'pleaselintme'
LL | fn pleaselintme() { } //~ WARNING item is named 'pleaselintme'
| ^^^^^^^^^^^^^^^^^^^^^
|
= note: #[warn(please_lint)] on by default

View file

@ -1,13 +1,13 @@
warning: function is never used: `lintme`
--> $DIR/lint-plugin-cmdline-allow.rs:20:1
|
20 | fn lintme() { }
LL | fn lintme() { }
| ^^^^^^^^^^^
|
note: lint level defined here
--> $DIR/lint-plugin-cmdline-allow.rs:17:9
|
17 | #![warn(unused)]
LL | #![warn(unused)]
| ^^^^^^
= note: #[warn(dead_code)] implied by #[warn(unused)]

View file

@ -1,7 +1,7 @@
warning: item is named 'lintme'
--> $DIR/lint-plugin-cmdline-load.rs:18:1
|
18 | fn lintme() { } //~ WARNING item is named 'lintme'
LL | fn lintme() { } //~ WARNING item is named 'lintme'
| ^^^^^^^^^^^^^^^
|
= note: #[warn(test_lint)] on by default

View file

@ -1,22 +1,22 @@
error: item is named 'lintme'
--> $DIR/lint-plugin-forbid-attrs.rs:18:1
|
18 | fn lintme() { } //~ ERROR item is named 'lintme'
LL | fn lintme() { } //~ ERROR item is named 'lintme'
| ^^^^^^^^^^^^^^^
|
note: lint level defined here
--> $DIR/lint-plugin-forbid-attrs.rs:16:11
|
16 | #![forbid(test_lint)]
LL | #![forbid(test_lint)]
| ^^^^^^^^^
error[E0453]: allow(test_lint) overruled by outer forbid(test_lint)
--> $DIR/lint-plugin-forbid-attrs.rs:20:9
|
16 | #![forbid(test_lint)]
LL | #![forbid(test_lint)]
| --------- `forbid` level set here
...
20 | #[allow(test_lint)]
LL | #[allow(test_lint)]
| ^^^^^^^^^ overruled by previous forbid
error: aborting due to 2 previous errors

View file

@ -1,7 +1,7 @@
warning: item is named 'lintme'
--> $DIR/lint-plugin.rs:18:1
|
18 | fn lintme() { } //~ WARNING item is named 'lintme'
LL | fn lintme() { } //~ WARNING item is named 'lintme'
| ^^^^^^^^^^^^^^^
|
= note: #[warn(test_lint)] on by default

View file

@ -1,7 +1,7 @@
error: proc-macro derive panicked
--> $DIR/load-panic.rs:17:10
|
17 | #[derive(A)]
LL | #[derive(A)]
| ^
|
= help: message: nope!

View file

@ -1,127 +1,127 @@
error: first final: "hello"
--> $DIR/parent-source-spans.rs:27:12
|
27 | three!($a, $b);
LL | three!($a, $b);
| ^^
...
44 | one!("hello", "world");
LL | one!("hello", "world");
| ----------------------- in this macro invocation
error: second final: "world"
--> $DIR/parent-source-spans.rs:27:16
|
27 | three!($a, $b);
LL | three!($a, $b);
| ^^
...
44 | one!("hello", "world");
LL | one!("hello", "world");
| ----------------------- in this macro invocation
error: first parent: "hello"
--> $DIR/parent-source-spans.rs:21:5
|
21 | two!($a, $b);
LL | two!($a, $b);
| ^^^^^^^^^^^^^
...
44 | one!("hello", "world");
LL | one!("hello", "world");
| ----------------------- in this macro invocation
error: second parent: "world"
--> $DIR/parent-source-spans.rs:21:5
|
21 | two!($a, $b);
LL | two!($a, $b);
| ^^^^^^^^^^^^^
...
44 | one!("hello", "world");
LL | one!("hello", "world");
| ----------------------- in this macro invocation
error: first grandparent: "hello"
--> $DIR/parent-source-spans.rs:44:5
|
44 | one!("hello", "world");
LL | one!("hello", "world");
| ^^^^^^^^^^^^^^^^^^^^^^^
error: second grandparent: "world"
--> $DIR/parent-source-spans.rs:44:5
|
44 | one!("hello", "world");
LL | one!("hello", "world");
| ^^^^^^^^^^^^^^^^^^^^^^^
error: first source: "hello"
--> $DIR/parent-source-spans.rs:44:5
|
44 | one!("hello", "world");
LL | one!("hello", "world");
| ^^^^^^^^^^^^^^^^^^^^^^^
error: second source: "world"
--> $DIR/parent-source-spans.rs:44:5
|
44 | one!("hello", "world");
LL | one!("hello", "world");
| ^^^^^^^^^^^^^^^^^^^^^^^
error: first final: "yay"
--> $DIR/parent-source-spans.rs:27:12
|
27 | three!($a, $b);
LL | three!($a, $b);
| ^^
...
50 | two!("yay", "rust");
LL | two!("yay", "rust");
| -------------------- in this macro invocation
error: second final: "rust"
--> $DIR/parent-source-spans.rs:27:16
|
27 | three!($a, $b);
LL | three!($a, $b);
| ^^
...
50 | two!("yay", "rust");
LL | two!("yay", "rust");
| -------------------- in this macro invocation
error: first parent: "yay"
--> $DIR/parent-source-spans.rs:50:5
|
50 | two!("yay", "rust");
LL | two!("yay", "rust");
| ^^^^^^^^^^^^^^^^^^^^
error: second parent: "rust"
--> $DIR/parent-source-spans.rs:50:5
|
50 | two!("yay", "rust");
LL | two!("yay", "rust");
| ^^^^^^^^^^^^^^^^^^^^
error: first source: "yay"
--> $DIR/parent-source-spans.rs:50:5
|
50 | two!("yay", "rust");
LL | two!("yay", "rust");
| ^^^^^^^^^^^^^^^^^^^^
error: second source: "rust"
--> $DIR/parent-source-spans.rs:50:5
|
50 | two!("yay", "rust");
LL | two!("yay", "rust");
| ^^^^^^^^^^^^^^^^^^^^
error: first final: "hip"
--> $DIR/parent-source-spans.rs:56:12
|
56 | three!("hip", "hop");
LL | three!("hip", "hop");
| ^^^^^
error: second final: "hop"
--> $DIR/parent-source-spans.rs:56:19
|
56 | three!("hip", "hop");
LL | three!("hip", "hop");
| ^^^^^
error: first source: "hip"
--> $DIR/parent-source-spans.rs:56:12
|
56 | three!("hip", "hop");
LL | three!("hip", "hop");
| ^^^^^
error: second source: "hop"
--> $DIR/parent-source-spans.rs:56:19
|
56 | three!("hip", "hop");
LL | three!("hip", "hop");
| ^^^^^
error: aborting due to 18 previous errors

View file

@ -1,10 +1,10 @@
error[E0308]: mismatched types
--> $DIR/signature.rs:17:1
|
17 | / pub unsafe extern fn foo(a: i32, b: u32) -> u32 {
18 | | //~^ ERROR: mismatched types
19 | | loop {}
20 | | }
LL | / pub unsafe extern fn foo(a: i32, b: u32) -> u32 {
LL | | //~^ ERROR: mismatched types
LL | | loop {}
LL | | }
| |_^ expected normal fn, found unsafe fn
|
= note: expected type `fn(proc_macro::TokenStream) -> proc_macro::TokenStream`

View file

@ -1,7 +1,7 @@
error: found 2 equal signs, need exactly 3
--> $DIR/three-equals.rs:25:5
|
25 | three_equals!(==); //~ ERROR found 2 equal signs, need exactly 3
LL | three_equals!(==); //~ ERROR found 2 equal signs, need exactly 3
| ^^^^^^^^^^^^^^^^^^
|
= help: input must be: `===`
@ -9,38 +9,38 @@ error: found 2 equal signs, need exactly 3
error: expected EOF, found `=`.
--> $DIR/three-equals.rs:28:21
|
28 | three_equals!(=====); //~ ERROR expected EOF
LL | three_equals!(=====); //~ ERROR expected EOF
| ^^
|
note: last good input was here
--> $DIR/three-equals.rs:28:21
|
28 | three_equals!(=====); //~ ERROR expected EOF
LL | three_equals!(=====); //~ ERROR expected EOF
| ^^
= help: input must be: `===`
error: expected `=`, found `abc`.
--> $DIR/three-equals.rs:31:19
|
31 | three_equals!(abc); //~ ERROR expected `=`
LL | three_equals!(abc); //~ ERROR expected `=`
| ^^^
error: expected `=`, found `!`.
--> $DIR/three-equals.rs:34:19
|
34 | three_equals!(!!); //~ ERROR expected `=`
LL | three_equals!(!!); //~ ERROR expected `=`
| ^
error: expected EOF, found `a`.
--> $DIR/three-equals.rs:37:22
|
37 | three_equals!(===a); //~ ERROR expected EOF
LL | three_equals!(===a); //~ ERROR expected EOF
| ^
|
note: last good input was here
--> $DIR/three-equals.rs:37:21
|
37 | three_equals!(===a); //~ ERROR expected EOF
LL | three_equals!(===a); //~ ERROR expected EOF
| ^
= help: input must be: `===`

View file

@ -1,61 +1,61 @@
error: cannot find derive macro `FooWithLongNan` in this scope
--> $DIR/resolve-error.rs:37:10
|
37 | #[derive(FooWithLongNan)]
LL | #[derive(FooWithLongNan)]
| ^^^^^^^^^^^^^^ help: try: `FooWithLongName`
error: cannot find attribute macro `attr_proc_macra` in this scope
--> $DIR/resolve-error.rs:41:3
|
41 | #[attr_proc_macra]
LL | #[attr_proc_macra]
| ^^^^^^^^^^^^^^^ help: try: `attr_proc_macro`
error: cannot find attribute macro `FooWithLongNan` in this scope
--> $DIR/resolve-error.rs:45:3
|
45 | #[FooWithLongNan]
LL | #[FooWithLongNan]
| ^^^^^^^^^^^^^^
error: cannot find derive macro `Dlone` in this scope
--> $DIR/resolve-error.rs:49:10
|
49 | #[derive(Dlone)]
LL | #[derive(Dlone)]
| ^^^^^ help: try: `Clone`
error: cannot find derive macro `Dlona` in this scope
--> $DIR/resolve-error.rs:53:10
|
53 | #[derive(Dlona)]
LL | #[derive(Dlona)]
| ^^^^^ help: try: `Clona`
error: cannot find derive macro `attr_proc_macra` in this scope
--> $DIR/resolve-error.rs:57:10
|
57 | #[derive(attr_proc_macra)]
LL | #[derive(attr_proc_macra)]
| ^^^^^^^^^^^^^^^
error: cannot find macro `FooWithLongNama!` in this scope
--> $DIR/resolve-error.rs:62:5
|
62 | FooWithLongNama!();
LL | FooWithLongNama!();
| ^^^^^^^^^^^^^^^ help: you could try the macro: `FooWithLongNam`
error: cannot find macro `attr_proc_macra!` in this scope
--> $DIR/resolve-error.rs:65:5
|
65 | attr_proc_macra!();
LL | attr_proc_macra!();
| ^^^^^^^^^^^^^^^ help: you could try the macro: `attr_proc_mac`
error: cannot find macro `Dlona!` in this scope
--> $DIR/resolve-error.rs:68:5
|
68 | Dlona!();
LL | Dlona!();
| ^^^^^
error: cannot find macro `bang_proc_macrp!` in this scope
--> $DIR/resolve-error.rs:71:5
|
71 | bang_proc_macrp!();
LL | bang_proc_macrp!();
| ^^^^^^^^^^^^^^^ help: you could try the macro: `bang_proc_macro`
error: aborting due to 10 previous errors

View file

@ -1,7 +1,7 @@
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:12:5
|
12 | f1(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | f1(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'r, 's> fn(&'r (), &'s ()) -> _`
@ -9,13 +9,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `f1`
--> $DIR/anonymous-higher-ranked-lifetime.rs:26:1
|
26 | fn f1<F>(_: F) where F: Fn(&(), &()) {}
LL | fn f1<F>(_: F) where F: Fn(&(), &()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:13:5
|
13 | f2(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | f2(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'a, 'r> fn(&'a (), &'r ()) -> _`
@ -23,13 +23,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `f2`
--> $DIR/anonymous-higher-ranked-lifetime.rs:27:1
|
27 | fn f2<F>(_: F) where F: for<'a> Fn(&'a (), &()) {}
LL | fn f2<F>(_: F) where F: for<'a> Fn(&'a (), &()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:14:5
|
14 | f3(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | f3(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'r> fn(&(), &'r ()) -> _`
@ -37,13 +37,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `f3`
--> $DIR/anonymous-higher-ranked-lifetime.rs:28:1
|
28 | fn f3<'a, F>(_: F) where F: Fn(&'a (), &()) {}
LL | fn f3<'a, F>(_: F) where F: Fn(&'a (), &()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:15:5
|
15 | f4(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | f4(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'s, 'r> fn(&'s (), &'r ()) -> _`
@ -51,13 +51,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `f4`
--> $DIR/anonymous-higher-ranked-lifetime.rs:29:1
|
29 | fn f4<F>(_: F) where F: for<'r> Fn(&(), &'r ()) {}
LL | fn f4<F>(_: F) where F: for<'r> Fn(&(), &'r ()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:16:5
|
16 | f5(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | f5(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'r> fn(&'r (), &'r ()) -> _`
@ -65,13 +65,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `f5`
--> $DIR/anonymous-higher-ranked-lifetime.rs:30:1
|
30 | fn f5<F>(_: F) where F: for<'r> Fn(&'r (), &'r ()) {}
LL | fn f5<F>(_: F) where F: for<'r> Fn(&'r (), &'r ()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:17:5
|
17 | g1(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | g1(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'r> fn(&'r (), std::boxed::Box<for<'s> std::ops::Fn(&'s ()) + 'static>) -> _`
@ -79,13 +79,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `g1`
--> $DIR/anonymous-higher-ranked-lifetime.rs:33:1
|
33 | fn g1<F>(_: F) where F: Fn(&(), Box<Fn(&())>) {}
LL | fn g1<F>(_: F) where F: Fn(&(), Box<Fn(&())>) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:18:5
|
18 | g2(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | g2(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'r> fn(&'r (), for<'s> fn(&'s ())) -> _`
@ -93,13 +93,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `g2`
--> $DIR/anonymous-higher-ranked-lifetime.rs:34:1
|
34 | fn g2<F>(_: F) where F: Fn(&(), fn(&())) {}
LL | fn g2<F>(_: F) where F: Fn(&(), fn(&())) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:19:5
|
19 | g3(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | g3(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'s> fn(&'s (), std::boxed::Box<for<'r> std::ops::Fn(&'r ()) + 'static>) -> _`
@ -107,13 +107,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `g3`
--> $DIR/anonymous-higher-ranked-lifetime.rs:35:1
|
35 | fn g3<F>(_: F) where F: for<'s> Fn(&'s (), Box<Fn(&())>) {}
LL | fn g3<F>(_: F) where F: for<'s> Fn(&'s (), Box<Fn(&())>) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:20:5
|
20 | g4(|_: (), _: ()| {}); //~ ERROR type mismatch
LL | g4(|_: (), _: ()| {}); //~ ERROR type mismatch
| ^^ -------------- found signature of `fn((), ()) -> _`
| |
| expected signature of `for<'s> fn(&'s (), for<'r> fn(&'r ())) -> _`
@ -121,13 +121,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `g4`
--> $DIR/anonymous-higher-ranked-lifetime.rs:36:1
|
36 | fn g4<F>(_: F) where F: Fn(&(), for<'r> fn(&'r ())) {}
LL | fn g4<F>(_: F) where F: Fn(&(), for<'r> fn(&'r ())) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:21:5
|
21 | h1(|_: (), _: (), _: (), _: ()| {}); //~ ERROR type mismatch
LL | h1(|_: (), _: (), _: (), _: ()| {}); //~ ERROR type mismatch
| ^^ ---------------------------- found signature of `fn((), (), (), ()) -> _`
| |
| expected signature of `for<'r, 's> fn(&'r (), std::boxed::Box<for<'t0> std::ops::Fn(&'t0 ()) + 'static>, &'s (), for<'t0, 't1> fn(&'t0 (), &'t1 ())) -> _`
@ -135,13 +135,13 @@ error[E0631]: type mismatch in closure arguments
note: required by `h1`
--> $DIR/anonymous-higher-ranked-lifetime.rs:39:1
|
39 | fn h1<F>(_: F) where F: Fn(&(), Box<Fn(&())>, &(), fn(&(), &())) {}
LL | fn h1<F>(_: F) where F: Fn(&(), Box<Fn(&())>, &(), fn(&(), &())) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0631]: type mismatch in closure arguments
--> $DIR/anonymous-higher-ranked-lifetime.rs:22:5
|
22 | h2(|_: (), _: (), _: (), _: ()| {}); //~ ERROR type mismatch
LL | h2(|_: (), _: (), _: (), _: ()| {}); //~ ERROR type mismatch
| ^^ ---------------------------- found signature of `fn((), (), (), ()) -> _`
| |
| expected signature of `for<'r, 't0> fn(&'r (), std::boxed::Box<for<'s> std::ops::Fn(&'s ()) + 'static>, &'t0 (), for<'s, 't1> fn(&'s (), &'t1 ())) -> _`
@ -149,7 +149,7 @@ error[E0631]: type mismatch in closure arguments
note: required by `h2`
--> $DIR/anonymous-higher-ranked-lifetime.rs:40:1
|
40 | fn h2<F>(_: F) where F: for<'t0> Fn(&(), Box<Fn(&())>, &'t0 (), fn(&(), &())) {}
LL | fn h2<F>(_: F) where F: for<'t0> Fn(&(), Box<Fn(&())>, &'t0 (), fn(&(), &())) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error: aborting due to 11 previous errors

View file

@ -1,7 +1,7 @@
error[E0038]: the trait `Foo` cannot be made into an object
--> $DIR/arbitrary-self-types-not-object-safe.rs:40:33
|
40 | let x = Box::new(5usize) as Box<Foo>;
LL | let x = Box::new(5usize) as Box<Foo>;
| ^^^^^^^^ the trait `Foo` cannot be made into an object
|
= note: method `foo` has a non-standard `self` type
@ -9,7 +9,7 @@ error[E0038]: the trait `Foo` cannot be made into an object
error[E0038]: the trait `Foo` cannot be made into an object
--> $DIR/arbitrary-self-types-not-object-safe.rs:40:13
|
40 | let x = Box::new(5usize) as Box<Foo>;
LL | let x = Box::new(5usize) as Box<Foo>;
| ^^^^^^^^^^^^^^^^ the trait `Foo` cannot be made into an object
|
= note: method `foo` has a non-standard `self` type

View file

@ -1,10 +1,10 @@
error[E0384]: cannot assign twice to immutable variable `x`
--> $DIR/asm-out-assign-imm.rs:29:9
|
26 | x = 1;
LL | x = 1;
| ----- first assignment to `x`
...
29 | asm!("mov $1, $0" : "=r"(x) : "r"(5));
LL | asm!("mov $1, $0" : "=r"(x) : "r"(5));
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot assign twice to immutable variable
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0308]: mismatched types
--> $DIR/associated-const-impl-wrong-lifetime.rs:18:5
|
18 | const NAME: &'a str = "unit";
LL | const NAME: &'a str = "unit";
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ lifetime mismatch
|
= note: expected type `&'static str`
@ -9,7 +9,7 @@ error[E0308]: mismatched types
note: the lifetime 'a as defined on the impl at 17:1...
--> $DIR/associated-const-impl-wrong-lifetime.rs:17:1
|
17 | impl<'a> Foo for &'a () {
LL | impl<'a> Foo for &'a () {
| ^^^^^^^^^^^^^^^^^^^^^^^
= note: ...does not necessarily outlive the static lifetime

View file

@ -1,10 +1,10 @@
error[E0326]: implemented const `BAR` has an incompatible type for trait
--> $DIR/associated-const-impl-wrong-type.rs:19:16
|
13 | const BAR: u32;
LL | const BAR: u32;
| --- type in trait
...
19 | const BAR: i32 = -1;
LL | const BAR: i32 = -1;
| ^^^ expected u32, found i32
error: aborting due to previous error

View file

@ -1,43 +1,43 @@
error[E0221]: ambiguous associated type `Color` in bounds of `C`
--> $DIR/associated-type-projection-from-multiple-supertraits.rs:29:32
|
15 | type Color;
LL | type Color;
| ----------- ambiguous `Color` from `Vehicle`
...
21 | type Color;
LL | type Color;
| ----------- ambiguous `Color` from `Box`
...
29 | fn dent<C:BoxCar>(c: C, color: C::Color) {
LL | fn dent<C:BoxCar>(c: C, color: C::Color) {
| ^^^^^^^^ ambiguous associated type `Color`
error[E0221]: ambiguous associated type `Color` in bounds of `BoxCar`
--> $DIR/associated-type-projection-from-multiple-supertraits.rs:33:33
|
15 | type Color;
LL | type Color;
| ----------- ambiguous `Color` from `Vehicle`
...
21 | type Color;
LL | type Color;
| ----------- ambiguous `Color` from `Box`
...
33 | fn dent_object<COLOR>(c: BoxCar<Color=COLOR>) {
LL | fn dent_object<COLOR>(c: BoxCar<Color=COLOR>) {
| ^^^^^^^^^^^ ambiguous associated type `Color`
error[E0191]: the value of the associated type `Color` (from the trait `Vehicle`) must be specified
--> $DIR/associated-type-projection-from-multiple-supertraits.rs:33:26
|
33 | fn dent_object<COLOR>(c: BoxCar<Color=COLOR>) {
LL | fn dent_object<COLOR>(c: BoxCar<Color=COLOR>) {
| ^^^^^^^^^^^^^^^^^^^ missing associated type `Color` value
error[E0221]: ambiguous associated type `Color` in bounds of `C`
--> $DIR/associated-type-projection-from-multiple-supertraits.rs:38:29
|
15 | type Color;
LL | type Color;
| ----------- ambiguous `Color` from `Vehicle`
...
21 | type Color;
LL | type Color;
| ----------- ambiguous `Color` from `Box`
...
38 | fn paint<C:BoxCar>(c: C, d: C::Color) {
LL | fn paint<C:BoxCar>(c: C, d: C::Color) {
| ^^^^^^^^ ambiguous associated type `Color`
error: aborting due to 4 previous errors

View file

@ -1,7 +1,7 @@
error[E0277]: the trait bound `(): Add<A>` is not satisfied
--> $DIR/associated-types-ICE-when-projecting-out-of-err.rs:33:11
|
33 | r = r + a;
LL | r = r + a;
| ^ the trait `Add<A>` is not implemented for `()`
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0223]: ambiguous associated type
--> $DIR/associated-types-in-ambiguous-context.rs:16:36
|
16 | fn get<T:Get,U:Get>(x: T, y: U) -> Get::Value {}
LL | fn get<T:Get,U:Get>(x: T, y: U) -> Get::Value {}
| ^^^^^^^^^^ ambiguous associated type
|
= note: specify the type using the syntax `<Type as Get>::Value`
@ -9,7 +9,7 @@ error[E0223]: ambiguous associated type
error[E0223]: ambiguous associated type
--> $DIR/associated-types-in-ambiguous-context.rs:25:10
|
25 | type X = std::ops::Deref::Target;
LL | type X = std::ops::Deref::Target;
| ^^^^^^^^^^^^^^^^^^^^^^^ ambiguous associated type
|
= note: specify the type using the syntax `<Type as std::ops::Deref>::Target`
@ -17,7 +17,7 @@ error[E0223]: ambiguous associated type
error[E0223]: ambiguous associated type
--> $DIR/associated-types-in-ambiguous-context.rs:21:23
|
21 | fn grab(&self) -> Grab::Value;
LL | fn grab(&self) -> Grab::Value;
| ^^^^^^^^^^^ ambiguous associated type
|
= note: specify the type using the syntax `<Type as Grab>::Value`

View file

@ -1,41 +1,41 @@
error[E0517]: attribute should be applied to struct, enum or union
--> $DIR/attr-usage-repr.rs:14:8
|
14 | #[repr(C)] //~ ERROR: attribute should be applied to struct, enum or union
LL | #[repr(C)] //~ ERROR: attribute should be applied to struct, enum or union
| ^
15 | fn f() {}
LL | fn f() {}
| --------- not a struct, enum or union
error[E0517]: attribute should be applied to enum
--> $DIR/attr-usage-repr.rs:26:8
|
26 | #[repr(i8)] //~ ERROR: attribute should be applied to enum
LL | #[repr(i8)] //~ ERROR: attribute should be applied to enum
| ^^
27 | struct SInt(f64, f64);
LL | struct SInt(f64, f64);
| ---------------------- not an enum
error[E0517]: attribute should be applied to struct or union
--> $DIR/attr-usage-repr.rs:32:8
|
32 | #[repr(align(8))] //~ ERROR: attribute should be applied to struct
LL | #[repr(align(8))] //~ ERROR: attribute should be applied to struct
| ^^^^^^^^
33 | enum EAlign { A, B }
LL | enum EAlign { A, B }
| -------------------- not a struct or union
error[E0517]: attribute should be applied to struct or union
--> $DIR/attr-usage-repr.rs:35:8
|
35 | #[repr(packed)] //~ ERROR: attribute should be applied to struct
LL | #[repr(packed)] //~ ERROR: attribute should be applied to struct
| ^^^^^^
36 | enum EPacked { A, B }
LL | enum EPacked { A, B }
| --------------------- not a struct or union
error[E0517]: attribute should be applied to struct
--> $DIR/attr-usage-repr.rs:38:8
|
38 | #[repr(simd)] //~ ERROR: attribute should be applied to struct
LL | #[repr(simd)] //~ ERROR: attribute should be applied to struct
| ^^^^
39 | enum ESimd { A, B }
LL | enum ESimd { A, B }
| ------------------- not a struct
error: aborting due to 5 previous errors

View file

@ -1,19 +1,19 @@
error[E0596]: cannot borrow immutable local variable `y` as mutable
--> $DIR/augmented-assignments.rs:30:5
|
28 | let y = Int(2);
LL | let y = Int(2);
| - consider changing this to `mut y`
29 | //~^ consider changing this to `mut y`
30 | y //~ error: cannot borrow immutable local variable `y` as mutable
LL | //~^ consider changing this to `mut y`
LL | y //~ error: cannot borrow immutable local variable `y` as mutable
| ^ cannot borrow mutably
error[E0382]: use of moved value: `x`
--> $DIR/augmented-assignments.rs:23:5
|
23 | x //~ error: use of moved value: `x`
LL | x //~ error: use of moved value: `x`
| ^ value used here after move
...
26 | x; //~ value moved here
LL | x; //~ value moved here
| - value moved here
|
= note: move occurs because `x` has type `Int`, which does not implement the `Copy` trait

View file

@ -1,7 +1,7 @@
error[E0369]: binary operation `%` cannot be applied to type `&&{integer}`
--> $DIR/binary-op-on-double-ref.rs:14:9
|
14 | x % 2 == 0
LL | x % 2 == 0
| ^^^^^
|
= note: this is a reference to a type that `%` can be applied to; you need to dereference this variable once for this operation to work

View file

@ -1,16 +1,16 @@
error[E0255]: the name `foo` is defined multiple times
--> $DIR/blind-item-item-shadow.rs:13:5
|
11 | mod foo { pub mod foo { } }
LL | mod foo { pub mod foo { } }
| ------- previous definition of the module `foo` here
12 |
13 | use foo::foo;
LL |
LL | use foo::foo;
| ^^^^^^^^ `foo` reimported here
|
= note: `foo` must be defined only once in the type namespace of this module
help: You can use `as` to change the binding name of the import
|
13 | use foo::foo as other_foo;
LL | use foo::foo as other_foo;
| ^^^^^^^^^^^^^^^^^^^^^
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0308]: mismatched types
--> $DIR/block-must-not-have-result-do.rs:13:9
|
13 | true //~ ERROR mismatched types
LL | true //~ ERROR mismatched types
| ^^^^ expected (), found bool
|
= note: expected type `()`

View file

@ -1,9 +1,9 @@
error[E0308]: mismatched types
--> $DIR/block-must-not-have-result-res.rs:15:9
|
14 | fn drop(&mut self) {
LL | fn drop(&mut self) {
| - expected `()` because of default return type
15 | true //~ ERROR mismatched types
LL | true //~ ERROR mismatched types
| ^^^^ expected (), found bool
|
= note: expected type `()`

View file

@ -1,7 +1,7 @@
error[E0308]: mismatched types
--> $DIR/block-must-not-have-result-while.rs:13:9
|
13 | true //~ ERROR mismatched types
LL | true //~ ERROR mismatched types
| ^^^^ expected (), found bool
|
= note: expected type `()`

View file

@ -1,12 +1,12 @@
error[E0308]: mismatched types
--> $DIR/consider-removing-last-semi.rs:11:18
|
11 | fn f() -> String { //~ ERROR mismatched types
LL | fn f() -> String { //~ ERROR mismatched types
| __________________^
12 | | 0u8;
13 | | "bla".to_string();
LL | | 0u8;
LL | | "bla".to_string();
| | - help: consider removing this semicolon
14 | | }
LL | | }
| |_^ expected struct `std::string::String`, found ()
|
= note: expected type `std::string::String`
@ -15,12 +15,12 @@ error[E0308]: mismatched types
error[E0308]: mismatched types
--> $DIR/consider-removing-last-semi.rs:16:18
|
16 | fn g() -> String { //~ ERROR mismatched types
LL | fn g() -> String { //~ ERROR mismatched types
| __________________^
17 | | "this won't work".to_string();
18 | | "removeme".to_string();
LL | | "this won't work".to_string();
LL | | "removeme".to_string();
| | - help: consider removing this semicolon
19 | | }
LL | | }
| |_^ expected struct `std::string::String`, found ()
|
= note: expected type `std::string::String`

View file

@ -1,13 +1,13 @@
error[E0308]: mismatched types
--> $DIR/issue-11714.rs:11:18
|
11 | fn blah() -> i32 { //~ ERROR mismatched types
LL | fn blah() -> i32 { //~ ERROR mismatched types
| __________________^
12 | | 1
13 | |
14 | | ;
LL | | 1
LL | |
LL | | ;
| | - help: consider removing this semicolon
15 | | }
LL | | }
| |_^ expected i32, found ()
|
= note: expected type `i32`

View file

@ -1,15 +1,15 @@
error[E0308]: mismatched types
--> $DIR/issue-13428.rs:13:20
|
13 | fn foo() -> String { //~ ERROR mismatched types
LL | fn foo() -> String { //~ ERROR mismatched types
| ____________________^
14 | | format!("Hello {}",
15 | | "world")
16 | | // Put the trailing semicolon on its own line to test that the
17 | | // note message gets the offending semicolon exactly
18 | | ;
LL | | format!("Hello {}",
LL | | "world")
LL | | // Put the trailing semicolon on its own line to test that the
LL | | // note message gets the offending semicolon exactly
LL | | ;
| | - help: consider removing this semicolon
19 | | }
LL | | }
| |_^ expected struct `std::string::String`, found ()
|
= note: expected type `std::string::String`
@ -18,12 +18,12 @@ error[E0308]: mismatched types
error[E0308]: mismatched types
--> $DIR/issue-13428.rs:21:20
|
21 | fn bar() -> String { //~ ERROR mismatched types
LL | fn bar() -> String { //~ ERROR mismatched types
| ____________________^
22 | | "foobar".to_string()
23 | | ;
LL | | "foobar".to_string()
LL | | ;
| | - help: consider removing this semicolon
24 | | }
LL | | }
| |_^ expected struct `std::string::String`, found ()
|
= note: expected type `std::string::String`

View file

@ -1,9 +1,9 @@
error[E0308]: mismatched types
--> $DIR/issue-13624.rs:17:5
|
16 | pub fn get_enum_struct_variant() -> () {
LL | pub fn get_enum_struct_variant() -> () {
| -- expected `()` because of return type
17 | Enum::EnumStructVariant { x: 1, y: 2, z: 3 }
LL | Enum::EnumStructVariant { x: 1, y: 2, z: 3 }
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected (), found enum `a::Enum`
|
= note: expected type `()`
@ -12,7 +12,7 @@ error[E0308]: mismatched types
error[E0308]: mismatched types
--> $DIR/issue-13624.rs:32:9
|
32 | a::Enum::EnumStructVariant { x, y, z } => {
LL | a::Enum::EnumStructVariant { x, y, z } => {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected (), found enum `a::Enum`
|
= note: expected type `()`

View file

@ -1,9 +1,9 @@
error[E0308]: mismatched types
--> $DIR/issue-20862.rs:12:5
|
11 | fn foo(x: i32) {
LL | fn foo(x: i32) {
| - possibly return type missing here?
12 | |y| x + y
LL | |y| x + y
| ^^^^^^^^^ expected (), found closure
|
= note: expected type `()`
@ -12,7 +12,7 @@ error[E0308]: mismatched types
error[E0618]: expected function, found `()`
--> $DIR/issue-20862.rs:17:13
|
17 | let x = foo(5)(2);
LL | let x = foo(5)(2);
| ^^^^^^^^^ not a function
error: aborting due to 2 previous errors

View file

@ -1,7 +1,7 @@
error[E0277]: the trait bound `{integer}: Scalar` is not satisfied
--> $DIR/issue-22645.rs:25:5
|
25 | b + 3 //~ ERROR E0277
LL | b + 3 //~ ERROR E0277
| ^ the trait `Scalar` is not implemented for `{integer}`
|
= help: the following implementations were found:
@ -11,10 +11,10 @@ error[E0277]: the trait bound `{integer}: Scalar` is not satisfied
error[E0308]: mismatched types
--> $DIR/issue-22645.rs:25:3
|
23 | fn main() {
LL | fn main() {
| - expected `()` because of default return type
24 | let b = Bob + 3.5;
25 | b + 3 //~ ERROR E0277
LL | let b = Bob + 3.5;
LL | b + 3 //~ ERROR E0277
| ^^^^^ expected (), found struct `Bob`
|
= note: expected type `()`

View file

@ -1,7 +1,7 @@
error[E0599]: no method named `b` found for type `&Self` in the current scope
--> $DIR/issue-3563.rs:13:17
|
13 | || self.b()
LL | || self.b()
| ^
|
= help: did you mean `a`?

View file

@ -1,9 +1,9 @@
error[E0308]: mismatched types
--> $DIR/issue-5500.rs:12:5
|
11 | fn main() {
LL | fn main() {
| - expected `()` because of default return type
12 | &panic!()
LL | &panic!()
| ^^^^^^^^^ expected (), found reference
|
= note: expected type `()`

View file

@ -1,18 +1,18 @@
error[E0308]: mismatched types
--> $DIR/unexpected-return-on-unit.rs:19:5
|
19 | foo() //~ ERROR mismatched types
LL | foo() //~ ERROR mismatched types
| ^^^^^ expected (), found usize
|
= note: expected type `()`
found type `usize`
help: try adding a semicolon
|
19 | foo(); //~ ERROR mismatched types
LL | foo(); //~ ERROR mismatched types
| ^
help: try adding a return type
|
18 | fn bar() -> usize {
LL | fn bar() -> usize {
| ^^^^^^^^
error: aborting due to previous error

View file

@ -1,10 +1,10 @@
error[E0599]: no variant named `hsl` found for type `color` in the current scope
--> $DIR/bogus-tag.rs:18:7
|
12 | enum color { rgb(isize, isize, isize), rgba(isize, isize, isize, isize), }
LL | enum color { rgb(isize, isize, isize), rgba(isize, isize, isize, isize), }
| ---------- variant `hsl` not found here
...
18 | color::hsl(h, s, l) => { println!("hsl"); }
LL | color::hsl(h, s, l) => { println!("hsl"); }
| ^^^^^^^^^^^^^^^^^^^ variant not found in `color`
error: aborting due to previous error

View file

@ -1,10 +1,10 @@
error[E0382]: use of moved value: `a`
--> $DIR/borrowck-box-insensitivity.rs:37:9
|
35 | let _x = a.x;
LL | let _x = a.x;
| -- value moved here
36 | //~^ value moved here
37 | let _y = a.y; //~ ERROR use of moved
LL | //~^ value moved here
LL | let _y = a.y; //~ ERROR use of moved
| ^^ value used here after move
|
= note: move occurs because `a.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
@ -12,10 +12,10 @@ error[E0382]: use of moved value: `a`
error[E0382]: use of moved value: `a`
--> $DIR/borrowck-box-insensitivity.rs:46:9
|
44 | let _x = a.x;
LL | let _x = a.x;
| -- value moved here
45 | //~^ value moved here
46 | let _y = a.y; //~ ERROR use of moved
LL | //~^ value moved here
LL | let _y = a.y; //~ ERROR use of moved
| ^^ value used here after move
|
= note: move occurs because `a.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
@ -23,10 +23,10 @@ error[E0382]: use of moved value: `a`
error[E0382]: use of moved value: `a`
--> $DIR/borrowck-box-insensitivity.rs:55:15
|
53 | let _x = a.x;
LL | let _x = a.x;
| -- value moved here
54 | //~^ value moved here
55 | let _y = &a.y; //~ ERROR use of moved
LL | //~^ value moved here
LL | let _y = &a.y; //~ ERROR use of moved
| ^^^ value used here after move
|
= note: move occurs because `a.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
@ -34,130 +34,130 @@ error[E0382]: use of moved value: `a`
error[E0505]: cannot move out of `a.y` because it is borrowed
--> $DIR/borrowck-box-insensitivity.rs:63:9
|
62 | let _x = &a.x;
LL | let _x = &a.x;
| --- borrow of `a.x` occurs here
63 | let _y = a.y;
LL | let _y = a.y;
| ^^ move out of `a.y` occurs here
error[E0503]: cannot use `a.y` because it was mutably borrowed
--> $DIR/borrowck-box-insensitivity.rs:71:9
|
70 | let _x = &mut a.x;
LL | let _x = &mut a.x;
| --- borrow of `a.x` occurs here
71 | let _y = a.y; //~ ERROR cannot use
LL | let _y = a.y; //~ ERROR cannot use
| ^^ use of borrowed `a.x`
error[E0505]: cannot move out of `a.y` because it is borrowed
--> $DIR/borrowck-box-insensitivity.rs:77:9
|
76 | let _x = &mut a.x;
LL | let _x = &mut a.x;
| --- borrow of `a.x` occurs here
77 | let _y = a.y;
LL | let _y = a.y;
| ^^ move out of `a.y` occurs here
error[E0502]: cannot borrow `a` (via `a.y`) as immutable because `a` is also borrowed as mutable (via `a.x`)
--> $DIR/borrowck-box-insensitivity.rs:85:15
|
84 | let _x = &mut a.x;
LL | let _x = &mut a.x;
| --- mutable borrow occurs here (via `a.x`)
85 | let _y = &a.y; //~ ERROR cannot borrow
LL | let _y = &a.y; //~ ERROR cannot borrow
| ^^^ immutable borrow occurs here (via `a.y`)
86 | //~^ immutable borrow occurs here (via `a.y`)
87 | }
LL | //~^ immutable borrow occurs here (via `a.y`)
LL | }
| - mutable borrow ends here
error[E0502]: cannot borrow `a` (via `a.y`) as mutable because `a` is also borrowed as immutable (via `a.x`)
--> $DIR/borrowck-box-insensitivity.rs:92:19
|
91 | let _x = &a.x;
LL | let _x = &a.x;
| --- immutable borrow occurs here (via `a.x`)
92 | let _y = &mut a.y; //~ ERROR cannot borrow
LL | let _y = &mut a.y; //~ ERROR cannot borrow
| ^^^ mutable borrow occurs here (via `a.y`)
93 | //~^ mutable borrow occurs here (via `a.y`)
94 | }
LL | //~^ mutable borrow occurs here (via `a.y`)
LL | }
| - immutable borrow ends here
error[E0382]: use of collaterally moved value: `a.y`
--> $DIR/borrowck-box-insensitivity.rs:100:9
|
98 | let _x = a.x.x;
| -- value moved here
99 | //~^ value moved here
100 | let _y = a.y; //~ ERROR use of collaterally moved
| ^^ value used here after move
|
= note: move occurs because `a.x.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
--> $DIR/borrowck-box-insensitivity.rs:100:9
|
LL | let _x = a.x.x;
| -- value moved here
LL | //~^ value moved here
LL | let _y = a.y; //~ ERROR use of collaterally moved
| ^^ value used here after move
|
= note: move occurs because `a.x.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
error[E0382]: use of collaterally moved value: `a.y`
--> $DIR/borrowck-box-insensitivity.rs:108:9
|
106 | let _x = a.x.x;
| -- value moved here
107 | //~^ value moved here
108 | let _y = a.y; //~ ERROR use of collaterally moved
| ^^ value used here after move
|
= note: move occurs because `a.x.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
--> $DIR/borrowck-box-insensitivity.rs:108:9
|
LL | let _x = a.x.x;
| -- value moved here
LL | //~^ value moved here
LL | let _y = a.y; //~ ERROR use of collaterally moved
| ^^ value used here after move
|
= note: move occurs because `a.x.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
error[E0382]: use of collaterally moved value: `a.y`
--> $DIR/borrowck-box-insensitivity.rs:116:15
|
114 | let _x = a.x.x;
| -- value moved here
115 | //~^ value moved here
116 | let _y = &a.y; //~ ERROR use of collaterally moved
| ^^^ value used here after move
|
= note: move occurs because `a.x.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
--> $DIR/borrowck-box-insensitivity.rs:116:15
|
LL | let _x = a.x.x;
| -- value moved here
LL | //~^ value moved here
LL | let _y = &a.y; //~ ERROR use of collaterally moved
| ^^^ value used here after move
|
= note: move occurs because `a.x.x` has type `std::boxed::Box<isize>`, which does not implement the `Copy` trait
error[E0505]: cannot move out of `a.y` because it is borrowed
--> $DIR/borrowck-box-insensitivity.rs:124:9
|
122 | let _x = &a.x.x;
| ----- borrow of `a.x.x` occurs here
123 | //~^ borrow of `a.x.x` occurs here
124 | let _y = a.y;
| ^^ move out of `a.y` occurs here
--> $DIR/borrowck-box-insensitivity.rs:124:9
|
LL | let _x = &a.x.x;
| ----- borrow of `a.x.x` occurs here
LL | //~^ borrow of `a.x.x` occurs here
LL | let _y = a.y;
| ^^ move out of `a.y` occurs here
error[E0503]: cannot use `a.y` because it was mutably borrowed
--> $DIR/borrowck-box-insensitivity.rs:132:9
|
131 | let _x = &mut a.x.x;
| ----- borrow of `a.x.x` occurs here
132 | let _y = a.y; //~ ERROR cannot use
| ^^ use of borrowed `a.x.x`
--> $DIR/borrowck-box-insensitivity.rs:132:9
|
LL | let _x = &mut a.x.x;
| ----- borrow of `a.x.x` occurs here
LL | let _y = a.y; //~ ERROR cannot use
| ^^ use of borrowed `a.x.x`
error[E0505]: cannot move out of `a.y` because it is borrowed
--> $DIR/borrowck-box-insensitivity.rs:138:9
|
137 | let _x = &mut a.x.x;
| ----- borrow of `a.x.x` occurs here
138 | let _y = a.y;
| ^^ move out of `a.y` occurs here
--> $DIR/borrowck-box-insensitivity.rs:138:9
|
LL | let _x = &mut a.x.x;
| ----- borrow of `a.x.x` occurs here
LL | let _y = a.y;
| ^^ move out of `a.y` occurs here
error[E0502]: cannot borrow `a.y` as immutable because `a.x.x` is also borrowed as mutable
--> $DIR/borrowck-box-insensitivity.rs:147:15
|
145 | let _x = &mut a.x.x;
| ----- mutable borrow occurs here
146 | //~^ mutable borrow occurs here
147 | let _y = &a.y; //~ ERROR cannot borrow
| ^^^ immutable borrow occurs here
148 | //~^ immutable borrow occurs here
149 | }
| - mutable borrow ends here
--> $DIR/borrowck-box-insensitivity.rs:147:15
|
LL | let _x = &mut a.x.x;
| ----- mutable borrow occurs here
LL | //~^ mutable borrow occurs here
LL | let _y = &a.y; //~ ERROR cannot borrow
| ^^^ immutable borrow occurs here
LL | //~^ immutable borrow occurs here
LL | }
| - mutable borrow ends here
error[E0502]: cannot borrow `a.y` as mutable because `a.x.x` is also borrowed as immutable
--> $DIR/borrowck-box-insensitivity.rs:155:19
|
153 | let _x = &a.x.x;
| ----- immutable borrow occurs here
154 | //~^ immutable borrow occurs here
155 | let _y = &mut a.y; //~ ERROR cannot borrow
| ^^^ mutable borrow occurs here
156 | //~^ mutable borrow occurs here
157 | }
| - immutable borrow ends here
--> $DIR/borrowck-box-insensitivity.rs:155:19
|
LL | let _x = &a.x.x;
| ----- immutable borrow occurs here
LL | //~^ immutable borrow occurs here
LL | let _y = &mut a.y; //~ ERROR cannot borrow
| ^^^ mutable borrow occurs here
LL | //~^ mutable borrow occurs here
LL | }
| - immutable borrow ends here
error: aborting due to 16 previous errors

View file

@ -1,151 +1,151 @@
error[E0499]: cannot borrow `x` as mutable more than once at a time (Ast)
--> $DIR/borrowck-closures-two-mut.rs:24:24
|
23 | let c1 = to_fn_mut(|| x = 4);
LL | let c1 = to_fn_mut(|| x = 4);
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
24 | let c2 = to_fn_mut(|| x = 5); //~ ERROR cannot borrow `x` as mutable more than once
LL | let c2 = to_fn_mut(|| x = 5); //~ ERROR cannot borrow `x` as mutable more than once
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
25 | //~| ERROR cannot borrow `x` as mutable more than once
26 | }
LL | //~| ERROR cannot borrow `x` as mutable more than once
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Ast)
--> $DIR/borrowck-closures-two-mut.rs:35:24
|
34 | let c1 = to_fn_mut(|| set(&mut x));
LL | let c1 = to_fn_mut(|| set(&mut x));
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
35 | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
LL | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
36 | //~| ERROR cannot borrow `x` as mutable more than once
37 | }
LL | //~| ERROR cannot borrow `x` as mutable more than once
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Ast)
--> $DIR/borrowck-closures-two-mut.rs:42:24
|
41 | let c1 = to_fn_mut(|| x = 5);
LL | let c1 = to_fn_mut(|| x = 5);
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
42 | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
LL | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
43 | //~| ERROR cannot borrow `x` as mutable more than once
44 | }
LL | //~| ERROR cannot borrow `x` as mutable more than once
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Ast)
--> $DIR/borrowck-closures-two-mut.rs:49:24
|
48 | let c1 = to_fn_mut(|| x = 5);
LL | let c1 = to_fn_mut(|| x = 5);
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
49 | let c2 = to_fn_mut(|| { let _y = to_fn_mut(|| set(&mut x)); }); // (nested closure)
LL | let c2 = to_fn_mut(|| { let _y = to_fn_mut(|| set(&mut x)); }); // (nested closure)
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
...
52 | }
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Ast)
--> $DIR/borrowck-closures-two-mut.rs:61:24
|
60 | let c1 = to_fn_mut(|| set(&mut *x.f));
LL | let c1 = to_fn_mut(|| set(&mut *x.f));
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
61 | let c2 = to_fn_mut(|| set(&mut *x.f));
LL | let c2 = to_fn_mut(|| set(&mut *x.f));
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
...
64 | }
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Mir)
--> $DIR/borrowck-closures-two-mut.rs:24:24
|
23 | let c1 = to_fn_mut(|| x = 4);
LL | let c1 = to_fn_mut(|| x = 4);
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
24 | let c2 = to_fn_mut(|| x = 5); //~ ERROR cannot borrow `x` as mutable more than once
LL | let c2 = to_fn_mut(|| x = 5); //~ ERROR cannot borrow `x` as mutable more than once
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
25 | //~| ERROR cannot borrow `x` as mutable more than once
26 | }
LL | //~| ERROR cannot borrow `x` as mutable more than once
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Mir)
--> $DIR/borrowck-closures-two-mut.rs:35:24
|
34 | let c1 = to_fn_mut(|| set(&mut x));
LL | let c1 = to_fn_mut(|| set(&mut x));
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
35 | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
LL | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
36 | //~| ERROR cannot borrow `x` as mutable more than once
37 | }
LL | //~| ERROR cannot borrow `x` as mutable more than once
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Mir)
--> $DIR/borrowck-closures-two-mut.rs:42:24
|
41 | let c1 = to_fn_mut(|| x = 5);
LL | let c1 = to_fn_mut(|| x = 5);
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
42 | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
LL | let c2 = to_fn_mut(|| set(&mut x)); //~ ERROR cannot borrow `x` as mutable more than once
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
43 | //~| ERROR cannot borrow `x` as mutable more than once
44 | }
LL | //~| ERROR cannot borrow `x` as mutable more than once
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Mir)
--> $DIR/borrowck-closures-two-mut.rs:49:24
|
48 | let c1 = to_fn_mut(|| x = 5);
LL | let c1 = to_fn_mut(|| x = 5);
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
49 | let c2 = to_fn_mut(|| { let _y = to_fn_mut(|| set(&mut x)); }); // (nested closure)
LL | let c2 = to_fn_mut(|| { let _y = to_fn_mut(|| set(&mut x)); }); // (nested closure)
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
...
52 | }
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time (Mir)
--> $DIR/borrowck-closures-two-mut.rs:61:24
|
60 | let c1 = to_fn_mut(|| set(&mut *x.f));
LL | let c1 = to_fn_mut(|| set(&mut *x.f));
| -- - previous borrow occurs due to use of `x` in closure
| |
| first mutable borrow occurs here
61 | let c2 = to_fn_mut(|| set(&mut *x.f));
LL | let c2 = to_fn_mut(|| set(&mut *x.f));
| ^^ - borrow occurs due to use of `x` in closure
| |
| second mutable borrow occurs here
...
64 | }
LL | }
| - first borrow ends here
error: aborting due to 10 previous errors

View file

@ -1,13 +1,13 @@
error[E0373]: closure may outlive the current function, but it borrows `books`, which is owned by the current function
--> $DIR/borrowck-escaping-closure-error-1.rs:23:11
|
23 | spawn(|| books.push(4));
LL | spawn(|| books.push(4));
| ^^ ----- `books` is borrowed here
| |
| may outlive borrowed value `books`
help: to force the closure to take ownership of `books` (and any other referenced variables), use the `move` keyword
|
23 | spawn(move || books.push(4));
LL | spawn(move || books.push(4));
| ^^^^^^^
error: aborting due to previous error

View file

@ -1,13 +1,13 @@
error[E0373]: closure may outlive the current function, but it borrows `books`, which is owned by the current function
--> $DIR/borrowck-escaping-closure-error-2.rs:21:14
|
21 | Box::new(|| books.push(4))
LL | Box::new(|| books.push(4))
| ^^ ----- `books` is borrowed here
| |
| may outlive borrowed value `books`
help: to force the closure to take ownership of `books` (and any other referenced variables), use the `move` keyword
|
21 | Box::new(move || books.push(4))
LL | Box::new(move || books.push(4))
| ^^^^^^^
error: aborting due to previous error

View file

@ -1,9 +1,9 @@
error[E0507]: cannot move out of captured outer variable in an `Fn` closure
--> $DIR/borrowck-in-static.rs:15:17
|
14 | let x = Box::new(0);
LL | let x = Box::new(0);
| - captured outer variable
15 | Box::new(|| x) //~ ERROR cannot move out of captured outer variable
LL | Box::new(|| x) //~ ERROR cannot move out of captured outer variable
| ^ cannot move out of captured outer variable in an `Fn` closure
error: aborting due to previous error

View file

@ -1,35 +1,35 @@
error[E0507]: cannot move out of borrowed content
--> $DIR/borrowck-move-error-with-note.rs:21:11
|
21 | match *f { //~ ERROR cannot move out of
LL | match *f { //~ ERROR cannot move out of
| ^^ cannot move out of borrowed content
22 | //~| cannot move out
23 | Foo::Foo1(num1,
LL | //~| cannot move out
LL | Foo::Foo1(num1,
| ---- hint: to prevent move, use `ref num1` or `ref mut num1`
24 | num2) => (),
LL | num2) => (),
| ---- ...and here (use `ref num2` or `ref mut num2`)
25 | Foo::Foo2(num) => (),
LL | Foo::Foo2(num) => (),
| --- ...and here (use `ref num` or `ref mut num`)
error[E0509]: cannot move out of type `S`, which implements the `Drop` trait
--> $DIR/borrowck-move-error-with-note.rs:40:9
|
40 | / S { //~ ERROR cannot move out of type `S`, which implements the `Drop` trait
41 | | //~| cannot move out of here
42 | | f: _s,
LL | / S { //~ ERROR cannot move out of type `S`, which implements the `Drop` trait
LL | | //~| cannot move out of here
LL | | f: _s,
| | -- hint: to prevent move, use `ref _s` or `ref mut _s`
43 | | g: _t
LL | | g: _t
| | -- ...and here (use `ref _t` or `ref mut _t`)
44 | | } => {}
LL | | } => {}
| |_________^ cannot move out of here
error[E0507]: cannot move out of borrowed content
--> $DIR/borrowck-move-error-with-note.rs:57:11
|
57 | match a.a { //~ ERROR cannot move out of
LL | match a.a { //~ ERROR cannot move out of
| ^ cannot move out of borrowed content
58 | //~| cannot move out
59 | n => {
LL | //~| cannot move out
LL | n => {
| - hint: to prevent move, use `ref n` or `ref mut n`
error: aborting due to 3 previous errors

View file

@ -1,14 +1,14 @@
error[E0508]: cannot move out of type `[Foo]`, a non-copy slice
--> $DIR/borrowck-move-out-of-vec-tail.rs:30:18
|
30 | &[Foo { string: a },
LL | &[Foo { string: a },
| ^ - hint: to prevent move, use `ref a` or `ref mut a`
| __________________|
| |
31 | | //~^ ERROR cannot move out of type `[Foo]`
32 | | //~| cannot move out
33 | | //~| to prevent move
34 | | Foo { string: b }] => {
LL | | //~^ ERROR cannot move out of type `[Foo]`
LL | | //~| cannot move out
LL | | //~| to prevent move
LL | | Foo { string: b }] => {
| |_________________________________-__^ cannot move out of here
| |
| ...and here (use `ref b` or `ref mut b`)

View file

@ -1,9 +1,9 @@
error[E0382]: use of moved value: `x` (Ast)
--> $DIR/borrowck-reinit.rs:18:16
|
17 | drop(x);
LL | drop(x);
| - value moved here
18 | let _ = (1,x); //~ ERROR use of moved value: `x` (Ast)
LL | let _ = (1,x); //~ ERROR use of moved value: `x` (Ast)
| ^ value used here after move
|
= note: move occurs because `x` has type `std::boxed::Box<i32>`, which does not implement the `Copy` trait
@ -11,9 +11,9 @@ error[E0382]: use of moved value: `x` (Ast)
error[E0382]: use of moved value: `x` (Mir)
--> $DIR/borrowck-reinit.rs:18:16
|
17 | drop(x);
LL | drop(x);
| - value moved here
18 | let _ = (1,x); //~ ERROR use of moved value: `x` (Ast)
LL | let _ = (1,x); //~ ERROR use of moved value: `x` (Ast)
| ^ value used here after move
|
= note: move occurs because `x` has type `std::boxed::Box<i32>`, which does not implement the `Copy` trait

View file

@ -1,37 +1,37 @@
error[E0502]: cannot borrow `x` as immutable because it is also borrowed as mutable
--> $DIR/borrowck-report-with-custom-diagnostic.rs:17:14
|
15 | let y = &mut x;
LL | let y = &mut x;
| - mutable borrow occurs here
16 | //~^ mutable borrow occurs here
17 | let z = &x; //~ ERROR cannot borrow
LL | //~^ mutable borrow occurs here
LL | let z = &x; //~ ERROR cannot borrow
| ^ immutable borrow occurs here
18 | //~^ immutable borrow occurs here
19 | }
LL | //~^ immutable borrow occurs here
LL | }
| - mutable borrow ends here
error[E0502]: cannot borrow `x` as mutable because it is also borrowed as immutable
--> $DIR/borrowck-report-with-custom-diagnostic.rs:28:26
|
26 | let y = &x;
LL | let y = &x;
| - immutable borrow occurs here
27 | //~^ immutable borrow occurs here
28 | let z = &mut x; //~ ERROR cannot borrow
LL | //~^ immutable borrow occurs here
LL | let z = &mut x; //~ ERROR cannot borrow
| ^ mutable borrow occurs here
29 | //~^ mutable borrow occurs here
30 | }
LL | //~^ mutable borrow occurs here
LL | }
| - immutable borrow ends here
error[E0499]: cannot borrow `x` as mutable more than once at a time
--> $DIR/borrowck-report-with-custom-diagnostic.rs:41:22
|
39 | let y = &mut x;
LL | let y = &mut x;
| - first mutable borrow occurs here
40 | //~^ first mutable borrow occurs here
41 | let z = &mut x; //~ ERROR cannot borrow
LL | //~^ first mutable borrow occurs here
LL | let z = &mut x; //~ ERROR cannot borrow
| ^ second mutable borrow occurs here
42 | //~^ second mutable borrow occurs here
43 | };
LL | //~^ second mutable borrow occurs here
LL | };
| - first borrow ends here
error: aborting due to 3 previous errors

View file

@ -1,38 +1,38 @@
error[E0506]: cannot assign to `vec[..]` because it is borrowed
--> $DIR/borrowck-vec-pattern-nesting.rs:21:13
|
19 | [box ref _a, _, _] => {
LL | [box ref _a, _, _] => {
| ------ borrow of `vec[..]` occurs here
20 | //~^ borrow of `vec[..]` occurs here
21 | vec[0] = box 4; //~ ERROR cannot assign
LL | //~^ borrow of `vec[..]` occurs here
LL | vec[0] = box 4; //~ ERROR cannot assign
| ^^^^^^^^^^^^^^ assignment to borrowed `vec[..]` occurs here
error[E0506]: cannot assign to `vec[..]` because it is borrowed
--> $DIR/borrowck-vec-pattern-nesting.rs:33:13
|
31 | &mut [ref _b..] => {
LL | &mut [ref _b..] => {
| ------ borrow of `vec[..]` occurs here
32 | //~^ borrow of `vec[..]` occurs here
33 | vec[0] = box 4; //~ ERROR cannot assign
LL | //~^ borrow of `vec[..]` occurs here
LL | vec[0] = box 4; //~ ERROR cannot assign
| ^^^^^^^^^^^^^^ assignment to borrowed `vec[..]` occurs here
error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy slice
--> $DIR/borrowck-vec-pattern-nesting.rs:43:14
|
43 | &mut [_a, //~ ERROR cannot move out
LL | &mut [_a, //~ ERROR cannot move out
| ^-- hint: to prevent move, use `ref _a` or `ref mut _a`
| ______________|
| |
44 | | //~| cannot move out
45 | | //~| to prevent move
46 | | ..
47 | | ] => {
LL | | //~| cannot move out
LL | | //~| to prevent move
LL | | ..
LL | | ] => {
| |_________^ cannot move out of here
error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy slice
--> $DIR/borrowck-vec-pattern-nesting.rs:56:13
|
56 | let a = vec[0]; //~ ERROR cannot move out
LL | let a = vec[0]; //~ ERROR cannot move out
| ^^^^^^
| |
| cannot move out of here
@ -41,10 +41,10 @@ error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy sli
error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy slice
--> $DIR/borrowck-vec-pattern-nesting.rs:64:14
|
64 | &mut [ //~ ERROR cannot move out
LL | &mut [ //~ ERROR cannot move out
| ______________^
65 | | //~^ cannot move out
66 | | _b] => {}
LL | | //~^ cannot move out
LL | | _b] => {}
| |__________--^ cannot move out of here
| |
| hint: to prevent move, use `ref _b` or `ref mut _b`
@ -52,7 +52,7 @@ error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy sli
error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy slice
--> $DIR/borrowck-vec-pattern-nesting.rs:69:13
|
69 | let a = vec[0]; //~ ERROR cannot move out
LL | let a = vec[0]; //~ ERROR cannot move out
| ^^^^^^
| |
| cannot move out of here
@ -61,7 +61,7 @@ error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy sli
error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy slice
--> $DIR/borrowck-vec-pattern-nesting.rs:77:14
|
77 | &mut [_a, _b, _c] => {} //~ ERROR cannot move out
LL | &mut [_a, _b, _c] => {} //~ ERROR cannot move out
| ^--^^--^^--^
| || | |
| || | ...and here (use `ref _c` or `ref mut _c`)
@ -72,7 +72,7 @@ error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy sli
error[E0508]: cannot move out of type `[std::boxed::Box<isize>]`, a non-copy slice
--> $DIR/borrowck-vec-pattern-nesting.rs:81:13
|
81 | let a = vec[0]; //~ ERROR cannot move out
LL | let a = vec[0]; //~ ERROR cannot move out
| ^^^^^^
| |
| cannot move out of here

View file

@ -1,17 +1,17 @@
error[E0384]: cannot assign twice to immutable variable `_x` (Ast)
--> $DIR/immutable-arg.rs:14:5
|
13 | fn foo(_x: u32) {
LL | fn foo(_x: u32) {
| -- first assignment to `_x`
14 | _x = 4;
LL | _x = 4;
| ^^^^^^ cannot assign twice to immutable variable
error[E0384]: cannot assign to immutable argument `_x` (Mir)
--> $DIR/immutable-arg.rs:14:5
|
13 | fn foo(_x: u32) {
LL | fn foo(_x: u32) {
| -- argument not declared as `mut`
14 | _x = 4;
LL | _x = 4;
| ^^^^^^ cannot assign to immutable argument
error: aborting due to 2 previous errors

View file

@ -1,7 +1,7 @@
error[E0382]: use of partially moved value: `maybe` (Ast)
--> $DIR/issue-41962.rs:17:30
|
17 | if let Some(thing) = maybe {
LL | if let Some(thing) = maybe {
| ----- ^^^^^ value used here after move
| |
| value moved here
@ -11,7 +11,7 @@ error[E0382]: use of partially moved value: `maybe` (Ast)
error[E0382]: use of moved value: `(maybe as std::prelude::v1::Some).0` (Ast)
--> $DIR/issue-41962.rs:17:21
|
17 | if let Some(thing) = maybe {
LL | if let Some(thing) = maybe {
| ^^^^^ value moved here in previous iteration of loop
|
= note: move occurs because the value has type `std::vec::Vec<bool>`, which does not implement the `Copy` trait
@ -19,16 +19,16 @@ error[E0382]: use of moved value: `(maybe as std::prelude::v1::Some).0` (Ast)
error[E0382]: use of moved value: `maybe` (Mir)
--> $DIR/issue-41962.rs:17:9
|
17 | if let Some(thing) = maybe {
LL | if let Some(thing) = maybe {
| ^ ----- value moved here
| _________|
| |
18 | | //~^ ERROR use of partially moved value: `maybe` (Ast) [E0382]
19 | | //~| ERROR use of moved value: `(maybe as std::prelude::v1::Some).0` (Ast) [E0382]
20 | | //~| ERROR use of moved value: `maybe` (Mir) [E0382]
21 | | //~| ERROR use of moved value: `maybe` (Mir) [E0382]
22 | | //~| ERROR use of moved value: `maybe.0` (Mir) [E0382]
23 | | }
LL | | //~^ ERROR use of partially moved value: `maybe` (Ast) [E0382]
LL | | //~| ERROR use of moved value: `(maybe as std::prelude::v1::Some).0` (Ast) [E0382]
LL | | //~| ERROR use of moved value: `maybe` (Mir) [E0382]
LL | | //~| ERROR use of moved value: `maybe` (Mir) [E0382]
LL | | //~| ERROR use of moved value: `maybe.0` (Mir) [E0382]
LL | | }
| |_________^ value used here after move
|
= note: move occurs because `maybe` has type `std::option::Option<std::vec::Vec<bool>>`, which does not implement the `Copy` trait
@ -36,7 +36,7 @@ error[E0382]: use of moved value: `maybe` (Mir)
error[E0382]: use of moved value: `maybe` (Mir)
--> $DIR/issue-41962.rs:17:16
|
17 | if let Some(thing) = maybe {
LL | if let Some(thing) = maybe {
| ^^^^^-----^
| | |
| | value moved here
@ -47,7 +47,7 @@ error[E0382]: use of moved value: `maybe` (Mir)
error[E0382]: use of moved value: `maybe.0` (Mir)
--> $DIR/issue-41962.rs:17:21
|
17 | if let Some(thing) = maybe {
LL | if let Some(thing) = maybe {
| ^^^^^ value moved here in previous iteration of loop
|
= note: move occurs because `maybe.0` has type `std::vec::Vec<bool>`, which does not implement the `Copy` trait

View file

@ -1,9 +1,9 @@
error: borrowed data cannot be stored outside of its closure
--> $DIR/issue-45983.rs:17:27
|
16 | let x = None;
LL | let x = None;
| - borrowed data cannot be stored into here...
17 | give_any(|y| x = Some(y));
LL | give_any(|y| x = Some(y));
| --- ^ cannot be stored outside of its closure
| |
| ...because it cannot outlive this closure

View file

@ -1,15 +1,15 @@
error: borrowed data cannot be stored outside of its closure
--> $DIR/issue-7573.rs:32:27
|
27 | let mut lines_to_use: Vec<&CrateId> = Vec::new();
LL | let mut lines_to_use: Vec<&CrateId> = Vec::new();
| - cannot infer an appropriate lifetime...
28 | //~^ NOTE cannot infer an appropriate lifetime
29 | let push_id = |installed_id: &CrateId| {
LL | //~^ NOTE cannot infer an appropriate lifetime
LL | let push_id = |installed_id: &CrateId| {
| ------- ------------------------ borrowed data cannot outlive this closure
| |
| ...so that variable is valid at time of its declaration
...
32 | lines_to_use.push(installed_id);
LL | lines_to_use.push(installed_id);
| ^^^^^^^^^^^^ cannot be stored outside of its closure
error: aborting due to previous error

View file

@ -1,28 +1,28 @@
error[E0499]: cannot borrow `*arg` as mutable more than once at a time
--> $DIR/mut-borrow-in-loop.rs:20:25
|
20 | (self.func)(arg) //~ ERROR cannot borrow
LL | (self.func)(arg) //~ ERROR cannot borrow
| ^^^ mutable borrow starts here in previous iteration of loop
21 | }
22 | }
LL | }
LL | }
| - mutable borrow ends here
error[E0499]: cannot borrow `*arg` as mutable more than once at a time
--> $DIR/mut-borrow-in-loop.rs:26:25
|
26 | (self.func)(arg) //~ ERROR cannot borrow
LL | (self.func)(arg) //~ ERROR cannot borrow
| ^^^ mutable borrow starts here in previous iteration of loop
27 | }
28 | }
LL | }
LL | }
| - mutable borrow ends here
error[E0499]: cannot borrow `*arg` as mutable more than once at a time
--> $DIR/mut-borrow-in-loop.rs:33:25
|
33 | (self.func)(arg) //~ ERROR cannot borrow
LL | (self.func)(arg) //~ ERROR cannot borrow
| ^^^ mutable borrow starts here in previous iteration of loop
34 | }
35 | }
LL | }
LL | }
| - mutable borrow ends here
error: aborting due to 3 previous errors

View file

@ -1,22 +1,22 @@
error[E0499]: cannot borrow `void` as mutable more than once at a time
--> $DIR/mut-borrow-outside-loop.rs:17:23
|
16 | let first = &mut void;
LL | let first = &mut void;
| ---- first mutable borrow occurs here
17 | let second = &mut void; //~ ERROR cannot borrow
LL | let second = &mut void; //~ ERROR cannot borrow
| ^^^^ second mutable borrow occurs here
...
25 | }
LL | }
| - first borrow ends here
error[E0499]: cannot borrow `inner_void` as mutable more than once at a time
--> $DIR/mut-borrow-outside-loop.rs:23:33
|
22 | let inner_first = &mut inner_void;
LL | let inner_first = &mut inner_void;
| ---------- first mutable borrow occurs here
23 | let inner_second = &mut inner_void; //~ ERROR cannot borrow
LL | let inner_second = &mut inner_void; //~ ERROR cannot borrow
| ^^^^^^^^^^ second mutable borrow occurs here
24 | }
LL | }
| - first borrow ends here
error: aborting due to 2 previous errors

View file

@ -1,25 +1,25 @@
error[E0195]: lifetime parameters or bounds on method `no_bound` do not match the trait declaration
--> $DIR/regions-bound-missing-bound-in-impl.rs:28:5
|
20 | fn no_bound<'b>(self, b: Inv<'b>);
LL | fn no_bound<'b>(self, b: Inv<'b>);
| ---------------------------------- lifetimes in impl do not match this method in trait
...
28 | fn no_bound<'b:'a>(self, b: Inv<'b>) {
LL | fn no_bound<'b:'a>(self, b: Inv<'b>) {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ lifetimes do not match method in trait
error[E0195]: lifetime parameters or bounds on method `has_bound` do not match the trait declaration
--> $DIR/regions-bound-missing-bound-in-impl.rs:32:5
|
21 | fn has_bound<'b:'a>(self, b: Inv<'b>);
LL | fn has_bound<'b:'a>(self, b: Inv<'b>);
| -------------------------------------- lifetimes in impl do not match this method in trait
...
32 | fn has_bound<'b>(self, b: Inv<'b>) {
LL | fn has_bound<'b>(self, b: Inv<'b>) {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ lifetimes do not match method in trait
error[E0308]: method not compatible with trait
--> $DIR/regions-bound-missing-bound-in-impl.rs:36:5
|
36 | fn wrong_bound1<'b,'c,'d:'a+'c>(self, b: Inv<'b>, c: Inv<'c>, d: Inv<'d>) {
LL | fn wrong_bound1<'b,'c,'d:'a+'c>(self, b: Inv<'b>, c: Inv<'c>, d: Inv<'d>) {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ lifetime mismatch
|
= note: expected type `fn(&'a isize, Inv<'c>, Inv<'c>, Inv<'d>)`
@ -27,21 +27,21 @@ error[E0308]: method not compatible with trait
note: the lifetime 'c as defined on the method body at 36:5...
--> $DIR/regions-bound-missing-bound-in-impl.rs:36:5
|
36 | fn wrong_bound1<'b,'c,'d:'a+'c>(self, b: Inv<'b>, c: Inv<'c>, d: Inv<'d>) {
LL | fn wrong_bound1<'b,'c,'d:'a+'c>(self, b: Inv<'b>, c: Inv<'c>, d: Inv<'d>) {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
note: ...does not necessarily outlive the lifetime 'c as defined on the method body at 36:5
--> $DIR/regions-bound-missing-bound-in-impl.rs:36:5
|
36 | fn wrong_bound1<'b,'c,'d:'a+'c>(self, b: Inv<'b>, c: Inv<'c>, d: Inv<'d>) {
LL | fn wrong_bound1<'b,'c,'d:'a+'c>(self, b: Inv<'b>, c: Inv<'c>, d: Inv<'d>) {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0276]: impl has stricter requirements than trait
--> $DIR/regions-bound-missing-bound-in-impl.rs:53:5
|
24 | fn another_bound<'x: 'a>(self, x: Inv<'x>, y: Inv<'t>);
LL | fn another_bound<'x: 'a>(self, x: Inv<'x>, y: Inv<'t>);
| ------------------------------------------------------- definition of `another_bound` from trait
...
53 | fn another_bound<'x: 't>(self, x: Inv<'x>, y: Inv<'t>) {
LL | fn another_bound<'x: 't>(self, x: Inv<'x>, y: Inv<'t>) {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ impl has extra requirement `'x: 't`
error: aborting due to 4 previous errors

View file

@ -1,9 +1,9 @@
error: borrowed data cannot be stored outside of its closure
--> $DIR/regions-escape-bound-fn-2.rs:18:27
|
17 | let mut x = None;
LL | let mut x = None;
| ----- borrowed data cannot be stored into here...
18 | with_int(|y| x = Some(y));
LL | with_int(|y| x = Some(y));
| --- ^ cannot be stored outside of its closure
| |
| ...because it cannot outlive this closure

View file

@ -1,9 +1,9 @@
error: borrowed data cannot be stored outside of its closure
--> $DIR/regions-escape-bound-fn.rs:18:27
|
17 | let mut x: Option<&isize> = None;
LL | let mut x: Option<&isize> = None;
| ----- borrowed data cannot be stored into here...
18 | with_int(|y| x = Some(y));
LL | with_int(|y| x = Some(y));
| --- ^ cannot be stored outside of its closure
| |
| ...because it cannot outlive this closure

View file

@ -1,9 +1,9 @@
error: borrowed data cannot be stored outside of its closure
--> $DIR/regions-escape-unboxed-closure.rs:16:32
|
15 | let mut x: Option<&isize> = None;
LL | let mut x: Option<&isize> = None;
| ----- borrowed data cannot be stored into here...
16 | with_int(&mut |y| x = Some(y));
LL | with_int(&mut |y| x = Some(y));
| --- ^ cannot be stored outside of its closure
| |
| ...because it cannot outlive this closure

View file

@ -1,10 +1,10 @@
error[E0507]: cannot move out of captured outer variable in an `Fn` closure
--> $DIR/unboxed-closures-move-upvar-from-non-once-ref-closure.rs:21:9
|
19 | let y = vec![format!("World")];
LL | let y = vec![format!("World")];
| - captured outer variable
20 | call(|| {
21 | y.into_iter();
LL | call(|| {
LL | y.into_iter();
| ^ cannot move out of captured outer variable in an `Fn` closure
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0054]: cannot cast as `bool`
--> $DIR/cast-as-bool.rs:12:13
|
12 | let u = 5 as bool;
LL | let u = 5 as bool;
| ^^^^^^^^^ unsupported cast
|
= help: compare with zero instead

View file

@ -1,7 +1,7 @@
error[E0425]: cannot find value `error` in this scope
--> $DIR/cast-errors-issue-43825.rs:12:17
|
12 | let error = error; //~ ERROR cannot find value `error`
LL | let error = error; //~ ERROR cannot find value `error`
| ^^^^^ not found in this scope
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0054]: cannot cast as `bool`
--> $DIR/cast-rfc0401-2.rs:16:13
|
16 | let _ = 3 as bool;
LL | let _ = 3 as bool;
| ^^^^^^^^^ unsupported cast
|
= help: compare with zero instead

View file

@ -1,7 +1,7 @@
error[E0620]: cast to unsized type: `&{integer}` as `std::marker::Send`
--> $DIR/cast-to-unsized-trait-object-suggestion.rs:12:5
|
12 | &1 as Send; //~ ERROR cast to unsized
LL | &1 as Send; //~ ERROR cast to unsized
| ^^^^^^----
| |
| help: try casting to a reference instead: `&Send`
@ -9,7 +9,7 @@ error[E0620]: cast to unsized type: `&{integer}` as `std::marker::Send`
error[E0620]: cast to unsized type: `std::boxed::Box<{integer}>` as `std::marker::Send`
--> $DIR/cast-to-unsized-trait-object-suggestion.rs:13:5
|
13 | Box::new(1) as Send; //~ ERROR cast to unsized
LL | Box::new(1) as Send; //~ ERROR cast to unsized
| ^^^^^^^^^^^^^^^----
| |
| help: try casting to a `Box` instead: `Box<Send>`

View file

@ -1,19 +1,19 @@
error: only u8 can be casted into char
--> $DIR/cast_char.rs:14:23
|
14 | const XYZ: char = 0x1F888 as char;
LL | const XYZ: char = 0x1F888 as char;
| ^^^^^^^^^^^^^^^ help: use a char literal instead: `'/u{1F888}'`
|
note: lint level defined here
--> $DIR/cast_char.rs:11:9
|
11 | #![deny(overflowing_literals)]
LL | #![deny(overflowing_literals)]
| ^^^^^^^^^^^^^^^^^^^^
error: only u8 can be casted into char
--> $DIR/cast_char.rs:16:22
|
16 | const XY: char = 129160 as char;
LL | const XY: char = 129160 as char;
| ^^^^^^^^^^^^^^ help: use a char literal instead: `'/u{1F888}'`
error: aborting due to 2 previous errors

View file

@ -1,7 +1,7 @@
error[E0606]: casting `*mut impl std::fmt::Debug+?Sized` as `*mut impl std::fmt::Debug+?Sized` is invalid
--> $DIR/casts-differing-anon.rs:33:13
|
33 | b_raw = f_raw as *mut _; //~ ERROR is invalid
LL | b_raw = f_raw as *mut _; //~ ERROR is invalid
| ^^^^^^^^^^^^^^^
|
= note: vtable kinds may not match

View file

@ -1,7 +1,7 @@
error[E0412]: cannot find type `Ipsum` in this scope
--> $DIR/casts-issue-46365.rs:12:12
|
12 | ipsum: Ipsum //~ ERROR cannot find type `Ipsum`
LL | ipsum: Ipsum //~ ERROR cannot find type `Ipsum`
| ^^^^^ not found in this scope
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0460]: found possibly newer version of crate `a` which `b` depends on
--> $DIR/changing-crates.rs:20:1
|
20 | extern crate b; //~ ERROR: found possibly newer version of crate `a` which `b` depends on
LL | extern crate b; //~ ERROR: found possibly newer version of crate `a` which `b` depends on
| ^^^^^^^^^^^^^^^
|
= note: perhaps that crate needs to be recompiled?

View file

@ -1,49 +1,49 @@
error[E0004]: non-exhaustive patterns: `(B, _)`, `(C, _)`, `(D, _)` and 2 more not covered
--> $DIR/issue-35609.rs:20:11
|
20 | match (A, ()) { //~ ERROR non-exhaustive
LL | match (A, ()) { //~ ERROR non-exhaustive
| ^^^^^^^ patterns `(B, _)`, `(C, _)`, `(D, _)` and 2 more not covered
error[E0004]: non-exhaustive patterns: `(_, B)`, `(_, C)`, `(_, D)` and 2 more not covered
--> $DIR/issue-35609.rs:24:11
|
24 | match (A, A) { //~ ERROR non-exhaustive
LL | match (A, A) { //~ ERROR non-exhaustive
| ^^^^^^ patterns `(_, B)`, `(_, C)`, `(_, D)` and 2 more not covered
error[E0004]: non-exhaustive patterns: `((B, _), _)`, `((C, _), _)`, `((D, _), _)` and 2 more not covered
--> $DIR/issue-35609.rs:28:11
|
28 | match ((A, ()), ()) { //~ ERROR non-exhaustive
LL | match ((A, ()), ()) { //~ ERROR non-exhaustive
| ^^^^^^^^^^^^^ patterns `((B, _), _)`, `((C, _), _)`, `((D, _), _)` and 2 more not covered
error[E0004]: non-exhaustive patterns: `((B, _), _)`, `((C, _), _)`, `((D, _), _)` and 2 more not covered
--> $DIR/issue-35609.rs:32:11
|
32 | match ((A, ()), A) { //~ ERROR non-exhaustive
LL | match ((A, ()), A) { //~ ERROR non-exhaustive
| ^^^^^^^^^^^^ patterns `((B, _), _)`, `((C, _), _)`, `((D, _), _)` and 2 more not covered
error[E0004]: non-exhaustive patterns: `((B, _), _)`, `((C, _), _)`, `((D, _), _)` and 2 more not covered
--> $DIR/issue-35609.rs:36:11
|
36 | match ((A, ()), ()) { //~ ERROR non-exhaustive
LL | match ((A, ()), ()) { //~ ERROR non-exhaustive
| ^^^^^^^^^^^^^ patterns `((B, _), _)`, `((C, _), _)`, `((D, _), _)` and 2 more not covered
error[E0004]: non-exhaustive patterns: `S(B, _)`, `S(C, _)`, `S(D, _)` and 2 more not covered
--> $DIR/issue-35609.rs:41:11
|
41 | match S(A, ()) { //~ ERROR non-exhaustive
LL | match S(A, ()) { //~ ERROR non-exhaustive
| ^^^^^^^^ patterns `S(B, _)`, `S(C, _)`, `S(D, _)` and 2 more not covered
error[E0004]: non-exhaustive patterns: `Sd { x: B, .. }`, `Sd { x: C, .. }`, `Sd { x: D, .. }` and 2 more not covered
--> $DIR/issue-35609.rs:45:11
|
45 | match (Sd { x: A, y: () }) { //~ ERROR non-exhaustive
LL | match (Sd { x: A, y: () }) { //~ ERROR non-exhaustive
| ^^^^^^^^^^^^^^^^^^^^ patterns `Sd { x: B, .. }`, `Sd { x: C, .. }`, `Sd { x: D, .. }` and 2 more not covered
error[E0004]: non-exhaustive patterns: `Some(B)`, `Some(C)`, `Some(D)` and 2 more not covered
--> $DIR/issue-35609.rs:49:11
|
49 | match Some(A) { //~ ERROR non-exhaustive
LL | match Some(A) { //~ ERROR non-exhaustive
| ^^^^^^^ patterns `Some(B)`, `Some(C)`, `Some(D)` and 2 more not covered
error: aborting due to 8 previous errors

View file

@ -1,24 +1,24 @@
warning: unreachable pattern
--> $DIR/issue-43253.rs:39:9
|
39 | 9 => {},
LL | 9 => {},
| ^
|
note: lint level defined here
--> $DIR/issue-43253.rs:14:9
|
14 | #![warn(unreachable_patterns)]
LL | #![warn(unreachable_patterns)]
| ^^^^^^^^^^^^^^^^^^^^
warning: unreachable pattern
--> $DIR/issue-43253.rs:45:9
|
45 | 8...9 => {},
LL | 8...9 => {},
| ^^^^^
warning: unreachable pattern
--> $DIR/issue-43253.rs:51:9
|
51 | 9...9 => {},
LL | 9...9 => {},
| ^^^^^

View file

@ -1,27 +1,27 @@
error: borrowed data cannot be stored outside of its closure
--> $DIR/expect-region-supply-region.rs:28:18
|
26 | let mut f: Option<&u32> = None;
LL | let mut f: Option<&u32> = None;
| ----- borrowed data cannot be stored into here...
27 | closure_expecting_bound(|x| {
LL | closure_expecting_bound(|x| {
| --- ...because it cannot outlive this closure
28 | f = Some(x); //~ ERROR borrowed data cannot be stored outside of its closure
LL | f = Some(x); //~ ERROR borrowed data cannot be stored outside of its closure
| ^ cannot be stored outside of its closure
error: borrowed data cannot be stored outside of its closure
--> $DIR/expect-region-supply-region.rs:38:18
|
36 | let mut f: Option<&u32> = None;
LL | let mut f: Option<&u32> = None;
| ----- borrowed data cannot be stored into here...
37 | closure_expecting_bound(|x: &u32| {
LL | closure_expecting_bound(|x: &u32| {
| --------- ...because it cannot outlive this closure
38 | f = Some(x); //~ ERROR borrowed data cannot be stored outside of its closure
LL | f = Some(x); //~ ERROR borrowed data cannot be stored outside of its closure
| ^ cannot be stored outside of its closure
error[E0308]: mismatched types
--> $DIR/expect-region-supply-region.rs:47:33
|
47 | closure_expecting_bound(|x: &'x u32| {
LL | closure_expecting_bound(|x: &'x u32| {
| ^^^^^^^ lifetime mismatch
|
= note: expected type `&u32`
@ -29,25 +29,25 @@ error[E0308]: mismatched types
note: the anonymous lifetime #2 defined on the body at 47:29...
--> $DIR/expect-region-supply-region.rs:47:29
|
47 | closure_expecting_bound(|x: &'x u32| {
LL | closure_expecting_bound(|x: &'x u32| {
| _____________________________^
48 | | //~^ ERROR mismatched types
49 | | //~| ERROR mismatched types
50 | |
LL | | //~^ ERROR mismatched types
LL | | //~| ERROR mismatched types
LL | |
... |
53 | | //~^ ERROR borrowed data cannot be stored outside of its closure
54 | | });
LL | | //~^ ERROR borrowed data cannot be stored outside of its closure
LL | | });
| |_____^
note: ...does not necessarily outlive the lifetime 'x as defined on the function body at 42:1
--> $DIR/expect-region-supply-region.rs:42:1
|
42 | fn expect_bound_supply_named<'x>() {
LL | fn expect_bound_supply_named<'x>() {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error[E0308]: mismatched types
--> $DIR/expect-region-supply-region.rs:47:33
|
47 | closure_expecting_bound(|x: &'x u32| {
LL | closure_expecting_bound(|x: &'x u32| {
| ^^^^^^^ lifetime mismatch
|
= note: expected type `&u32`
@ -55,31 +55,31 @@ error[E0308]: mismatched types
note: the lifetime 'x as defined on the function body at 42:1...
--> $DIR/expect-region-supply-region.rs:42:1
|
42 | fn expect_bound_supply_named<'x>() {
LL | fn expect_bound_supply_named<'x>() {
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
note: ...does not necessarily outlive the anonymous lifetime #2 defined on the body at 47:29
--> $DIR/expect-region-supply-region.rs:47:29
|
47 | closure_expecting_bound(|x: &'x u32| {
LL | closure_expecting_bound(|x: &'x u32| {
| _____________________________^
48 | | //~^ ERROR mismatched types
49 | | //~| ERROR mismatched types
50 | |
LL | | //~^ ERROR mismatched types
LL | | //~| ERROR mismatched types
LL | |
... |
53 | | //~^ ERROR borrowed data cannot be stored outside of its closure
54 | | });
LL | | //~^ ERROR borrowed data cannot be stored outside of its closure
LL | | });
| |_____^
error: borrowed data cannot be stored outside of its closure
--> $DIR/expect-region-supply-region.rs:52:18
|
43 | let mut f: Option<&u32> = None;
LL | let mut f: Option<&u32> = None;
| ----- borrowed data cannot be stored into here...
...
47 | closure_expecting_bound(|x: &'x u32| {
LL | closure_expecting_bound(|x: &'x u32| {
| ------------ ...because it cannot outlive this closure
...
52 | f = Some(x);
LL | f = Some(x);
| ^ cannot be stored outside of its closure
error: aborting due to 5 previous errors

View file

@ -1,12 +1,12 @@
error[E0525]: expected a closure that implements the `Fn` trait, but this closure only implements `FnMut`
--> $DIR/issue-26046-fn-mut.rs:14:19
|
14 | let closure = || { //~ ERROR expected a closure that
LL | let closure = || { //~ ERROR expected a closure that
| ^^ this closure implements `FnMut`, not `Fn`
15 | num += 1;
LL | num += 1;
| --- closure is `FnMut` because it mutates the variable `num` here
...
18 | Box::new(closure)
LL | Box::new(closure)
| ----------------- the requirement to implement `Fn` derives from here
error: aborting due to previous error

View file

@ -1,12 +1,12 @@
error[E0525]: expected a closure that implements the `Fn` trait, but this closure only implements `FnOnce`
--> $DIR/issue-26046-fn-once.rs:14:19
|
14 | let closure = move || { //~ ERROR expected a closure
LL | let closure = move || { //~ ERROR expected a closure
| ^^^^^^^ this closure implements `FnOnce`, not `Fn`
15 | vec
LL | vec
| --- closure is `FnOnce` because it moves the variable `vec` out of its environment
...
18 | Box::new(closure)
LL | Box::new(closure)
| ----------------- the requirement to implement `Fn` derives from here
error: aborting due to previous error

View file

@ -1,15 +1,15 @@
error[E0382]: use of moved value: `debug_dump_dict`
--> $DIR/issue-42065.rs:21:5
|
20 | debug_dump_dict();
LL | debug_dump_dict();
| --------------- value moved here
21 | debug_dump_dict();
LL | debug_dump_dict();
| ^^^^^^^^^^^^^^^ value used here after move
|
note: closure cannot be invoked more than once because it moves the variable `dict` out of its environment
--> $DIR/issue-42065.rs:16:29
|
16 | for (key, value) in dict {
LL | for (key, value) in dict {
| ^^^^
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error: requires at least a format string argument
--> $DIR/bad-format-args.rs:12:5
|
12 | format!();
LL | format!();
| ^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)
@ -9,7 +9,7 @@ error: requires at least a format string argument
error: expected token: `,`
--> $DIR/bad-format-args.rs:13:5
|
13 | format!("" 1);
LL | format!("" 1);
| ^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)
@ -17,7 +17,7 @@ error: expected token: `,`
error: expected token: `,`
--> $DIR/bad-format-args.rs:14:5
|
14 | format!("", 1 1);
LL | format!("", 1 1);
| ^^^^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

View file

@ -1,9 +1,9 @@
error[E0592]: duplicate definitions with name `f`
--> $DIR/coherence-overlapping-inherent-impl-trait.rs:14:10
|
14 | impl C { fn f() {} } //~ ERROR duplicate
LL | impl C { fn f() {} } //~ ERROR duplicate
| ^^^^^^^^^ duplicate definitions for `f`
15 | impl C { fn f() {} }
LL | impl C { fn f() {} }
| --------- other definition for `f`
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0321]: cross-crate traits with a default impl, like `std::marker::Send`, can only be implemented for a struct/enum type, not `&'static main::Foo`
--> $DIR/empty_span.rs:17:5
|
17 | unsafe impl Send for &'static Foo { } //~ ERROR cross-crate traits with a default impl
LL | unsafe impl Send for &'static Foo { } //~ ERROR cross-crate traits with a default impl
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
error: aborting due to previous error

View file

@ -1,11 +1,11 @@
error[E0596]: cannot borrow immutable local variable `x` as mutable
--> $DIR/huge_multispan_highlight.rs:100:18
|
12 | let x = "foo";
| - consider changing this to `mut x`
--> $DIR/huge_multispan_highlight.rs:100:18
|
LL | let x = "foo";
| - consider changing this to `mut x`
...
100 | let y = &mut x; //~ ERROR cannot borrow
| ^ cannot borrow mutably
LL | let y = &mut x; //~ ERROR cannot borrow
| ^ cannot borrow mutably
error: aborting due to previous error

View file

@ -1,12 +1,12 @@
error[E0499]: cannot borrow `x` as mutable more than once at a time
--> $DIR/issue-11715.rs:100:18
|
99 | let y = &mut x;
| - first mutable borrow occurs here
100 | let z = &mut x; //~ ERROR cannot borrow
| ^ second mutable borrow occurs here
101 | }
| - first borrow ends here
--> $DIR/issue-11715.rs:100:18
|
LL | let y = &mut x;
| - first mutable borrow occurs here
LL | let z = &mut x; //~ ERROR cannot borrow
| ^ second mutable borrow occurs here
LL | }
| - first borrow ends here
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error[E0600]: cannot apply unary operator `!` to type `&'static str`
--> $DIR/issue-28308.rs:12:5
|
12 | assert!("foo");
LL | assert!("foo");
| ^^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

View file

@ -1,7 +1,7 @@
error[E0499]: cannot borrow `v` as mutable more than once at a time
--> $DIR/one_line.rs:13:12
|
13 | v.push(v.pop().unwrap()); //~ ERROR cannot borrow
LL | v.push(v.pop().unwrap()); //~ ERROR cannot borrow
| - ^ - first borrow ends here
| | |
| | second mutable borrow occurs here

View file

@ -1,28 +1,28 @@
error[E0592]: duplicate definitions with name `id`
--> $DIR/overlapping_inherent_impls.rs:19:5
|
19 | fn id() {} //~ ERROR duplicate definitions
LL | fn id() {} //~ ERROR duplicate definitions
| ^^^^^^^^^^ duplicate definitions for `id`
...
23 | fn id() {}
LL | fn id() {}
| ---------- other definition for `id`
error[E0592]: duplicate definitions with name `bar`
--> $DIR/overlapping_inherent_impls.rs:29:5
|
29 | fn bar(&self) {} //~ ERROR duplicate definitions
LL | fn bar(&self) {} //~ ERROR duplicate definitions
| ^^^^^^^^^^^^^^^^ duplicate definitions for `bar`
...
33 | fn bar(&self) {}
LL | fn bar(&self) {}
| ---------------- other definition for `bar`
error[E0592]: duplicate definitions with name `baz`
--> $DIR/overlapping_inherent_impls.rs:39:5
|
39 | fn baz(&self) {} //~ ERROR duplicate definitions
LL | fn baz(&self) {} //~ ERROR duplicate definitions
| ^^^^^^^^^^^^^^^^ duplicate definitions for `baz`
...
43 | fn baz(&self) {}
LL | fn baz(&self) {}
| ---------------- other definition for `baz`
|
= note: upstream crates may add new impl of trait `std::marker::Copy` for type `std::vec::Vec<_>` in future versions

View file

@ -1,7 +1,7 @@
error[E0509]: cannot move out of type `S`, which implements the `Drop` trait
--> $DIR/overlapping_spans.rs:21:9
|
21 | S {f:_s} => {} //~ ERROR cannot move out
LL | S {f:_s} => {} //~ ERROR cannot move out
| ^^^^^--^
| | |
| | hint: to prevent move, use `ref _s` or `ref mut _s`

View file

@ -1,15 +1,15 @@
error[E0425]: cannot find value `bar` in this scope
--> $DIR/tab.rs:14:2
|
14 | bar; //~ ERROR cannot find value `bar`
LL | bar; //~ ERROR cannot find value `bar`
| ^^^ not found in this scope
error[E0308]: mismatched types
--> $DIR/tab.rs:18:2
|
17 | fn foo() {
LL | fn foo() {
| - help: try adding a return type: `-> &'static str`
18 | "bar boo" //~ ERROR mismatched types
LL | "bar boo" //~ ERROR mismatched types
| ^^^^^^^^^^^^^^^^^^^^ expected (), found reference
|
= note: expected type `()`

View file

@ -1,9 +1,9 @@
error: unterminated double quote string
--> $DIR/tab_2.rs:14:7
|
14 | """; //~ ERROR unterminated double quote
LL | """; //~ ERROR unterminated double quote
| ___________________^
15 | | }
LL | | }
| |__^
error: aborting due to previous error

View file

@ -1,10 +1,10 @@
error[E0382]: use of moved value: `some_vec`
--> $DIR/tab_3.rs:17:20
|
15 | some_vec.into_iter();
LL | some_vec.into_iter();
| -------- value moved here
16 | {
17 | println!("{:?}", some_vec); //~ ERROR use of moved
LL | {
LL | println!("{:?}", some_vec); //~ ERROR use of moved
| ^^^^^^^^ value used here after move
|
= note: move occurs because `some_vec` has type `std::vec::Vec<&str>`, which does not implement the `Copy` trait

View file

@ -1,7 +1,7 @@
error[E0404]: expected trait, found type alias `Bar`
--> $DIR/two_files.rs:15:6
|
15 | impl Bar for Baz { } //~ ERROR expected trait, found type alias
LL | impl Bar for Baz { } //~ ERROR expected trait, found type alias
| ^^^ type aliases cannot be used for traits
error: cannot continue compilation due to previous error

View file

@ -1,7 +1,7 @@
error: invalid ABI: expected one of [cdecl, stdcall, fastcall, vectorcall, thiscall, aapcs, win64, sysv64, ptx-kernel, msp430-interrupt, x86-interrupt, Rust, C, system, rust-intrinsic, rust-call, platform-intrinsic, unadjusted], found `路濫狼á́́`
--> $DIR/unicode.rs:11:8
|
11 | extern "路濫狼á́́" fn foo() {} //~ ERROR invalid ABI
LL | extern "路濫狼á́́" fn foo() {} //~ ERROR invalid ABI
| ^^^^^^^^^
error: aborting due to previous error

View file

@ -1,7 +1,7 @@
error: invalid width `7` for integer literal
--> $DIR/unicode_2.rs:14:25
|
14 | let _ = ("a̐éö̲", 0u7); //~ ERROR invalid width
LL | let _ = ("a̐éö̲", 0u7); //~ ERROR invalid width
| ^^^
|
= help: valid widths are 8, 16, 32, 64 and 128
@ -9,7 +9,7 @@ error: invalid width `7` for integer literal
error: invalid width `42` for integer literal
--> $DIR/unicode_2.rs:15:20
|
15 | let _ = ("아あ", 1i42); //~ ERROR invalid width
LL | let _ = ("아あ", 1i42); //~ ERROR invalid width
| ^^^^
|
= help: valid widths are 8, 16, 32, 64 and 128
@ -17,7 +17,7 @@ error: invalid width `42` for integer literal
error[E0425]: cannot find value `a̐é` in this scope
--> $DIR/unicode_2.rs:16:13
|
16 | let _ = a̐é; //~ ERROR cannot find
LL | let _ = a̐é; //~ ERROR cannot find
| ^^ not found in this scope
error: aborting due to 3 previous errors

View file

@ -1,7 +1,7 @@
warning: denote infinite loops with `loop { ... }`
--> $DIR/unicode_3.rs:14:45
|
14 | let s = "ZͨA͑ͦ͒͋ͤ͑̚L̄͑͋Ĝͨͥ̿͒̽̈́Oͥ͛ͭ!̏"; while true { break; }
LL | let s = "ZͨA͑ͦ͒͋ͤ͑̚L̄͑͋Ĝͨͥ̿͒̽̈́Oͥ͛ͭ!̏"; while true { break; }
| ^^^^^^^^^^ help: use `loop`
|
= note: #[warn(while_true)] on by default

View file

@ -1,11 +1,11 @@
error[E0308]: mismatched types
--> $DIR/coercion-missing-tail-expected-type.rs:13:28
|
13 | fn plus_one(x: i32) -> i32 { //~ ERROR mismatched types
LL | fn plus_one(x: i32) -> i32 { //~ ERROR mismatched types
| ____________________________^
14 | | x + 1;
LL | | x + 1;
| | - help: consider removing this semicolon
15 | | }
LL | | }
| |_^ expected i32, found ()
|
= note: expected type `i32`
@ -14,11 +14,11 @@ error[E0308]: mismatched types
error[E0308]: mismatched types
--> $DIR/coercion-missing-tail-expected-type.rs:17:29
|
17 | fn foo() -> Result<u8, u64> { //~ ERROR mismatched types
LL | fn foo() -> Result<u8, u64> { //~ ERROR mismatched types
| _____________________________^
18 | | Ok(1);
LL | | Ok(1);
| | - help: consider removing this semicolon
19 | | }
LL | | }
| |_^ expected enum `std::result::Result`, found ()
|
= note: expected type `std::result::Result<u8, u64>`

View file

@ -1,7 +1,7 @@
error[E0412]: cannot find type `DoesNotExist` in this scope
--> $DIR/coherence-error-suppression.rs:19:14
|
19 | impl Foo for DoesNotExist {} //~ ERROR cannot find type `DoesNotExist` in this scope
LL | impl Foo for DoesNotExist {} //~ ERROR cannot find type `DoesNotExist` in this scope
| ^^^^^^^^^^^^ not found in this scope
error: aborting due to previous error

View file

@ -1,37 +1,37 @@
error[E0206]: the trait `Copy` may not be implemented for this type
--> $DIR/coherence-impls-copy.rs:29:15
|
29 | impl Copy for &'static mut MyType {}
LL | impl Copy for &'static mut MyType {}
| ^^^^^^^^^^^^^^^^^^^ type is not a structure or enumeration
error[E0206]: the trait `Copy` may not be implemented for this type
--> $DIR/coherence-impls-copy.rs:33:15
|
33 | impl Copy for (MyType, MyType) {}
LL | impl Copy for (MyType, MyType) {}
| ^^^^^^^^^^^^^^^^ type is not a structure or enumeration
error[E0206]: the trait `Copy` may not be implemented for this type
--> $DIR/coherence-impls-copy.rs:37:15
|
37 | impl Copy for &'static NotSync {}
LL | impl Copy for &'static NotSync {}
| ^^^^^^^^^^^^^^^^ type is not a structure or enumeration
error[E0206]: the trait `Copy` may not be implemented for this type
--> $DIR/coherence-impls-copy.rs:40:15
|
40 | impl Copy for [MyType] {}
LL | impl Copy for [MyType] {}
| ^^^^^^^^ type is not a structure or enumeration
error[E0206]: the trait `Copy` may not be implemented for this type
--> $DIR/coherence-impls-copy.rs:44:15
|
44 | impl Copy for &'static [NotSync] {}
LL | impl Copy for &'static [NotSync] {}
| ^^^^^^^^^^^^^^^^^^ type is not a structure or enumeration
error[E0117]: only traits defined in the current crate can be implemented for arbitrary types
--> $DIR/coherence-impls-copy.rs:33:1
|
33 | impl Copy for (MyType, MyType) {}
LL | impl Copy for (MyType, MyType) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ impl doesn't use types inside crate
|
= note: the impl does not reference any types defined in this crate
@ -40,7 +40,7 @@ error[E0117]: only traits defined in the current crate can be implemented for ar
error[E0117]: only traits defined in the current crate can be implemented for arbitrary types
--> $DIR/coherence-impls-copy.rs:40:1
|
40 | impl Copy for [MyType] {}
LL | impl Copy for [MyType] {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^ impl doesn't use types inside crate
|
= note: the impl does not reference any types defined in this crate
@ -49,7 +49,7 @@ error[E0117]: only traits defined in the current crate can be implemented for ar
error[E0117]: only traits defined in the current crate can be implemented for arbitrary types
--> $DIR/coherence-impls-copy.rs:44:1
|
44 | impl Copy for &'static [NotSync] {}
LL | impl Copy for &'static [NotSync] {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ impl doesn't use types inside crate
|
= note: the impl does not reference any types defined in this crate

View file

@ -1,19 +1,19 @@
error[E0592]: duplicate definitions with name `dummy`
--> $DIR/coherence-overlap-downstream-inherent.rs:17:26
|
17 | impl<T:Sugar> Sweet<T> { fn dummy(&self) { } }
LL | impl<T:Sugar> Sweet<T> { fn dummy(&self) { } }
| ^^^^^^^^^^^^^^^^^^^ duplicate definitions for `dummy`
18 | //~^ ERROR E0592
19 | impl<T:Fruit> Sweet<T> { fn dummy(&self) { } }
LL | //~^ ERROR E0592
LL | impl<T:Fruit> Sweet<T> { fn dummy(&self) { } }
| ------------------- other definition for `dummy`
error[E0592]: duplicate definitions with name `f`
--> $DIR/coherence-overlap-downstream-inherent.rs:23:38
|
23 | impl<X, T> A<T, X> where T: Bar<X> { fn f(&self) {} }
LL | impl<X, T> A<T, X> where T: Bar<X> { fn f(&self) {} }
| ^^^^^^^^^^^^^^ duplicate definitions for `f`
24 | //~^ ERROR E0592
25 | impl<X> A<i32, X> { fn f(&self) {} }
LL | //~^ ERROR E0592
LL | impl<X> A<i32, X> { fn f(&self) {} }
| -------------- other definition for `f`
|
= note: downstream crates may implement trait `Bar<_>` for type `i32`

View file

@ -1,17 +1,17 @@
error[E0119]: conflicting implementations of trait `Sweet`:
--> $DIR/coherence-overlap-downstream.rs:18:1
|
17 | impl<T:Sugar> Sweet for T { }
LL | impl<T:Sugar> Sweet for T { }
| ------------------------- first implementation here
18 | impl<T:Fruit> Sweet for T { }
LL | impl<T:Fruit> Sweet for T { }
| ^^^^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation
error[E0119]: conflicting implementations of trait `Foo<_>` for type `i32`:
--> $DIR/coherence-overlap-downstream.rs:24:1
|
23 | impl<X, T> Foo<X> for T where T: Bar<X> {}
LL | impl<X, T> Foo<X> for T where T: Bar<X> {}
| --------------------------------------- first implementation here
24 | impl<X> Foo<X> for i32 {}
LL | impl<X> Foo<X> for i32 {}
| ^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation for `i32`
|
= note: downstream crates may implement trait `Bar<_>` for type `i32`

View file

@ -1,10 +1,10 @@
error[E0592]: duplicate definitions with name `dummy`
--> $DIR/coherence-overlap-issue-23516-inherent.rs:19:25
|
19 | impl<T:Sugar> Cake<T> { fn dummy(&self) { } }
LL | impl<T:Sugar> Cake<T> { fn dummy(&self) { } }
| ^^^^^^^^^^^^^^^^^^^ duplicate definitions for `dummy`
20 | //~^ ERROR E0592
21 | impl<U:Sugar> Cake<Box<U>> { fn dummy(&self) { } }
LL | //~^ ERROR E0592
LL | impl<U:Sugar> Cake<Box<U>> { fn dummy(&self) { } }
| ------------------- other definition for `dummy`
|
= note: downstream crates may implement trait `Sugar` for type `std::boxed::Box<_>`

View file

@ -1,9 +1,9 @@
error[E0119]: conflicting implementations of trait `Sweet` for type `std::boxed::Box<_>`:
--> $DIR/coherence-overlap-issue-23516.rs:18:1
|
17 | impl<T:Sugar> Sweet for T { }
LL | impl<T:Sugar> Sweet for T { }
| ------------------------- first implementation here
18 | impl<U:Sugar> Sweet for Box<U> { }
LL | impl<U:Sugar> Sweet for Box<U> { }
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation for `std::boxed::Box<_>`
|
= note: downstream crates may implement trait `Sugar` for type `std::boxed::Box<_>`

View file

@ -1,10 +1,10 @@
error[E0592]: duplicate definitions with name `dummy`
--> $DIR/coherence-overlap-upstream-inherent.rs:21:32
|
21 | impl<T> A<T> where T: Remote { fn dummy(&self) { } }
LL | impl<T> A<T> where T: Remote { fn dummy(&self) { } }
| ^^^^^^^^^^^^^^^^^^^ duplicate definitions for `dummy`
22 | //~^ ERROR E0592
23 | impl A<i16> { fn dummy(&self) { } }
LL | //~^ ERROR E0592
LL | impl A<i16> { fn dummy(&self) { } }
| ------------------- other definition for `dummy`
|
= note: upstream crates may add new impl of trait `coherence_lib::Remote` for type `i16` in future versions

Some files were not shown because too many files have changed in this diff Show more