diff options
| author | DutchGhost <kasper199914@gmail.com> | 2020-03-16 14:45:37 +0100 |
|---|---|---|
| committer | DutchGhost <kasper199914@gmail.com> | 2020-03-16 14:45:37 +0100 |
| commit | 0760803c06ff4128405ea22e390625938a15bcb2 (patch) | |
| tree | afdd33b64e0fba2bd0293dc11316209ac5f150df | |
| parent | dcc23217b7364056d5a83aaa058993ccd83b6e78 (diff) | |
| download | rust-0760803c06ff4128405ea22e390625938a15bcb2.tar.gz rust-0760803c06ff4128405ea22e390625938a15bcb2.zip | |
rather than removing const_forget_box, stick an attribute on it and explain it cant be called in ctfe yet
| -rw-r--r-- | src/libcore/tests/mem.rs | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/libcore/tests/mem.rs b/src/libcore/tests/mem.rs index 1502c9ac375..ab6f08fb3ad 100644 --- a/src/libcore/tests/mem.rs +++ b/src/libcore/tests/mem.rs @@ -134,4 +134,16 @@ fn test_discriminant_send_sync() { fn test_const_forget() { const _: () = forget(0i32); const _: () = forget(Vec::<Vec<Box<i32>>>::new()); + + // Writing this function signature without const-forget + // triggers compiler errors: + // 1) That we use a non-const fn inside a const fn + // 2) without the forget, it complains about the destructor of Box + // + // FIXME: this method cannot be called in const-eval yet, as Box isn't + // const constructable + #[allow(unused)] + const fn const_forget_box<T: ?Sized>(x: Box<T>) { + forget(x); + } } |
