From 473dafc59354a5284f49efd63d2cdb22f9e989da Mon Sep 17 00:00:00 2001 From: Santiago Gimeno Date: Thu, 3 Oct 2024 18:53:39 +0200 Subject: [PATCH] win: fix WriteFile() error translation (#4562) Translate `ERROR_BROKEN_PIPE` and `ERROR_NO_DATA` to `UV_EPIPE` instead of their default translation, which will be used for the rest of cases. Refs: https://github.com/libuv/libuv/issues/4548#issuecomment-2383998849 --- src/win/error.c | 9 +++++++++ src/win/fs.c | 2 +- src/win/internal.h | 2 ++ src/win/stream.c | 4 ++-- 4 files changed, 14 insertions(+), 3 deletions(-) diff --git a/src/win/error.c b/src/win/error.c index 5cc264fea86..58587c5fb78 100644 --- a/src/win/error.c +++ b/src/win/error.c @@ -172,3 +172,12 @@ int uv_translate_sys_error(int sys_errno) { default: return UV_UNKNOWN; } } + +int uv_translate_write_sys_error(int sys_errno) { + switch (sys_errno) { + case ERROR_BROKEN_PIPE: return UV_EPIPE; + case ERROR_NO_DATA: return UV_EPIPE; + default: + return uv_translate_sys_error(sys_errno); + } +} diff --git a/src/win/fs.c b/src/win/fs.c index d87246e0ff3..fadefb51101 100644 --- a/src/win/fs.c +++ b/src/win/fs.c @@ -1078,7 +1078,7 @@ void fs__write(uv_fs_t* req) { error = ERROR_INVALID_FLAGS; } - SET_REQ_WIN32_ERROR(req, error); + SET_REQ_UV_ERROR(req, uv_translate_write_sys_error(error), error); } } diff --git a/src/win/internal.h b/src/win/internal.h index 867dea5e0ed..be408af6661 100644 --- a/src/win/internal.h +++ b/src/win/internal.h @@ -330,4 +330,6 @@ void uv__wake_all_loops(void); */ void uv__init_detect_system_wakeup(void); +int uv_translate_write_sys_error(int sys_errno); + #endif /* UV_WIN_INTERNAL_H_ */ diff --git a/src/win/stream.c b/src/win/stream.c index 61a82fe4e6e..a53a10b0382 100644 --- a/src/win/stream.c +++ b/src/win/stream.c @@ -131,7 +131,7 @@ int uv_write(uv_write_t* req, case UV_NAMED_PIPE: err = uv__pipe_write( loop, req, (uv_pipe_t*) handle, bufs, nbufs, NULL, cb); - break; + return uv_translate_write_sys_error(err); case UV_TTY: err = uv__tty_write(loop, req, (uv_tty_t*) handle, bufs, nbufs, cb); break; @@ -164,7 +164,7 @@ int uv_write2(uv_write_t* req, err = uv__pipe_write( loop, req, (uv_pipe_t*) handle, bufs, nbufs, send_handle, cb); - return uv_translate_sys_error(err); + return uv_translate_write_sys_error(err); }