2011-06-27 13:41:16 -05:00
|
|
|
use std;
|
2011-08-15 18:38:23 -05:00
|
|
|
import std::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
|
|
|
|
let a = [0, 1, 2, 3, 4];
|
|
|
|
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 a = [0, 1, 2];
|
|
|
|
// 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.
|
2011-08-22 17:04:28 -05:00
|
|
|
let a: [int] = [0];
|
2011-07-27 07:19:39 -05:00
|
|
|
let i = 20;
|
|
|
|
let expected_len = 1u;
|
|
|
|
while i > 0 {
|
2011-08-15 18:38:23 -05:00
|
|
|
log_err vec::len(a);
|
|
|
|
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(); }
|