add codegen test
This commit is contained in:
parent
b6702939f7
commit
8f259ade66
69
tests/codegen/vecdeque-drain.rs
Normal file
69
tests/codegen/vecdeque-drain.rs
Normal file
@ -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);
|
||||
}
|
Loading…
Reference in New Issue
Block a user