Reduce error codes length when too much are thrown
This commit is contained in:
parent
5747fd6611
commit
16fb6b082d
7 changed files with 136 additions and 7 deletions
|
@ -122,9 +122,12 @@ impl Drop for EmitterWriter {
|
|||
let mut error_codes = self.error_codes.clone().into_iter().collect::<Vec<_>>();
|
||||
error_codes.sort();
|
||||
if error_codes.len() > 1 {
|
||||
let limit = if error_codes.len() > 9 { 9 } else { error_codes.len() };
|
||||
writeln!(self.dst,
|
||||
"You've got a few errors: {}",
|
||||
error_codes.join(", ")).expect("failed to give tips...");
|
||||
"You've got a few errors: {}{}",
|
||||
error_codes[..limit].join(", "),
|
||||
if error_codes.len() > 9 { "..." } else { "" }
|
||||
).expect("failed to give tips...");
|
||||
writeln!(self.dst,
|
||||
"If you want more information on an error, try using \
|
||||
\"rustc --explain {}\"",
|
||||
|
|
|
@ -1,5 +1,3 @@
|
|||
thread 'rustc' panicked at 'lolnope', $DIR/auxiliary/plugin.rs:27:5
|
||||
note: Run with `RUST_BACKTRACE=1` for a backtrace.
|
||||
error: proc-macro derive panicked
|
||||
--> $DIR/issue-36935.rs:18:15
|
||||
|
|
||||
|
|
|
@ -1,5 +1,3 @@
|
|||
thread 'rustc' panicked at 'nope!', $DIR/auxiliary/derive-panic.rs:22:5
|
||||
note: Run with `RUST_BACKTRACE=1` for a backtrace.
|
||||
error: proc-macro derive panicked
|
||||
--> $DIR/load-panic.rs:17:10
|
||||
|
|
||||
|
|
53
src/test/ui/error-festival.rs
Normal file
53
src/test/ui/error-festival.rs
Normal file
|
@ -0,0 +1,53 @@
|
|||
// Copyright 2018 The Rust Project Developers. See the COPYRIGHT
|
||||
// file at the top-level directory of this distribution and at
|
||||
// http://rust-lang.org/COPYRIGHT.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
enum Question {
|
||||
Yes,
|
||||
No,
|
||||
}
|
||||
|
||||
mod foo {
|
||||
const FOO: u32 = 0;
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let x = "a";
|
||||
x += 2;
|
||||
//~^ ERROR E0368
|
||||
y = 2;
|
||||
//~^ ERROR E0425
|
||||
x.z();
|
||||
//~^ ERROR E0599
|
||||
|
||||
!Question::Yes;
|
||||
//~^ ERROR E0600
|
||||
|
||||
foo::FOO;
|
||||
//~^ ERROR E0603
|
||||
|
||||
0u32 as char;
|
||||
//~^ ERROR E0604
|
||||
|
||||
let x = 0u8;
|
||||
x as Vec<u8>;
|
||||
//~^ ERROR E0605
|
||||
|
||||
let x = 5;
|
||||
let x_is_nonzero = x as bool;
|
||||
//~^ ERROR E0054
|
||||
|
||||
let x = &0u8;
|
||||
let y: u32 = x as u32;
|
||||
//~^ ERROR E0606
|
||||
|
||||
let v = 0 as *const u8;
|
||||
v as *const [u8];
|
||||
//~^ ERROR E0607
|
||||
}
|
76
src/test/ui/error-festival.stderr
Normal file
76
src/test/ui/error-festival.stderr
Normal file
|
@ -0,0 +1,76 @@
|
|||
error[E0425]: cannot find value `y` in this scope
|
||||
--> $DIR/error-festival.rs:24:5
|
||||
|
|
||||
24 | y = 2;
|
||||
| ^ did you mean `x`?
|
||||
|
||||
error[E0603]: constant `FOO` is private
|
||||
--> $DIR/error-festival.rs:32:5
|
||||
|
|
||||
32 | foo::FOO;
|
||||
| ^^^^^^^^
|
||||
|
||||
error[E0368]: binary assignment operation `+=` cannot be applied to type `&str`
|
||||
--> $DIR/error-festival.rs:22:5
|
||||
|
|
||||
22 | x += 2;
|
||||
| -^^^^^
|
||||
| |
|
||||
| cannot use `+=` on type `&str`
|
||||
|
||||
error[E0599]: no method named `z` found for type `&str` in the current scope
|
||||
--> $DIR/error-festival.rs:26:7
|
||||
|
|
||||
26 | x.z();
|
||||
| ^
|
||||
|
||||
error[E0600]: cannot apply unary operator `!` to type `Question`
|
||||
--> $DIR/error-festival.rs:29:5
|
||||
|
|
||||
29 | !Question::Yes;
|
||||
| ^^^^^^^^^^^^^^
|
||||
|
||||
error[E0604]: only `u8` can be cast as `char`, not `u32`
|
||||
--> $DIR/error-festival.rs:35:5
|
||||
|
|
||||
35 | 0u32 as char;
|
||||
| ^^^^^^^^^^^^
|
||||
|
||||
error[E0605]: non-primitive cast: `u8` as `std::vec::Vec<u8>`
|
||||
--> $DIR/error-festival.rs:39:5
|
||||
|
|
||||
39 | x as Vec<u8>;
|
||||
| ^^^^^^^^^^^^
|
||||
|
|
||||
= note: an `as` expression can only be used to convert between primitive types. Consider using the `From` trait
|
||||
|
||||
error[E0054]: cannot cast as `bool`
|
||||
--> $DIR/error-festival.rs:43:24
|
||||
|
|
||||
43 | let x_is_nonzero = x as bool;
|
||||
| ^^^^^^^^^ unsupported cast
|
||||
|
|
||||
= help: compare with zero instead
|
||||
|
||||
error[E0606]: casting `&u8` as `u32` is invalid
|
||||
--> $DIR/error-festival.rs:47:18
|
||||
|
|
||||
47 | let y: u32 = x as u32;
|
||||
| ^^^^^^^^ cannot cast `&u8` as `u32`
|
||||
|
|
||||
help: did you mean `*x`?
|
||||
--> $DIR/error-festival.rs:47:18
|
||||
|
|
||||
47 | let y: u32 = x as u32;
|
||||
| ^
|
||||
|
||||
error[E0607]: cannot cast thin pointer `*const u8` to fat pointer `*const [u8]`
|
||||
--> $DIR/error-festival.rs:51:5
|
||||
|
|
||||
51 | v as *const [u8];
|
||||
| ^^^^^^^^^^^^^^^^
|
||||
|
||||
error: aborting due to 10 previous errors
|
||||
|
||||
You've got a few errors: E0054, E0368, E0425, E0599, E0600, E0603, E0604, E0605, E0606...
|
||||
If you want more information on an error, try using "rustc --explain E0054"
|
|
@ -12,3 +12,4 @@ help: change the closure to accept a tuple instead of individual arguments
|
|||
|
||||
error: aborting due to previous error
|
||||
|
||||
If you want more information on this error, try using "rustc --explain E0593"
|
||||
|
|
|
@ -15,4 +15,4 @@ error[E0282]: type annotations needed
|
|||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
If you want more information on this error, try using "rustc --explain E0619"
|
||||
If you want more information on this error, try using "rustc --explain E0282"
|
||||
|
|
Loading…
Add table
Reference in a new issue