2011-06-27 13:41:16 -05:00
|
|
|
use std;
|
2011-12-13 18:25:51 -06:00
|
|
|
import vec;
|
2011-06-27 13:41:16 -05:00
|
|
|
|
2011-08-22 17:04:28 -05:00
|
|
|
fn test_heap_to_heap() {
|
|
|
|
// a spills onto the heap
|
2012-06-25 22:00:46 -05:00
|
|
|
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
|
2012-06-25 22:00:46 -05:00
|
|
|
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() {
|
2011-06-24 18:23:11 -05:00
|
|
|
// Make sure we properly handle repeated self-appends.
|
2012-06-25 22:00:46 -05:00
|
|
|
let mut a: [int]/~ = [0]/~;
|
2012-03-22 10:39:41 -05:00
|
|
|
let mut i = 20;
|
|
|
|
let mut expected_len = 1u;
|
2011-07-27 07:19:39 -05:00
|
|
|
while i > 0 {
|
2011-12-22 19:53:53 -06:00
|
|
|
log(error, vec::len(a));
|
2011-08-15 18:38:23 -05:00
|
|
|
assert (vec::len(a) == expected_len);
|
2011-06-24 18:23:11 -05:00
|
|
|
a += a;
|
|
|
|
i -= 1;
|
2011-06-27 13:41:16 -05:00
|
|
|
expected_len *= 2u;
|
2011-06-24 18:23:11 -05:00
|
|
|
}
|
2011-08-10 11:27:22 -05:00
|
|
|
}
|
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(); }
|