2012-02-14 00:43:45 -08:00
|
|
|
// error-pattern:explicit failure
|
|
|
|
// Testing that runtime failure doesn't cause callbacks to abort abnormally.
|
|
|
|
// Instead the failure will be delivered after the callbacks return.
|
|
|
|
|
2012-07-03 16:11:00 -07:00
|
|
|
extern mod rustrt {
|
2012-02-14 00:43:45 -08:00
|
|
|
fn rust_dbg_call(cb: *u8,
|
2012-03-12 20:04:27 -07:00
|
|
|
data: libc::uintptr_t) -> libc::uintptr_t;
|
2012-02-14 00:43:45 -08:00
|
|
|
}
|
|
|
|
|
2012-07-03 16:32:02 -07:00
|
|
|
extern fn cb(data: libc::uintptr_t) -> libc::uintptr_t {
|
2012-02-14 00:43:45 -08:00
|
|
|
if data == 1u {
|
|
|
|
data
|
|
|
|
} else {
|
|
|
|
count(data - 1u) + count(data - 1u)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn count(n: uint) -> uint {
|
|
|
|
task::yield();
|
|
|
|
rustrt::rust_dbg_call(cb, n)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
2012-07-04 15:04:28 -04:00
|
|
|
for iter::repeat(10u) {
|
|
|
|
do task::spawn {
|
2012-02-14 00:43:45 -08:00
|
|
|
let result = count(5u);
|
|
|
|
#debug("result = %?", result);
|
|
|
|
fail;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|