2011-06-27 11:41:16 -07:00
|
|
|
use std;
|
2011-12-13 16:25:51 -08:00
|
|
|
import vec;
|
2011-06-27 11:41:16 -07:00
|
|
|
|
2011-08-22 15:04:28 -07:00
|
|
|
fn test_heap_to_heap() {
|
|
|
|
// a spills onto the heap
|
|
|
|
let a = [0, 1, 2, 3, 4];
|
|
|
|
a += a;
|
2011-09-02 15:34:58 -07: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 15:04:28 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_stack_to_heap() {
|
|
|
|
// a is entirely on the stack
|
|
|
|
let a = [0, 1, 2];
|
|
|
|
// a spills to the heap
|
|
|
|
a += a;
|
2011-09-02 15:34:58 -07: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 15:04:28 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_loop() {
|
2011-06-24 16:23:11 -07:00
|
|
|
// Make sure we properly handle repeated self-appends.
|
2011-08-22 15:04:28 -07:00
|
|
|
let a: [int] = [0];
|
2011-07-27 14:19:39 +02:00
|
|
|
let i = 20;
|
|
|
|
let expected_len = 1u;
|
|
|
|
while i > 0 {
|
2011-08-15 16:38:23 -07:00
|
|
|
log_err vec::len(a);
|
|
|
|
assert (vec::len(a) == expected_len);
|
2011-06-24 16:23:11 -07:00
|
|
|
a += a;
|
|
|
|
i -= 1;
|
2011-06-27 11:41:16 -07:00
|
|
|
expected_len *= 2u;
|
2011-06-24 16:23:11 -07:00
|
|
|
}
|
2011-08-10 09:27:22 -07:00
|
|
|
}
|
2011-08-22 15:04:28 -07:00
|
|
|
|
2011-09-02 15:34:58 -07:00
|
|
|
fn main() { test_heap_to_heap(); test_stack_to_heap(); test_loop(); }
|