-
Notifications
You must be signed in to change notification settings - Fork 13.2k
/
Copy pathvar-captured-in-sendable-closure.rs
75 lines (55 loc) · 1.6 KB
/
var-captured-in-sendable-closure.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//@ compile-flags:-g
// === GDB TESTS ===================================================================================
// gdb-command:run
// gdb-command:print constant
// gdb-check:$1 = 1
// gdb-command:print a_struct
// gdb-check:$2 = var_captured_in_sendable_closure::Struct {a: -2, b: 3.5, c: 4}
// gdb-command:print *owned
// gdb-check:$3 = 5
// gdb-command:continue
// gdb-command:print constant2
// gdb-check:$4 = 6
// gdb-command:continue
// === LLDB TESTS ==================================================================================
// lldb-command:run
// lldb-command:v constant
// lldb-check:[...] 1
// lldb-command:v a_struct
// lldb-check:[...] { a = -2 b = 3.5 c = 4 }
// lldb-command:v *owned
// lldb-check:[...] 5
#![allow(unused_variables)]
#![feature(omit_gdb_pretty_printer_section)]
#![omit_gdb_pretty_printer_section]
struct Struct {
a: isize,
b: f64,
c: usize
}
fn main() {
let constant = 1;
let a_struct = Struct {
a: -2,
b: 3.5,
c: 4
};
let owned: Box<_> = Box::new(5);
let closure = move || {
zzz(); // #break
do_something(&constant, &a_struct.a, &*owned);
};
closure();
let constant2 = 6_usize;
// The `self` argument of the following closure should be passed by value
// to FnOnce::call_once(self, args), which gets codegened a bit differently
// than the regular case. Let's make sure this is supported too.
let immedate_env = move || {
zzz(); // #break
return constant2;
};
immedate_env();
}
fn do_something(_: &isize, _:&isize, _:&isize) {
}
fn zzz() {()}