2018-08-30 14:18:55 +02:00
|
|
|
//@ run-pass
|
2021-12-03 15:32:51 +00:00
|
|
|
//@ needs-unwind
|
2018-08-30 14:18:55 +02:00
|
|
|
|
2016-02-11 12:34:41 +01:00
|
|
|
//@ ignore-emscripten no threads support
|
|
|
|
|
2015-01-04 17:43:24 +13:00
|
|
|
// Test that if a slicing expr[..] fails, the correct cleanups happen.
|
2014-09-18 09:33:31 +12:00
|
|
|
|
2024-08-24 06:49:09 +03:00
|
|
|
// FIXME(static_mut_refs): this could use an atomic
|
|
|
|
#![allow(static_mut_refs)]
|
2015-03-22 13:13:15 -07:00
|
|
|
|
2015-02-17 15:24:34 -08:00
|
|
|
use std::thread;
|
2014-09-18 09:33:31 +12:00
|
|
|
|
|
|
|
struct Foo;
|
|
|
|
|
2015-03-25 17:06:52 -07:00
|
|
|
static mut DTOR_COUNT: isize = 0;
|
2014-09-18 09:33:31 +12:00
|
|
|
|
|
|
|
impl Drop for Foo {
|
|
|
|
fn drop(&mut self) { unsafe { DTOR_COUNT += 1; } }
|
|
|
|
}
|
|
|
|
|
2015-03-25 17:06:52 -07:00
|
|
|
fn bar() -> usize {
|
2014-10-09 15:17:22 -04:00
|
|
|
panic!();
|
2014-09-18 09:33:31 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
fn foo() {
|
|
|
|
let x: &[_] = &[Foo, Foo];
|
2021-06-18 15:09:40 +08:00
|
|
|
let _ = &x[3..bar()];
|
2014-09-18 09:33:31 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
2015-02-17 15:24:34 -08:00
|
|
|
let _ = thread::spawn(move|| foo()).join();
|
2015-06-07 21:00:38 +03:00
|
|
|
unsafe { assert_eq!(DTOR_COUNT, 2); }
|
2014-09-18 09:33:31 +12:00
|
|
|
}
|