2015-01-16 15:54:58 -08: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.
|
|
|
|
|
|
|
|
#![allow(non_snake_case)]
|
|
|
|
|
2015-10-26 20:31:11 +01: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-05-10 10:43:30 +01:00
|
|
|
register_long_diagnostics! {
|
|
|
|
|
2015-05-10 11:40:43 +01:00
|
|
|
E0154: r##"
|
|
|
|
Imports (`use` statements) are not allowed after non-item statements, such as
|
|
|
|
variable declarations and expression statements.
|
|
|
|
|
2015-05-11 09:10:19 +01:00
|
|
|
Here is an example that demonstrates the error:
|
2015-05-13 12:00:59 +01:00
|
|
|
|
2016-05-22 19:00:20 +02:00
|
|
|
```ignore
|
2015-05-10 11:40:43 +01:00
|
|
|
fn f() {
|
|
|
|
// Variable declaration before import
|
|
|
|
let x = 0;
|
|
|
|
use std::io::Read;
|
2016-02-07 13:02:52 +01:00
|
|
|
// ...
|
2015-05-10 11:40:43 +01:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
The solution is to declare the imports at the top of the block, function, or
|
|
|
|
file.
|
|
|
|
|
|
|
|
Here is the previous example again, with the correct order:
|
2015-05-13 12:00:59 +01:00
|
|
|
|
2015-05-10 11:40:43 +01:00
|
|
|
```
|
|
|
|
fn f() {
|
|
|
|
use std::io::Read;
|
|
|
|
let x = 0;
|
2016-02-07 13:02:52 +01:00
|
|
|
// ...
|
2015-05-10 11:40:43 +01:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
See the Declaration Statements section of the reference for more information
|
|
|
|
about what constitutes an Item declaration and what does not:
|
|
|
|
|
2015-08-09 14:15:05 -07:00
|
|
|
https://doc.rust-lang.org/reference.html#statements
|
2015-05-10 11:40:43 +01:00
|
|
|
"##,
|
|
|
|
|
2015-05-13 22:32:52 -05:00
|
|
|
E0251: r##"
|
|
|
|
Two items of the same name cannot be imported without rebinding one of the
|
|
|
|
items under a new local name.
|
|
|
|
|
|
|
|
An example of this error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-05-13 22:32:52 -05:00
|
|
|
use foo::baz;
|
|
|
|
use bar::*; // error, do `use foo::baz as quux` instead on the previous line
|
|
|
|
|
|
|
|
fn main() {}
|
|
|
|
|
|
|
|
mod foo {
|
|
|
|
pub struct baz;
|
|
|
|
}
|
|
|
|
|
|
|
|
mod bar {
|
|
|
|
pub mod baz {}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0252: r##"
|
|
|
|
Two items of the same name cannot be imported without rebinding one of the
|
|
|
|
items under a new local name.
|
|
|
|
|
|
|
|
An example of this error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-05-13 22:32:52 -05:00
|
|
|
use foo::baz;
|
|
|
|
use bar::baz; // error, do `use bar::baz as quux` instead
|
|
|
|
|
|
|
|
fn main() {}
|
|
|
|
|
|
|
|
mod foo {
|
|
|
|
pub struct baz;
|
|
|
|
}
|
|
|
|
|
|
|
|
mod bar {
|
|
|
|
pub mod baz {}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-18 17:25:29 +01:00
|
|
|
E0253: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
Attempt was made to import an unimportable value. This can happen when trying
|
|
|
|
to import a method from a trait. An example of this error:
|
2015-07-18 17:25:29 +01:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-18 17:25:29 +01:00
|
|
|
mod foo {
|
|
|
|
pub trait MyTrait {
|
2015-07-18 20:46:47 +01:00
|
|
|
fn do_something();
|
2015-07-18 17:25:29 +01:00
|
|
|
}
|
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-07-18 20:46:47 +01:00
|
|
|
use foo::MyTrait::do_something;
|
2015-07-18 17:25:29 +01:00
|
|
|
```
|
|
|
|
|
2015-07-28 17:53:50 +03:00
|
|
|
It's invalid to directly import methods belonging to a trait or concrete type.
|
2015-07-18 17:25:29 +01:00
|
|
|
"##,
|
|
|
|
|
2015-05-13 22:32:52 -05:00
|
|
|
E0255: r##"
|
|
|
|
You can't import a value whose name is the same as another value defined in the
|
|
|
|
module.
|
|
|
|
|
|
|
|
An example of this error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-05-14 02:50:39 -05:00
|
|
|
use bar::foo; // error, do `use bar::foo as baz` instead
|
2015-05-13 22:32:52 -05:00
|
|
|
|
2015-05-14 02:50:39 -05:00
|
|
|
fn foo() {}
|
2015-05-13 22:32:52 -05:00
|
|
|
|
2015-05-14 02:50:39 -05:00
|
|
|
mod bar {
|
|
|
|
pub fn foo() {}
|
2015-05-13 22:32:52 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0256: r##"
|
|
|
|
You can't import a type or module when the name of the item being imported is
|
|
|
|
the same as another type or submodule defined in the module.
|
|
|
|
|
|
|
|
An example of this error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-05-13 22:32:52 -05:00
|
|
|
use foo::Bar; // error
|
|
|
|
|
2015-05-14 02:50:39 -05:00
|
|
|
type Bar = u32;
|
2015-05-13 22:32:52 -05:00
|
|
|
|
|
|
|
mod foo {
|
|
|
|
pub mod Bar { }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-05-10 12:09:41 +01:00
|
|
|
E0259: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
The name chosen for an external crate conflicts with another external crate
|
|
|
|
that has been imported into the current module.
|
2015-05-10 12:09:41 +01:00
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
Erroneous code example:
|
2015-05-13 12:00:59 +01:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-05-11 09:10:49 +01:00
|
|
|
extern crate a;
|
|
|
|
extern crate crate_a as a;
|
2015-05-10 12:09:41 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
The solution is to choose a different name that doesn't conflict with any
|
|
|
|
external crate imported into the current module.
|
|
|
|
|
|
|
|
Correct example:
|
2015-05-13 12:00:59 +01:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-05-11 09:10:49 +01:00
|
|
|
extern crate a;
|
|
|
|
extern crate crate_a as other_name;
|
2015-05-10 12:09:41 +01:00
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-05-10 12:26:19 +01:00
|
|
|
E0260: r##"
|
|
|
|
The name for an item declaration conflicts with an external crate's name.
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
For instance:
|
2015-05-13 12:00:59 +01:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-05-11 09:10:49 +01:00
|
|
|
extern crate abc;
|
2015-05-10 12:26:19 +01:00
|
|
|
|
|
|
|
struct abc;
|
|
|
|
```
|
|
|
|
|
|
|
|
There are two possible solutions:
|
|
|
|
|
|
|
|
Solution #1: Rename the item.
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-05-11 09:10:49 +01:00
|
|
|
extern crate abc;
|
2015-05-10 12:26:19 +01:00
|
|
|
|
|
|
|
struct xyz;
|
|
|
|
```
|
|
|
|
|
|
|
|
Solution #2: Import the crate with a different name.
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-05-11 09:10:49 +01:00
|
|
|
extern crate abc as xyz;
|
2015-05-10 12:26:19 +01:00
|
|
|
|
|
|
|
struct abc;
|
|
|
|
```
|
|
|
|
|
|
|
|
See the Declaration Statements section of the reference for more information
|
|
|
|
about what constitutes an Item declaration and what does not:
|
|
|
|
|
2015-08-09 14:15:05 -07:00
|
|
|
https://doc.rust-lang.org/reference.html#statements
|
2015-05-10 12:26:19 +01:00
|
|
|
"##,
|
|
|
|
|
2015-07-16 19:21:11 +01:00
|
|
|
E0364: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
Private items cannot be publicly re-exported. This error indicates that you
|
|
|
|
attempted to `pub use` a type or value that was not itself public.
|
2015-07-16 19:21:11 +01:00
|
|
|
|
|
|
|
Here is an example that demonstrates the error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-16 19:21:11 +01:00
|
|
|
mod foo {
|
|
|
|
const X: u32 = 1;
|
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-07-16 19:21:11 +01:00
|
|
|
pub use foo::X;
|
|
|
|
```
|
|
|
|
|
|
|
|
The solution to this problem is to ensure that the items that you are
|
|
|
|
re-exporting are themselves marked with `pub`:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-07-16 19:21:11 +01:00
|
|
|
mod foo {
|
|
|
|
pub const X: u32 = 1;
|
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-07-16 19:21:11 +01:00
|
|
|
pub use foo::X;
|
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
See the 'Use Declarations' section of the reference for more information on
|
|
|
|
this topic:
|
2015-07-16 19:21:11 +01:00
|
|
|
|
2015-08-09 14:15:05 -07:00
|
|
|
https://doc.rust-lang.org/reference.html#use-declarations
|
2015-07-16 19:21:11 +01:00
|
|
|
"##,
|
|
|
|
|
|
|
|
E0365: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
Private modules cannot be publicly re-exported. This error indicates that you
|
|
|
|
attempted to `pub use` a module that was not itself public.
|
2015-07-16 19:21:11 +01:00
|
|
|
|
|
|
|
Here is an example that demonstrates the error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-16 19:21:11 +01:00
|
|
|
mod foo {
|
|
|
|
pub const X: u32 = 1;
|
|
|
|
}
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
pub use foo as foo2;
|
2015-07-16 19:21:11 +01:00
|
|
|
```
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-07-16 19:21:11 +01:00
|
|
|
The solution to this problem is to ensure that the module that you are
|
|
|
|
re-exporting is itself marked with `pub`:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-07-16 19:21:11 +01:00
|
|
|
pub mod foo {
|
|
|
|
pub const X: u32 = 1;
|
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-07-16 19:21:11 +01:00
|
|
|
pub use foo as foo2;
|
|
|
|
```
|
|
|
|
|
|
|
|
See the 'Use Declarations' section of the reference for more information
|
|
|
|
on this topic:
|
|
|
|
|
2015-08-09 14:15:05 -07:00
|
|
|
https://doc.rust-lang.org/reference.html#use-declarations
|
2015-07-17 17:21:58 +02:00
|
|
|
"##,
|
2015-05-10 10:43:30 +01:00
|
|
|
|
2015-11-19 02:01:19 +05:30
|
|
|
E0401: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
Inner items do not inherit type parameters from the functions they are embedded
|
|
|
|
in. For example, this will not compile:
|
2015-11-19 02:01:19 +05:30
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-11-19 02:01:19 +05:30
|
|
|
fn foo<T>(x: T) {
|
|
|
|
fn bar(y: T) { // T is defined in the "outer" function
|
|
|
|
// ..
|
|
|
|
}
|
|
|
|
bar(x);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
Nor will this:
|
2015-12-07 14:58:26 +05:30
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-12-07 14:58:26 +05:30
|
|
|
fn foo<T>(x: T) {
|
|
|
|
type MaybeT = Option<T>;
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
Or this:
|
2015-12-07 14:58:26 +05:30
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-12-07 14:58:26 +05:30
|
|
|
fn foo<T>(x: T) {
|
|
|
|
struct Foo {
|
|
|
|
x: T,
|
|
|
|
}
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Items inside functions are basically just like top-level items, except
|
|
|
|
that they can only be used from the function they are in.
|
2015-11-19 02:01:19 +05:30
|
|
|
|
|
|
|
There are a couple of solutions for this.
|
|
|
|
|
2015-12-07 14:58:26 +05:30
|
|
|
If the item is a function, you may use a closure:
|
2015-11-19 02:01:19 +05:30
|
|
|
|
|
|
|
```
|
|
|
|
fn foo<T>(x: T) {
|
|
|
|
let bar = |y: T| { // explicit type annotation may not be necessary
|
|
|
|
// ..
|
2016-02-07 13:02:52 +01:00
|
|
|
};
|
2015-11-19 02:01:19 +05:30
|
|
|
bar(x);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-12-07 14:58:26 +05:30
|
|
|
For a generic item, you can copy over the parameters:
|
2015-11-19 02:01:19 +05:30
|
|
|
|
|
|
|
```
|
|
|
|
fn foo<T>(x: T) {
|
|
|
|
fn bar<T>(y: T) {
|
|
|
|
// ..
|
|
|
|
}
|
|
|
|
bar(x);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-12-07 14:58:26 +05:30
|
|
|
```
|
|
|
|
fn foo<T>(x: T) {
|
|
|
|
type MaybeT<T> = Option<T>;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-11-19 02:01:19 +05:30
|
|
|
Be sure to copy over any bounds as well:
|
|
|
|
|
|
|
|
```
|
|
|
|
fn foo<T: Copy>(x: T) {
|
|
|
|
fn bar<T: Copy>(y: T) {
|
|
|
|
// ..
|
|
|
|
}
|
|
|
|
bar(x);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-12-07 14:58:26 +05:30
|
|
|
```
|
|
|
|
fn foo<T: Copy>(x: T) {
|
|
|
|
struct Foo<T: Copy> {
|
|
|
|
x: T,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-11-19 02:01:19 +05:30
|
|
|
This may require additional type hints in the function body.
|
|
|
|
|
2015-12-07 14:58:26 +05:30
|
|
|
In case the item is a function inside an `impl`, defining a private helper
|
|
|
|
function might be easier:
|
2015-11-19 02:01:19 +05:30
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-11-19 02:01:19 +05:30
|
|
|
impl<T> Foo<T> {
|
|
|
|
pub fn foo(&self, x: T) {
|
|
|
|
self.bar(x);
|
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-11-19 02:01:19 +05:30
|
|
|
fn bar(&self, y: T) {
|
|
|
|
// ..
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
For default impls in traits, the private helper solution won't work, however
|
|
|
|
closures or copying the parameters should still work.
|
|
|
|
"##,
|
|
|
|
|
2015-07-17 14:00:03 +02:00
|
|
|
E0403: r##"
|
|
|
|
Some type parameters have the same name. Example of erroneous code:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-17 14:00:03 +02:00
|
|
|
fn foo<T, T>(s: T, u: T) {} // error: the name `T` is already used for a type
|
|
|
|
// parameter in this type parameter list
|
|
|
|
```
|
|
|
|
|
2015-07-17 17:21:58 +02:00
|
|
|
Please verify that none of the type parameterss are misspelled, and rename any
|
2015-07-17 14:14:41 +02:00
|
|
|
clashing parameters. Example:
|
2015-07-17 14:00:03 +02:00
|
|
|
|
|
|
|
```
|
2015-07-17 14:14:41 +02:00
|
|
|
fn foo<T, Y>(s: T, u: Y) {} // ok!
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-17 14:55:42 +02:00
|
|
|
E0404: r##"
|
2015-07-17 17:21:58 +02:00
|
|
|
You tried to implement something which was not a trait on an object. Example of
|
|
|
|
erroneous code:
|
2015-07-17 14:55:42 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-17 14:55:42 +02:00
|
|
|
struct Foo;
|
|
|
|
struct Bar;
|
|
|
|
|
|
|
|
impl Foo for Bar {} // error: `Foo` is not a trait
|
|
|
|
```
|
|
|
|
|
2015-07-17 17:21:58 +02:00
|
|
|
Please verify that you didn't misspell the trait's name or otherwise use the
|
|
|
|
wrong identifier. Example:
|
2015-07-17 14:55:42 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
trait Foo {
|
|
|
|
// some functions
|
|
|
|
}
|
|
|
|
struct Bar;
|
|
|
|
|
|
|
|
impl Foo for Bar { // ok!
|
|
|
|
// functions implementation
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-17 14:14:41 +02:00
|
|
|
E0405: r##"
|
2016-02-14 02:47:27 +01:00
|
|
|
The code refers to a trait that is not in scope. Example of erroneous code:
|
2015-07-17 14:14:41 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-17 14:14:41 +02:00
|
|
|
struct Foo;
|
|
|
|
|
2016-02-14 02:47:27 +01:00
|
|
|
impl SomeTrait for Foo {} // error: trait `SomeTrait` is not in scope
|
2015-07-17 14:14:41 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
Please verify that the name of the trait wasn't misspelled and ensure that it
|
|
|
|
was imported. Example:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-07-17 14:14:41 +02:00
|
|
|
// solution 1:
|
|
|
|
use some_file::SomeTrait;
|
|
|
|
|
|
|
|
// solution 2:
|
|
|
|
trait SomeTrait {
|
|
|
|
// some functions
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Foo;
|
|
|
|
|
|
|
|
impl SomeTrait for Foo { // ok!
|
|
|
|
// implements functions
|
|
|
|
}
|
2015-07-17 14:00:03 +02:00
|
|
|
```
|
2015-07-17 15:54:44 +02:00
|
|
|
"##,
|
|
|
|
|
|
|
|
E0407: r##"
|
2015-07-17 17:21:58 +02:00
|
|
|
A definition of a method not in the implemented trait was given in a trait
|
|
|
|
implementation. Example of erroneous code:
|
2015-07-17 15:54:44 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-17 15:54:44 +02:00
|
|
|
trait Foo {
|
|
|
|
fn a();
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Bar;
|
|
|
|
|
|
|
|
impl Foo for Bar {
|
|
|
|
fn a() {}
|
|
|
|
fn b() {} // error: method `b` is not a member of trait `Foo`
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-07-17 17:21:58 +02:00
|
|
|
Please verify you didn't misspell the method name and you used the correct
|
|
|
|
trait. First example:
|
2015-07-17 15:54:44 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
trait Foo {
|
|
|
|
fn a();
|
|
|
|
fn b();
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Bar;
|
|
|
|
|
|
|
|
impl Foo for Bar {
|
|
|
|
fn a() {}
|
|
|
|
fn b() {} // ok!
|
|
|
|
}
|
|
|
|
```
|
2015-07-17 17:21:58 +02:00
|
|
|
|
|
|
|
Second example:
|
|
|
|
|
|
|
|
```
|
|
|
|
trait Foo {
|
|
|
|
fn a();
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Bar;
|
|
|
|
|
|
|
|
impl Foo for Bar {
|
|
|
|
fn a() {}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Bar {
|
|
|
|
fn b() {}
|
|
|
|
}
|
|
|
|
```
|
2015-07-17 15:54:44 +02:00
|
|
|
"##,
|
2015-07-17 14:00:03 +02:00
|
|
|
|
2016-05-06 20:20:04 +05:30
|
|
|
E0408: r##"
|
|
|
|
An "or" pattern was used where the variable bindings are not consistently bound
|
|
|
|
across patterns.
|
|
|
|
|
|
|
|
Example of erroneous code:
|
|
|
|
|
|
|
|
```compile_fail
|
|
|
|
match x {
|
|
|
|
Some(y) | None => { /* use y */ } // error: variable `y` from pattern #1 is
|
2016-05-06 20:42:23 +05:30
|
|
|
// not bound in pattern #2
|
2016-05-06 20:20:04 +05:30
|
|
|
_ => ()
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Here, `y` is bound to the contents of the `Some` and can be used within the
|
|
|
|
block corresponding to the match arm. However, in case `x` is `None`, we have
|
|
|
|
not specified what `y` is, and the block will use a nonexistent variable.
|
|
|
|
|
|
|
|
To fix this error, either split into multiple match arms:
|
|
|
|
|
|
|
|
```
|
|
|
|
let x = Some(1);
|
|
|
|
match x {
|
|
|
|
Some(y) => { /* use y */ }
|
|
|
|
None => { /* ... */ }
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
or, bind the variable to a field of the same type in all sub-patterns of the
|
|
|
|
or pattern:
|
|
|
|
|
|
|
|
```
|
2016-05-06 20:42:23 +05:30
|
|
|
let x = (0, 2);
|
2016-05-06 20:20:04 +05:30
|
|
|
match x {
|
|
|
|
(0, y) | (y, 0) => { /* use y */}
|
2016-05-06 20:42:23 +05:30
|
|
|
_ => {}
|
2016-05-06 20:20:04 +05:30
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
In this example, if `x` matches the pattern `(0, _)`, the second field is set
|
2016-05-06 20:42:23 +05:30
|
|
|
to `y`. If it matches `(_, 0)`, the first field is set to `y`; so in all
|
2016-05-06 20:20:04 +05:30
|
|
|
cases `y` is set to some value.
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0409: r##"
|
|
|
|
An "or" pattern was used where the variable bindings are not consistently bound
|
|
|
|
across patterns.
|
|
|
|
|
|
|
|
Example of erroneous code:
|
|
|
|
|
|
|
|
```compile_fail
|
2016-05-06 20:42:23 +05:30
|
|
|
let x = (0, 2);
|
2016-05-06 20:20:04 +05:30
|
|
|
match x {
|
|
|
|
(0, ref y) | (y, 0) => { /* use y */} // error: variable `y` is bound with
|
2016-05-06 20:42:23 +05:30
|
|
|
// different mode in pattern #2
|
|
|
|
// than in pattern #1
|
2016-05-06 20:20:04 +05:30
|
|
|
_ => ()
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Here, `y` is bound by-value in one case and by-reference in the other.
|
|
|
|
|
|
|
|
To fix this error, just use the same mode in both cases.
|
2016-05-06 20:42:23 +05:30
|
|
|
Generally using `ref` or `ref mut` where not already used will fix this:
|
2016-05-06 20:20:04 +05:30
|
|
|
|
2016-05-06 20:42:23 +05:30
|
|
|
```ignore
|
|
|
|
let x = (0, 2);
|
2016-05-06 20:20:04 +05:30
|
|
|
match x {
|
|
|
|
(0, ref y) | (ref y, 0) => { /* use y */}
|
|
|
|
_ => ()
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-05-06 20:42:23 +05:30
|
|
|
Alternatively, split the pattern:
|
2016-05-06 20:20:04 +05:30
|
|
|
|
2016-05-06 20:42:23 +05:30
|
|
|
```
|
|
|
|
let x = (0, 2);
|
2016-05-06 20:20:04 +05:30
|
|
|
match x {
|
|
|
|
(y, 0) => { /* use y */ }
|
2016-05-06 20:42:23 +05:30
|
|
|
(0, ref y) => { /* use y */}
|
2016-05-06 20:20:04 +05:30
|
|
|
_ => ()
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-08-28 15:25:39 +02:00
|
|
|
E0411: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
The `Self` keyword was used outside an impl or a trait. Erroneous code example:
|
2015-08-28 15:25:39 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-08-28 15:25:39 +02:00
|
|
|
<Self>::foo; // error: use of `Self` outside of an impl or trait
|
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
The `Self` keyword represents the current type, which explains why it can only
|
|
|
|
be used inside an impl or a trait. It gives access to the associated items of a
|
|
|
|
type:
|
2015-08-28 15:42:03 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
trait Foo {
|
|
|
|
type Bar;
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Baz : Foo {
|
|
|
|
fn bar() -> Self::Bar; // like this
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
However, be careful when two types have a common associated type:
|
2015-08-28 15:25:39 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-08-28 15:25:39 +02:00
|
|
|
trait Foo {
|
|
|
|
type Bar;
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Foo2 {
|
|
|
|
type Bar;
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Baz : Foo + Foo2 {
|
|
|
|
fn bar() -> Self::Bar;
|
|
|
|
// error: ambiguous associated type `Bar` in bounds of `Self`
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
This problem can be solved by specifying from which trait we want to use the
|
|
|
|
`Bar` type:
|
2015-08-28 15:25:39 +02:00
|
|
|
|
|
|
|
```
|
2016-02-07 13:02:52 +01:00
|
|
|
trait Foo {
|
|
|
|
type Bar;
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Foo2 {
|
|
|
|
type Bar;
|
|
|
|
}
|
|
|
|
|
2015-08-28 15:25:39 +02:00
|
|
|
trait Baz : Foo + Foo2 {
|
|
|
|
fn bar() -> <Self as Foo>::Bar; // ok!
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-08-04 12:02:30 +02:00
|
|
|
E0412: r##"
|
2016-02-14 02:47:27 +01:00
|
|
|
The type name used is not in scope. Example of erroneous codes:
|
2015-08-04 12:02:30 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2016-02-14 02:47:27 +01:00
|
|
|
impl Something {} // error: type name `Something` is not in scope
|
2016-02-15 17:57:21 +01:00
|
|
|
|
2015-08-06 11:57:53 +02:00
|
|
|
// or:
|
2016-02-15 17:57:21 +01:00
|
|
|
|
2015-08-06 11:57:53 +02:00
|
|
|
trait Foo {
|
2016-02-14 02:47:27 +01:00
|
|
|
fn bar(N); // error: type name `N` is not in scope
|
2015-08-06 11:57:53 +02:00
|
|
|
}
|
2016-02-15 17:57:21 +01:00
|
|
|
|
2015-08-06 20:47:10 +02:00
|
|
|
// or:
|
2016-02-15 17:57:21 +01:00
|
|
|
|
2016-02-14 02:47:27 +01:00
|
|
|
fn foo(x: T) {} // type name `T` is not in scope
|
2015-08-04 12:02:30 +02:00
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
To fix this error, please verify you didn't misspell the type name, you did
|
|
|
|
declare it or imported it into the scope. Examples:
|
2015-08-04 12:02:30 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
struct Something;
|
|
|
|
|
2015-08-06 20:47:10 +02:00
|
|
|
impl Something {} // ok!
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-08-06 11:57:53 +02:00
|
|
|
// or:
|
2016-02-07 13:02:52 +01:00
|
|
|
|
2015-08-06 11:57:53 +02:00
|
|
|
trait Foo {
|
|
|
|
type N;
|
|
|
|
|
2015-08-06 20:47:10 +02:00
|
|
|
fn bar(Self::N); // ok!
|
2015-08-06 11:57:53 +02:00
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
|
|
|
|
// or:
|
|
|
|
|
2015-08-06 20:47:10 +02:00
|
|
|
fn foo<T>(x: T) {} // ok!
|
2015-08-04 12:02:30 +02:00
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-08-06 15:21:25 +02:00
|
|
|
E0415: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
More than one function parameter have the same name. Example of erroneous code:
|
2015-08-06 15:21:25 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-08-06 15:21:25 +02:00
|
|
|
fn foo(f: i32, f: i32) {} // error: identifier `f` is bound more than
|
|
|
|
// once in this parameter list
|
|
|
|
```
|
|
|
|
|
|
|
|
Please verify you didn't misspell parameters' name. Example:
|
|
|
|
|
|
|
|
```
|
|
|
|
fn foo(f: i32, g: i32) {} // ok!
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-08-06 15:30:33 +02:00
|
|
|
E0416: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
An identifier is bound more than once in a pattern. Example of erroneous code:
|
2015-08-06 15:30:33 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-08-06 15:30:33 +02:00
|
|
|
match (1, 2) {
|
|
|
|
(x, x) => {} // error: identifier `x` is bound more than once in the
|
|
|
|
// same pattern
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Please verify you didn't misspell identifiers' name. Example:
|
|
|
|
|
|
|
|
```
|
|
|
|
match (1, 2) {
|
|
|
|
(x, y) => {} // ok!
|
|
|
|
}
|
|
|
|
```
|
2015-08-07 15:23:00 +02:00
|
|
|
|
|
|
|
Or maybe did you mean to unify? Consider using a guard:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-08-07 15:23:00 +02:00
|
|
|
match (A, B, C) {
|
|
|
|
(x, x2, see) if x == x2 => { /* A and B are equal, do one thing */ }
|
|
|
|
(y, z, see) => { /* A and B unequal; do another thing */ }
|
|
|
|
}
|
|
|
|
```
|
2015-08-06 15:30:33 +02:00
|
|
|
"##,
|
|
|
|
|
2015-09-20 13:36:08 -07:00
|
|
|
E0422: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
You are trying to use an identifier that is either undefined or not a struct.
|
|
|
|
For instance:
|
2016-02-07 13:02:52 +01:00
|
|
|
|
|
|
|
``` compile_fail
|
2015-09-20 13:36:08 -07:00
|
|
|
fn main () {
|
|
|
|
let x = Foo { x: 1, y: 2 };
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
In this case, `Foo` is undefined, so it inherently isn't anything, and
|
|
|
|
definitely not a struct.
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-09-20 13:36:08 -07:00
|
|
|
fn main () {
|
|
|
|
let foo = 1;
|
|
|
|
let x = foo { x: 1, y: 2 };
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
In this case, `foo` is defined, but is not a struct, so Rust can't use it as
|
|
|
|
one.
|
2015-09-20 13:36:08 -07:00
|
|
|
"##,
|
|
|
|
|
2015-07-29 14:53:25 +02:00
|
|
|
E0423: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
A `struct` variant name was used like a function name. Example of erroneous
|
|
|
|
code:
|
2015-07-29 14:45:24 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-29 14:45:24 +02:00
|
|
|
struct Foo { a: bool};
|
|
|
|
|
2015-08-06 15:42:22 +02:00
|
|
|
let f = Foo();
|
2015-07-29 14:45:24 +02:00
|
|
|
// error: `Foo` is a struct variant name, but this expression uses
|
|
|
|
// it like a function name
|
|
|
|
```
|
|
|
|
|
2016-02-15 17:57:21 +01:00
|
|
|
Please verify you didn't misspell the name of what you actually wanted to use
|
|
|
|
here. Example:
|
2015-07-29 14:45:24 +02:00
|
|
|
|
|
|
|
```
|
2015-08-06 15:42:22 +02:00
|
|
|
fn Foo() -> u32 { 0 }
|
2015-07-29 14:45:24 +02:00
|
|
|
|
2015-08-06 15:42:22 +02:00
|
|
|
let f = Foo(); // ok!
|
2015-07-29 14:45:24 +02:00
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-23 12:44:59 +02:00
|
|
|
E0424: r##"
|
2015-07-23 16:19:37 +02:00
|
|
|
The `self` keyword was used in a static method. Example of erroneous code:
|
2015-07-23 12:44:59 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-23 12:44:59 +02:00
|
|
|
struct Foo;
|
|
|
|
|
|
|
|
impl Foo {
|
|
|
|
fn bar(self) {}
|
|
|
|
|
|
|
|
fn foo() {
|
|
|
|
self.bar(); // error: `self` is not available in a static method.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-07-24 17:26:41 +02:00
|
|
|
Please check if the method's argument list should have contained `self`,
|
|
|
|
`&self`, or `&mut self` (in case you didn't want to create a static
|
|
|
|
method), and add it if so. Example:
|
2015-07-23 12:44:59 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
struct Foo;
|
|
|
|
|
|
|
|
impl Foo {
|
|
|
|
fn bar(self) {}
|
|
|
|
|
|
|
|
fn foo(self) {
|
|
|
|
self.bar(); // ok!
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-24 14:58:00 +02:00
|
|
|
E0425: r##"
|
2015-07-24 17:26:41 +02:00
|
|
|
An unresolved name was used. Example of erroneous codes:
|
2015-07-24 14:58:00 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-24 17:26:41 +02:00
|
|
|
something_that_doesnt_exist::foo;
|
|
|
|
// error: unresolved name `something_that_doesnt_exist::foo`
|
|
|
|
|
|
|
|
// or:
|
2016-02-15 17:57:21 +01:00
|
|
|
|
2015-07-24 17:26:41 +02:00
|
|
|
trait Foo {
|
|
|
|
fn bar() {
|
|
|
|
Self; // error: unresolved name `Self`
|
|
|
|
}
|
|
|
|
}
|
2015-08-10 15:29:06 +02:00
|
|
|
|
|
|
|
// or:
|
2016-02-15 17:57:21 +01:00
|
|
|
|
2015-08-10 15:29:06 +02:00
|
|
|
let x = unknown_variable; // error: unresolved name `unknown_variable`
|
2015-07-24 14:58:00 +02:00
|
|
|
```
|
|
|
|
|
2015-08-11 19:16:23 +02:00
|
|
|
Please verify that the name wasn't misspelled and ensure that the
|
|
|
|
identifier being referred to is valid for the given situation. Example:
|
2015-07-24 14:58:00 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
enum something_that_does_exist {
|
2016-02-07 13:02:52 +01:00
|
|
|
Foo,
|
2015-07-24 14:58:00 +02:00
|
|
|
}
|
2016-02-07 13:02:52 +01:00
|
|
|
```
|
2015-08-10 15:29:06 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
Or:
|
|
|
|
|
|
|
|
```
|
2015-07-24 14:58:00 +02:00
|
|
|
mod something_that_does_exist {
|
|
|
|
pub static foo : i32 = 0i32;
|
|
|
|
}
|
|
|
|
|
|
|
|
something_that_does_exist::foo; // ok!
|
2016-02-07 13:02:52 +01:00
|
|
|
```
|
2015-08-10 15:29:06 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
Or:
|
|
|
|
|
|
|
|
```
|
2015-08-10 15:29:06 +02:00
|
|
|
let unknown_variable = 12u32;
|
|
|
|
let x = unknown_variable; // ok!
|
2015-07-24 14:58:00 +02:00
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-24 14:44:44 +02:00
|
|
|
E0426: r##"
|
|
|
|
An undeclared label was used. Example of erroneous code:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-24 14:44:44 +02:00
|
|
|
loop {
|
|
|
|
break 'a; // error: use of undeclared label `'a`
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-07-24 17:26:41 +02:00
|
|
|
Please verify you spelt or declare the label correctly. Example:
|
2015-07-24 14:44:44 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
'a: loop {
|
|
|
|
break 'a; // ok!
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-17 16:09:25 +02:00
|
|
|
E0428: r##"
|
|
|
|
A type or module has been defined more than once. Example of erroneous
|
|
|
|
code:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-17 16:09:25 +02:00
|
|
|
struct Bar;
|
|
|
|
struct Bar; // error: duplicate definition of value `Bar`
|
|
|
|
```
|
|
|
|
|
2015-07-17 17:21:58 +02:00
|
|
|
Please verify you didn't misspell the type/module's name or remove/rename the
|
2015-07-17 16:09:25 +02:00
|
|
|
duplicated one. Example:
|
|
|
|
|
|
|
|
```
|
|
|
|
struct Bar;
|
|
|
|
struct Bar2; // ok!
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2016-05-29 17:50:08 -07:00
|
|
|
E0429: r##"
|
2016-05-30 16:45:41 -07:00
|
|
|
The `self` keyword cannot appear alone as the last segment in a `use`
|
|
|
|
declaration.
|
2016-05-29 17:50:08 -07:00
|
|
|
|
|
|
|
Example of erroneous code:
|
|
|
|
|
|
|
|
```compile_fail
|
|
|
|
use std::fmt::self; // error: `self` imports are only allowed within a { } list
|
|
|
|
```
|
|
|
|
|
2016-05-30 16:45:41 -07:00
|
|
|
To use a namespace itself in addition to some of its members, `self` may appear
|
|
|
|
as part of a brace-enclosed list of imports:
|
2016-05-29 17:50:08 -07:00
|
|
|
|
|
|
|
```
|
2016-05-30 16:45:41 -07:00
|
|
|
use std::fmt::{self, Debug};
|
2016-05-29 17:50:08 -07:00
|
|
|
```
|
|
|
|
|
2016-05-30 16:45:41 -07:00
|
|
|
If you only want to import the namespace, do so directly:
|
2016-05-29 17:50:08 -07:00
|
|
|
|
|
|
|
```
|
2016-05-30 16:45:41 -07:00
|
|
|
use std::fmt;
|
2016-05-29 17:50:08 -07:00
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-24 12:19:36 +02:00
|
|
|
E0430: r##"
|
2015-07-24 12:24:12 +02:00
|
|
|
The `self` import appears more than once in the list. Erroneous code example:
|
2015-07-24 12:19:36 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-24 12:19:36 +02:00
|
|
|
use something::{self, self}; // error: `self` import can only appear once in
|
|
|
|
// the list
|
|
|
|
```
|
|
|
|
|
|
|
|
Please verify you didn't misspell the import name or remove the duplicated
|
2015-07-24 12:30:14 +02:00
|
|
|
`self` import. Example:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-07-24 12:30:14 +02:00
|
|
|
use something::self; // ok!
|
|
|
|
```
|
2015-07-24 12:19:36 +02:00
|
|
|
"##,
|
|
|
|
|
2015-07-24 12:24:12 +02:00
|
|
|
E0431: r##"
|
2016-02-15 17:57:21 +01:00
|
|
|
An invalid `self` import was made. Erroneous code example:
|
2015-07-24 12:24:12 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-24 12:24:12 +02:00
|
|
|
use {self}; // error: `self` import can only appear in an import list with a
|
|
|
|
// non-empty prefix
|
|
|
|
```
|
|
|
|
|
2015-07-24 17:26:41 +02:00
|
|
|
You cannot import the current module into itself, please remove this import
|
|
|
|
or verify you didn't misspell it.
|
2015-07-24 12:24:12 +02:00
|
|
|
"##,
|
|
|
|
|
2015-07-24 12:30:14 +02:00
|
|
|
E0432: r##"
|
|
|
|
An import was unresolved. Erroneous code example:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-24 12:30:14 +02:00
|
|
|
use something::Foo; // error: unresolved import `something::Foo`.
|
|
|
|
```
|
|
|
|
|
2016-05-01 20:40:16 +02:00
|
|
|
Paths in `use` statements are relative to the crate root. To import items
|
|
|
|
relative to the current and parent modules, use the `self::` and `super::`
|
|
|
|
prefixes, respectively. Also verify that you didn't misspell the import
|
|
|
|
name and that the import exists in the module from where you tried to
|
|
|
|
import it. Example:
|
2015-07-24 12:30:14 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2016-05-01 20:40:16 +02:00
|
|
|
use self::something::Foo; // ok!
|
2015-07-24 12:30:14 +02:00
|
|
|
|
|
|
|
mod something {
|
|
|
|
pub struct Foo;
|
|
|
|
}
|
|
|
|
```
|
2015-11-12 18:05:45 +09:00
|
|
|
|
|
|
|
Or, if you tried to use a module from an external crate, you may have missed
|
2016-05-01 20:40:16 +02:00
|
|
|
the `extern crate` declaration (which is usually placed in the crate root):
|
2015-11-12 18:05:45 +09:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```ignore
|
2015-11-12 18:05:45 +09:00
|
|
|
extern crate homura; // Required to use the `homura` crate
|
|
|
|
|
|
|
|
use homura::Madoka;
|
|
|
|
```
|
2015-07-24 12:30:14 +02:00
|
|
|
"##,
|
|
|
|
|
2015-07-17 17:21:58 +02:00
|
|
|
E0433: r##"
|
|
|
|
Invalid import. Example of erroneous code:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-17 17:21:58 +02:00
|
|
|
use something_which_doesnt_exist;
|
|
|
|
// error: unresolved import `something_which_doesnt_exist`
|
|
|
|
```
|
|
|
|
|
|
|
|
Please verify you didn't misspell the import's name.
|
|
|
|
"##,
|
|
|
|
|
2016-04-26 14:38:24 -05:00
|
|
|
E0434: r##"
|
|
|
|
This error indicates that a variable usage inside an inner function is invalid
|
|
|
|
because the variable comes from a dynamic environment. Inner functions do not
|
|
|
|
have access to their containing environment.
|
|
|
|
|
|
|
|
Example of erroneous code:
|
|
|
|
|
|
|
|
```compile_fail
|
|
|
|
fn foo() {
|
|
|
|
let y = 5;
|
|
|
|
fn bar() -> u32 {
|
|
|
|
y // error: can't capture dynamic environment in a fn item; use the
|
|
|
|
// || { ... } closure form instead.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Functions do not capture local variables. To fix this error, you can replace the
|
|
|
|
function with a closure:
|
|
|
|
|
|
|
|
```
|
|
|
|
fn foo() {
|
|
|
|
let y = 5;
|
|
|
|
let bar = || {
|
|
|
|
y
|
|
|
|
};
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
or replace the captured variable with a constant or a static item:
|
|
|
|
|
|
|
|
```
|
|
|
|
fn foo() {
|
|
|
|
static mut X: u32 = 4;
|
|
|
|
const Y: u32 = 5;
|
|
|
|
fn bar() -> u32 {
|
|
|
|
unsafe {
|
|
|
|
X = 3;
|
|
|
|
}
|
|
|
|
Y
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-31 14:40:27 +02:00
|
|
|
E0435: r##"
|
2015-08-06 15:42:22 +02:00
|
|
|
A non-constant value was used to initialise a constant. Example of erroneous
|
|
|
|
code:
|
2015-07-31 14:40:27 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-31 14:40:27 +02:00
|
|
|
let foo = 42u32;
|
|
|
|
const FOO : u32 = foo; // error: attempt to use a non-constant value in a
|
|
|
|
// constant
|
|
|
|
```
|
|
|
|
|
2015-08-06 15:42:22 +02:00
|
|
|
To fix this error, please replace the value with a constant. Example:
|
2015-07-31 14:40:27 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
const FOO : u32 = 42u32; // ok!
|
2016-02-07 13:02:52 +01:00
|
|
|
```
|
2015-07-31 14:40:27 +02:00
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
Or:
|
|
|
|
|
|
|
|
```
|
2015-07-31 14:40:27 +02:00
|
|
|
const OTHER_FOO : u32 = 42u32;
|
|
|
|
const FOO : u32 = OTHER_FOO; // ok!
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
2015-07-22 16:52:40 -04:00
|
|
|
E0437: r##"
|
2015-07-31 12:55:53 +02:00
|
|
|
Trait implementations can only implement associated types that are members of
|
|
|
|
the trait in question. This error indicates that you attempted to implement
|
|
|
|
an associated type whose name does not match the name of any associated type
|
|
|
|
in the trait.
|
2015-07-22 16:52:40 -04:00
|
|
|
|
|
|
|
Here is an example that demonstrates the error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-22 16:52:40 -04:00
|
|
|
trait Foo {}
|
|
|
|
|
|
|
|
impl Foo for i32 {
|
|
|
|
type Bar = bool;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
The solution to this problem is to remove the extraneous associated type:
|
|
|
|
|
|
|
|
```
|
|
|
|
trait Foo {}
|
|
|
|
|
|
|
|
impl Foo for i32 {}
|
|
|
|
```
|
|
|
|
"##,
|
|
|
|
|
|
|
|
E0438: r##"
|
2015-07-31 12:55:53 +02:00
|
|
|
Trait implementations can only implement associated constants that are
|
|
|
|
members of the trait in question. This error indicates that you
|
|
|
|
attempted to implement an associated constant whose name does not
|
|
|
|
match the name of any associated constant in the trait.
|
2015-07-22 16:52:40 -04:00
|
|
|
|
|
|
|
Here is an example that demonstrates the error:
|
|
|
|
|
2016-02-07 13:02:52 +01:00
|
|
|
```compile_fail
|
2015-07-22 16:52:40 -04:00
|
|
|
#![feature(associated_consts)]
|
|
|
|
|
|
|
|
trait Foo {}
|
|
|
|
|
|
|
|
impl Foo for i32 {
|
|
|
|
const BAR: bool = true;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
The solution to this problem is to remove the extraneous associated constant:
|
|
|
|
|
|
|
|
```
|
|
|
|
trait Foo {}
|
|
|
|
|
|
|
|
impl Foo for i32 {}
|
|
|
|
```
|
|
|
|
"##
|
|
|
|
|
2015-05-10 10:43:30 +01:00
|
|
|
}
|
|
|
|
|
2015-01-16 15:54:58 -08:00
|
|
|
register_diagnostics! {
|
2016-06-03 23:15:00 +03:00
|
|
|
// E0153, unused error code
|
|
|
|
// E0157, unused error code
|
2015-01-18 13:46:57 -08:00
|
|
|
E0254, // import conflicts with imported crate in this module
|
2016-06-03 23:15:00 +03:00
|
|
|
// E0257,
|
|
|
|
// E0258,
|
2015-07-13 00:31:09 +02:00
|
|
|
E0402, // cannot use an outer type parameter in this context
|
|
|
|
E0406, // undeclared associated type
|
2016-06-03 23:15:00 +03:00
|
|
|
// E0410, merged into 408
|
|
|
|
// E0413, merged into 530
|
|
|
|
// E0414, merged into 530
|
|
|
|
// E0417, merged into 532
|
|
|
|
// E0418, merged into 532
|
|
|
|
// E0419, merged into 531
|
|
|
|
// E0420, merged into 532
|
|
|
|
// E0421, merged into 531
|
|
|
|
E0530, // X bindings cannot shadow Ys
|
|
|
|
E0531, // unresolved pattern path kind `name`
|
|
|
|
E0532, // expected pattern path kind, found another pattern path kind
|
|
|
|
// E0427, merged into 530
|
2015-01-16 15:54:58 -08:00
|
|
|
}
|