diff options
| author | Lukas Markeffsky <@> | 2023-11-23 23:11:22 +0100 |
|---|---|---|
| committer | Lukas Markeffsky <@> | 2024-02-16 13:11:05 +0100 |
| commit | 8f259ade66fa051b7918412a83f2fb8ef3ded92f (patch) | |
| tree | 2afc3e93c84938e3a9dab10731abbfce70861e57 | |
| parent | b6702939f72c6c55a74fc5f343d34c01e3d8521b (diff) | |
| download | rust-8f259ade66fa051b7918412a83f2fb8ef3ded92f.tar.gz rust-8f259ade66fa051b7918412a83f2fb8ef3ded92f.zip | |
add codegen test
| -rw-r--r-- | tests/codegen/vecdeque-drain.rs | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/tests/codegen/vecdeque-drain.rs b/tests/codegen/vecdeque-drain.rs new file mode 100644 index 00000000000..f8263c69572 --- /dev/null +++ b/tests/codegen/vecdeque-drain.rs @@ -0,0 +1,69 @@ +// Check that draining at the front or back doesn't copy memory. + +// compile-flags: -O +// ignore-debug: the debug assertions get in the way + +#![crate_type = "lib"] + +use std::collections::VecDeque; + +// CHECK-LABEL: @clear +// CHECK-NOT: call +// CHECK-NOT: br +// CHECK: getelementptr inbounds +// CHECK-NEXT: {{call void @llvm.memset|store}} +// CHECK-NEXT: ret void +#[no_mangle] +pub fn clear(v: &mut VecDeque<i32>) { + v.drain(..); +} + +// CHECK-LABEL: @truncate +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK-NOT: br +// CHECK: ret void +#[no_mangle] +pub fn truncate(v: &mut VecDeque<i32>, n: usize) { + if n < v.len() { + v.drain(n..); + } +} + +// CHECK-LABEL: @advance +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK: br +// CHECK-NOT: call +// CHECK-NOT: br +// CHECK: ret void +#[no_mangle] +pub fn advance(v: &mut VecDeque<i32>, n: usize) { + if n < v.len() { + v.drain(..n); + } else { + v.clear(); + } +} + +// CHECK-LABEL: @remove +// CHECK: call +// CHECK: ret void +#[no_mangle] +pub fn remove(v: &mut VecDeque<i32>, a: usize, b: usize) { + v.drain(a..b); +} |
