2019-07-26 16:54:25 -05:00
|
|
|
// run-pass
|
2015-10-29 15:45:56 -05:00
|
|
|
// 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).
|
|
|
|
|
2018-01-02 07:11:41 -06:00
|
|
|
#[cfg(windows)]
|
2015-10-29 15:45:56 -05:00
|
|
|
fn main() {
|
2018-01-02 07:11:41 -06:00
|
|
|
use std::process::{self, Command};
|
|
|
|
use std::env;
|
2015-10-29 15:45:56 -05:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
2018-01-02 07:11:41 -06:00
|
|
|
|
|
|
|
#[cfg(not(windows))]
|
|
|
|
fn main() {}
|