From 698f8c2f01ea549d77d7dc3338a12e04c11057b9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:02:58 +0200 Subject: Adding upstream version 1.64.0+dfsg1. Signed-off-by: Daniel Baumann --- src/test/ui/weird-exit-code.rs | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 src/test/ui/weird-exit-code.rs (limited to 'src/test/ui/weird-exit-code.rs') diff --git a/src/test/ui/weird-exit-code.rs b/src/test/ui/weird-exit-code.rs new file mode 100644 index 000000000..a067b7b5b --- /dev/null +++ b/src/test/ui/weird-exit-code.rs @@ -0,0 +1,28 @@ +// run-pass +// 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). + +#[cfg(windows)] +fn main() { + use std::process::{self, Command}; + use std::env; + + 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() {} -- cgit v1.2.3