summaryrefslogtreecommitdiffstats
path: root/src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir')
-rw-r--r--src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir69
1 files changed, 69 insertions, 0 deletions
diff --git a/src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir b/src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir
new file mode 100644
index 000000000..d60b06460
--- /dev/null
+++ b/src/test/mir-opt/inline/inline_closure_captures.foo.Inline.after.mir
@@ -0,0 +1,69 @@
+// MIR for `foo` after Inline
+
+fn foo(_1: T, _2: i32) -> (i32, T) {
+ debug t => _1; // in scope 0 at $DIR/inline-closure-captures.rs:+0:17: +0:18
+ debug q => _2; // in scope 0 at $DIR/inline-closure-captures.rs:+0:23: +0:24
+ let mut _0: (i32, T); // return place in scope 0 at $DIR/inline-closure-captures.rs:+0:34: +0:42
+ let _3: [closure@foo<T>::{closure#0}]; // in scope 0 at $DIR/inline-closure-captures.rs:+1:9: +1:10
+ let mut _4: &i32; // in scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ let mut _5: &T; // in scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ let mut _6: &[closure@foo<T>::{closure#0}]; // in scope 0 at $DIR/inline-closure-captures.rs:+2:5: +2:6
+ let mut _7: (i32,); // in scope 0 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ let mut _8: i32; // in scope 0 at $DIR/inline-closure-captures.rs:+2:7: +2:8
+ let mut _9: i32; // in scope 0 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ scope 1 {
+ debug x => _3; // in scope 1 at $DIR/inline-closure-captures.rs:+1:9: +1:10
+ scope 2 (inlined foo::<T>::{closure#0}) { // at $DIR/inline-closure-captures.rs:12:5: 12:9
+ debug _q => _9; // in scope 2 at $DIR/inline-closure-captures.rs:+1:14: +1:16
+ debug q => (*((*_6).0: &i32)); // in scope 2 at $DIR/inline-closure-captures.rs:+0:23: +0:24
+ debug t => (*((*_6).1: &T)); // in scope 2 at $DIR/inline-closure-captures.rs:+0:17: +0:18
+ let mut _10: i32; // in scope 2 at $DIR/inline-closure-captures.rs:+1:19: +1:20
+ let mut _11: T; // in scope 2 at $DIR/inline-closure-captures.rs:+1:22: +1:23
+ let mut _12: &i32; // in scope 2 at $DIR/inline-closure-captures.rs:+1:13: +1:17
+ let mut _13: &T; // in scope 2 at $DIR/inline-closure-captures.rs:+1:13: +1:17
+ }
+ }
+
+ bb0: {
+ StorageLive(_3); // scope 0 at $DIR/inline-closure-captures.rs:+1:9: +1:10
+ StorageLive(_4); // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ _4 = &_2; // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ StorageLive(_5); // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ _5 = &_1; // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ Deinit(_3); // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ (_3.0: &i32) = move _4; // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ (_3.1: &T) = move _5; // scope 0 at $DIR/inline-closure-captures.rs:+1:13: +1:24
+ StorageDead(_5); // scope 0 at $DIR/inline-closure-captures.rs:+1:16: +1:17
+ StorageDead(_4); // scope 0 at $DIR/inline-closure-captures.rs:+1:16: +1:17
+ StorageLive(_6); // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:6
+ _6 = &_3; // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:6
+ StorageLive(_7); // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ StorageLive(_8); // scope 1 at $DIR/inline-closure-captures.rs:+2:7: +2:8
+ _8 = _2; // scope 1 at $DIR/inline-closure-captures.rs:+2:7: +2:8
+ Deinit(_7); // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ (_7.0: i32) = move _8; // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ StorageLive(_9); // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ _9 = move (_7.0: i32); // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ StorageLive(_10); // scope 2 at $DIR/inline-closure-captures.rs:+1:19: +1:20
+ StorageLive(_12); // scope 2 at $DIR/inline-closure-captures.rs:+1:19: +1:20
+ _12 = deref_copy ((*_6).0: &i32); // scope 2 at $DIR/inline-closure-captures.rs:+1:19: +1:20
+ _10 = (*_12); // scope 2 at $DIR/inline-closure-captures.rs:+1:19: +1:20
+ StorageDead(_12); // scope 2 at $DIR/inline-closure-captures.rs:+1:22: +1:23
+ StorageLive(_11); // scope 2 at $DIR/inline-closure-captures.rs:+1:22: +1:23
+ StorageLive(_13); // scope 2 at $DIR/inline-closure-captures.rs:+1:22: +1:23
+ _13 = deref_copy ((*_6).1: &T); // scope 2 at $DIR/inline-closure-captures.rs:+1:22: +1:23
+ _11 = (*_13); // scope 2 at $DIR/inline-closure-captures.rs:+1:22: +1:23
+ StorageDead(_13); // scope 2 at $DIR/inline-closure-captures.rs:+1:18: +1:24
+ Deinit(_0); // scope 2 at $DIR/inline-closure-captures.rs:+1:18: +1:24
+ (_0.0: i32) = move _10; // scope 2 at $DIR/inline-closure-captures.rs:+1:18: +1:24
+ (_0.1: T) = move _11; // scope 2 at $DIR/inline-closure-captures.rs:+1:18: +1:24
+ StorageDead(_11); // scope 2 at $DIR/inline-closure-captures.rs:+1:23: +1:24
+ StorageDead(_10); // scope 2 at $DIR/inline-closure-captures.rs:+1:23: +1:24
+ StorageDead(_9); // scope 1 at $DIR/inline-closure-captures.rs:+2:5: +2:9
+ StorageDead(_8); // scope 1 at $DIR/inline-closure-captures.rs:+2:8: +2:9
+ StorageDead(_7); // scope 1 at $DIR/inline-closure-captures.rs:+2:8: +2:9
+ StorageDead(_6); // scope 1 at $DIR/inline-closure-captures.rs:+2:8: +2:9
+ StorageDead(_3); // scope 0 at $DIR/inline-closure-captures.rs:+3:1: +3:2
+ return; // scope 0 at $DIR/inline-closure-captures.rs:+3:2: +3:2
+ }
+}