mirror of
https://github.com/rust-lang/rust.git
synced 2025-06-05 11:48:30 +00:00
Rollup merge of #67055 - lqd:const_qualif, r=oli-obk
Make const-qualification look at more `const fn`s As explained in a lot more detail in #67053 this makes const-qualification not ignore the unstable const fns in libcore. r? @oli-obk cc @ecstatic-morse (Still a bit unsure about the `cfg`s here, for bootstrapping, does that seem correct ?) Fixes #67053.
This commit is contained in:
commit
a008aff075
@ -74,6 +74,8 @@
|
|||||||
#![feature(const_fn)]
|
#![feature(const_fn)]
|
||||||
#![feature(const_fn_union)]
|
#![feature(const_fn_union)]
|
||||||
#![feature(const_generics)]
|
#![feature(const_generics)]
|
||||||
|
#![cfg_attr(not(bootstrap), feature(const_ptr_offset_from))]
|
||||||
|
#![cfg_attr(not(bootstrap), feature(const_type_name))]
|
||||||
#![feature(custom_inner_attributes)]
|
#![feature(custom_inner_attributes)]
|
||||||
#![feature(decl_macro)]
|
#![feature(decl_macro)]
|
||||||
#![feature(doc_cfg)]
|
#![feature(doc_cfg)]
|
||||||
|
@ -77,7 +77,12 @@ impl ConstKind {
|
|||||||
let mode = match tcx.hir().body_owner_kind(hir_id) {
|
let mode = match tcx.hir().body_owner_kind(hir_id) {
|
||||||
HirKind::Closure => return None,
|
HirKind::Closure => return None,
|
||||||
|
|
||||||
HirKind::Fn if tcx.is_const_fn(def_id) => ConstKind::ConstFn,
|
// Note: this is deliberately checking for `is_const_fn_raw`, as the `is_const_fn`
|
||||||
|
// checks take into account the `rustc_const_unstable` attribute combined with enabled
|
||||||
|
// feature gates. Otherwise, const qualification would _not check_ whether this
|
||||||
|
// function body follows the `const fn` rules, as an unstable `const fn` would
|
||||||
|
// be considered "not const". More details are available in issue #67053.
|
||||||
|
HirKind::Fn if tcx.is_const_fn_raw(def_id) => ConstKind::ConstFn,
|
||||||
HirKind::Fn => return None,
|
HirKind::Fn => return None,
|
||||||
|
|
||||||
HirKind::Const => ConstKind::Const,
|
HirKind::Const => ConstKind::Const,
|
||||||
|
29
src/test/ui/consts/unstable-const-fn-in-libcore.rs
Normal file
29
src/test/ui/consts/unstable-const-fn-in-libcore.rs
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
// This is a non-regression test for const-qualification of unstable items in libcore
|
||||||
|
// as explained in issue #67053.
|
||||||
|
// const-qualification could miss some `const fn`s if they were unstable and the feature
|
||||||
|
// gate was not enabled in libcore.
|
||||||
|
|
||||||
|
#![stable(feature = "core", since = "1.6.0")]
|
||||||
|
#![feature(const_if_match)]
|
||||||
|
#![feature(rustc_const_unstable)]
|
||||||
|
#![feature(staged_api)]
|
||||||
|
|
||||||
|
enum Opt<T> {
|
||||||
|
Some(T),
|
||||||
|
None,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T> Opt<T> {
|
||||||
|
#[rustc_const_unstable(feature = "foo")]
|
||||||
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
|
const fn unwrap_or_else<F: FnOnce() -> T>(self, f: F) -> T {
|
||||||
|
//~^ ERROR destructors cannot be evaluated at compile-time
|
||||||
|
//~| ERROR destructors cannot be evaluated at compile-time
|
||||||
|
match self {
|
||||||
|
Opt::Some(t) => t,
|
||||||
|
Opt::None => f(), //~ ERROR E0015
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
22
src/test/ui/consts/unstable-const-fn-in-libcore.stderr
Normal file
22
src/test/ui/consts/unstable-const-fn-in-libcore.stderr
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
error[E0015]: calls in constant functions are limited to constant functions, tuple structs and tuple variants
|
||||||
|
--> $DIR/unstable-const-fn-in-libcore.rs:24:26
|
||||||
|
|
|
||||||
|
LL | Opt::None => f(),
|
||||||
|
| ^^^
|
||||||
|
|
||||||
|
error[E0493]: destructors cannot be evaluated at compile-time
|
||||||
|
--> $DIR/unstable-const-fn-in-libcore.rs:19:53
|
||||||
|
|
|
||||||
|
LL | const fn unwrap_or_else<F: FnOnce() -> T>(self, f: F) -> T {
|
||||||
|
| ^ constant functions cannot evaluate destructors
|
||||||
|
|
||||||
|
error[E0493]: destructors cannot be evaluated at compile-time
|
||||||
|
--> $DIR/unstable-const-fn-in-libcore.rs:19:47
|
||||||
|
|
|
||||||
|
LL | const fn unwrap_or_else<F: FnOnce() -> T>(self, f: F) -> T {
|
||||||
|
| ^^^^ constant functions cannot evaluate destructors
|
||||||
|
|
||||||
|
error: aborting due to 3 previous errors
|
||||||
|
|
||||||
|
Some errors have detailed explanations: E0015, E0493.
|
||||||
|
For more information about an error, try `rustc --explain E0015`.
|
Loading…
Reference in New Issue
Block a user