Skip to content

Commit eb1c632

Browse files
committed
Add a test case for const fn sizing, just to be safe.
1 parent 514fd3e commit eb1c632

File tree

1 file changed

+27
-0
lines changed

1 file changed

+27
-0
lines changed

src/test/run-pass/const-vec-of-fns.rs

+27
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
/*!
12+
* Try to double-check that const fns have the right size (with or
13+
* without dummy env ptr, as appropriate) by iterating a size-2 array.
14+
* If the const size differs from the runtime size, the second element
15+
* should be read as a null or otherwise wrong pointer and crash.
16+
*/
17+
18+
fn f() { }
19+
const bare_fns: &[extern fn()] = &[f, f];
20+
// NOTE Why does this not type without the struct?
21+
struct S(&fn());
22+
const closures: &[S] = &[S(f), S(f)];
23+
24+
pub fn main() {
25+
for bare_fns.each |&bare_fn| { bare_fn() }
26+
for closures.each |&closure| { (*closure)() }
27+
}

0 commit comments

Comments
 (0)