blob: e661a4f6adc53c5b195eab31f5bcba7bb6ed2ab3 [file] [log] [blame] [edit]
//! On Windows the GetExitCodeProcess API is used to get the exit code of a
//! process, but it's easy to mistake a process exiting with the code 259 as
//! "still running" because this is the value of the STILL_ACTIVE constant. Make
//! sure we handle this case in the standard library and correctly report the
//! status.
//!
//! Note that this is disabled on unix as processes exiting with 259 will have
//! their exit status truncated to 3 (only the lower 8 bits are used).
//@ run-pass
#[cfg(windows)]
fn main() {
use std::env;
use std::process::{self, Command};
if env::args().len() == 1 {
let status = Command::new(env::current_exe().unwrap()).arg("foo").status().unwrap();
assert_eq!(status.code(), Some(259));
} else {
process::exit(259);
}
}
#[cfg(not(windows))]
fn main() {}