//@ run-pass //@ needs-unwind //@ ignore-emscripten no threads support // Test that if a slicing expr[..] fails, the correct cleanups happen. // FIXME(static_mut_refs): this could use an atomic #![allow(static_mut_refs)] use std::thread; struct Foo; static mut DTOR_COUNT: isize = 0; impl Drop for Foo { fn drop(&mut self) { unsafe { DTOR_COUNT += 1; } } } fn bar() -> usize { panic!(); } fn foo() { let x: &[_] = &[Foo, Foo]; let _ = &x[3..bar()]; } fn main() { let _ = thread::spawn(move|| foo()).join(); unsafe { assert_eq!(DTOR_COUNT, 2); } }