1
0
mirror of https://github.com/libuv/libuv synced 2025-03-28 21:13:16 +00:00

process: make the 'status' parameter for exit_cb an int64_t

This means we no longer have to strip the high bit from the process exit
code on Windows, which is problematic because an unhandled SEH exception
can make a process exit with a status code that has the high bit set.
This commit is contained in:
Bert Belder 2013-08-22 18:30:10 +02:00
parent ed82eae13a
commit 66ae0ff562
6 changed files with 21 additions and 14 deletions

View File

@ -384,7 +384,7 @@ typedef void (*uv_async_cb)(uv_async_t* handle, int status);
typedef void (*uv_prepare_cb)(uv_prepare_t* handle, int status);
typedef void (*uv_check_cb)(uv_check_t* handle, int status);
typedef void (*uv_idle_cb)(uv_idle_t* handle, int status);
typedef void (*uv_exit_cb)(uv_process_t*, int exit_status, int term_signal);
typedef void (*uv_exit_cb)(uv_process_t*, int64_t exit_status, int term_signal);
typedef void (*uv_walk_cb)(uv_handle_t* handle, void* arg);
typedef void (*uv_fs_cb)(uv_fs_t* req);
typedef void (*uv_work_cb)(uv_work_t* req);

View File

@ -758,9 +758,6 @@ void uv_process_proc_exit(uv_loop_t* loop, uv_process_t* handle) {
} else if (!GetExitCodeProcess(handle->process_handle, &status)) {
/* Unable to to obtain the exit code. This should never happen. */
exit_code = uv_translate_sys_error(GetLastError());
} else {
/* Make sure the exit code is >= 0. */
exit_code = status & INT_MAX;
}
/* Fire the exit callback. */

View File

@ -64,7 +64,9 @@ static void process_close_cb(uv_handle_t* handle) {
}
static void exit_cb(uv_process_t* process, int exit_status, int term_signal) {
static void exit_cb(uv_process_t* process,
int64_t exit_status,
int term_signal) {
ASSERT(exit_status == 42);
ASSERT(term_signal == 0);
uv_close((uv_handle_t*)process, process_close_cb);

View File

@ -84,7 +84,9 @@ static void on_connection(uv_stream_t* server, int status) {
}
static void exit_cb(uv_process_t* process, int exit_status, int term_signal) {
static void exit_cb(uv_process_t* process,
int64_t exit_status,
int term_signal) {
printf("exit_cb\n");
exit_cb_called++;
ASSERT(exit_status == 0);

View File

@ -52,7 +52,9 @@ static void close_cb(uv_handle_t* handle) {
}
static void exit_cb(uv_process_t* process, int exit_status, int term_signal) {
static void exit_cb(uv_process_t* process,
int64_t exit_status,
int term_signal) {
printf("exit_cb\n");
exit_cb_called++;
ASSERT(exit_status == 1);
@ -62,7 +64,7 @@ static void exit_cb(uv_process_t* process, int exit_status, int term_signal) {
static void expect(uv_process_t* process,
int exit_status,
int64_t exit_status,
int term_signal,
int err) {
printf("exit_cb\n");
@ -74,20 +76,22 @@ static void expect(uv_process_t* process,
static void exit_cb_expect_enoent(uv_process_t* process,
int exit_status,
int64_t exit_status,
int term_signal) {
expect(process, exit_status, term_signal, UV_ENOENT);
}
static void exit_cb_expect_eperm(uv_process_t* process,
int exit_status,
int64_t exit_status,
int term_signal) {
expect(process, exit_status, term_signal, UV_EPERM);
}
static void kill_cb(uv_process_t* process, int exit_status, int term_signal) {
static void kill_cb(uv_process_t* process,
int64_t exit_status,
int term_signal) {
int err;
printf("exit_cb\n");
@ -109,7 +113,7 @@ static void kill_cb(uv_process_t* process, int exit_status, int term_signal) {
ASSERT(err == UV_ESRCH);
}
static void detach_failure_cb(uv_process_t* process, int exit_status, int term_signal) {
static void detach_failure_cb(uv_process_t* process, int64_t exit_status, int term_signal) {
printf("detach_cb\n");
exit_cb_called++;
}
@ -886,7 +890,7 @@ TEST_IMPL(spawn_setgid_fails) {
#ifdef _WIN32
static void exit_cb_unexpected(uv_process_t* process,
int exit_status,
int64_t exit_status,
int term_signal) {
ASSERT(0 && "should not have been called");
}

View File

@ -48,7 +48,9 @@ static void close_cb(uv_handle_t* handle) {
}
static void exit_cb(uv_process_t* process, int exit_status, int term_signal) {
static void exit_cb(uv_process_t* process,
int64_t exit_status,
int term_signal) {
printf("exit_cb\n");
exit_cb_called++;
ASSERT(exit_status == 0);