4e04d57efa
Moved such overflow checking into one place (in `rustc::middle::ty`, since it needs to be run on-demand during `const_eval` in some scenarios), and revised `rustc_typeck` accordingly. (Note that we only check for overflow if program did not provide a discriminant value explicitly.) Fix #23030 Fix #23221 Fix #23235
138 lines
5.1 KiB
Rust
138 lines
5.1 KiB
Rust
// 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)]
|
|
|
|
register_long_diagnostics! {
|
|
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.
|
|
"##,
|
|
|
|
E0003: r##"
|
|
Not-a-Number (NaN) values can not be compared for equality and hence can never 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() => ...
|
|
"##,
|
|
|
|
E0004: r##"
|
|
This error indicates that the compiler can not guarantee a matching pattern for 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.
|
|
|
|
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".
|
|
"##,
|
|
|
|
// 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.
|
|
"##,
|
|
|
|
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.
|
|
"##
|
|
}
|
|
|
|
register_diagnostics! {
|
|
E0002,
|
|
E0007,
|
|
E0008,
|
|
E0009,
|
|
E0010,
|
|
E0011,
|
|
E0012,
|
|
E0013,
|
|
E0014,
|
|
E0015,
|
|
E0016,
|
|
E0017,
|
|
E0018,
|
|
E0019,
|
|
E0020,
|
|
E0022,
|
|
E0079, // enum variant: expected signed integer constant
|
|
E0080, // enum variant: constant evaluation error
|
|
E0109,
|
|
E0110,
|
|
E0133,
|
|
E0134,
|
|
E0135,
|
|
E0136,
|
|
E0137,
|
|
E0138,
|
|
E0139,
|
|
E0152,
|
|
E0158,
|
|
E0161,
|
|
E0162,
|
|
E0165,
|
|
E0170,
|
|
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
|
|
E0297, // refutable pattern in for loop binding
|
|
E0298, // mismatched types between arms
|
|
E0299, // mismatched types between arms
|
|
E0300, // unexpanded macro
|
|
E0301, // cannot mutable borrow in a pattern guard
|
|
E0302, // cannot assign in a pattern guard
|
|
E0303, // pattern bindings are not allowed after an `@`
|
|
E0304, // expected signed integer constant
|
|
E0305, // expected constant
|
|
E0306, // expected positive integer for repeat count
|
|
E0307, // expected constant integer for repeat count
|
|
E0308,
|
|
E0309, // thing may not live long enough
|
|
E0310, // thing may not live long enough
|
|
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
|
|
E0315, // cannot invoke closure outside of its lifetime
|
|
E0316, // nested quantification of lifetimes
|
|
E0370 // discriminant overflow
|
|
}
|
|
|
|
__build_diagnostic_array! { DIAGNOSTICS }
|