// Copyright 2012 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. #[macro_escape]; #[doc(hidden)]; macro_rules! rterrln ( ($( $arg:expr),+) => ( { ::rt::util::dumb_println(fmt!( $($arg),+ )); } ) ) // Some basic logging. Enabled by passing `--cfg rtdebug` to the libstd build. macro_rules! rtdebug ( ($( $arg:expr),+) => ( { if cfg!(rtdebug) { rterrln!( $($arg),+ ) } }) ) macro_rules! rtassert ( ( $arg:expr ) => ( { if ::rt::util::ENFORCE_SANITY { if !$arg { rtabort!("assertion failed: %s", stringify!($arg)); } } } ) ) macro_rules! rtabort( ($( $msg:expr),+) => ( { ::rt::util::abort(fmt!($($msg),+)); } ) ) macro_rules! assert_once_ever( ($( $msg:expr),+) => ( { // FIXME(#8472) extra function should not be needed to hide unsafe fn assert_once_ever() { unsafe { static mut already_happened: int = 0; // Double-check lock to avoid a swap in the common case. if already_happened != 0 || ::unstable::intrinsics::atomic_xchg_relaxed(&mut already_happened, 1) != 0 { fail!(fmt!("assert_once_ever happened twice: %s", fmt!($($msg),+))); } } } assert_once_ever(); } ) ) #[cfg(test)] mod tests { #[test] fn test_assert_once_ever_ok() { assert_once_ever!("help i'm stuck in an"); assert_once_ever!("assertion error message"); } #[test] #[ignore(cfg(windows))] #[should_fail] fn test_assert_once_ever_fail() { use task; fn f() { assert_once_ever!("if you're seeing this... good!") } // linked & watched, naturally task::spawn(f); task::spawn(f); } }