rust/src/test/run-pass/vec-self-append.rs

50 lines
1.1 KiB
Rust
Raw Normal View History

use std;
import vec;
2011-08-22 17:04:28 -05:00
fn test_heap_to_heap() {
// a spills onto the heap
let mut a = [0, 1, 2, 3, 4]/~;
2011-08-22 17:04:28 -05:00
a += a;
2011-09-02 17:34:58 -05:00
assert (vec::len(a) == 10u);
assert (a[0] == 0);
assert (a[1] == 1);
assert (a[2] == 2);
assert (a[3] == 3);
assert (a[4] == 4);
assert (a[5] == 0);
assert (a[6] == 1);
assert (a[7] == 2);
assert (a[8] == 3);
assert (a[9] == 4);
2011-08-22 17:04:28 -05:00
}
fn test_stack_to_heap() {
// a is entirely on the stack
let mut a = [0, 1, 2]/~;
2011-08-22 17:04:28 -05:00
// a spills to the heap
a += a;
2011-09-02 17:34:58 -05:00
assert (vec::len(a) == 6u);
assert (a[0] == 0);
assert (a[1] == 1);
assert (a[2] == 2);
assert (a[3] == 0);
assert (a[4] == 1);
assert (a[5] == 2);
2011-08-22 17:04:28 -05:00
}
fn test_loop() {
// Make sure we properly handle repeated self-appends.
let mut a: [int]/~ = [0]/~;
let mut i = 20;
let mut expected_len = 1u;
2011-07-27 07:19:39 -05:00
while i > 0 {
log(error, vec::len(a));
2011-08-15 18:38:23 -05:00
assert (vec::len(a) == expected_len);
a += a;
i -= 1;
expected_len *= 2u;
}
}
2011-08-22 17:04:28 -05:00
2011-09-02 17:34:58 -05:00
fn main() { test_heap_to_heap(); test_stack_to_heap(); test_loop(); }