fix_uv_fs_mkdir_for_invalid_names.patch 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
  2. From: Bartosz Sosnowski <[email protected]>
  3. Date: Thu, 11 Jul 2019 12:45:38 +0200
  4. Subject: win, fs: mkdir return UV_EINVAL for invalid names
  5. MIME-Version: 1.0
  6. Content-Type: text/plain; charset=UTF-8
  7. Content-Transfer-Encoding: 8bit
  8. Makes uv_fs_mkdir return UV_EINVAL for invalid filenames instead of
  9. UV_ENOENT.
  10. Ref: https://github.com/nodejs/node/issues/28599
  11. PR-URL: https://github.com/libuv/libuv/pull/2375
  12. Reviewed-By: Anna Henningsen <[email protected]>
  13. Reviewed-By: Saúl Ibarra Corretgé <[email protected]>
  14. Reviewed-By: Colin Ihrig <[email protected]>
  15. diff --git a/deps/uv/src/win/fs.c b/deps/uv/src/win/fs.c
  16. index 9e2f084c8d0e9c0cc60cf5010bdc396bf5eb22e5..088191320cc671a8bc6ae45f07b3b05f95b01b08 100644
  17. --- a/deps/uv/src/win/fs.c
  18. +++ b/deps/uv/src/win/fs.c
  19. @@ -850,8 +850,13 @@ void fs__unlink(uv_fs_t* req) {
  20. void fs__mkdir(uv_fs_t* req) {
  21. /* TODO: use req->mode. */
  22. - int result = _wmkdir(req->file.pathw);
  23. - SET_REQ_RESULT(req, result);
  24. + req->result = _wmkdir(req->file.pathw);
  25. + if (req->result == -1) {
  26. + req->sys_errno_ = _doserrno;
  27. + req->result = req->sys_errno_ == ERROR_INVALID_NAME
  28. + ? UV_EINVAL
  29. + : uv_translate_sys_error(req->sys_errno_);
  30. + }
  31. }
  32. diff --git a/deps/uv/test/test-fs.c b/deps/uv/test/test-fs.c
  33. index c3153c717b7cd391f71b6184d62e4ee55841591b..fb64ae6b037be591a30a63d9e5450dcfd48e3bdc 100644
  34. --- a/deps/uv/test/test-fs.c
  35. +++ b/deps/uv/test/test-fs.c
  36. @@ -3815,4 +3815,16 @@ TEST_IMPL(fs_fchmod_archive_readonly) {
  37. return 0;
  38. }
  39. +
  40. +TEST_IMPL(fs_invalid_mkdir_name) {
  41. + uv_loop_t* loop;
  42. + uv_fs_t req;
  43. + int r;
  44. +
  45. + loop = uv_default_loop();
  46. + r = uv_fs_mkdir(loop, &req, "invalid>", 0, NULL);
  47. + ASSERT(r == UV_EINVAL);
  48. +
  49. + return 0;
  50. +}
  51. #endif
  52. diff --git a/deps/uv/test/test-list.h b/deps/uv/test/test-list.h
  53. index 8886b07c8a74736208d5614257f832f59d79633a..29e9cbf85df3f07dd3a017ffca1cea0b56e76b89 100644
  54. --- a/deps/uv/test/test-list.h
  55. +++ b/deps/uv/test/test-list.h
  56. @@ -372,6 +372,7 @@ TEST_DECLARE (fs_exclusive_sharing_mode)
  57. TEST_DECLARE (fs_file_flag_no_buffering)
  58. TEST_DECLARE (fs_open_readonly_acl)
  59. TEST_DECLARE (fs_fchmod_archive_readonly)
  60. +TEST_DECLARE (fs_invalid_mkdir_name)
  61. #endif
  62. TEST_DECLARE (strscpy)
  63. TEST_DECLARE (threadpool_queue_work_simple)
  64. @@ -957,6 +958,7 @@ TASK_LIST_START
  65. TEST_ENTRY (fs_file_flag_no_buffering)
  66. TEST_ENTRY (fs_open_readonly_acl)
  67. TEST_ENTRY (fs_fchmod_archive_readonly)
  68. + TEST_ENTRY (fs_invalid_mkdir_name)
  69. #endif
  70. TEST_ENTRY (get_osfhandle_valid_handle)
  71. TEST_ENTRY (open_osfhandle_valid_handle)