Skip to content

Commit 4c363e3

Browse files
committed
Move the const-forget test into ui tests
1 parent 0760803 commit 4c363e3

File tree

2 files changed

+22
-18
lines changed

2 files changed

+22
-18
lines changed

src/libcore/tests/mem.rs

-18
Original file line numberDiff line numberDiff line change
@@ -129,21 +129,3 @@ fn test_discriminant_send_sync() {
129129
is_send_sync::<Discriminant<Regular>>();
130130
is_send_sync::<Discriminant<NotSendSync>>();
131131
}
132-
133-
#[test]
134-
fn test_const_forget() {
135-
const _: () = forget(0i32);
136-
const _: () = forget(Vec::<Vec<Box<i32>>>::new());
137-
138-
// Writing this function signature without const-forget
139-
// triggers compiler errors:
140-
// 1) That we use a non-const fn inside a const fn
141-
// 2) without the forget, it complains about the destructor of Box
142-
//
143-
// FIXME: this method cannot be called in const-eval yet, as Box isn't
144-
// const constructable
145-
#[allow(unused)]
146-
const fn const_forget_box<T: ?Sized>(x: Box<T>) {
147-
forget(x);
148-
}
149-
}

src/test/ui/consts/const_forget.rs

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
// run-pass
2+
3+
#![feature(const_forget)]
4+
5+
use std::mem::forget;
6+
7+
const _: () = forget(0i32);
8+
const _: () = forget(Vec::<Vec<Box<i32>>>::new());
9+
10+
// Writing this function signature without const-forget
11+
// triggers compiler errors:
12+
// 1) That we use a non-const fn inside a const fn
13+
// 2) without the forget, it complains about the destructor of Box
14+
//
15+
// FIXME: this method cannot be called in const-eval yet, as Box isn't
16+
// const constructable
17+
#[allow(unused)]
18+
const fn const_forget_box<T: ?Sized>(b: Box<T>) {
19+
forget(b);
20+
}
21+
22+
fn main() {}

0 commit comments

Comments
 (0)