rust/src/librustc_passes/diagnostics.rs

191 lines
4.3 KiB
Rust
Raw Normal View History

// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
#![allow(non_snake_case)]
register_long_diagnostics! {
2016-01-21 10:52:37 +01:00
E0014: r##"
Constants can only be initialized by a constant value or, in a future
version of Rust, a call to a const function. This error indicates the use
of a path (like a::b, or x) denoting something other than one of these
2016-02-07 13:02:52 +01:00
allowed items. Erroneous code xample:
2016-01-21 10:52:37 +01:00
2016-02-07 13:02:52 +01:00
```compile_fail
2016-01-21 10:52:37 +01:00
const FOO: i32 = { let x = 0; x }; // 'x' isn't a constant nor a function!
```
To avoid it, you have to replace the non-constant value:
```
const FOO: i32 = { const X : i32 = 0; X };
// or even:
2016-02-07 13:02:52 +01:00
const FOO2: i32 = { 0 }; // but brackets are useless here
2016-01-21 10:52:37 +01:00
```
"##,
E0030: r##"
When matching against a range, the compiler verifies that the range is
non-empty. Range patterns include both end-points, so this is equivalent to
requiring the start of the range to be less than or equal to the end of the
range.
For example:
2016-02-07 13:02:52 +01:00
```compile_fail
2016-01-21 10:52:37 +01:00
match 5u32 {
// This range is ok, albeit pointless.
2016-02-07 13:02:52 +01:00
1 ... 1 => {}
2016-01-21 10:52:37 +01:00
// This range is empty, and the compiler can tell.
2016-02-07 13:02:52 +01:00
1000 ... 5 => {}
2016-01-21 10:52:37 +01:00
}
```
"##,
E0161: r##"
2016-05-27 22:05:10 +02:00
A value was moved. However, its size was not known at compile time, and only
values of a known size can be moved.
Erroneous code example:
```compile_fail
#![feature(box_syntax)]
fn main() {
let array: &[isize] = &[1, 2, 3];
let _x: Box<[isize]> = box *array;
// error: cannot move a value of type [isize]: the size of [isize] cannot
// be statically determined
}
```
2016-01-21 10:52:37 +01:00
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
2016-05-27 22:05:10 +02:00
it around as usual. Example:
```
#![feature(box_syntax)]
fn main() {
let array: &[isize] = &[1, 2, 3];
let _x: Box<&[isize]> = box array; // ok!
}
```
2016-01-21 10:52:37 +01:00
"##,
E0265: r##"
This error indicates that a static or constant references itself.
All statics and constants need to resolve to a value in an acyclic manner.
For example, neither of the following can be sensibly compiled:
2016-02-07 13:02:52 +01:00
```compile_fail
2016-01-21 10:52:37 +01:00
const X: u32 = X;
```
2016-02-07 13:02:52 +01:00
```compile_fail
2016-01-21 10:52:37 +01:00
const X: u32 = Y;
const Y: u32 = X;
```
"##,
E0267: r##"
This error indicates the use of a loop keyword (`break` or `continue`) inside a
closure but outside of any loop. Erroneous code example:
2016-02-07 13:02:52 +01:00
```compile_fail
2016-01-21 10:52:37 +01:00
let w = || { break; }; // error: `break` inside of a closure
```
`break` and `continue` keywords can be used as normal inside closures as long as
they are also contained within a loop. To halt the execution of a closure you
should instead use a return statement. Example:
```
let w = || {
for _ in 0..10 {
break;
}
};
w();
```
"##,
E0268: r##"
This error indicates the use of a loop keyword (`break` or `continue`) outside
of a loop. Without a loop to break out of or continue in, no sensible action can
be taken. Erroneous code example:
2016-02-07 13:02:52 +01:00
```compile_fail
2016-01-21 10:52:37 +01:00
fn some_func() {
break; // error: `break` outside of loop
}
```
Please verify that you are using `break` and `continue` only in loops. Example:
```
fn some_func() {
for _ in 0..10 {
break; // ok!
}
}
```
"##,
E0449: r##"
A visibility qualifier was used when it was unnecessary. Erroneous code
examples:
```compile_fail
struct Bar;
trait Foo {
fn foo();
}
pub impl Bar {} // error: unnecessary visibility qualifier
pub impl Foo for Bar { // error: unnecessary visibility qualifier
pub fn foo() {} // error: unnecessary visibility qualifier
}
```
To fix this error, please remove the visibility qualifier when it is not
required. Example:
```ignore
struct Bar;
trait Foo {
fn foo();
}
// Directly implemented methods share the visibility of the type itself,
// so `pub` is unnecessary here
impl Bar {}
// Trait methods share the visibility of the trait, so `pub` is
// unnecessary in either case
pub impl Foo for Bar {
pub fn foo() {}
}
```
"##,
}
register_diagnostics! {
E0472, // asm! is unsupported on this target
}