2014-07-01 18:39:41 +02:00
|
|
|
// Copyright 2014 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.
|
|
|
|
|
2014-07-19 00:45:17 +12:00
|
|
|
#![allow(non_snake_case)]
|
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
// Error messages for EXXXX errors.
|
|
|
|
// Each message should start and end with a new line, and be wrapped to 80 characters.
|
|
|
|
// In vim you can `:set tw=80` and use `gq` to wrap paragraphs. Use `:set tw=0` to disable.
|
2015-01-17 17:20:24 -08:00
|
|
|
register_long_diagnostics! {
|
2014-07-01 18:39:41 +02:00
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
E0001: r##"
|
|
|
|
This error suggests that the expression arm corresponding to the noted pattern
|
|
|
|
will never be reached as for all possible values of the expression being
|
|
|
|
matched, one of the preceding patterns will match.
|
|
|
|
|
|
|
|
This means that perhaps some of the preceding patterns are too general, this one
|
|
|
|
is too specific or the ordering is incorrect.
|
2015-01-17 17:20:24 -08:00
|
|
|
"##,
|
|
|
|
|
2015-04-06 23:49:40 -07:00
|
|
|
E0002: r##"
|
|
|
|
This error indicates that an empty match expression is illegal because the type
|
|
|
|
it is matching on is non-empty (there exist values of this type). In safe code
|
|
|
|
it is impossible to create an instance of an empty type, so empty match
|
|
|
|
expressions are almost never desired. This error is typically fixed by adding
|
|
|
|
one or more cases to the match expression.
|
|
|
|
|
|
|
|
An example of an empty type is `enum Empty { }`.
|
|
|
|
"##,
|
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
E0003: r##"
|
2015-04-06 23:49:40 -07:00
|
|
|
Not-a-Number (NaN) values cannot be compared for equality and hence can never
|
2015-04-04 12:37:25 -07:00
|
|
|
match the input to a match expression. To match against NaN values, you should
|
|
|
|
instead use the `is_nan` method in a guard, as in: x if x.is_nan() => ...
|
2015-01-17 17:20:24 -08:00
|
|
|
"##,
|
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
E0004: r##"
|
2015-04-06 23:49:40 -07:00
|
|
|
This error indicates that the compiler cannot guarantee a matching pattern for
|
2015-04-04 12:37:25 -07:00
|
|
|
one or more possible inputs to a match expression. Guaranteed matches are
|
|
|
|
required in order to assign values to match expressions, or alternatively,
|
|
|
|
determine the flow of execution.
|
2015-01-17 17:20:24 -08:00
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
If you encounter this error you must alter your patterns so that every possible
|
|
|
|
value of the input type is matched. For types with a small number of variants
|
|
|
|
(like enums) you should probably cover all cases explicitly. Alternatively, the
|
|
|
|
underscore `_` wildcard pattern can be added after all other patterns to match
|
|
|
|
"anything else".
|
2015-01-17 17:20:24 -08:00
|
|
|
"##,
|
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
// FIXME: Remove duplication here?
|
|
|
|
E0005: r##"
|
|
|
|
Patterns used to bind names must be irrefutable, that is, they must guarantee that a
|
|
|
|
name will be extracted in all cases. If you encounter this error you probably need
|
|
|
|
to use a `match` or `if let` to deal with the possibility of failure.
|
2015-01-17 17:20:24 -08:00
|
|
|
"##,
|
|
|
|
|
2015-04-04 12:37:25 -07:00
|
|
|
E0006: r##"
|
|
|
|
Patterns used to bind names must be irrefutable, that is, they must guarantee that a
|
|
|
|
name will be extracted in all cases. If you encounter this error you probably need
|
|
|
|
to use a `match` or `if let` to deal with the possibility of failure.
|
2015-04-06 23:49:40 -07:00
|
|
|
"##,
|
|
|
|
|
|
|
|
E0007: r##"
|
|
|
|
This error indicates that the bindings in a match arm would require a value to
|
|
|
|
be moved into more than one location, thus violating unique ownership. Code like
|
|
|
|
the following is invalid as it requires the entire Option<String> to be moved
|
|
|
|
into a variable called `op_string` while simultaneously requiring the inner
|
|
|
|
String to be moved into a variable called `s`.
|
|
|
|
|
|
|
|
let x = Some("s".to_string());
|
|
|
|
match x {
|
|
|
|
op_string @ Some(s) => ...
|
|
|
|
None => ...
|
|
|
|
}
|
|
|
|
|
|
|
|
See also Error 303.
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0008: r##"
|
|
|
|
Names bound in match arms retain their type in pattern guards. As such, if a
|
|
|
|
name is bound by move in a pattern, it should also be moved to wherever it is
|
|
|
|
referenced in the pattern guard code. Doing so however would prevent the name
|
|
|
|
from being available in the body of the match arm. Consider the following:
|
|
|
|
|
|
|
|
match Some("hi".to_string()) {
|
|
|
|
Some(s) if s.len() == 0 => // use s.
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
The variable `s` has type String, and its use in the guard is as a variable of
|
|
|
|
type String. The guard code effectively executes in a separate scope to the body
|
|
|
|
of the arm, so the value would be moved into this anonymous scope and therefore
|
|
|
|
become unavailable in the body of the arm. Although this example seems
|
|
|
|
innocuous, the problem is most clear when considering functions that take their
|
|
|
|
argument by value.
|
|
|
|
|
|
|
|
match Some("hi".to_string()) {
|
|
|
|
Some(s) if { drop(s); false } => (),
|
|
|
|
Some(s) => // use s.
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
The value would be dropped in the guard then become unavailable not only in the
|
|
|
|
body of that arm but also in all subsequent arms! The solution is to bind by
|
|
|
|
reference when using guards or refactor the entire expression, perhaps by
|
|
|
|
putting the condition inside the body of the arm.
|
|
|
|
"##,
|
|
|
|
|
2015-04-15 11:31:20 +12:00
|
|
|
E0152: r##"
|
|
|
|
Lang items are already implemented in the standard library. Unless you are
|
|
|
|
writing a free-standing application (e.g. a kernel), you do not need to provide
|
|
|
|
them yourself.
|
|
|
|
|
|
|
|
You can build a free-standing crate by adding `#![no_std]` to the crate
|
|
|
|
attributes:
|
|
|
|
|
|
|
|
#![feature(no_std)]
|
|
|
|
#![no_std]
|
|
|
|
|
|
|
|
See also https://doc.rust-lang.org/book/no-stdlib.html
|
|
|
|
"##,
|
|
|
|
|
2015-04-15 11:54:21 +12:00
|
|
|
E0158: r##"
|
|
|
|
`const` and `static` mean different things. A `const` is a compile-time
|
|
|
|
constant, an alias for a literal value. This property means you can match it
|
|
|
|
directly within a pattern.
|
|
|
|
|
|
|
|
The `static` keyword, on the other hand, guarantees a fixed location in memory.
|
|
|
|
This does not always mean that the value is constant. For example, a global
|
|
|
|
mutex can be declared `static` as well.
|
|
|
|
|
|
|
|
If you want to match against a `static`, consider using a guard instead:
|
|
|
|
|
|
|
|
static FORTY_TWO: i32 = 42;
|
|
|
|
match Some(42) {
|
|
|
|
Some(x) if x == FORTY_TWO => ...
|
|
|
|
...
|
|
|
|
}
|
|
|
|
"##,
|
|
|
|
|
2015-04-15 20:25:58 +12:00
|
|
|
E0161: r##"
|
|
|
|
In Rust, you can only move a value when its size is known at compile time.
|
|
|
|
|
|
|
|
To work around this restriction, consider "hiding" the value behind a reference:
|
|
|
|
either `&x` or `&mut x`. Since a reference has a fixed size, this lets you move
|
|
|
|
it around as usual.
|
|
|
|
"##,
|
|
|
|
|
2015-04-14 20:00:17 +02:00
|
|
|
E0162: r##"
|
|
|
|
An if-let pattern attempts to match the pattern, and enters the body if the
|
|
|
|
match was succesful. If the match is irrefutable (when it cannot fail to match),
|
|
|
|
use a regular `let`-binding instead. For instance:
|
|
|
|
|
|
|
|
struct Irrefutable(i32);
|
|
|
|
let irr = Irrefutable(0);
|
|
|
|
|
|
|
|
// This fails to compile because the match is irrefutable.
|
|
|
|
if let Irrefutable(x) = irr {
|
|
|
|
// This body will always be executed.
|
|
|
|
foo(x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Try this instead:
|
|
|
|
let Irrefutable(x) = irr;
|
|
|
|
foo(x);
|
|
|
|
"##,
|
|
|
|
|
2015-04-14 20:11:04 +02:00
|
|
|
E0165: r##"
|
|
|
|
A while-let pattern attempts to match the pattern, and enters the body if the
|
|
|
|
match was succesful. If the match is irrefutable (when it cannot fail to match),
|
|
|
|
use a regular `let`-binding inside a `loop` instead. For instance:
|
|
|
|
|
|
|
|
struct Irrefutable(i32);
|
|
|
|
let irr = Irrefutable(0);
|
|
|
|
|
|
|
|
// This fails to compile because the match is irrefutable.
|
|
|
|
while let Irrefutable(x) = irr {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
// Try this instead:
|
|
|
|
loop {
|
|
|
|
let Irrefutable(x) = irr;
|
|
|
|
...
|
|
|
|
}
|
|
|
|
"##,
|
|
|
|
|
2015-04-15 20:51:30 +12:00
|
|
|
E0170: r##"
|
|
|
|
Enum variants are qualified by default. For example, given this type:
|
|
|
|
|
|
|
|
enum Method {
|
|
|
|
GET,
|
|
|
|
POST
|
|
|
|
}
|
|
|
|
|
|
|
|
you would match it using:
|
|
|
|
|
|
|
|
match m {
|
|
|
|
Method::GET => ...
|
|
|
|
Method::POST => ...
|
|
|
|
}
|
|
|
|
|
|
|
|
If you don't qualify the names, the code will bind new variables named "GET" and
|
|
|
|
"POST" instead. This behavior is likely not what you want, so rustc warns when
|
|
|
|
that happens.
|
|
|
|
|
|
|
|
Qualified names are good practice, and most code works well with them. But if
|
|
|
|
you prefer them unqualified, you can import the variants into scope:
|
|
|
|
|
|
|
|
use Method::*;
|
|
|
|
enum Method { GET, POST }
|
|
|
|
"##,
|
|
|
|
|
2015-04-14 18:27:41 +02:00
|
|
|
E0297: r##"
|
|
|
|
Patterns used to bind names must be irrefutable. That is, they must guarantee
|
|
|
|
that a name will be extracted in all cases. Instead of pattern matching the
|
|
|
|
loop variable, consider using a `match` or `if let` inside the loop body. For
|
|
|
|
instance:
|
|
|
|
|
|
|
|
// This fails because `None` is not covered.
|
|
|
|
for Some(x) in xs {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
// Match inside the loop instead:
|
|
|
|
for item in xs {
|
|
|
|
match item {
|
|
|
|
Some(x) => ...
|
|
|
|
None => ...
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Or use `if let`:
|
|
|
|
for item in xs {
|
|
|
|
if let Some(x) = item {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"##,
|
|
|
|
|
2015-04-14 19:31:42 +02:00
|
|
|
E0301: r##"
|
|
|
|
Mutable borrows are not allowed in pattern guards, because matching cannot have
|
|
|
|
side effects. Side effects could alter the matched object or the environment
|
|
|
|
on which the match depends in such a way, that the match would not be
|
|
|
|
exhaustive. For instance, the following would not match any arm if mutable
|
|
|
|
borrows were allowed:
|
|
|
|
|
|
|
|
match Some(()) {
|
|
|
|
None => { },
|
|
|
|
option if option.take().is_none() => { /* impossible, option is `Some` */ },
|
|
|
|
Some(_) => { } // When the previous match failed, the option became `None`.
|
|
|
|
}
|
|
|
|
"##,
|
|
|
|
|
2015-04-14 19:39:58 +02:00
|
|
|
E0302: r##"
|
|
|
|
Assignments are not allowed in pattern guards, because matching cannot have
|
|
|
|
side effects. Side effects could alter the matched object or the environment
|
|
|
|
on which the match depends in such a way, that the match would not be
|
|
|
|
exhaustive. For instance, the following would not match any arm if assignments
|
|
|
|
were allowed:
|
|
|
|
|
|
|
|
match Some(()) {
|
|
|
|
None => { },
|
|
|
|
option if { option = None; false } { },
|
|
|
|
Some(_) => { } // When the previous match failed, the option became `None`.
|
|
|
|
}
|
|
|
|
"##,
|
|
|
|
|
2015-04-06 23:49:40 -07:00
|
|
|
E0303: r##"
|
|
|
|
In certain cases it is possible for sub-bindings to violate memory safety.
|
|
|
|
Updates to the borrow checker in a future version of Rust may remove this
|
|
|
|
restriction, but for now patterns must be rewritten without sub-bindings.
|
|
|
|
|
|
|
|
// Code like this...
|
|
|
|
match Some(5) {
|
|
|
|
ref op_num @ Some(num) => ...
|
|
|
|
None => ...
|
|
|
|
}
|
|
|
|
|
|
|
|
// ... should be updated to code like this.
|
|
|
|
match Some(5) {
|
|
|
|
Some(num) => {
|
|
|
|
let op_num = &Some(num);
|
|
|
|
...
|
|
|
|
}
|
|
|
|
None => ...
|
|
|
|
}
|
|
|
|
|
|
|
|
See also https://github.com/rust-lang/rust/issues/14587
|
2015-04-15 21:15:09 +12:00
|
|
|
"##,
|
|
|
|
|
|
|
|
E0306: r##"
|
|
|
|
In an array literal `[x; N]`, `N` is the number of elements in the array. This
|
|
|
|
number cannot be negative.
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0307: r##"
|
|
|
|
The length of an array is part of its type. For this reason, this length must be
|
|
|
|
a compile-time constant.
|
2015-04-18 08:25:43 -04:00
|
|
|
"##,
|
|
|
|
|
|
|
|
E0308: r##"
|
|
|
|
This error occurs when the compiler was unable to infer the concrete type of a
|
|
|
|
variable. This error can occur for several cases, the most common of which is
|
|
|
|
that there is a mismatch in the expected type that the compiler inferred, and
|
|
|
|
the actual type that the user defined a variable as.
|
|
|
|
|
2015-04-18 20:25:24 -04:00
|
|
|
let a: char = 7; // An integral type can't be contained in a character, so
|
2015-04-18 08:25:43 -04:00
|
|
|
// there is a mismatch.
|
|
|
|
|
|
|
|
let b: u32 = 7; // Either use the right type...
|
|
|
|
let c = 7; // ...or let the compiler infer it.
|
|
|
|
|
|
|
|
let d: char = c; // This also causes a mismatch because c is some sort
|
|
|
|
// of number whereas d is definitely a character.
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0309: r##"
|
|
|
|
Types in type definitions have lifetimes associated with them that represent
|
|
|
|
how long the data stored within them is guaranteed to be live. This lifetime
|
|
|
|
must be as long as the data needs to be alive, and missing the constraint that
|
|
|
|
denotes this will cause this error.
|
|
|
|
|
|
|
|
// This won't compile because T is not constrained, meaning the data
|
|
|
|
// stored in it is not guaranteed to last as long as the reference
|
|
|
|
struct Foo<'a, T> {
|
|
|
|
foo: &'a T
|
|
|
|
}
|
|
|
|
|
|
|
|
// This will compile, because it has the constraint on the type parameter
|
|
|
|
struct Foo<'a, T: 'a> {
|
|
|
|
foo: &'a T
|
|
|
|
}
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0310: r##"
|
|
|
|
Types in type definitions have lifetimes associated with them that represent
|
|
|
|
how long the data stored within them is guaranteed to be live. This lifetime
|
|
|
|
must be as long as the data needs to be alive, and missing the constraint that
|
|
|
|
denotes this will cause this error.
|
|
|
|
|
|
|
|
// This won't compile because T is not constrained to the static lifetime
|
|
|
|
// the reference needs
|
|
|
|
struct Foo<T> {
|
|
|
|
foo: &'static T
|
|
|
|
}
|
|
|
|
|
|
|
|
// This will compile, because it has the constraint on the type parameter
|
|
|
|
struct Foo<T: 'static> {
|
|
|
|
foo: &'static T
|
|
|
|
}
|
2015-01-17 17:20:24 -08:00
|
|
|
"##
|
2015-04-04 12:37:25 -07:00
|
|
|
|
2015-01-17 17:20:24 -08:00
|
|
|
}
|
2014-07-11 18:54:01 +02:00
|
|
|
|
2015-04-18 08:25:43 -04:00
|
|
|
|
2014-11-14 09:18:10 -08:00
|
|
|
register_diagnostics! {
|
2014-07-11 18:54:01 +02:00
|
|
|
E0009,
|
|
|
|
E0010,
|
|
|
|
E0011,
|
|
|
|
E0012,
|
2015-01-29 13:57:06 +02:00
|
|
|
E0013,
|
2014-07-11 18:54:01 +02:00
|
|
|
E0014,
|
|
|
|
E0015,
|
|
|
|
E0016,
|
|
|
|
E0017,
|
2014-10-25 20:18:32 +03:00
|
|
|
E0018,
|
2014-07-11 18:54:01 +02:00
|
|
|
E0019,
|
|
|
|
E0020,
|
|
|
|
E0022,
|
2015-03-27 01:43:14 +01:00
|
|
|
E0079, // enum variant: expected signed integer constant
|
|
|
|
E0080, // enum variant: constant evaluation error
|
2014-07-17 19:56:37 +02:00
|
|
|
E0109,
|
|
|
|
E0110,
|
|
|
|
E0133,
|
|
|
|
E0134,
|
|
|
|
E0135,
|
|
|
|
E0136,
|
|
|
|
E0137,
|
|
|
|
E0138,
|
|
|
|
E0139,
|
2015-01-18 16:58:25 -08:00
|
|
|
E0261, // use of undeclared lifetime name
|
|
|
|
E0262, // illegal lifetime parameter name
|
|
|
|
E0263, // lifetime name declared twice in same scope
|
|
|
|
E0264, // unknown external lang item
|
|
|
|
E0265, // recursive constant
|
|
|
|
E0266, // expected item
|
|
|
|
E0267, // thing inside of a closure
|
|
|
|
E0268, // thing outside of a loop
|
|
|
|
E0269, // not all control paths return a value
|
|
|
|
E0270, // computation may converge in a function marked as diverging
|
|
|
|
E0271, // type mismatch resolving
|
|
|
|
E0272, // rustc_on_unimplemented attribute refers to non-existent type parameter
|
|
|
|
E0273, // rustc_on_unimplemented must have named format arguments
|
|
|
|
E0274, // rustc_on_unimplemented must have a value
|
|
|
|
E0275, // overflow evaluating requirement
|
|
|
|
E0276, // requirement appears on impl method but not on corresponding trait method
|
|
|
|
E0277, // trait is not implemented for type
|
|
|
|
E0278, // requirement is not satisfied
|
|
|
|
E0279, // requirement is not satisfied
|
|
|
|
E0280, // requirement is not satisfied
|
|
|
|
E0281, // type implements trait but other trait is required
|
|
|
|
E0282, // unable to infer enough type information about
|
|
|
|
E0283, // cannot resolve type
|
|
|
|
E0284, // cannot resolve type
|
|
|
|
E0285, // overflow evaluation builtin bounds
|
|
|
|
E0296, // malformed recursion limit attribute
|
|
|
|
E0298, // mismatched types between arms
|
|
|
|
E0299, // mismatched types between arms
|
|
|
|
E0300, // unexpanded macro
|
|
|
|
E0304, // expected signed integer constant
|
|
|
|
E0305, // expected constant
|
|
|
|
E0311, // thing may not live long enough
|
|
|
|
E0312, // lifetime of reference outlives lifetime of borrowed content
|
|
|
|
E0313, // lifetime of borrowed pointer outlives lifetime of captured variable
|
|
|
|
E0314, // closure outlives stack frame
|
2015-02-05 21:46:01 +13:00
|
|
|
E0315, // cannot invoke closure outside of its lifetime
|
2015-03-27 01:43:14 +01:00
|
|
|
E0316, // nested quantification of lifetimes
|
|
|
|
E0370 // discriminant overflow
|
2014-11-14 09:18:10 -08:00
|
|
|
}
|
2015-01-16 15:54:58 -08:00
|
|
|
|
|
|
|
__build_diagnostic_array! { DIAGNOSTICS }
|