Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
6026ec09
Commit
6026ec09
authored
May 20, 2020
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update to libuv 1.38
parent
706833bf
Changes
38
Hide whitespace changes
Inline
Side-by-side
Showing
38 changed files
with
838 additions
and
402 deletions
+838
-402
deps/README.rst
deps/README.rst
+1
-1
deps/libuv/.gitignore
deps/libuv/.gitignore
+1
-0
deps/libuv/AUTHORS
deps/libuv/AUTHORS
+8
-0
deps/libuv/CMakeLists.txt
deps/libuv/CMakeLists.txt
+59
-20
deps/libuv/ChangeLog
deps/libuv/ChangeLog
+83
-1
deps/libuv/Makefile.am
deps/libuv/Makefile.am
+2
-1
deps/libuv/configure.ac
deps/libuv/configure.ac
+11
-9
deps/libuv/include/uv.h
deps/libuv/include/uv.h
+14
-6
deps/libuv/include/uv/version.h
deps/libuv/include/uv/version.h
+1
-1
deps/libuv/src/threadpool.c
deps/libuv/src/threadpool.c
+2
-2
deps/libuv/src/timer.c
deps/libuv/src/timer.c
+1
-6
deps/libuv/src/unix/aix.c
deps/libuv/src/unix/aix.c
+1
-1
deps/libuv/src/unix/async.c
deps/libuv/src/unix/async.c
+23
-10
deps/libuv/src/unix/bsd-proctitle.c
deps/libuv/src/unix/bsd-proctitle.c
+7
-0
deps/libuv/src/unix/darwin-proctitle.c
deps/libuv/src/unix/darwin-proctitle.c
+1
-2
deps/libuv/src/unix/darwin-stub.h
deps/libuv/src/unix/darwin-stub.h
+97
-0
deps/libuv/src/unix/fs.c
deps/libuv/src/unix/fs.c
+12
-4
deps/libuv/src/unix/fsevents.c
deps/libuv/src/unix/fsevents.c
+25
-29
deps/libuv/src/unix/internal.h
deps/libuv/src/unix/internal.h
+0
-2
deps/libuv/src/unix/linux-core.c
deps/libuv/src/unix/linux-core.c
+11
-9
deps/libuv/src/unix/loop.c
deps/libuv/src/unix/loop.c
+2
-0
deps/libuv/src/unix/no-proctitle.c
deps/libuv/src/unix/no-proctitle.c
+3
-0
deps/libuv/src/unix/proctitle.c
deps/libuv/src/unix/proctitle.c
+1
-1
deps/libuv/src/unix/signal.c
deps/libuv/src/unix/signal.c
+2
-2
deps/libuv/src/unix/thread.c
deps/libuv/src/unix/thread.c
+5
-4
deps/libuv/src/unix/udp.c
deps/libuv/src/unix/udp.c
+35
-54
deps/libuv/src/uv-common.c
deps/libuv/src/uv-common.c
+46
-0
deps/libuv/src/uv-common.h
deps/libuv/src/uv-common.h
+10
-0
deps/libuv/src/win/core.c
deps/libuv/src/win/core.c
+6
-6
deps/libuv/src/win/error.c
deps/libuv/src/win/error.c
+1
-0
deps/libuv/src/win/fs-event.c
deps/libuv/src/win/fs-event.c
+26
-7
deps/libuv/src/win/fs.c
deps/libuv/src/win/fs.c
+116
-35
deps/libuv/src/win/poll.c
deps/libuv/src/win/poll.c
+62
-121
deps/libuv/src/win/signal.c
deps/libuv/src/win/signal.c
+5
-0
deps/libuv/src/win/udp.c
deps/libuv/src/win/udp.c
+8
-18
deps/libuv/src/win/util.c
deps/libuv/src/win/util.c
+142
-50
deps/libuv/src/win/winapi.h
deps/libuv/src/win/winapi.h
+7
-0
docs/changes/1621.feature
docs/changes/1621.feature
+1
-0
No files found.
deps/README.rst
View file @
6026ec09
...
@@ -76,7 +76,7 @@ Updating libuv
...
@@ -76,7 +76,7 @@ Updating libuv
rm -rf libuv/test/*.[ch] libuv/test/test.gyp # must leave the fixtures/ dir
rm -rf libuv/test/*.[ch] libuv/test/test.gyp # must leave the fixtures/ dir
rm -rf libuv/tools
rm -rf libuv/tools
rm -f libuv/android-configure*
rm -f libuv/android-configure*
rm -f libuv/uv_win_longpath.manifest
At this point there might be new files in libuv that need added to git
At this point there might be new files in libuv that need added to git
and the build process. Evaluate those and add them to git and to
and the build process. Evaluate those and add them to git and to
...
...
deps/libuv/.gitignore
View file @
6026ec09
...
@@ -67,6 +67,7 @@ ipch
...
@@ -67,6 +67,7 @@ ipch
# Clion / IntelliJ project files
# Clion / IntelliJ project files
/.idea/
/.idea/
cmake-build-debug/
*.xcodeproj
*.xcodeproj
*.xcworkspace
*.xcworkspace
...
...
deps/libuv/AUTHORS
View file @
6026ec09
...
@@ -424,3 +424,11 @@ Lin Zhang <linroid@gmail.com>
...
@@ -424,3 +424,11 @@ Lin Zhang <linroid@gmail.com>
Sk Sajidul Kadir <sheikh.sajid522@gmail.com>
Sk Sajidul Kadir <sheikh.sajid522@gmail.com>
twosee <twose@qq.com>
twosee <twose@qq.com>
Rikard Falkeborn <rikard.falkeborn@gmail.com>
Rikard Falkeborn <rikard.falkeborn@gmail.com>
Yash Ladha <yashladhapankajladha123@gmail.com>
James Ross <git@james-ross.co.uk>
Colin Finck <colin@reactos.org>
Shohei YOSHIDA <syohex@gmail.com>
Philip Chimento <philip.chimento@gmail.com>
Michal Artazov <michal@artazov.cz>
Jeroen Roovers <jer@gentoo.org>
MasterDuke17 <MasterDuke17@users.noreply.github.com>
deps/libuv/CMakeLists.txt
View file @
6026ec09
...
@@ -24,6 +24,12 @@ cmake_dependent_option(LIBUV_BUILD_BENCH
...
@@ -24,6 +24,12 @@ cmake_dependent_option(LIBUV_BUILD_BENCH
"Build the benchmarks when building unit tests and we are the root project"
ON
"Build the benchmarks when building unit tests and we are the root project"
ON
"LIBUV_BUILD_TESTS"
OFF
)
"LIBUV_BUILD_TESTS"
OFF
)
# Qemu Build
option
(
QEMU
"build for qemu"
OFF
)
if
(
QEMU
)
add_definitions
(
-D__QEMU__=1
)
endif
()
# Compiler check
# Compiler check
string
(
CONCAT is-msvc $<OR:
string
(
CONCAT is-msvc $<OR:
$<C_COMPILER_ID:MSVC>,
$<C_COMPILER_ID:MSVC>,
...
@@ -31,6 +37,18 @@ string(CONCAT is-msvc $<OR:
...
@@ -31,6 +37,18 @@ string(CONCAT is-msvc $<OR:
>
)
>
)
check_c_compiler_flag
(
/W4 UV_LINT_W4
)
check_c_compiler_flag
(
/W4 UV_LINT_W4
)
check_c_compiler_flag
(
/wd4100 UV_LINT_NO_UNUSED_PARAMETER_MSVC
)
check_c_compiler_flag
(
/wd4127 UV_LINT_NO_CONDITIONAL_CONSTANT_MSVC
)
check_c_compiler_flag
(
/wd4201 UV_LINT_NO_NONSTANDARD_MSVC
)
check_c_compiler_flag
(
/wd4206 UV_LINT_NO_NONSTANDARD_EMPTY_TU_MSVC
)
check_c_compiler_flag
(
/wd4210 UV_LINT_NO_NONSTANDARD_FILE_SCOPE_MSVC
)
check_c_compiler_flag
(
/wd4232 UV_LINT_NO_NONSTANDARD_NONSTATIC_DLIMPORT_MSVC
)
check_c_compiler_flag
(
/wd4456 UV_LINT_NO_HIDES_LOCAL
)
check_c_compiler_flag
(
/wd4457 UV_LINT_NO_HIDES_PARAM
)
check_c_compiler_flag
(
/wd4459 UV_LINT_NO_HIDES_GLOBAL
)
check_c_compiler_flag
(
/wd4706 UV_LINT_NO_CONDITIONAL_ASSIGNMENT_MSVC
)
check_c_compiler_flag
(
/wd4996 UV_LINT_NO_UNSAFE_MSVC
)
check_c_compiler_flag
(
-Wall UV_LINT_WALL
)
# DO NOT use this under MSVC
check_c_compiler_flag
(
-Wall UV_LINT_WALL
)
# DO NOT use this under MSVC
# TODO: Place these into its own function
# TODO: Place these into its own function
...
@@ -38,10 +56,21 @@ check_c_compiler_flag(-Wno-unused-parameter UV_LINT_NO_UNUSED_PARAMETER)
...
@@ -38,10 +56,21 @@ check_c_compiler_flag(-Wno-unused-parameter UV_LINT_NO_UNUSED_PARAMETER)
check_c_compiler_flag
(
-Wstrict-prototypes UV_LINT_STRICT_PROTOTYPES
)
check_c_compiler_flag
(
-Wstrict-prototypes UV_LINT_STRICT_PROTOTYPES
)
check_c_compiler_flag
(
-Wextra UV_LINT_EXTRA
)
check_c_compiler_flag
(
-Wextra UV_LINT_EXTRA
)
set
(
lint-no-unused-parameter $<$<BOOL:
${
UV_LINT_NO_UNUSED_PARAMETER
}
>:-Wno-unused-parameter>
)
set
(
lint-no-unused-parameter $<$<BOOL:
${
UV_LINT_NO_UNUSED_PARAMETER
}
>:-Wno-unused-parameter>
)
set
(
lint-strict-prototypes $<$<BOOL:
${
UV_LINT_STRICT_PROTOTYPES
}
>:-Wstrict-prototypes>
)
set
(
lint-strict-prototypes $<$<BOOL:
${
UV_LINT_STRICT_PROTOTYPES
}
>:-Wstrict-prototypes>
)
set
(
lint-extra $<$<BOOL:
${
UV_LINT_EXTRA
}
>:-Wextra>
)
set
(
lint-extra $<$<BOOL:
${
UV_LINT_EXTRA
}
>:-Wextra>
)
set
(
lint-w4 $<$<BOOL:
${
UV_LINT_W4
}
>:/W4>
)
set
(
lint-w4 $<$<BOOL:
${
UV_LINT_W4
}
>:/W4>
)
set
(
lint-no-unused-parameter-msvc $<$<BOOL:
${
UV_LINT_NO_UNUSED_PARAMETER_MSVC
}
>:/wd4100>
)
set
(
lint-no-conditional-constant-msvc $<$<BOOL:
${
UV_LINT_NO_CONDITIONAL_CONSTANT_MSVC
}
>:/wd4127>
)
set
(
lint-no-nonstandard-msvc $<$<BOOL:
${
UV_LINT_NO_NONSTANDARD_MSVC
}
>:/wd4201>
)
set
(
lint-no-nonstandard-empty-tu-msvc $<$<BOOL:
${
UV_LINT_NO_NONSTANDARD_EMPTY_TU_MSVC
}
>:/wd4206>
)
set
(
lint-no-nonstandard-file-scope-msvc $<$<BOOL:
${
UV_LINT_NO_NONSTANDARD_FILE_SCOPE_MSVC
}
>:/wd4210>
)
set
(
lint-no-nonstandard-nonstatic-dlimport-msvc $<$<BOOL:
${
UV_LINT_NO_NONSTANDARD_NONSTATIC_DLIMPORT_MSVC
}
>:/wd4232>
)
set
(
lint-no-hides-local-msvc $<$<BOOL:
${
UV_LINT_NO_HIDES_LOCAL
}
>:/wd4456>
)
set
(
lint-no-hides-param-msvc $<$<BOOL:
${
UV_LINT_NO_HIDES_PARAM
}
>:/wd4457>
)
set
(
lint-no-hides-global-msvc $<$<BOOL:
${
UV_LINT_NO_HIDES_GLOBAL
}
>:/wd4459>
)
set
(
lint-no-conditional-assignment-msvc $<$<BOOL:
${
UV_LINT_NO_CONDITIONAL_ASSIGNMENT_MSVC
}
>:/wd4706>
)
set
(
lint-no-unsafe-msvc $<$<BOOL:
${
UV_LINT_NO_UNSAFE_MSVC
}
>:/wd4996>
)
# Unfortunately, this one is complicated because MSVC and clang-cl support -Wall
# Unfortunately, this one is complicated because MSVC and clang-cl support -Wall
# but using it is like calling -Weverything
# but using it is like calling -Weverything
string
(
CONCAT lint-default $<
string
(
CONCAT lint-default $<
...
@@ -50,6 +79,17 @@ string(CONCAT lint-default $<
...
@@ -50,6 +79,17 @@ string(CONCAT lint-default $<
list
(
APPEND uv_cflags
${
lint-strict-prototypes
}
${
lint-extra
}
${
lint-default
}
${
lint-w4
}
)
list
(
APPEND uv_cflags
${
lint-strict-prototypes
}
${
lint-extra
}
${
lint-default
}
${
lint-w4
}
)
list
(
APPEND uv_cflags
${
lint-no-unused-parameter
}
)
list
(
APPEND uv_cflags
${
lint-no-unused-parameter
}
)
list
(
APPEND uv_cflags
${
lint-no-unused-parameter-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-conditional-constant-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-nonstandard-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-nonstandard-empty-tu-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-nonstandard-file-scope-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-nonstandard-nonstatic-dlimport-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-hides-local-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-hides-param-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-hides-global-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-conditional-assignment-msvc
}
)
list
(
APPEND uv_cflags
${
lint-no-unsafe-msvc
}
)
set
(
uv_sources
set
(
uv_sources
src/fs-poll.c
src/fs-poll.c
...
@@ -64,22 +104,9 @@ set(uv_sources
...
@@ -64,22 +104,9 @@ set(uv_sources
src/version.c
)
src/version.c
)
if
(
WIN32
)
if
(
WIN32
)
if
(
CMAKE_SYSTEM_VERSION VERSION_GREATER 10
)
# Windows 10
list
(
APPEND uv_defines WIN32_LEAN_AND_MEAN _WIN32_WINNT=0x0600
)
set
(
windows-version 0x0A00
)
elseif
(
CMAKE_SYSTEM_VERSION VERSION_GREATER 6.3
)
# Windows 8.1
set
(
windows-version 0x0603
)
elseif
(
CMAKE_SYSTEM_VERSION VERSION_GREATER 6.2
)
# Windows 8
set
(
windows-version 0x0602
)
elseif
(
CMAKE_SYSTEM_VERSION VERSION_GREATER 6.1
)
# Windows 7
set
(
windows-version 0x0601
)
elseif
(
CMAKE_SYSTEM_VERSION VERSION_GREATER 6.0
)
# Windows Vista
set
(
windows-version 0x0600
)
else
()
message
(
FATAL_ERROR
"Windows Vista is the minimum version supported"
)
endif
()
list
(
APPEND uv_defines WIN32_LEAN_AND_MEAN _WIN32_WINNT=
${
windows-version
}
)
list
(
APPEND uv_libraries
list
(
APPEND uv_libraries
$<$<STREQUAL:
${
windows-version
}
,0x0600>:psapi>
psapi
iphlpapi
iphlpapi
userenv
userenv
ws2_32
)
ws2_32
)
...
@@ -155,7 +182,7 @@ if(CMAKE_SYSTEM_NAME STREQUAL "AIX")
...
@@ -155,7 +182,7 @@ if(CMAKE_SYSTEM_NAME STREQUAL "AIX")
endif
()
endif
()
if
(
CMAKE_SYSTEM_NAME STREQUAL
"Android"
)
if
(
CMAKE_SYSTEM_NAME STREQUAL
"Android"
)
list
(
APPEND uv_libs dl
)
list
(
APPEND uv_lib
rarie
s dl
)
list
(
APPEND uv_sources
list
(
APPEND uv_sources
src/unix/android-ifaddrs.c
src/unix/android-ifaddrs.c
src/unix/linux-core.c
src/unix/linux-core.c
...
@@ -489,7 +516,7 @@ if(LIBUV_BUILD_TESTS)
...
@@ -489,7 +516,7 @@ if(LIBUV_BUILD_TESTS)
test/test-walk-handles.c
test/test-walk-handles.c
test/test-watcher-cross-stop.c
)
test/test-watcher-cross-stop.c
)
add_executable
(
uv_run_tests
${
uv_test_sources
}
)
add_executable
(
uv_run_tests
${
uv_test_sources
}
uv_win_longpath.manifest
)
target_compile_definitions
(
uv_run_tests
target_compile_definitions
(
uv_run_tests
PRIVATE
${
uv_defines
}
USING_UV_SHARED=1
)
PRIVATE
${
uv_defines
}
USING_UV_SHARED=1
)
target_compile_options
(
uv_run_tests PRIVATE
${
uv_cflags
}
)
target_compile_options
(
uv_run_tests PRIVATE
${
uv_cflags
}
)
...
@@ -501,10 +528,14 @@ if(LIBUV_BUILD_TESTS)
...
@@ -501,10 +528,14 @@ if(LIBUV_BUILD_TESTS)
set_tests_properties
(
uv_test PROPERTIES ENVIRONMENT
set_tests_properties
(
uv_test PROPERTIES ENVIRONMENT
"LIBPATH=
${
CMAKE_BINARY_DIR
}
:$ENV{LIBPATH}"
)
"LIBPATH=
${
CMAKE_BINARY_DIR
}
:$ENV{LIBPATH}"
)
endif
()
endif
()
add_executable
(
uv_run_tests_a
${
uv_test_sources
}
)
add_executable
(
uv_run_tests_a
${
uv_test_sources
}
uv_win_longpath.manifest
)
target_compile_definitions
(
uv_run_tests_a PRIVATE
${
uv_defines
}
)
target_compile_definitions
(
uv_run_tests_a PRIVATE
${
uv_defines
}
)
target_compile_options
(
uv_run_tests_a PRIVATE
${
uv_cflags
}
)
target_compile_options
(
uv_run_tests_a PRIVATE
${
uv_cflags
}
)
target_link_libraries
(
uv_run_tests_a uv_a
${
uv_test_libraries
}
)
if
(
QEMU
)
target_link_libraries
(
uv_run_tests_a uv_a
${
uv_test_libraries
}
-static
)
else
()
target_link_libraries
(
uv_run_tests_a uv_a
${
uv_test_libraries
}
)
endif
()
add_test
(
NAME uv_test_a
add_test
(
NAME uv_test_a
COMMAND uv_run_tests_a
COMMAND uv_run_tests_a
WORKING_DIRECTORY
${
CMAKE_CURRENT_SOURCE_DIR
}
)
WORKING_DIRECTORY
${
CMAKE_CURRENT_SOURCE_DIR
}
)
...
@@ -544,3 +575,11 @@ if(WIN32)
...
@@ -544,3 +575,11 @@ if(WIN32)
RUNTIME DESTINATION lib/$<CONFIG>
RUNTIME DESTINATION lib/$<CONFIG>
ARCHIVE DESTINATION lib/$<CONFIG>
)
ARCHIVE DESTINATION lib/$<CONFIG>
)
endif
()
endif
()
message
(
STATUS
"summary of build options:
Install prefix:
${
CMAKE_INSTALL_PREFIX
}
Target system:
${
CMAKE_SYSTEM_NAME
}
Compiler:
C compiler:
${
CMAKE_C_COMPILER
}
CFLAGS:
${
CMAKE_C_FLAGS_
${
_build_type
}}
${
CMAKE_C_FLAGS
}
"
)
deps/libuv/ChangeLog
View file @
6026ec09
2020.04.16, Version 1.36.0 (Stable)
2020.05.18, Version 1.38.0 (Stable)
Changes since version 1.37.0:
* test: skip poll_duplex and poll_unidirectional on PASE (Xu Meng)
* linux: make cpu_times consistently be milliseconds (James Ross)
* win: DRY uv_poll_start() and uv_poll_stop() (Ben Noordhuis)
* win: DRY uv_poll_close() (Ben Noordhuis)
* unix,win: add uv_library_shutdown() (Ben Noordhuis)
* unix: yield cpu when spinlocking on async handle (Ben Noordhuis)
* win: remove dep on GetQueuedCompletionStatusEx (Colin Finck)
* doc: correct source lines (Shohei YOSHIDA)
* build,android: fix typo (twosee)
* doc: uv_cancel() handles uv_random_t requests (Philip Chimento)
* doc: fix unescaped character (Philip Chimento)
* build,cmake: fix compilation on old MinGW (erw7)
* build: remove unnessesary MSVC warnings (Bartosz Sosnowski)
* win: make uv_udp_init_ex() accept UV_UDP_RECVMMSG (Ben Noordhuis)
* unix: simplify uv__udp_init_ex() (Ben Noordhuis)
* win: remove MAX_PATH limitations (Bartosz Sosnowski)
* build, win: add long path aware manifest (Bartosz Sosnowski)
* doc: check/idle/prepare functions always succeed (Ben Noordhuis)
* darwin: fix build with non-apple compilers (Ben Noordhuis)
* win: support environment variables > 32767 chars (Ben Noordhuis)
* unix: fully initialize struct msghdr (Ben Noordhuis)
* doc: add uv_replace_allocator thread safety warning (twosee)
* unix: fix int overflow when copying large files (Michal Artazov)
* fs: report original error (Bartosz Sosnowski)
* win, fs: add IO_REPARSE_TAG_APPEXECLINK support (Bartosz Sosnowski)
* doc: fix formatting (Ben Noordhuis)
* unix: fix memory leak when uv_loop_init() fails (Anna Henningsen)
* unix: shrink uv_udp_set_source_membership() stack (Ben Noordhuis)
* unix,win: fix wrong sizeof argument to memcpy() (Ben Noordhuis)
* build: check for libraries not provided by libc (Jeroen Roovers)
* doc: fix the order of arguments to calloc() (MasterDuke17)
* unix: don't abort when getrlimit() fails (Ben Noordhuis)
* test: support common user profile on IBMi (Xu Meng)
* build: test on more platforms via QEMU in CI (gengjiawen)
2020.04.20, Version 1.37.0 (Stable), 02a9e1be252b623ee032a3137c0b0c94afbe6809
Changes since version 1.36.0:
* timer: remove redundant check in heap compare (Yash Ladha)
* udp: add flag to enable recvmmsg(2) explicitly (Saúl Ibarra Corretgé)
2020.04.16, Version 1.36.0 (Stable), 533b738838ad8407032e14b6772b29ef9af63cfa
Changes since version 1.35.0:
Changes since version 1.35.0:
...
...
deps/libuv/Makefile.am
View file @
6026ec09
...
@@ -409,8 +409,9 @@ uvinclude_HEADERS += include/uv/darwin.h
...
@@ -409,8 +409,9 @@ uvinclude_HEADERS += include/uv/darwin.h
libuv_la_CFLAGS
+=
-D_DARWIN_USE_64_BIT_INODE
=
1
libuv_la_CFLAGS
+=
-D_DARWIN_USE_64_BIT_INODE
=
1
libuv_la_CFLAGS
+=
-D_DARWIN_UNLIMITED_SELECT
=
1
libuv_la_CFLAGS
+=
-D_DARWIN_UNLIMITED_SELECT
=
1
libuv_la_SOURCES
+=
src/unix/bsd-ifaddrs.c
\
libuv_la_SOURCES
+=
src/unix/bsd-ifaddrs.c
\
src/unix/darwin.c
\
src/unix/darwin-proctitle.c
\
src/unix/darwin-proctitle.c
\
src/unix/darwin-stub.h
\
src/unix/darwin.c
\
src/unix/fsevents.c
\
src/unix/fsevents.c
\
src/unix/kqueue.c
\
src/unix/kqueue.c
\
src/unix/proctitle.c
\
src/unix/proctitle.c
\
...
...
deps/libuv/configure.ac
View file @
6026ec09
...
@@ -13,7 +13,7 @@
...
@@ -13,7 +13,7 @@
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
AC_PREREQ(2.57)
AC_PREREQ(2.57)
AC_INIT([libuv], [1.3
6
.0], [https://github.com/libuv/libuv/issues])
AC_INIT([libuv], [1.3
8
.0], [https://github.com/libuv/libuv/issues])
AC_CONFIG_MACRO_DIR([m4])
AC_CONFIG_MACRO_DIR([m4])
m4_include([m4/libuv-extra-automake-flags.m4])
m4_include([m4/libuv-extra-automake-flags.m4])
m4_include([m4/as_case.m4])
m4_include([m4/as_case.m4])
...
@@ -38,15 +38,17 @@ m4_ifdef([AM_PROG_AR], [AM_PROG_AR])
...
@@ -38,15 +38,17 @@ m4_ifdef([AM_PROG_AR], [AM_PROG_AR])
AC_PROG_LIBTOOL
AC_PROG_LIBTOOL
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
LT_INIT
LT_INIT
# TODO(bnoordhuis) Check for -pthread vs. -pthreads
AX_PTHREAD([
LIBS="$LIBS $PTHREAD_LIBS"
CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
])
AC_CHECK_LIB([dl], [dlopen])
AC_CHECK_LIB([dl], [dlopen])
AC_CHECK_LIB([kstat], [kstat_lookup])
AC_SEARCH_LIBS([kstat_lookup], [kstat])
AC_CHECK_LIB([nsl], [gethostbyname])
AC_SEARCH_LIBS([gethostbyname], [nsl])
AC_CHECK_LIB([perfstat], [perfstat_cpu])
AC_SEARCH_LIBS([perfstat_cpu], [perfstat])
AC_CHECK_LIB([pthread], [pthread_mutex_init])
AC_SEARCH_LIBS([clock_gettime], [rt])
AC_CHECK_LIB([rt], [clock_gettime])
AC_SEARCH_LIBS([sendfile], [sendfile])
AC_CHECK_LIB([sendfile], [sendfile])
AC_SEARCH_LIBS([socket], [socket])
AC_CHECK_LIB([socket], [socket])
AC_SYS_LARGEFILE
AC_SYS_LARGEFILE
AM_CONDITIONAL([AIX], [AS_CASE([$host_os],[aix*], [true], [false])])
AM_CONDITIONAL([AIX], [AS_CASE([$host_os],[aix*], [true], [false])])
AM_CONDITIONAL([ANDROID], [AS_CASE([$host_os],[linux-android*],[true], [false])])
AM_CONDITIONAL([ANDROID], [AS_CASE([$host_os],[linux-android*],[true], [false])])
...
...
deps/libuv/include/uv.h
View file @
6026ec09
...
@@ -265,6 +265,8 @@ typedef void* (*uv_realloc_func)(void* ptr, size_t size);
...
@@ -265,6 +265,8 @@ typedef void* (*uv_realloc_func)(void* ptr, size_t size);
typedef
void
*
(
*
uv_calloc_func
)(
size_t
count
,
size_t
size
);
typedef
void
*
(
*
uv_calloc_func
)(
size_t
count
,
size_t
size
);
typedef
void
(
*
uv_free_func
)(
void
*
ptr
);
typedef
void
(
*
uv_free_func
)(
void
*
ptr
);
UV_EXTERN
void
uv_library_shutdown
(
void
);
UV_EXTERN
int
uv_replace_allocator
(
uv_malloc_func
malloc_func
,
UV_EXTERN
int
uv_replace_allocator
(
uv_malloc_func
malloc_func
,
uv_realloc_func
realloc_func
,
uv_realloc_func
realloc_func
,
uv_calloc_func
calloc_func
,
uv_calloc_func
calloc_func
,
...
@@ -610,7 +612,12 @@ enum uv_udp_flags {
...
@@ -610,7 +612,12 @@ enum uv_udp_flags {
* Indicates that the message was received by recvmmsg, so the buffer provided
* Indicates that the message was received by recvmmsg, so the buffer provided
* must not be freed by the recv_cb callback.
* must not be freed by the recv_cb callback.
*/
*/
UV_UDP_MMSG_CHUNK
=
8
UV_UDP_MMSG_CHUNK
=
8
,
/*
* Indicates that recvmmsg should be used, if available.
*/
UV_UDP_RECVMMSG
=
256
};
};
typedef
void
(
*
uv_udp_send_cb
)(
uv_udp_send_t
*
req
,
int
status
);
typedef
void
(
*
uv_udp_send_cb
)(
uv_udp_send_t
*
req
,
int
status
);
...
@@ -1064,11 +1071,11 @@ UV_EXTERN int uv_cancel(uv_req_t* req);
...
@@ -1064,11 +1071,11 @@ UV_EXTERN int uv_cancel(uv_req_t* req);
struct
uv_cpu_times_s
{
struct
uv_cpu_times_s
{
uint64_t
user
;
uint64_t
user
;
/* milliseconds */
uint64_t
nice
;
uint64_t
nice
;
/* milliseconds */
uint64_t
sys
;
uint64_t
sys
;
/* milliseconds */
uint64_t
idle
;
uint64_t
idle
;
/* milliseconds */
uint64_t
irq
;
uint64_t
irq
;
/* milliseconds */
};
};
struct
uv_cpu_info_s
{
struct
uv_cpu_info_s
{
...
@@ -1300,6 +1307,7 @@ struct uv_fs_s {
...
@@ -1300,6 +1307,7 @@ struct uv_fs_s {
UV_EXTERN
uv_fs_type
uv_fs_get_type
(
const
uv_fs_t
*
);
UV_EXTERN
uv_fs_type
uv_fs_get_type
(
const
uv_fs_t
*
);
UV_EXTERN
ssize_t
uv_fs_get_result
(
const
uv_fs_t
*
);
UV_EXTERN
ssize_t
uv_fs_get_result
(
const
uv_fs_t
*
);
UV_EXTERN
int
uv_fs_get_system_error
(
const
uv_fs_t
*
);
UV_EXTERN
void
*
uv_fs_get_ptr
(
const
uv_fs_t
*
);
UV_EXTERN
void
*
uv_fs_get_ptr
(
const
uv_fs_t
*
);
UV_EXTERN
const
char
*
uv_fs_get_path
(
const
uv_fs_t
*
);
UV_EXTERN
const
char
*
uv_fs_get_path
(
const
uv_fs_t
*
);
UV_EXTERN
uv_stat_t
*
uv_fs_get_statbuf
(
uv_fs_t
*
);
UV_EXTERN
uv_stat_t
*
uv_fs_get_statbuf
(
uv_fs_t
*
);
...
...
deps/libuv/include/uv/version.h
View file @
6026ec09
...
@@ -31,7 +31,7 @@
...
@@ -31,7 +31,7 @@
*/
*/
#define UV_VERSION_MAJOR 1
#define UV_VERSION_MAJOR 1
#define UV_VERSION_MINOR 3
6
#define UV_VERSION_MINOR 3
8
#define UV_VERSION_PATCH 0
#define UV_VERSION_PATCH 0
#define UV_VERSION_IS_RELEASE 1
#define UV_VERSION_IS_RELEASE 1
#define UV_VERSION_SUFFIX ""
#define UV_VERSION_SUFFIX ""
...
...
deps/libuv/src/threadpool.c
View file @
6026ec09
...
@@ -160,8 +160,8 @@ static void post(QUEUE* q, enum uv__work_kind kind) {
...
@@ -160,8 +160,8 @@ static void post(QUEUE* q, enum uv__work_kind kind) {
}
}
void
uv__threadpool_cleanup
(
void
)
{
#ifndef _WIN32
#ifndef _WIN32
UV_DESTRUCTOR
(
static
void
cleanup
(
void
))
{
unsigned
int
i
;
unsigned
int
i
;
if
(
nthreads
==
0
)
if
(
nthreads
==
0
)
...
@@ -181,8 +181,8 @@ UV_DESTRUCTOR(static void cleanup(void)) {
...
@@ -181,8 +181,8 @@ UV_DESTRUCTOR(static void cleanup(void)) {
threads
=
NULL
;
threads
=
NULL
;
nthreads
=
0
;
nthreads
=
0
;
}
#endif
#endif
}
static
void
init_threads
(
void
)
{
static
void
init_threads
(
void
)
{
...
...
deps/libuv/src/timer.c
View file @
6026ec09
...
@@ -51,12 +51,7 @@ static int timer_less_than(const struct heap_node* ha,
...
@@ -51,12 +51,7 @@ static int timer_less_than(const struct heap_node* ha,
/* Compare start_id when both have the same timeout. start_id is
/* Compare start_id when both have the same timeout. start_id is
* allocated with loop->timer_counter in uv_timer_start().
* allocated with loop->timer_counter in uv_timer_start().
*/
*/
if
(
a
->
start_id
<
b
->
start_id
)
return
a
->
start_id
<
b
->
start_id
;
return
1
;
if
(
b
->
start_id
<
a
->
start_id
)
return
0
;
return
0
;
}
}
...
...
deps/libuv/src/unix/aix.c
View file @
6026ec09
...
@@ -926,7 +926,7 @@ int uv_get_process_title(char* buffer, size_t size) {
...
@@ -926,7 +926,7 @@ int uv_get_process_title(char* buffer, size_t size) {
}
}
UV_DESTRUCTOR
(
static
void
free_args_mem
(
void
)
)
{
void
uv__process_title_cleanup
(
void
)
{
uv__free
(
args_mem
);
/* Keep valgrind happy. */
uv__free
(
args_mem
);
/* Keep valgrind happy. */
args_mem
=
NULL
;
args_mem
=
NULL
;
}
}
...
...
deps/libuv/src/unix/async.c
View file @
6026ec09
...
@@ -32,6 +32,7 @@
...
@@ -32,6 +32,7 @@
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
#include <unistd.h>
#include <unistd.h>
#include <sched.h>
/* sched_yield() */
#ifdef __linux__
#ifdef __linux__
#include <sys/eventfd.h>
#include <sys/eventfd.h>
...
@@ -81,20 +82,32 @@ int uv_async_send(uv_async_t* handle) {
...
@@ -81,20 +82,32 @@ int uv_async_send(uv_async_t* handle) {
/* Only call this from the event loop thread. */
/* Only call this from the event loop thread. */
static
int
uv__async_spin
(
uv_async_t
*
handle
)
{
static
int
uv__async_spin
(
uv_async_t
*
handle
)
{
int
i
;
int
rc
;
int
rc
;
for
(;;)
{
for
(;;)
{
/* rc=0 -- handle is not pending.
/* 997 is not completely chosen at random. It's a prime number, acyclical
* rc=1 -- handle is pending, other thread is still working with it.
* by nature, and should therefore hopefully dampen sympathetic resonance.
* rc=2 -- handle is pending, other thread is done.
*/
*/
rc
=
cmpxchgi
(
&
handle
->
pending
,
2
,
0
);
for
(
i
=
0
;
i
<
997
;
i
++
)
{
/* rc=0 -- handle is not pending.
if
(
rc
!=
1
)
* rc=1 -- handle is pending, other thread is still working with it.
return
rc
;
* rc=2 -- handle is pending, other thread is done.
*/
/* Other thread is busy with this handle, spin until it's done. */
rc
=
cmpxchgi
(
&
handle
->
pending
,
2
,
0
);
cpu_relax
();
if
(
rc
!=
1
)
return
rc
;
/* Other thread is busy with this handle, spin until it's done. */
cpu_relax
();
}
/* Yield the CPU. We may have preempted the other thread while it's
* inside the critical section and if it's running on the same CPU
* as us, we'll just burn CPU cycles until the end of our time slice.
*/
sched_yield
();
}
}
}
}
...
...
deps/libuv/src/unix/bsd-proctitle.c
View file @
6026ec09
...
@@ -37,6 +37,13 @@ static void init_process_title_mutex_once(void) {
...
@@ -37,6 +37,13 @@ static void init_process_title_mutex_once(void) {
}
}
void
uv__process_title_cleanup
(
void
)
{
/* TODO(bnoordhuis) uv_mutex_destroy(&process_title_mutex)
* and reset process_title_mutex_once?
*/
}
char
**
uv_setup_args
(
int
argc
,
char
**
argv
)
{
char
**
uv_setup_args
(
int
argc
,
char
**
argv
)
{
process_title
=
argc
>
0
?
uv__strdup
(
argv
[
0
])
:
NULL
;
process_title
=
argc
>
0
?
uv__strdup
(
argv
[
0
])
:
NULL
;
return
argv
;
return
argv
;
...
...
deps/libuv/src/unix/darwin-proctitle.c
View file @
6026ec09
...
@@ -30,8 +30,7 @@
...
@@ -30,8 +30,7 @@
#include <TargetConditionals.h>
#include <TargetConditionals.h>
#if !TARGET_OS_IPHONE
#if !TARGET_OS_IPHONE
# include <CoreFoundation/CoreFoundation.h>
#include "darwin-stub.h"
# include <ApplicationServices/ApplicationServices.h>
#endif
#endif
...
...
deps/libuv/src/unix/darwin-stub.h
0 → 100644
View file @
6026ec09
/* Copyright libuv project contributors. All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to
* deal in the Software without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*/
#ifndef UV_DARWIN_STUB_H_
#define UV_DARWIN_STUB_H_
#include <stdint.h>
struct
CFArrayCallBacks
;
struct
CFRunLoopSourceContext
;
struct
FSEventStreamContext
;
typedef
double
CFAbsoluteTime
;
typedef
double
CFTimeInterval
;
typedef
int
FSEventStreamEventFlags
;
typedef
int
OSStatus
;
typedef
long
CFIndex
;
typedef
struct
CFArrayCallBacks
CFArrayCallBacks
;
typedef
struct
CFRunLoopSourceContext
CFRunLoopSourceContext
;
typedef
struct
FSEventStreamContext
FSEventStreamContext
;
typedef
uint32_t
FSEventStreamCreateFlags
;
typedef
uint64_t
FSEventStreamEventId
;
typedef
unsigned
CFStringEncoding
;
typedef
void
*
CFAllocatorRef
;
typedef
void
*
CFArrayRef
;
typedef
void
*
CFBundleRef
;
typedef
void
*
CFDictionaryRef
;
typedef
void
*
CFRunLoopRef
;
typedef
void
*
CFRunLoopSourceRef
;
typedef
void
*
CFStringRef
;
typedef
void
*
CFTypeRef
;
typedef
void
*
FSEventStreamRef
;
typedef
void
(
*
FSEventStreamCallback
)(
const
FSEventStreamRef
,
void
*
,
size_t
,
void
*
,
const
FSEventStreamEventFlags
*
,
const
FSEventStreamEventId
*
);
struct
CFRunLoopSourceContext
{
CFIndex
version
;
void
*
info
;
void
*
pad
[
7
];
void
(
*
perform
)(
void
*
);
};
struct
FSEventStreamContext
{
CFIndex
version
;
void
*
info
;
void
*
pad
[
3
];
};
static
const
CFStringEncoding
kCFStringEncodingUTF8
=
0x8000100
;
static
const
OSStatus
noErr
=
0
;
static
const
FSEventStreamEventId
kFSEventStreamEventIdSinceNow
=
-
1
;
static
const
int
kFSEventStreamCreateFlagNoDefer
=
2
;
static
const
int
kFSEventStreamCreateFlagFileEvents
=
16
;
static
const
int
kFSEventStreamEventFlagEventIdsWrapped
=
8
;
static
const
int
kFSEventStreamEventFlagHistoryDone
=
16
;
static
const
int
kFSEventStreamEventFlagItemChangeOwner
=
0x4000
;
static
const
int
kFSEventStreamEventFlagItemCreated
=
0x100
;
static
const
int
kFSEventStreamEventFlagItemFinderInfoMod
=
0x2000
;
static
const
int
kFSEventStreamEventFlagItemInodeMetaMod
=
0x400
;
static
const
int
kFSEventStreamEventFlagItemIsDir
=
0x20000
;
static
const
int
kFSEventStreamEventFlagItemModified
=
0x1000
;
static
const
int
kFSEventStreamEventFlagItemRemoved
=
0x200
;
static
const
int
kFSEventStreamEventFlagItemRenamed
=
0x800
;
static
const
int
kFSEventStreamEventFlagItemXattrMod
=
0x8000
;
static
const
int
kFSEventStreamEventFlagKernelDropped
=
4
;
static
const
int
kFSEventStreamEventFlagMount
=
64
;
static
const
int
kFSEventStreamEventFlagRootChanged
=
32
;
static
const
int
kFSEventStreamEventFlagUnmount
=
128
;
static
const
int
kFSEventStreamEventFlagUserDropped
=
2
;
#endif
/* UV_DARWIN_STUB_H_ */
deps/libuv/src/unix/fs.c
View file @
6026ec09
...
@@ -1110,9 +1110,10 @@ static ssize_t uv__fs_copyfile(uv_fs_t* req) {
...
@@ -1110,9 +1110,10 @@ static ssize_t uv__fs_copyfile(uv_fs_t* req) {
int
dst_flags
;
int
dst_flags
;
int
result
;
int
result
;
int
err
;
int
err
;
size_t
bytes_to_send
;
off_t
bytes_to_send
;
int64_t
in_offset
;
off_t
in_offset
;
ssize_t
bytes_written
;
off_t
bytes_written
;
size_t
bytes_chunk
;
dstfd
=
-
1
;
dstfd
=
-
1
;
err
=
0
;
err
=
0
;
...
@@ -1211,7 +1212,10 @@ static ssize_t uv__fs_copyfile(uv_fs_t* req) {
...
@@ -1211,7 +1212,10 @@ static ssize_t uv__fs_copyfile(uv_fs_t* req) {
bytes_to_send
=
src_statsbuf
.
st_size
;
bytes_to_send
=
src_statsbuf
.
st_size
;
in_offset
=
0
;
in_offset
=
0
;
while
(
bytes_to_send
!=
0
)
{
while
(
bytes_to_send
!=
0
)
{
uv_fs_sendfile
(
NULL
,
&
fs_req
,
dstfd
,
srcfd
,
in_offset
,
bytes_to_send
,
NULL
);
bytes_chunk
=
SSIZE_MAX
;
if
(
bytes_to_send
<
(
off_t
)
bytes_chunk
)
bytes_chunk
=
bytes_to_send
;
uv_fs_sendfile
(
NULL
,
&
fs_req
,
dstfd
,
srcfd
,
in_offset
,
bytes_chunk
,
NULL
);
bytes_written
=
fs_req
.
result
;
bytes_written
=
fs_req
.
result
;
uv_fs_req_cleanup
(
&
fs_req
);
uv_fs_req_cleanup
(
&
fs_req
);
...
@@ -2082,3 +2086,7 @@ int uv_fs_statfs(uv_loop_t* loop,
...
@@ -2082,3 +2086,7 @@ int uv_fs_statfs(uv_loop_t* loop,
PATH
;
PATH
;
POST
;
POST
;
}
}
int
uv_fs_get_system_error
(
const
uv_fs_t
*
req
)
{
return
-
req
->
result
;
}
deps/libuv/src/unix/fsevents.c
View file @
6026ec09
...
@@ -41,34 +41,33 @@ void uv__fsevents_loop_delete(uv_loop_t* loop) {
...
@@ -41,34 +41,33 @@ void uv__fsevents_loop_delete(uv_loop_t* loop) {
#else
/* TARGET_OS_IPHONE */
#else
/* TARGET_OS_IPHONE */
#include "darwin-stub.h"
#include <dlfcn.h>
#include <dlfcn.h>
#include <assert.h>
#include <assert.h>
#include <stdlib.h>
#include <stdlib.h>
#include <pthread.h>
#include <pthread.h>
#include <CoreFoundation/CFRunLoop.h>
static
const
int
kFSEventsModified
=
#include <CoreServices/CoreServices.h>
kFSEventStreamEventFlagItemChangeOwner
|
kFSEventStreamEventFlagItemFinderInfoMod
|
/* These are macros to avoid "initializer element is not constant" errors
kFSEventStreamEventFlagItemInodeMetaMod
|
* with old versions of gcc.
kFSEventStreamEventFlagItemModified
|
*/
kFSEventStreamEventFlagItemXattrMod
;
#define kFSEventsModified (kFSEventStreamEventFlagItemFinderInfoMod | \
kFSEventStreamEventFlagItemModified | \
static
const
int
kFSEventsRenamed
=
kFSEventStreamEventFlagItemInodeMetaMod | \
kFSEventStreamEventFlagItemCreated
|
kFSEventStreamEventFlagItemChangeOwner | \
kFSEventStreamEventFlagItemRemoved
|
kFSEventStreamEventFlagItemXattrMod)
kFSEventStreamEventFlagItemRenamed
;
#define kFSEventsRenamed (kFSEventStreamEventFlagItemCreated | \
static
const
int
kFSEventsSystem
=
kFSEventStreamEventFlagItemRemoved | \
kFSEventStreamEventFlagUserDropped
|
kFSEventStreamEventFlagItemRenamed)
kFSEventStreamEventFlagKernelDropped
|
kFSEventStreamEventFlagEventIdsWrapped
|
#define kFSEventsSystem (kFSEventStreamEventFlagUserDropped | \
kFSEventStreamEventFlagHistoryDone
|
kFSEventStreamEventFlagKernelDropped | \
kFSEventStreamEventFlagMount
|
kFSEventStreamEventFlagEventIdsWrapped | \
kFSEventStreamEventFlagUnmount
|
kFSEventStreamEventFlagHistoryDone | \
kFSEventStreamEventFlagRootChanged
;
kFSEventStreamEventFlagMount | \
kFSEventStreamEventFlagUnmount | \
kFSEventStreamEventFlagRootChanged)
typedef
struct
uv__fsevents_event_s
uv__fsevents_event_t
;
typedef
struct
uv__fsevents_event_s
uv__fsevents_event_t
;
typedef
struct
uv__cf_loop_signal_s
uv__cf_loop_signal_t
;
typedef
struct
uv__cf_loop_signal_s
uv__cf_loop_signal_t
;
...
@@ -148,7 +147,7 @@ static void (*pFSEventStreamRelease)(FSEventStreamRef);
...
@@ -148,7 +147,7 @@ static void (*pFSEventStreamRelease)(FSEventStreamRef);
static
void
(
*
pFSEventStreamScheduleWithRunLoop
)(
FSEventStreamRef
,
static
void
(
*
pFSEventStreamScheduleWithRunLoop
)(
FSEventStreamRef
,
CFRunLoopRef
,
CFRunLoopRef
,
CFStringRef
);
CFStringRef
);
static
Boolean
(
*
pFSEventStreamStart
)(
FSEventStreamRef
);
static
int
(
*
pFSEventStreamStart
)(
FSEventStreamRef
);
static
void
(
*
pFSEventStreamStop
)(
FSEventStreamRef
);
static
void
(
*
pFSEventStreamStop
)(
FSEventStreamRef
);
#define UV__FSEVENTS_PROCESS(handle, block) \
#define UV__FSEVENTS_PROCESS(handle, block) \
...
@@ -215,7 +214,7 @@ static void uv__fsevents_push_event(uv_fs_event_t* handle,
...
@@ -215,7 +214,7 @@ static void uv__fsevents_push_event(uv_fs_event_t* handle,
/* Runs in CF thread, when there're events in FSEventStream */
/* Runs in CF thread, when there're events in FSEventStream */
static
void
uv__fsevents_event_cb
(
Const
FSEventStreamRef
streamRef
,
static
void
uv__fsevents_event_cb
(
const
FSEventStreamRef
streamRef
,
void
*
info
,
void
*
info
,
size_t
numEvents
,
size_t
numEvents
,
void
*
eventPaths
,
void
*
eventPaths
,
...
@@ -340,11 +339,8 @@ static int uv__fsevents_create_stream(uv_loop_t* loop, CFArrayRef paths) {
...
@@ -340,11 +339,8 @@ static int uv__fsevents_create_stream(uv_loop_t* loop, CFArrayRef paths) {
FSEventStreamCreateFlags
flags
;
FSEventStreamCreateFlags
flags
;
/* Initialize context */
/* Initialize context */
ctx
.
version
=
0
;
memset
(
&
ctx
,
0
,
sizeof
(
ctx
))
;
ctx
.
info
=
loop
;
ctx
.
info
=
loop
;
ctx
.
retain
=
NULL
;
ctx
.
release
=
NULL
;
ctx
.
copyDescription
=
NULL
;
latency
=
0
.
05
;
latency
=
0
.
05
;
...
...
deps/libuv/src/unix/internal.h
View file @
6026ec09
...
@@ -106,10 +106,8 @@ int uv__pthread_sigmask(int how, const sigset_t* set, sigset_t* oset);
...
@@ -106,10 +106,8 @@ int uv__pthread_sigmask(int how, const sigset_t* set, sigset_t* oset);
#if defined(__clang__) || \
#if defined(__clang__) || \
defined(__GNUC__) || \
defined(__GNUC__) || \
defined(__INTEL_COMPILER)
defined(__INTEL_COMPILER)
# define UV_DESTRUCTOR(declaration) __attribute__((destructor)) declaration
# define UV_UNUSED(declaration) __attribute__((unused)) declaration
# define UV_UNUSED(declaration) __attribute__((unused)) declaration
#else
#else
# define UV_DESTRUCTOR(declaration) declaration
# define UV_UNUSED(declaration) declaration
# define UV_UNUSED(declaration) declaration
#endif
#endif
...
...
deps/libuv/src/unix/linux-core.c
View file @
6026ec09
...
@@ -768,7 +768,8 @@ static int read_times(FILE* statfile_fp,
...
@@ -768,7 +768,8 @@ static int read_times(FILE* statfile_fp,
unsigned
int
numcpus
,
unsigned
int
numcpus
,
uv_cpu_info_t
*
ci
)
{
uv_cpu_info_t
*
ci
)
{
struct
uv_cpu_times_s
ts
;
struct
uv_cpu_times_s
ts
;
uint64_t
clock_ticks
;
unsigned
int
ticks
;
unsigned
int
multiplier
;
uint64_t
user
;
uint64_t
user
;
uint64_t
nice
;
uint64_t
nice
;
uint64_t
sys
;
uint64_t
sys
;
...
@@ -779,9 +780,10 @@ static int read_times(FILE* statfile_fp,
...
@@ -779,9 +780,10 @@ static int read_times(FILE* statfile_fp,
uint64_t
len
;
uint64_t
len
;
char
buf
[
1024
];
char
buf
[
1024
];
clock_ticks
=
sysconf
(
_SC_CLK_TCK
);
ticks
=
(
unsigned
int
)
sysconf
(
_SC_CLK_TCK
);
assert
(
clock_ticks
!=
(
uint64_t
)
-
1
);
multiplier
=
((
uint64_t
)
1000L
/
ticks
);
assert
(
clock_ticks
!=
0
);
assert
(
ticks
!=
(
unsigned
int
)
-
1
);
assert
(
ticks
!=
0
);
rewind
(
statfile_fp
);
rewind
(
statfile_fp
);
...
@@ -823,11 +825,11 @@ static int read_times(FILE* statfile_fp,
...
@@ -823,11 +825,11 @@ static int read_times(FILE* statfile_fp,
&
irq
))
&
irq
))
abort
();
abort
();
ts
.
user
=
clock_ticks
*
us
er
;
ts
.
user
=
user
*
multipli
er
;
ts
.
nice
=
clock_ticks
*
nice
;
ts
.
nice
=
nice
*
multiplier
;
ts
.
sys
=
clock_ticks
*
sys
;
ts
.
sys
=
sys
*
multiplier
;
ts
.
idle
=
clock_ticks
*
idle
;
ts
.
idle
=
idle
*
multiplier
;
ts
.
irq
=
clock_ticks
*
irq
;
ts
.
irq
=
irq
*
multiplier
;
ci
[
num
++
].
cpu_times
=
ts
;
ci
[
num
++
].
cpu_times
=
ts
;
}
}
assert
(
num
==
numcpus
);
assert
(
num
==
numcpus
);
...
...
deps/libuv/src/unix/loop.c
View file @
6026ec09
...
@@ -106,6 +106,8 @@ fail_rwlock_init:
...
@@ -106,6 +106,8 @@ fail_rwlock_init:
fail_signal_init:
fail_signal_init:
uv__platform_loop_delete
(
loop
);
uv__platform_loop_delete
(
loop
);
uv__free
(
loop
->
watchers
);
loop
->
nwatchers
=
0
;
return
err
;
return
err
;
}
}
...
...
deps/libuv/src/unix/no-proctitle.c
View file @
6026ec09
...
@@ -29,6 +29,9 @@ char** uv_setup_args(int argc, char** argv) {
...
@@ -29,6 +29,9 @@ char** uv_setup_args(int argc, char** argv) {
return
argv
;
return
argv
;
}
}
void
uv__process_title_cleanup
(
void
)
{
}
int
uv_set_process_title
(
const
char
*
title
)
{
int
uv_set_process_title
(
const
char
*
title
)
{
return
0
;
return
0
;
}
}
...
...
deps/libuv/src/unix/proctitle.c
View file @
6026ec09
...
@@ -145,7 +145,7 @@ int uv_get_process_title(char* buffer, size_t size) {
...
@@ -145,7 +145,7 @@ int uv_get_process_title(char* buffer, size_t size) {
}
}
UV_DESTRUCTOR
(
static
void
free_args_mem
(
void
)
)
{
void
uv__process_title_cleanup
(
void
)
{
uv__free
(
args_mem
);
/* Keep valgrind happy. */
uv__free
(
args_mem
);
/* Keep valgrind happy. */
args_mem
=
NULL
;
args_mem
=
NULL
;
}
}
deps/libuv/src/unix/signal.c
View file @
6026ec09
...
@@ -77,7 +77,7 @@ static void uv__signal_global_init(void) {
...
@@ -77,7 +77,7 @@ static void uv__signal_global_init(void) {
}
}
UV_DESTRUCTOR
(
static
void
uv__signal_global_fini
(
void
)
)
{
void
uv__signal_cleanup
(
void
)
{
/* We can only use signal-safe functions here.
/* We can only use signal-safe functions here.
* That includes read/write and close, fortunately.
* That includes read/write and close, fortunately.
* We do all of this directly here instead of resetting
* We do all of this directly here instead of resetting
...
@@ -98,7 +98,7 @@ UV_DESTRUCTOR(static void uv__signal_global_fini(void)) {
...
@@ -98,7 +98,7 @@ UV_DESTRUCTOR(static void uv__signal_global_fini(void)) {
static
void
uv__signal_global_reinit
(
void
)
{
static
void
uv__signal_global_reinit
(
void
)
{
uv__signal_
global_fini
();
uv__signal_
cleanup
();
if
(
uv__make_pipe
(
uv__signal_lock_pipefd
,
0
))
if
(
uv__make_pipe
(
uv__signal_lock_pipefd
,
0
))
abort
();
abort
();
...
...
deps/libuv/src/unix/thread.c
View file @
6026ec09
...
@@ -172,10 +172,11 @@ static size_t thread_stack_size(void) {
...
@@ -172,10 +172,11 @@ static size_t thread_stack_size(void) {
#if defined(__APPLE__) || defined(__linux__)
#if defined(__APPLE__) || defined(__linux__)
struct
rlimit
lim
;
struct
rlimit
lim
;
if
(
getrlimit
(
RLIMIT_STACK
,
&
lim
))
/* getrlimit() can fail on some aarch64 systems due to a glibc bug where
abort
();
* the system call wrapper invokes the wrong system call. Don't treat
* that as fatal, just use the default stack size instead.
if
(
lim
.
rlim_cur
!=
RLIM_INFINITY
)
{
*/
if
(
0
==
getrlimit
(
RLIMIT_STACK
,
&
lim
)
&&
lim
.
rlim_cur
!=
RLIM_INFINITY
)
{
/* pthread_attr_setstacksize() expects page-aligned values. */
/* pthread_attr_setstacksize() expects page-aligned values. */
lim
.
rlim_cur
-=
lim
.
rlim_cur
%
(
rlim_t
)
getpagesize
();
lim
.
rlim_cur
-=
lim
.
rlim_cur
%
(
rlim_t
)
getpagesize
();
...
...
deps/libuv/src/unix/udp.c
View file @
6026ec09
...
@@ -42,6 +42,11 @@
...
@@ -42,6 +42,11 @@
# define IPV6_DROP_MEMBERSHIP IPV6_LEAVE_GROUP
# define IPV6_DROP_MEMBERSHIP IPV6_LEAVE_GROUP
#endif
#endif
union
uv__sockaddr
{
struct
sockaddr_in6
in6
;
struct
sockaddr_in
in
;
struct
sockaddr
addr
;
};
static
void
uv__udp_run_completed
(
uv_udp_t
*
handle
);
static
void
uv__udp_run_completed
(
uv_udp_t
*
handle
);
static
void
uv__udp_io
(
uv_loop_t
*
loop
,
uv__io_t
*
w
,
unsigned
int
revents
);
static
void
uv__udp_io
(
uv_loop_t
*
loop
,
uv__io_t
*
w
,
unsigned
int
revents
);
...
@@ -202,6 +207,9 @@ static int uv__udp_recvmmsg(uv_udp_t* handle, uv_buf_t* buf) {
...
@@ -202,6 +207,9 @@ static int uv__udp_recvmmsg(uv_udp_t* handle, uv_buf_t* buf) {
msgs
[
k
].
msg_hdr
.
msg_iovlen
=
1
;
msgs
[
k
].
msg_hdr
.
msg_iovlen
=
1
;
msgs
[
k
].
msg_hdr
.
msg_name
=
peers
+
k
;
msgs
[
k
].
msg_hdr
.
msg_name
=
peers
+
k
;
msgs
[
k
].
msg_hdr
.
msg_namelen
=
sizeof
(
peers
[
0
]);
msgs
[
k
].
msg_hdr
.
msg_namelen
=
sizeof
(
peers
[
0
]);
msgs
[
k
].
msg_hdr
.
msg_control
=
NULL
;
msgs
[
k
].
msg_hdr
.
msg_controllen
=
0
;
msgs
[
k
].
msg_hdr
.
msg_flags
=
0
;
}
}
do
do
...
@@ -262,11 +270,9 @@ static void uv__udp_recvmsg(uv_udp_t* handle) {
...
@@ -262,11 +270,9 @@ static void uv__udp_recvmsg(uv_udp_t* handle) {
assert
(
buf
.
base
!=
NULL
);
assert
(
buf
.
base
!=
NULL
);
#if HAVE_MMSG
#if HAVE_MMSG
uv_once
(
&
once
,
uv__udp_mmsg_init
);
if
(
handle
->
flags
&
UV_HANDLE_UDP_RECVMMSG
)
{
if
(
uv__recvmmsg_avail
)
{
uv_once
(
&
once
,
uv__udp_mmsg_init
);
/* Returned space for more than 1 datagram, use it to receive
if
(
uv__recvmmsg_avail
)
{
* multiple datagrams. */
if
(
buf
.
len
>=
2
*
UV__UDP_DGRAM_MAXSIZE
)
{
nread
=
uv__udp_recvmmsg
(
handle
,
&
buf
);
nread
=
uv__udp_recvmmsg
(
handle
,
&
buf
);
if
(
nread
>
0
)
if
(
nread
>
0
)
count
-=
nread
;
count
-=
nread
;
...
@@ -566,11 +572,7 @@ int uv__udp_bind(uv_udp_t* handle,
...
@@ -566,11 +572,7 @@ int uv__udp_bind(uv_udp_t* handle,
static
int
uv__udp_maybe_deferred_bind
(
uv_udp_t
*
handle
,
static
int
uv__udp_maybe_deferred_bind
(
uv_udp_t
*
handle
,
int
domain
,
int
domain
,
unsigned
int
flags
)
{
unsigned
int
flags
)
{
union
{
union
uv__sockaddr
taddr
;
struct
sockaddr_in6
in6
;
struct
sockaddr_in
in
;
struct
sockaddr
addr
;
}
taddr
;
socklen_t
addrlen
;
socklen_t
addrlen
;
if
(
handle
->
io_watcher
.
fd
!=
-
1
)
if
(
handle
->
io_watcher
.
fd
!=
-
1
)
...
@@ -923,8 +925,10 @@ static int uv__udp_set_source_membership6(uv_udp_t* handle,
...
@@ -923,8 +925,10 @@ static int uv__udp_set_source_membership6(uv_udp_t* handle,
mreq
.
gsr_interface
=
0
;
mreq
.
gsr_interface
=
0
;
}
}
memcpy
(
&
mreq
.
gsr_group
,
multicast_addr
,
sizeof
(
mreq
.
gsr_group
));
STATIC_ASSERT
(
sizeof
(
mreq
.
gsr_group
)
>=
sizeof
(
*
multicast_addr
));
memcpy
(
&
mreq
.
gsr_source
,
source_addr
,
sizeof
(
mreq
.
gsr_source
));
STATIC_ASSERT
(
sizeof
(
mreq
.
gsr_source
)
>=
sizeof
(
*
source_addr
));
memcpy
(
&
mreq
.
gsr_group
,
multicast_addr
,
sizeof
(
*
multicast_addr
));
memcpy
(
&
mreq
.
gsr_source
,
source_addr
,
sizeof
(
*
source_addr
));
if
(
membership
==
UV_JOIN_GROUP
)
if
(
membership
==
UV_JOIN_GROUP
)
optname
=
MCAST_JOIN_SOURCE_GROUP
;
optname
=
MCAST_JOIN_SOURCE_GROUP
;
...
@@ -946,26 +950,17 @@ static int uv__udp_set_source_membership6(uv_udp_t* handle,
...
@@ -946,26 +950,17 @@ static int uv__udp_set_source_membership6(uv_udp_t* handle,
#endif
#endif
int
uv_udp_init_ex
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
,
unsigned
int
flags
)
{
int
uv__udp_init_ex
(
uv_loop_t
*
loop
,
int
domain
;
uv_udp_t
*
handle
,
int
err
;
unsigned
flags
,
int
domain
)
{
int
fd
;
int
fd
;
/* Use the lower 8 bits for the domain */
fd
=
-
1
;
domain
=
flags
&
0xFF
;
if
(
domain
!=
AF_INET
&&
domain
!=
AF_INET6
&&
domain
!=
AF_UNSPEC
)
return
UV_EINVAL
;
if
(
flags
&
~
0xFF
)
return
UV_EINVAL
;
if
(
domain
!=
AF_UNSPEC
)
{
if
(
domain
!=
AF_UNSPEC
)
{
err
=
uv__socket
(
domain
,
SOCK_DGRAM
,
0
);
fd
=
uv__socket
(
domain
,
SOCK_DGRAM
,
0
);
if
(
err
<
0
)
if
(
fd
<
0
)
return
err
;
return
fd
;
fd
=
err
;
}
else
{
fd
=
-
1
;
}
}
uv__handle_init
(
loop
,
(
uv_handle_t
*
)
handle
,
UV_UDP
);
uv__handle_init
(
loop
,
(
uv_handle_t
*
)
handle
,
UV_UDP
);
...
@@ -981,11 +976,6 @@ int uv_udp_init_ex(uv_loop_t* loop, uv_udp_t* handle, unsigned int flags) {
...
@@ -981,11 +976,6 @@ int uv_udp_init_ex(uv_loop_t* loop, uv_udp_t* handle, unsigned int flags) {
}
}
int
uv_udp_init
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
)
{
return
uv_udp_init_ex
(
loop
,
handle
,
AF_UNSPEC
);
}
int
uv_udp_open
(
uv_udp_t
*
handle
,
uv_os_sock_t
sock
)
{
int
uv_udp_open
(
uv_udp_t
*
handle
,
uv_os_sock_t
sock
)
{
int
err
;
int
err
;
...
@@ -1043,40 +1033,31 @@ int uv_udp_set_source_membership(uv_udp_t* handle,
...
@@ -1043,40 +1033,31 @@ int uv_udp_set_source_membership(uv_udp_t* handle,
uv_membership
membership
)
{
uv_membership
membership
)
{
#if !defined(__OpenBSD__) && !defined(__NetBSD__) && !defined(__ANDROID__)
#if !defined(__OpenBSD__) && !defined(__NetBSD__) && !defined(__ANDROID__)
int
err
;
int
err
;
struct
sockaddr_storage
mcast_addr
;
union
uv__sockaddr
mcast_addr
;
struct
sockaddr_in
*
mcast_addr4
;
union
uv__sockaddr
src_addr
;
struct
sockaddr_in6
*
mcast_addr6
;
struct
sockaddr_storage
src_addr
;
err
=
uv_ip4_addr
(
multicast_addr
,
0
,
&
mcast_addr
.
in
);
struct
sockaddr_in
*
src_addr4
;
struct
sockaddr_in6
*
src_addr6
;
mcast_addr4
=
(
struct
sockaddr_in
*
)
&
mcast_addr
;
mcast_addr6
=
(
struct
sockaddr_in6
*
)
&
mcast_addr
;
src_addr4
=
(
struct
sockaddr_in
*
)
&
src_addr
;
src_addr6
=
(
struct
sockaddr_in6
*
)
&
src_addr
;
err
=
uv_ip4_addr
(
multicast_addr
,
0
,
mcast_addr4
);
if
(
err
)
{
if
(
err
)
{
err
=
uv_ip6_addr
(
multicast_addr
,
0
,
mcast_addr
6
);
err
=
uv_ip6_addr
(
multicast_addr
,
0
,
&
mcast_addr
.
in
6
);
if
(
err
)
if
(
err
)
return
err
;
return
err
;
err
=
uv_ip6_addr
(
source_addr
,
0
,
src_addr
6
);
err
=
uv_ip6_addr
(
source_addr
,
0
,
&
src_addr
.
in
6
);
if
(
err
)
if
(
err
)
return
err
;
return
err
;
return
uv__udp_set_source_membership6
(
handle
,
return
uv__udp_set_source_membership6
(
handle
,
mcast_addr
6
,
&
mcast_addr
.
in
6
,
interface_addr
,
interface_addr
,
src_addr
6
,
&
src_addr
.
in
6
,
membership
);
membership
);
}
}
err
=
uv_ip4_addr
(
source_addr
,
0
,
src_addr4
);
err
=
uv_ip4_addr
(
source_addr
,
0
,
&
src_addr
.
in
);
if
(
err
)
if
(
err
)
return
err
;
return
err
;
return
uv__udp_set_source_membership4
(
handle
,
return
uv__udp_set_source_membership4
(
handle
,
mcast_addr4
,
&
mcast_addr
.
in
,
interface_addr
,
interface_addr
,
src_addr4
,
&
src_addr
.
in
,
membership
);
membership
);
#else
#else
return
UV_ENOSYS
;
return
UV_ENOSYS
;
...
...
deps/libuv/src/uv-common.c
View file @
6026ec09
...
@@ -293,6 +293,36 @@ int uv_tcp_bind(uv_tcp_t* handle,
...
@@ -293,6 +293,36 @@ int uv_tcp_bind(uv_tcp_t* handle,
}
}
int
uv_udp_init_ex
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
,
unsigned
flags
)
{
unsigned
extra_flags
;
int
domain
;
int
rc
;
/* Use the lower 8 bits for the domain. */
domain
=
flags
&
0xFF
;
if
(
domain
!=
AF_INET
&&
domain
!=
AF_INET6
&&
domain
!=
AF_UNSPEC
)
return
UV_EINVAL
;
/* Use the higher bits for extra flags. */
extra_flags
=
flags
&
~
0xFF
;
if
(
extra_flags
&
~
UV_UDP_RECVMMSG
)
return
UV_EINVAL
;
rc
=
uv__udp_init_ex
(
loop
,
handle
,
flags
,
domain
);
if
(
rc
==
0
)
if
(
extra_flags
&
UV_UDP_RECVMMSG
)
handle
->
flags
|=
UV_HANDLE_UDP_RECVMMSG
;
return
rc
;
}
int
uv_udp_init
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
)
{
return
uv_udp_init_ex
(
loop
,
handle
,
AF_UNSPEC
);
}
int
uv_udp_bind
(
uv_udp_t
*
handle
,
int
uv_udp_bind
(
uv_udp_t
*
handle
,
const
struct
sockaddr
*
addr
,
const
struct
sockaddr
*
addr
,
unsigned
int
flags
)
{
unsigned
int
flags
)
{
...
@@ -821,3 +851,19 @@ void uv_free_cpu_info(uv_cpu_info_t* cpu_infos, int count) {
...
@@ -821,3 +851,19 @@ void uv_free_cpu_info(uv_cpu_info_t* cpu_infos, int count) {
uv__free
(
cpu_infos
);
uv__free
(
cpu_infos
);
}
}
#ifdef __GNUC__
/* Also covers __clang__ and __INTEL_COMPILER. */
__attribute__
((
destructor
))
#endif
void
uv_library_shutdown
(
void
)
{
static
int
was_shutdown
;
if
(
was_shutdown
)
return
;
uv__process_title_cleanup
();
uv__signal_cleanup
();
uv__threadpool_cleanup
();
was_shutdown
=
1
;
}
deps/libuv/src/uv-common.h
View file @
6026ec09
...
@@ -104,6 +104,7 @@ enum {
...
@@ -104,6 +104,7 @@ enum {
/* Only used by uv_udp_t handles. */
/* Only used by uv_udp_t handles. */
UV_HANDLE_UDP_PROCESSING
=
0x01000000
,
UV_HANDLE_UDP_PROCESSING
=
0x01000000
,
UV_HANDLE_UDP_CONNECTED
=
0x02000000
,
UV_HANDLE_UDP_CONNECTED
=
0x02000000
,
UV_HANDLE_UDP_RECVMMSG
=
0x04000000
,
/* Only used by uv_pipe_t handles. */
/* Only used by uv_pipe_t handles. */
UV_HANDLE_NON_OVERLAPPED_PIPE
=
0x01000000
,
UV_HANDLE_NON_OVERLAPPED_PIPE
=
0x01000000
,
...
@@ -138,6 +139,11 @@ int uv__tcp_connect(uv_connect_t* req,
...
@@ -138,6 +139,11 @@ int uv__tcp_connect(uv_connect_t* req,
unsigned
int
addrlen
,
unsigned
int
addrlen
,
uv_connect_cb
cb
);
uv_connect_cb
cb
);
int
uv__udp_init_ex
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
,
unsigned
flags
,
int
domain
);
int
uv__udp_bind
(
uv_udp_t
*
handle
,
int
uv__udp_bind
(
uv_udp_t
*
handle
,
const
struct
sockaddr
*
addr
,
const
struct
sockaddr
*
addr
,
unsigned
int
addrlen
,
unsigned
int
addrlen
,
...
@@ -200,6 +206,10 @@ int uv__next_timeout(const uv_loop_t* loop);
...
@@ -200,6 +206,10 @@ int uv__next_timeout(const uv_loop_t* loop);
void
uv__run_timers
(
uv_loop_t
*
loop
);
void
uv__run_timers
(
uv_loop_t
*
loop
);
void
uv__timer_close
(
uv_timer_t
*
handle
);
void
uv__timer_close
(
uv_timer_t
*
handle
);
void
uv__process_title_cleanup
(
void
);
void
uv__signal_cleanup
(
void
);
void
uv__threadpool_cleanup
(
void
);
#define uv__has_active_reqs(loop) \
#define uv__has_active_reqs(loop) \
((loop)->active_reqs.count > 0)
((loop)->active_reqs.count > 0)
...
...
deps/libuv/src/win/core.c
View file @
6026ec09
...
@@ -449,12 +449,12 @@ static void uv__poll(uv_loop_t* loop, DWORD timeout) {
...
@@ -449,12 +449,12 @@ static void uv__poll(uv_loop_t* loop, DWORD timeout) {
timeout_time
=
loop
->
time
+
timeout
;
timeout_time
=
loop
->
time
+
timeout
;
for
(
repeat
=
0
;
;
repeat
++
)
{
for
(
repeat
=
0
;
;
repeat
++
)
{
success
=
GetQueuedCompletionStatusEx
(
loop
->
iocp
,
success
=
p
GetQueuedCompletionStatusEx
(
loop
->
iocp
,
overlappeds
,
overlappeds
,
ARRAY_SIZE
(
overlappeds
),
ARRAY_SIZE
(
overlappeds
),
&
count
,
&
count
,
timeout
,
timeout
,
FALSE
);
FALSE
);
if
(
success
)
{
if
(
success
)
{
for
(
i
=
0
;
i
<
count
;
i
++
)
{
for
(
i
=
0
;
i
<
count
;
i
++
)
{
...
...
deps/libuv/src/win/error.c
View file @
6026ec09
...
@@ -72,6 +72,7 @@ int uv_translate_sys_error(int sys_errno) {
...
@@ -72,6 +72,7 @@ int uv_translate_sys_error(int sys_errno) {
case
ERROR_NOACCESS
:
return
UV_EACCES
;
case
ERROR_NOACCESS
:
return
UV_EACCES
;
case
WSAEACCES
:
return
UV_EACCES
;
case
WSAEACCES
:
return
UV_EACCES
;
case
ERROR_ELEVATION_REQUIRED
:
return
UV_EACCES
;
case
ERROR_ELEVATION_REQUIRED
:
return
UV_EACCES
;
case
ERROR_CANT_ACCESS_FILE
:
return
UV_EACCES
;
case
ERROR_ADDRESS_ALREADY_ASSOCIATED
:
return
UV_EADDRINUSE
;
case
ERROR_ADDRESS_ALREADY_ASSOCIATED
:
return
UV_EADDRINUSE
;
case
WSAEADDRINUSE
:
return
UV_EADDRINUSE
;
case
WSAEADDRINUSE
:
return
UV_EADDRINUSE
;
case
WSAEADDRNOTAVAIL
:
return
UV_EADDRNOTAVAIL
;
case
WSAEADDRNOTAVAIL
:
return
UV_EADDRNOTAVAIL
;
...
...
deps/libuv/src/win/fs-event.c
View file @
6026ec09
...
@@ -83,6 +83,7 @@ static void uv_relative_path(const WCHAR* filename,
...
@@ -83,6 +83,7 @@ static void uv_relative_path(const WCHAR* filename,
static
int
uv_split_path
(
const
WCHAR
*
filename
,
WCHAR
**
dir
,
static
int
uv_split_path
(
const
WCHAR
*
filename
,
WCHAR
**
dir
,
WCHAR
**
file
)
{
WCHAR
**
file
)
{
size_t
len
,
i
;
size_t
len
,
i
;
DWORD
dir_len
;
if
(
filename
==
NULL
)
{
if
(
filename
==
NULL
)
{
if
(
dir
!=
NULL
)
if
(
dir
!=
NULL
)
...
@@ -97,12 +98,16 @@ static int uv_split_path(const WCHAR* filename, WCHAR** dir,
...
@@ -97,12 +98,16 @@ static int uv_split_path(const WCHAR* filename, WCHAR** dir,
if
(
i
==
0
)
{
if
(
i
==
0
)
{
if
(
dir
)
{
if
(
dir
)
{
*
dir
=
(
WCHAR
*
)
uv__malloc
((
MAX_PATH
+
1
)
*
sizeof
(
WCHAR
));
dir_len
=
GetCurrentDirectoryW
(
0
,
NULL
);
if
(
dir_len
==
0
)
{
return
-
1
;
}
*
dir
=
(
WCHAR
*
)
uv__malloc
(
dir_len
*
sizeof
(
WCHAR
));
if
(
!*
dir
)
{
if
(
!*
dir
)
{
uv_fatal_error
(
ERROR_OUTOFMEMORY
,
"uv__malloc"
);
uv_fatal_error
(
ERROR_OUTOFMEMORY
,
"uv__malloc"
);
}
}
if
(
!
GetCurrentDirectoryW
(
MAX_PATH
,
*
dir
))
{
if
(
!
GetCurrentDirectoryW
(
dir_len
,
*
dir
))
{
uv__free
(
*
dir
);
uv__free
(
*
dir
);
*
dir
=
NULL
;
*
dir
=
NULL
;
return
-
1
;
return
-
1
;
...
@@ -155,9 +160,11 @@ int uv_fs_event_start(uv_fs_event_t* handle,
...
@@ -155,9 +160,11 @@ int uv_fs_event_start(uv_fs_event_t* handle,
int
name_size
,
is_path_dir
,
size
;
int
name_size
,
is_path_dir
,
size
;
DWORD
attr
,
last_error
;
DWORD
attr
,
last_error
;
WCHAR
*
dir
=
NULL
,
*
dir_to_watch
,
*
pathw
=
NULL
;
WCHAR
*
dir
=
NULL
,
*
dir_to_watch
,
*
pathw
=
NULL
;
WCHAR
short_path_buffer
[
MAX_PATH
];
DWORD
short_path_buffer_len
;
WCHAR
*
short_path_buffer
;
WCHAR
*
short_path
,
*
long_path
;
WCHAR
*
short_path
,
*
long_path
;
short_path
=
NULL
;
if
(
uv__is_active
(
handle
))
if
(
uv__is_active
(
handle
))
return
UV_EINVAL
;
return
UV_EINVAL
;
...
@@ -230,13 +237,23 @@ int uv_fs_event_start(uv_fs_event_t* handle,
...
@@ -230,13 +237,23 @@ int uv_fs_event_start(uv_fs_event_t* handle,
*/
*/
/* Convert to short path. */
/* Convert to short path. */
short_path_buffer
=
NULL
;
short_path_buffer_len
=
GetShortPathNameW
(
pathw
,
NULL
,
0
);
if
(
short_path_buffer_len
==
0
)
{
goto
short_path_done
;
}
short_path_buffer
=
uv__malloc
(
short_path_buffer_len
*
sizeof
(
WCHAR
));
if
(
short_path_buffer
==
NULL
)
{
goto
short_path_done
;
}
if
(
GetShortPathNameW
(
pathw
,
if
(
GetShortPathNameW
(
pathw
,
short_path_buffer
,
short_path_buffer
,
ARRAY_SIZE
(
short_path_buffer
)))
{
short_path_buffer_len
)
==
0
)
{
short_path
=
short_path_buffer
;
uv__free
(
short_path_buffer
);
}
else
{
short_path_buffer
=
NULL
;
short_path
=
NULL
;
}
}
short_path_done:
short_path
=
short_path_buffer
;
if
(
uv_split_path
(
pathw
,
&
dir
,
&
handle
->
filew
)
!=
0
)
{
if
(
uv_split_path
(
pathw
,
&
dir
,
&
handle
->
filew
)
!=
0
)
{
last_error
=
GetLastError
();
last_error
=
GetLastError
();
...
@@ -346,6 +363,8 @@ error:
...
@@ -346,6 +363,8 @@ error:
if
(
uv__is_active
(
handle
))
if
(
uv__is_active
(
handle
))
uv__handle_stop
(
handle
);
uv__handle_stop
(
handle
);
uv__free
(
short_path
);
return
uv_translate_sys_error
(
last_error
);
return
uv_translate_sys_error
(
last_error
);
}
}
...
...
deps/libuv/src/win/fs.c
View file @
6026ec09
...
@@ -257,6 +257,7 @@ INLINE static void uv_fs_req_init(uv_loop_t* loop, uv_fs_t* req,
...
@@ -257,6 +257,7 @@ INLINE static void uv_fs_req_init(uv_loop_t* loop, uv_fs_t* req,
req
->
loop
=
loop
;
req
->
loop
=
loop
;
req
->
flags
=
0
;
req
->
flags
=
0
;
req
->
fs_type
=
fs_type
;
req
->
fs_type
=
fs_type
;
req
->
sys_errno_
=
0
;
req
->
result
=
0
;
req
->
result
=
0
;
req
->
ptr
=
NULL
;
req
->
ptr
=
NULL
;
req
->
path
=
NULL
;
req
->
path
=
NULL
;
...
@@ -321,6 +322,8 @@ INLINE static int fs__readlink_handle(HANDLE handle, char** target_ptr,
...
@@ -321,6 +322,8 @@ INLINE static int fs__readlink_handle(HANDLE handle, char** target_ptr,
WCHAR
*
w_target
;
WCHAR
*
w_target
;
DWORD
w_target_len
;
DWORD
w_target_len
;
DWORD
bytes
;
DWORD
bytes
;
size_t
i
;
size_t
len
;
if
(
!
DeviceIoControl
(
handle
,
if
(
!
DeviceIoControl
(
handle
,
FSCTL_GET_REPARSE_POINT
,
FSCTL_GET_REPARSE_POINT
,
...
@@ -405,6 +408,38 @@ INLINE static int fs__readlink_handle(HANDLE handle, char** target_ptr,
...
@@ -405,6 +408,38 @@ INLINE static int fs__readlink_handle(HANDLE handle, char** target_ptr,
w_target
+=
4
;
w_target
+=
4
;
w_target_len
-=
4
;
w_target_len
-=
4
;
}
else
if
(
reparse_data
->
ReparseTag
==
IO_REPARSE_TAG_APPEXECLINK
)
{
/* String #3 in the list has the target filename. */
if
(
reparse_data
->
AppExecLinkReparseBuffer
.
StringCount
<
3
)
{
SetLastError
(
ERROR_SYMLINK_NOT_SUPPORTED
);
return
-
1
;
}
w_target
=
reparse_data
->
AppExecLinkReparseBuffer
.
StringList
;
/* The StringList buffer contains a list of strings separated by "\0", */
/* with "\0\0" terminating the list. Move to the 3rd string in the list: */
for
(
i
=
0
;
i
<
2
;
++
i
)
{
len
=
wcslen
(
w_target
);
if
(
len
==
0
)
{
SetLastError
(
ERROR_SYMLINK_NOT_SUPPORTED
);
return
-
1
;
}
w_target
+=
len
+
1
;
}
w_target_len
=
wcslen
(
w_target
);
if
(
w_target_len
==
0
)
{
SetLastError
(
ERROR_SYMLINK_NOT_SUPPORTED
);
return
-
1
;
}
/* Make sure it is an absolute path. */
if
(
!
(
w_target_len
>=
3
&&
((
w_target
[
0
]
>=
L'a'
&&
w_target
[
0
]
<=
L'z'
)
||
(
w_target
[
0
]
>=
L'A'
&&
w_target
[
0
]
<=
L'Z'
))
&&
w_target
[
1
]
==
L':'
&&
w_target
[
2
]
==
L'\\'
))
{
SetLastError
(
ERROR_SYMLINK_NOT_SUPPORTED
);
return
-
1
;
}
}
else
{
}
else
{
/* Reparse tag does not indicate a symlink. */
/* Reparse tag does not indicate a symlink. */
SetLastError
(
ERROR_SYMLINK_NOT_SUPPORTED
);
SetLastError
(
ERROR_SYMLINK_NOT_SUPPORTED
);
...
@@ -2840,7 +2875,8 @@ int uv_fs_open(uv_loop_t* loop, uv_fs_t* req, const char* path, int flags,
...
@@ -2840,7 +2875,8 @@ int uv_fs_open(uv_loop_t* loop, uv_fs_t* req, const char* path, int flags,
INIT
(
UV_FS_OPEN
);
INIT
(
UV_FS_OPEN
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
info
.
file_flags
=
flags
;
req
->
fs
.
info
.
file_flags
=
flags
;
...
@@ -2865,8 +2901,10 @@ int uv_fs_read(uv_loop_t* loop,
...
@@ -2865,8 +2901,10 @@ int uv_fs_read(uv_loop_t* loop,
uv_fs_cb
cb
)
{
uv_fs_cb
cb
)
{
INIT
(
UV_FS_READ
);
INIT
(
UV_FS_READ
);
if
(
bufs
==
NULL
||
nbufs
==
0
)
if
(
bufs
==
NULL
||
nbufs
==
0
)
{
SET_REQ_UV_ERROR
(
req
,
UV_EINVAL
,
ERROR_INVALID_PARAMETER
);
return
UV_EINVAL
;
return
UV_EINVAL
;
}
req
->
file
.
fd
=
fd
;
req
->
file
.
fd
=
fd
;
...
@@ -2875,8 +2913,10 @@ int uv_fs_read(uv_loop_t* loop,
...
@@ -2875,8 +2913,10 @@ int uv_fs_read(uv_loop_t* loop,
if
(
nbufs
>
ARRAY_SIZE
(
req
->
fs
.
info
.
bufsml
))
if
(
nbufs
>
ARRAY_SIZE
(
req
->
fs
.
info
.
bufsml
))
req
->
fs
.
info
.
bufs
=
uv__malloc
(
nbufs
*
sizeof
(
*
bufs
));
req
->
fs
.
info
.
bufs
=
uv__malloc
(
nbufs
*
sizeof
(
*
bufs
));
if
(
req
->
fs
.
info
.
bufs
==
NULL
)
if
(
req
->
fs
.
info
.
bufs
==
NULL
)
{
SET_REQ_UV_ERROR
(
req
,
UV_ENOMEM
,
ERROR_OUTOFMEMORY
);
return
UV_ENOMEM
;
return
UV_ENOMEM
;
}
memcpy
(
req
->
fs
.
info
.
bufs
,
bufs
,
nbufs
*
sizeof
(
*
bufs
));
memcpy
(
req
->
fs
.
info
.
bufs
,
bufs
,
nbufs
*
sizeof
(
*
bufs
));
...
@@ -2894,8 +2934,10 @@ int uv_fs_write(uv_loop_t* loop,
...
@@ -2894,8 +2934,10 @@ int uv_fs_write(uv_loop_t* loop,
uv_fs_cb
cb
)
{
uv_fs_cb
cb
)
{
INIT
(
UV_FS_WRITE
);
INIT
(
UV_FS_WRITE
);
if
(
bufs
==
NULL
||
nbufs
==
0
)
if
(
bufs
==
NULL
||
nbufs
==
0
)
{
SET_REQ_UV_ERROR
(
req
,
UV_EINVAL
,
ERROR_INVALID_PARAMETER
);
return
UV_EINVAL
;
return
UV_EINVAL
;
}
req
->
file
.
fd
=
fd
;
req
->
file
.
fd
=
fd
;
...
@@ -2904,8 +2946,10 @@ int uv_fs_write(uv_loop_t* loop,
...
@@ -2904,8 +2946,10 @@ int uv_fs_write(uv_loop_t* loop,
if
(
nbufs
>
ARRAY_SIZE
(
req
->
fs
.
info
.
bufsml
))
if
(
nbufs
>
ARRAY_SIZE
(
req
->
fs
.
info
.
bufsml
))
req
->
fs
.
info
.
bufs
=
uv__malloc
(
nbufs
*
sizeof
(
*
bufs
));
req
->
fs
.
info
.
bufs
=
uv__malloc
(
nbufs
*
sizeof
(
*
bufs
));
if
(
req
->
fs
.
info
.
bufs
==
NULL
)
if
(
req
->
fs
.
info
.
bufs
==
NULL
)
{
SET_REQ_UV_ERROR
(
req
,
UV_ENOMEM
,
ERROR_OUTOFMEMORY
);
return
UV_ENOMEM
;
return
UV_ENOMEM
;
}
memcpy
(
req
->
fs
.
info
.
bufs
,
bufs
,
nbufs
*
sizeof
(
*
bufs
));
memcpy
(
req
->
fs
.
info
.
bufs
,
bufs
,
nbufs
*
sizeof
(
*
bufs
));
...
@@ -2921,7 +2965,8 @@ int uv_fs_unlink(uv_loop_t* loop, uv_fs_t* req, const char* path,
...
@@ -2921,7 +2965,8 @@ int uv_fs_unlink(uv_loop_t* loop, uv_fs_t* req, const char* path,
INIT
(
UV_FS_UNLINK
);
INIT
(
UV_FS_UNLINK
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -2935,7 +2980,8 @@ int uv_fs_mkdir(uv_loop_t* loop, uv_fs_t* req, const char* path, int mode,
...
@@ -2935,7 +2980,8 @@ int uv_fs_mkdir(uv_loop_t* loop, uv_fs_t* req, const char* path, int mode,
INIT
(
UV_FS_MKDIR
);
INIT
(
UV_FS_MKDIR
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
info
.
mode
=
mode
;
req
->
fs
.
info
.
mode
=
mode
;
...
@@ -2951,8 +2997,10 @@ int uv_fs_mkdtemp(uv_loop_t* loop,
...
@@ -2951,8 +2997,10 @@ int uv_fs_mkdtemp(uv_loop_t* loop,
INIT
(
UV_FS_MKDTEMP
);
INIT
(
UV_FS_MKDTEMP
);
err
=
fs__capture_path
(
req
,
tpl
,
NULL
,
TRUE
);
err
=
fs__capture_path
(
req
,
tpl
,
NULL
,
TRUE
);
if
(
err
)
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
POST
;
POST
;
}
}
...
@@ -2966,8 +3014,10 @@ int uv_fs_mkstemp(uv_loop_t* loop,
...
@@ -2966,8 +3014,10 @@ int uv_fs_mkstemp(uv_loop_t* loop,
INIT
(
UV_FS_MKSTEMP
);
INIT
(
UV_FS_MKSTEMP
);
err
=
fs__capture_path
(
req
,
tpl
,
NULL
,
TRUE
);
err
=
fs__capture_path
(
req
,
tpl
,
NULL
,
TRUE
);
if
(
err
)
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
POST
;
POST
;
}
}
...
@@ -2979,7 +3029,8 @@ int uv_fs_rmdir(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_fs_cb cb) {
...
@@ -2979,7 +3029,8 @@ int uv_fs_rmdir(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_fs_cb cb) {
INIT
(
UV_FS_RMDIR
);
INIT
(
UV_FS_RMDIR
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -2993,7 +3044,8 @@ int uv_fs_scandir(uv_loop_t* loop, uv_fs_t* req, const char* path, int flags,
...
@@ -2993,7 +3044,8 @@ int uv_fs_scandir(uv_loop_t* loop, uv_fs_t* req, const char* path, int flags,
INIT
(
UV_FS_SCANDIR
);
INIT
(
UV_FS_SCANDIR
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
info
.
file_flags
=
flags
;
req
->
fs
.
info
.
file_flags
=
flags
;
...
@@ -3008,8 +3060,10 @@ int uv_fs_opendir(uv_loop_t* loop,
...
@@ -3008,8 +3060,10 @@ int uv_fs_opendir(uv_loop_t* loop,
INIT
(
UV_FS_OPENDIR
);
INIT
(
UV_FS_OPENDIR
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
POST
;
POST
;
}
}
...
@@ -3022,6 +3076,7 @@ int uv_fs_readdir(uv_loop_t* loop,
...
@@ -3022,6 +3076,7 @@ int uv_fs_readdir(uv_loop_t* loop,
if
(
dir
==
NULL
||
if
(
dir
==
NULL
||
dir
->
dirents
==
NULL
||
dir
->
dirents
==
NULL
||
dir
->
dir_handle
==
INVALID_HANDLE_VALUE
)
{
dir
->
dir_handle
==
INVALID_HANDLE_VALUE
)
{
SET_REQ_UV_ERROR
(
req
,
UV_EINVAL
,
ERROR_INVALID_PARAMETER
);
return
UV_EINVAL
;
return
UV_EINVAL
;
}
}
...
@@ -3034,8 +3089,10 @@ int uv_fs_closedir(uv_loop_t* loop,
...
@@ -3034,8 +3089,10 @@ int uv_fs_closedir(uv_loop_t* loop,
uv_dir_t
*
dir
,
uv_dir_t
*
dir
,
uv_fs_cb
cb
)
{
uv_fs_cb
cb
)
{
INIT
(
UV_FS_CLOSEDIR
);
INIT
(
UV_FS_CLOSEDIR
);
if
(
dir
==
NULL
)
if
(
dir
==
NULL
)
{
SET_REQ_UV_ERROR
(
req
,
UV_EINVAL
,
ERROR_INVALID_PARAMETER
);
return
UV_EINVAL
;
return
UV_EINVAL
;
}
req
->
ptr
=
dir
;
req
->
ptr
=
dir
;
POST
;
POST
;
}
}
...
@@ -3047,7 +3104,8 @@ int uv_fs_link(uv_loop_t* loop, uv_fs_t* req, const char* path,
...
@@ -3047,7 +3104,8 @@ int uv_fs_link(uv_loop_t* loop, uv_fs_t* req, const char* path,
INIT
(
UV_FS_LINK
);
INIT
(
UV_FS_LINK
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3061,7 +3119,8 @@ int uv_fs_symlink(uv_loop_t* loop, uv_fs_t* req, const char* path,
...
@@ -3061,7 +3119,8 @@ int uv_fs_symlink(uv_loop_t* loop, uv_fs_t* req, const char* path,
INIT
(
UV_FS_SYMLINK
);
INIT
(
UV_FS_SYMLINK
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
info
.
file_flags
=
flags
;
req
->
fs
.
info
.
file_flags
=
flags
;
...
@@ -3076,7 +3135,8 @@ int uv_fs_readlink(uv_loop_t* loop, uv_fs_t* req, const char* path,
...
@@ -3076,7 +3135,8 @@ int uv_fs_readlink(uv_loop_t* loop, uv_fs_t* req, const char* path,
INIT
(
UV_FS_READLINK
);
INIT
(
UV_FS_READLINK
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3090,12 +3150,14 @@ int uv_fs_realpath(uv_loop_t* loop, uv_fs_t* req, const char* path,
...
@@ -3090,12 +3150,14 @@ int uv_fs_realpath(uv_loop_t* loop, uv_fs_t* req, const char* path,
INIT
(
UV_FS_REALPATH
);
INIT
(
UV_FS_REALPATH
);
if
(
!
path
)
{
if
(
!
path
)
{
SET_REQ_UV_ERROR
(
req
,
UV_EINVAL
,
ERROR_INVALID_PARAMETER
);
return
UV_EINVAL
;
return
UV_EINVAL
;
}
}
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3109,7 +3171,8 @@ int uv_fs_chown(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_uid_t uid,
...
@@ -3109,7 +3171,8 @@ int uv_fs_chown(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_uid_t uid,
INIT
(
UV_FS_CHOWN
);
INIT
(
UV_FS_CHOWN
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3130,8 +3193,10 @@ int uv_fs_lchown(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_uid_t uid,
...
@@ -3130,8 +3193,10 @@ int uv_fs_lchown(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_uid_t uid,
INIT
(
UV_FS_LCHOWN
);
INIT
(
UV_FS_LCHOWN
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
}
}
...
@@ -3142,7 +3207,8 @@ int uv_fs_stat(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_fs_cb cb) {
...
@@ -3142,7 +3207,8 @@ int uv_fs_stat(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_fs_cb cb) {
INIT
(
UV_FS_STAT
);
INIT
(
UV_FS_STAT
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3155,7 +3221,8 @@ int uv_fs_lstat(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_fs_cb cb) {
...
@@ -3155,7 +3221,8 @@ int uv_fs_lstat(uv_loop_t* loop, uv_fs_t* req, const char* path, uv_fs_cb cb) {
INIT
(
UV_FS_LSTAT
);
INIT
(
UV_FS_LSTAT
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3176,7 +3243,8 @@ int uv_fs_rename(uv_loop_t* loop, uv_fs_t* req, const char* path,
...
@@ -3176,7 +3243,8 @@ int uv_fs_rename(uv_loop_t* loop, uv_fs_t* req, const char* path,
INIT
(
UV_FS_RENAME
);
INIT
(
UV_FS_RENAME
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
POST
;
POST
;
...
@@ -3219,13 +3287,15 @@ int uv_fs_copyfile(uv_loop_t* loop,
...
@@ -3219,13 +3287,15 @@ int uv_fs_copyfile(uv_loop_t* loop,
if
(
flags
&
~
(
UV_FS_COPYFILE_EXCL
|
if
(
flags
&
~
(
UV_FS_COPYFILE_EXCL
|
UV_FS_COPYFILE_FICLONE
|
UV_FS_COPYFILE_FICLONE
|
UV_FS_COPYFILE_FICLONE_FORCE
))
{
UV_FS_COPYFILE_FICLONE_FORCE
))
{
SET_REQ_UV_ERROR
(
req
,
UV_EINVAL
,
ERROR_INVALID_PARAMETER
);
return
UV_EINVAL
;
return
UV_EINVAL
;
}
}
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
new_path
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
uv_translate_sys_error
(
err
);
return
req
->
result
;
}
req
->
fs
.
info
.
file_flags
=
flags
;
req
->
fs
.
info
.
file_flags
=
flags
;
POST
;
POST
;
...
@@ -3252,8 +3322,10 @@ int uv_fs_access(uv_loop_t* loop,
...
@@ -3252,8 +3322,10 @@ int uv_fs_access(uv_loop_t* loop,
INIT
(
UV_FS_ACCESS
);
INIT
(
UV_FS_ACCESS
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
req
->
fs
.
info
.
mode
=
flags
;
req
->
fs
.
info
.
mode
=
flags
;
POST
;
POST
;
...
@@ -3267,7 +3339,8 @@ int uv_fs_chmod(uv_loop_t* loop, uv_fs_t* req, const char* path, int mode,
...
@@ -3267,7 +3339,8 @@ int uv_fs_chmod(uv_loop_t* loop, uv_fs_t* req, const char* path, int mode,
INIT
(
UV_FS_CHMOD
);
INIT
(
UV_FS_CHMOD
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
info
.
mode
=
mode
;
req
->
fs
.
info
.
mode
=
mode
;
...
@@ -3291,7 +3364,8 @@ int uv_fs_utime(uv_loop_t* loop, uv_fs_t* req, const char* path, double atime,
...
@@ -3291,7 +3364,8 @@ int uv_fs_utime(uv_loop_t* loop, uv_fs_t* req, const char* path, double atime,
INIT
(
UV_FS_UTIME
);
INIT
(
UV_FS_UTIME
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
time
.
atime
=
atime
;
req
->
fs
.
time
.
atime
=
atime
;
...
@@ -3316,7 +3390,8 @@ int uv_fs_lutime(uv_loop_t* loop, uv_fs_t* req, const char* path, double atime,
...
@@ -3316,7 +3390,8 @@ int uv_fs_lutime(uv_loop_t* loop, uv_fs_t* req, const char* path, double atime,
INIT
(
UV_FS_LUTIME
);
INIT
(
UV_FS_LUTIME
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
{
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
}
req
->
fs
.
time
.
atime
=
atime
;
req
->
fs
.
time
.
atime
=
atime
;
...
@@ -3333,8 +3408,14 @@ int uv_fs_statfs(uv_loop_t* loop,
...
@@ -3333,8 +3408,14 @@ int uv_fs_statfs(uv_loop_t* loop,
INIT
(
UV_FS_STATFS
);
INIT
(
UV_FS_STATFS
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
err
=
fs__capture_path
(
req
,
path
,
NULL
,
cb
!=
NULL
);
if
(
err
)
if
(
err
)
{
return
uv_translate_sys_error
(
err
);
SET_REQ_WIN32_ERROR
(
req
,
err
);
return
req
->
result
;
}
POST
;
POST
;
}
}
int
uv_fs_get_system_error
(
const
uv_fs_t
*
req
)
{
return
req
->
sys_errno_
;
}
deps/libuv/src/win/poll.c
View file @
6026ec09
...
@@ -134,32 +134,6 @@ static void uv__fast_poll_submit_poll_req(uv_loop_t* loop, uv_poll_t* handle) {
...
@@ -134,32 +134,6 @@ static void uv__fast_poll_submit_poll_req(uv_loop_t* loop, uv_poll_t* handle) {
}
}
static
int
uv__fast_poll_cancel_poll_req
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
)
{
AFD_POLL_INFO
afd_poll_info
;
int
result
;
afd_poll_info
.
Exclusive
=
TRUE
;
afd_poll_info
.
NumberOfHandles
=
1
;
afd_poll_info
.
Timeout
.
QuadPart
=
INT64_MAX
;
afd_poll_info
.
Handles
[
0
].
Handle
=
(
HANDLE
)
handle
->
socket
;
afd_poll_info
.
Handles
[
0
].
Status
=
0
;
afd_poll_info
.
Handles
[
0
].
Events
=
AFD_POLL_ALL
;
result
=
uv_msafd_poll
(
handle
->
socket
,
&
afd_poll_info
,
uv__get_afd_poll_info_dummy
(),
uv__get_overlapped_dummy
());
if
(
result
==
SOCKET_ERROR
)
{
DWORD
error
=
WSAGetLastError
();
if
(
error
!=
WSA_IO_PENDING
)
return
error
;
}
return
0
;
}
static
void
uv__fast_poll_process_poll_req
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
,
static
void
uv__fast_poll_process_poll_req
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
,
uv_req_t
*
req
)
{
uv_req_t
*
req
)
{
unsigned
char
mask_events
;
unsigned
char
mask_events
;
...
@@ -226,44 +200,6 @@ static void uv__fast_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
...
@@ -226,44 +200,6 @@ static void uv__fast_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
}
}
static
int
uv__fast_poll_set
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
,
int
events
)
{
assert
(
handle
->
type
==
UV_POLL
);
assert
(
!
(
handle
->
flags
&
UV_HANDLE_CLOSING
));
assert
((
events
&
~
(
UV_READABLE
|
UV_WRITABLE
|
UV_DISCONNECT
))
==
0
);
handle
->
events
=
events
;
if
(
handle
->
events
!=
0
)
{
uv__handle_start
(
handle
);
}
else
{
uv__handle_stop
(
handle
);
}
if
((
handle
->
events
&
~
(
handle
->
submitted_events_1
|
handle
->
submitted_events_2
))
!=
0
)
{
uv__fast_poll_submit_poll_req
(
handle
->
loop
,
handle
);
}
return
0
;
}
static
int
uv__fast_poll_close
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
)
{
handle
->
events
=
0
;
uv__handle_closing
(
handle
);
if
(
handle
->
submitted_events_1
==
0
&&
handle
->
submitted_events_2
==
0
)
{
uv_want_endgame
(
loop
,
(
uv_handle_t
*
)
handle
);
return
0
;
}
else
{
/* Cancel outstanding poll requests by executing another, unique poll
* request that forces the outstanding ones to return. */
return
uv__fast_poll_cancel_poll_req
(
loop
,
handle
);
}
}
static
SOCKET
uv__fast_poll_create_peer_socket
(
HANDLE
iocp
,
static
SOCKET
uv__fast_poll_create_peer_socket
(
HANDLE
iocp
,
WSAPROTOCOL_INFOW
*
protocol_info
)
{
WSAPROTOCOL_INFOW
*
protocol_info
)
{
SOCKET
sock
=
0
;
SOCKET
sock
=
0
;
...
@@ -469,41 +405,6 @@ static void uv__slow_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
...
@@ -469,41 +405,6 @@ static void uv__slow_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
}
}
static
int
uv__slow_poll_set
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
,
int
events
)
{
assert
(
handle
->
type
==
UV_POLL
);
assert
(
!
(
handle
->
flags
&
UV_HANDLE_CLOSING
));
assert
((
events
&
~
(
UV_READABLE
|
UV_WRITABLE
))
==
0
);
handle
->
events
=
events
;
if
(
handle
->
events
!=
0
)
{
uv__handle_start
(
handle
);
}
else
{
uv__handle_stop
(
handle
);
}
if
((
handle
->
events
&
~
(
handle
->
submitted_events_1
|
handle
->
submitted_events_2
))
!=
0
)
{
uv__slow_poll_submit_poll_req
(
handle
->
loop
,
handle
);
}
return
0
;
}
static
int
uv__slow_poll_close
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
)
{
handle
->
events
=
0
;
uv__handle_closing
(
handle
);
if
(
handle
->
submitted_events_1
==
0
&&
handle
->
submitted_events_2
==
0
)
{
uv_want_endgame
(
loop
,
(
uv_handle_t
*
)
handle
);
}
return
0
;
}
int
uv_poll_init
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
,
int
fd
)
{
int
uv_poll_init
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
,
int
fd
)
{
return
uv_poll_init_socket
(
loop
,
handle
,
(
SOCKET
)
uv__get_osfhandle
(
fd
));
return
uv_poll_init_socket
(
loop
,
handle
,
(
SOCKET
)
uv__get_osfhandle
(
fd
));
}
}
...
@@ -582,35 +483,43 @@ int uv_poll_init_socket(uv_loop_t* loop, uv_poll_t* handle,
...
@@ -582,35 +483,43 @@ int uv_poll_init_socket(uv_loop_t* loop, uv_poll_t* handle,
}
}
int
uv_poll_star
t
(
uv_poll_t
*
handle
,
int
events
,
uv_poll_cb
cb
)
{
static
int
uv__poll_se
t
(
uv_poll_t
*
handle
,
int
events
,
uv_poll_cb
cb
)
{
int
err
;
int
submitted_events
;
if
(
!
(
handle
->
flags
&
UV_HANDLE_POLL_SLOW
))
{
assert
(
handle
->
type
==
UV_POLL
);
err
=
uv__fast_poll_set
(
handle
->
loop
,
handle
,
events
);
assert
(
!
(
handle
->
flags
&
UV_HANDLE_CLOSING
));
}
else
{
assert
((
events
&
~
(
UV_READABLE
|
UV_WRITABLE
|
UV_DISCONNECT
))
==
0
);
err
=
uv__slow_poll_set
(
handle
->
loop
,
handle
,
events
);
}
handle
->
events
=
events
;
handle
->
poll_cb
=
cb
;
if
(
err
)
{
if
(
handle
->
events
==
0
)
{
return
uv_translate_sys_error
(
err
);
uv__handle_stop
(
handle
);
return
0
;
}
}
handle
->
poll_cb
=
cb
;
uv__handle_start
(
handle
);
submitted_events
=
handle
->
submitted_events_1
|
handle
->
submitted_events_2
;
if
(
handle
->
events
&
~
submitted_events
)
{
if
(
handle
->
flags
&
UV_HANDLE_POLL_SLOW
)
{
uv__slow_poll_submit_poll_req
(
handle
->
loop
,
handle
);
}
else
{
uv__fast_poll_submit_poll_req
(
handle
->
loop
,
handle
);
}
}
return
0
;
return
0
;
}
}
int
uv_poll_stop
(
uv_poll_t
*
handle
)
{
int
uv_poll_start
(
uv_poll_t
*
handle
,
int
events
,
uv_poll_cb
cb
)
{
int
err
;
return
uv__poll_set
(
handle
,
events
,
cb
);
}
if
(
!
(
handle
->
flags
&
UV_HANDLE_POLL_SLOW
))
{
err
=
uv__fast_poll_set
(
handle
->
loop
,
handle
,
0
);
}
else
{
err
=
uv__slow_poll_set
(
handle
->
loop
,
handle
,
0
);
}
return
uv_translate_sys_error
(
err
);
int
uv_poll_stop
(
uv_poll_t
*
handle
)
{
return
uv__poll_set
(
handle
,
0
,
handle
->
poll_cb
);
}
}
...
@@ -624,11 +533,43 @@ void uv_process_poll_req(uv_loop_t* loop, uv_poll_t* handle, uv_req_t* req) {
...
@@ -624,11 +533,43 @@ void uv_process_poll_req(uv_loop_t* loop, uv_poll_t* handle, uv_req_t* req) {
int
uv_poll_close
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
)
{
int
uv_poll_close
(
uv_loop_t
*
loop
,
uv_poll_t
*
handle
)
{
if
(
!
(
handle
->
flags
&
UV_HANDLE_POLL_SLOW
))
{
AFD_POLL_INFO
afd_poll_info
;
return
uv__fast_poll_close
(
loop
,
handle
);
DWORD
error
;
}
else
{
int
result
;
return
uv__slow_poll_close
(
loop
,
handle
);
handle
->
events
=
0
;
uv__handle_closing
(
handle
);
if
(
handle
->
submitted_events_1
==
0
&&
handle
->
submitted_events_2
==
0
)
{
uv_want_endgame
(
loop
,
(
uv_handle_t
*
)
handle
);
return
0
;
}
if
(
handle
->
flags
&
UV_HANDLE_POLL_SLOW
)
return
0
;
/* Cancel outstanding poll requests by executing another, unique poll
* request that forces the outstanding ones to return. */
afd_poll_info
.
Exclusive
=
TRUE
;
afd_poll_info
.
NumberOfHandles
=
1
;
afd_poll_info
.
Timeout
.
QuadPart
=
INT64_MAX
;
afd_poll_info
.
Handles
[
0
].
Handle
=
(
HANDLE
)
handle
->
socket
;
afd_poll_info
.
Handles
[
0
].
Status
=
0
;
afd_poll_info
.
Handles
[
0
].
Events
=
AFD_POLL_ALL
;
result
=
uv_msafd_poll
(
handle
->
socket
,
&
afd_poll_info
,
uv__get_afd_poll_info_dummy
(),
uv__get_overlapped_dummy
());
if
(
result
==
SOCKET_ERROR
)
{
error
=
WSAGetLastError
();
if
(
error
!=
WSA_IO_PENDING
)
return
uv_translate_sys_error
(
error
);
}
}
return
0
;
}
}
...
...
deps/libuv/src/win/signal.c
View file @
6026ec09
...
@@ -46,6 +46,11 @@ void uv_signals_init(void) {
...
@@ -46,6 +46,11 @@ void uv_signals_init(void) {
}
}
void
uv__signal_cleanup
(
void
)
{
/* TODO(bnoordhuis) Undo effects of uv_signal_init()? */
}
static
int
uv__signal_compare
(
uv_signal_t
*
w1
,
uv_signal_t
*
w2
)
{
static
int
uv__signal_compare
(
uv_signal_t
*
w1
,
uv_signal_t
*
w2
)
{
/* Compare signums first so all watchers with the same signnum end up
/* Compare signums first so all watchers with the same signnum end up
* adjacent. */
* adjacent. */
...
...
deps/libuv/src/win/udp.c
View file @
6026ec09
...
@@ -125,17 +125,10 @@ static int uv_udp_set_socket(uv_loop_t* loop, uv_udp_t* handle, SOCKET socket,
...
@@ -125,17 +125,10 @@ static int uv_udp_set_socket(uv_loop_t* loop, uv_udp_t* handle, SOCKET socket,
}
}
int
uv_udp_init_ex
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
,
unsigned
int
flags
)
{
int
uv__udp_init_ex
(
uv_loop_t
*
loop
,
int
domain
;
uv_udp_t
*
handle
,
unsigned
flags
,
/* Use the lower 8 bits for the domain */
int
domain
)
{
domain
=
flags
&
0xFF
;
if
(
domain
!=
AF_INET
&&
domain
!=
AF_INET6
&&
domain
!=
AF_UNSPEC
)
return
UV_EINVAL
;
if
(
flags
&
~
0xFF
)
return
UV_EINVAL
;
uv__handle_init
(
loop
,
(
uv_handle_t
*
)
handle
,
UV_UDP
);
uv__handle_init
(
loop
,
(
uv_handle_t
*
)
handle
,
UV_UDP
);
handle
->
socket
=
INVALID_SOCKET
;
handle
->
socket
=
INVALID_SOCKET
;
handle
->
reqs_pending
=
0
;
handle
->
reqs_pending
=
0
;
...
@@ -174,11 +167,6 @@ int uv_udp_init_ex(uv_loop_t* loop, uv_udp_t* handle, unsigned int flags) {
...
@@ -174,11 +167,6 @@ int uv_udp_init_ex(uv_loop_t* loop, uv_udp_t* handle, unsigned int flags) {
}
}
int
uv_udp_init
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
)
{
return
uv_udp_init_ex
(
loop
,
handle
,
AF_UNSPEC
);
}
void
uv_udp_close
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
)
{
void
uv_udp_close
(
uv_loop_t
*
loop
,
uv_udp_t
*
handle
)
{
uv_udp_recv_stop
(
handle
);
uv_udp_recv_stop
(
handle
);
closesocket
(
handle
->
socket
);
closesocket
(
handle
->
socket
);
...
@@ -786,8 +774,10 @@ int uv__udp_set_source_membership6(uv_udp_t* handle,
...
@@ -786,8 +774,10 @@ int uv__udp_set_source_membership6(uv_udp_t* handle,
mreq
.
gsr_interface
=
0
;
mreq
.
gsr_interface
=
0
;
}
}
memcpy
(
&
mreq
.
gsr_group
,
multicast_addr
,
sizeof
(
mreq
.
gsr_group
));
STATIC_ASSERT
(
sizeof
(
mreq
.
gsr_group
)
>=
sizeof
(
*
multicast_addr
));
memcpy
(
&
mreq
.
gsr_source
,
source_addr
,
sizeof
(
mreq
.
gsr_source
));
STATIC_ASSERT
(
sizeof
(
mreq
.
gsr_source
)
>=
sizeof
(
*
source_addr
));
memcpy
(
&
mreq
.
gsr_group
,
multicast_addr
,
sizeof
(
*
multicast_addr
));
memcpy
(
&
mreq
.
gsr_source
,
source_addr
,
sizeof
(
*
source_addr
));
if
(
membership
==
UV_JOIN_GROUP
)
if
(
membership
==
UV_JOIN_GROUP
)
optname
=
MCAST_JOIN_SOURCE_GROUP
;
optname
=
MCAST_JOIN_SOURCE_GROUP
;
...
...
deps/libuv/src/win/util.c
View file @
6026ec09
...
@@ -60,9 +60,6 @@
...
@@ -60,9 +60,6 @@
#endif
#endif
/* Maximum environment variable size, including the terminating null */
#define MAX_ENV_VAR_LENGTH 32767
/* A RtlGenRandom() by any other name... */
/* A RtlGenRandom() by any other name... */
extern
BOOLEAN
NTAPI
SystemFunction036
(
PVOID
Buffer
,
ULONG
BufferLength
);
extern
BOOLEAN
NTAPI
SystemFunction036
(
PVOID
Buffer
,
ULONG
BufferLength
);
...
@@ -154,20 +151,26 @@ int uv_exepath(char* buffer, size_t* size_ptr) {
...
@@ -154,20 +151,26 @@ int uv_exepath(char* buffer, size_t* size_ptr) {
int
uv_cwd
(
char
*
buffer
,
size_t
*
size
)
{
int
uv_cwd
(
char
*
buffer
,
size_t
*
size
)
{
DWORD
utf16_len
;
DWORD
utf16_len
;
WCHAR
utf16_buffer
[
MAX_PATH
]
;
WCHAR
*
utf16_buffer
;
int
r
;
int
r
;
if
(
buffer
==
NULL
||
size
==
NULL
)
{
if
(
buffer
==
NULL
||
size
==
NULL
)
{
return
UV_EINVAL
;
return
UV_EINVAL
;
}
}
utf16_len
=
GetCurrentDirectoryW
(
MAX_PATH
,
utf16_buffer
);
utf16_len
=
GetCurrentDirectoryW
(
0
,
NULL
);
if
(
utf16_len
==
0
)
{
if
(
utf16_len
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
}
else
if
(
utf16_len
>
MAX_PATH
)
{
}
/* This should be impossible; however the CRT has a code path to deal with
utf16_buffer
=
uv__malloc
(
utf16_len
*
sizeof
(
WCHAR
));
* this scenario, so I added a check anyway. */
if
(
utf16_buffer
==
NULL
)
{
return
UV_EIO
;
return
UV_ENOMEM
;
}
utf16_len
=
GetCurrentDirectoryW
(
utf16_len
,
utf16_buffer
);
if
(
utf16_len
==
0
)
{
uv__free
(
utf16_buffer
);
return
uv_translate_sys_error
(
GetLastError
());
}
}
/* utf16_len contains the length, *not* including the terminating null. */
/* utf16_len contains the length, *not* including the terminating null. */
...
@@ -191,8 +194,10 @@ int uv_cwd(char* buffer, size_t* size) {
...
@@ -191,8 +194,10 @@ int uv_cwd(char* buffer, size_t* size) {
NULL
,
NULL
,
NULL
);
NULL
);
if
(
r
==
0
)
{
if
(
r
==
0
)
{
uv__free
(
utf16_buffer
);
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
}
else
if
(
r
>
(
int
)
*
size
)
{
}
else
if
(
r
>
(
int
)
*
size
)
{
uv__free
(
utf16_buffer
);
*
size
=
r
;
*
size
=
r
;
return
UV_ENOBUFS
;
return
UV_ENOBUFS
;
}
}
...
@@ -206,6 +211,8 @@ int uv_cwd(char* buffer, size_t* size) {
...
@@ -206,6 +211,8 @@ int uv_cwd(char* buffer, size_t* size) {
*
size
>
INT_MAX
?
INT_MAX
:
(
int
)
*
size
,
*
size
>
INT_MAX
?
INT_MAX
:
(
int
)
*
size
,
NULL
,
NULL
,
NULL
);
NULL
);
uv__free
(
utf16_buffer
);
if
(
r
==
0
)
{
if
(
r
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
}
}
...
@@ -216,43 +223,61 @@ int uv_cwd(char* buffer, size_t* size) {
...
@@ -216,43 +223,61 @@ int uv_cwd(char* buffer, size_t* size) {
int
uv_chdir
(
const
char
*
dir
)
{
int
uv_chdir
(
const
char
*
dir
)
{
WCHAR
utf16_buffer
[
MAX_PATH
]
;
WCHAR
*
utf16_buffer
;
size_t
utf16_len
;
size_t
utf16_len
,
new_utf16_len
;
WCHAR
drive_letter
,
env_var
[
4
];
WCHAR
drive_letter
,
env_var
[
4
];
if
(
dir
==
NULL
)
{
if
(
dir
==
NULL
)
{
return
UV_EINVAL
;
return
UV_EINVAL
;
}
}
utf16_len
=
MultiByteToWideChar
(
CP_UTF8
,
0
,
dir
,
-
1
,
NULL
,
0
);
if
(
utf16_len
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
}
utf16_buffer
=
uv__malloc
(
utf16_len
*
sizeof
(
WCHAR
));
if
(
utf16_buffer
==
NULL
)
{
return
UV_ENOMEM
;
}
if
(
MultiByteToWideChar
(
CP_UTF8
,
if
(
MultiByteToWideChar
(
CP_UTF8
,
0
,
0
,
dir
,
dir
,
-
1
,
-
1
,
utf16_buffer
,
utf16_buffer
,
MAX_PATH
)
==
0
)
{
utf16_len
)
==
0
)
{
DWORD
error
=
GetLastError
();
uv__free
(
utf16_buffer
);
/* The maximum length of the current working directory is 260 chars,
return
uv_translate_sys_error
(
GetLastError
());
* including terminating null. If it doesn't fit, the path name must be too
* long. */
if
(
error
==
ERROR_INSUFFICIENT_BUFFER
)
{
return
UV_ENAMETOOLONG
;
}
else
{
return
uv_translate_sys_error
(
error
);
}
}
}
if
(
!
SetCurrentDirectoryW
(
utf16_buffer
))
{
if
(
!
SetCurrentDirectoryW
(
utf16_buffer
))
{
uv__free
(
utf16_buffer
);
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
}
}
/* Windows stores the drive-local path in an "hidden" environment variable,
/* Windows stores the drive-local path in an "hidden" environment variable,
* which has the form "=C:=C:\Windows". SetCurrentDirectory does not update
* which has the form "=C:=C:\Windows". SetCurrentDirectory does not update
* this, so we'll have to do it. */
* this, so we'll have to do it. */
utf16_len
=
GetCurrentDirectoryW
(
MAX_PATH
,
utf16_buffer
);
new_utf16_len
=
GetCurrentDirectoryW
(
utf16_len
,
utf16_buffer
);
if
(
new_utf16_len
>
utf16_len
)
{
uv__free
(
utf16_buffer
);
utf16_buffer
=
uv__malloc
(
new_utf16_len
*
sizeof
(
WCHAR
));
if
(
utf16_buffer
==
NULL
)
{
/* When updating the environment variable fails, return UV_OK anyway.
* We did successfully change current working directory, only updating
* hidden env variable failed. */
return
0
;
}
new_utf16_len
=
GetCurrentDirectoryW
(
new_utf16_len
,
utf16_buffer
);
}
if
(
utf16_len
==
0
)
{
if
(
utf16_len
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
uv__free
(
utf16_buffer
);
}
else
if
(
utf16_len
>
MAX_PATH
)
{
return
0
;
return
UV_EIO
;
}
}
/* The returned directory should not have a trailing slash, unless it points
/* The returned directory should not have a trailing slash, unless it points
...
@@ -284,11 +309,10 @@ int uv_chdir(const char* dir) {
...
@@ -284,11 +309,10 @@ int uv_chdir(const char* dir) {
env_var
[
2
]
=
L':'
;
env_var
[
2
]
=
L':'
;
env_var
[
3
]
=
L'\0'
;
env_var
[
3
]
=
L'\0'
;
if
(
!
SetEnvironmentVariableW
(
env_var
,
utf16_buffer
))
{
SetEnvironmentVariableW
(
env_var
,
utf16_buffer
);
return
uv_translate_sys_error
(
GetLastError
());
}
}
}
uv__free
(
utf16_buffer
);
return
0
;
return
0
;
}
}
...
@@ -361,6 +385,10 @@ char** uv_setup_args(int argc, char** argv) {
...
@@ -361,6 +385,10 @@ char** uv_setup_args(int argc, char** argv) {
}
}
void
uv__process_title_cleanup
(
void
)
{
}
int
uv_set_process_title
(
const
char
*
title
)
{
int
uv_set_process_title
(
const
char
*
title
)
{
int
err
;
int
err
;
int
length
;
int
length
;
...
@@ -1163,20 +1191,29 @@ int uv_os_homedir(char* buffer, size_t* size) {
...
@@ -1163,20 +1191,29 @@ int uv_os_homedir(char* buffer, size_t* size) {
int
uv_os_tmpdir
(
char
*
buffer
,
size_t
*
size
)
{
int
uv_os_tmpdir
(
char
*
buffer
,
size_t
*
size
)
{
wchar_t
path
[
MAX_PATH
+
2
]
;
wchar_t
*
path
;
DWORD
bufsize
;
DWORD
bufsize
;
size_t
len
;
size_t
len
;
if
(
buffer
==
NULL
||
size
==
NULL
||
*
size
==
0
)
if
(
buffer
==
NULL
||
size
==
NULL
||
*
size
==
0
)
return
UV_EINVAL
;
return
UV_EINVAL
;
len
=
GetTempPathW
(
ARRAY_SIZE
(
path
),
path
);
len
=
0
;
len
=
GetTempPathW
(
0
,
NULL
);
if
(
len
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
}
/* Include space for terminating null char. */
len
+=
1
;
path
=
uv__malloc
(
len
*
sizeof
(
wchar_t
));
if
(
path
==
NULL
)
{
return
UV_ENOMEM
;
}
len
=
GetTempPathW
(
len
,
path
);
if
(
len
==
0
)
{
if
(
len
==
0
)
{
uv__free
(
path
);
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
}
else
if
(
len
>
ARRAY_SIZE
(
path
))
{
/* This should not be possible */
return
UV_EIO
;
}
}
/* The returned directory should not have a trailing slash, unless it points
/* The returned directory should not have a trailing slash, unless it points
...
@@ -1191,8 +1228,10 @@ int uv_os_tmpdir(char* buffer, size_t* size) {
...
@@ -1191,8 +1228,10 @@ int uv_os_tmpdir(char* buffer, size_t* size) {
bufsize
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
path
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
bufsize
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
path
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
if
(
bufsize
==
0
)
{
if
(
bufsize
==
0
)
{
uv__free
(
path
);
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
}
else
if
(
bufsize
>
*
size
)
{
}
else
if
(
bufsize
>
*
size
)
{
uv__free
(
path
);
*
size
=
bufsize
;
*
size
=
bufsize
;
return
UV_ENOBUFS
;
return
UV_ENOBUFS
;
}
}
...
@@ -1206,6 +1245,7 @@ int uv_os_tmpdir(char* buffer, size_t* size) {
...
@@ -1206,6 +1245,7 @@ int uv_os_tmpdir(char* buffer, size_t* size) {
*
size
,
*
size
,
NULL
,
NULL
,
NULL
);
NULL
);
uv__free
(
path
);
if
(
bufsize
==
0
)
if
(
bufsize
==
0
)
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
...
@@ -1325,7 +1365,7 @@ int uv__convert_utf8_to_utf16(const char* utf8, int utf8len, WCHAR** utf16) {
...
@@ -1325,7 +1365,7 @@ int uv__convert_utf8_to_utf16(const char* utf8, int utf8len, WCHAR** utf16) {
int
uv__getpwuid_r
(
uv_passwd_t
*
pwd
)
{
int
uv__getpwuid_r
(
uv_passwd_t
*
pwd
)
{
HANDLE
token
;
HANDLE
token
;
wchar_t
username
[
UNLEN
+
1
];
wchar_t
username
[
UNLEN
+
1
];
wchar_t
path
[
MAX_PATH
]
;
wchar_t
*
path
;
DWORD
bufsize
;
DWORD
bufsize
;
int
r
;
int
r
;
...
@@ -1336,15 +1376,24 @@ int uv__getpwuid_r(uv_passwd_t* pwd) {
...
@@ -1336,15 +1376,24 @@ int uv__getpwuid_r(uv_passwd_t* pwd) {
if
(
OpenProcessToken
(
GetCurrentProcess
(),
TOKEN_READ
,
&
token
)
==
0
)
if
(
OpenProcessToken
(
GetCurrentProcess
(),
TOKEN_READ
,
&
token
)
==
0
)
return
uv_translate_sys_error
(
GetLastError
());
return
uv_translate_sys_error
(
GetLastError
());
bufsize
=
ARRAY_SIZE
(
path
);
bufsize
=
0
;
if
(
!
GetUserProfileDirectoryW
(
token
,
path
,
&
bufsize
))
{
GetUserProfileDirectoryW
(
token
,
NULL
,
&
bufsize
);
if
(
GetLastError
()
!=
ERROR_INSUFFICIENT_BUFFER
)
{
r
=
GetLastError
();
r
=
GetLastError
();
CloseHandle
(
token
);
CloseHandle
(
token
);
return
uv_translate_sys_error
(
r
);
}
/* This should not be possible */
path
=
uv__malloc
(
bufsize
*
sizeof
(
wchar_t
));
if
(
r
==
ERROR_INSUFFICIENT_BUFFER
)
if
(
path
==
NULL
)
{
return
UV_ENOMEM
;
CloseHandle
(
token
);
return
UV_ENOMEM
;
}
if
(
!
GetUserProfileDirectoryW
(
token
,
path
,
&
bufsize
))
{
r
=
GetLastError
();
CloseHandle
(
token
);
uv__free
(
path
);
return
uv_translate_sys_error
(
r
);
return
uv_translate_sys_error
(
r
);
}
}
...
@@ -1354,6 +1403,7 @@ int uv__getpwuid_r(uv_passwd_t* pwd) {
...
@@ -1354,6 +1403,7 @@ int uv__getpwuid_r(uv_passwd_t* pwd) {
bufsize
=
ARRAY_SIZE
(
username
);
bufsize
=
ARRAY_SIZE
(
username
);
if
(
!
GetUserNameW
(
username
,
&
bufsize
))
{
if
(
!
GetUserNameW
(
username
,
&
bufsize
))
{
r
=
GetLastError
();
r
=
GetLastError
();
uv__free
(
path
);
/* This should not be possible */
/* This should not be possible */
if
(
r
==
ERROR_INSUFFICIENT_BUFFER
)
if
(
r
==
ERROR_INSUFFICIENT_BUFFER
)
...
@@ -1364,6 +1414,7 @@ int uv__getpwuid_r(uv_passwd_t* pwd) {
...
@@ -1364,6 +1414,7 @@ int uv__getpwuid_r(uv_passwd_t* pwd) {
pwd
->
homedir
=
NULL
;
pwd
->
homedir
=
NULL
;
r
=
uv__convert_utf16_to_utf8
(
path
,
-
1
,
&
pwd
->
homedir
);
r
=
uv__convert_utf16_to_utf8
(
path
,
-
1
,
&
pwd
->
homedir
);
uv__free
(
path
);
if
(
r
!=
0
)
if
(
r
!=
0
)
return
r
;
return
r
;
...
@@ -1461,7 +1512,9 @@ fail:
...
@@ -1461,7 +1512,9 @@ fail:
int
uv_os_getenv
(
const
char
*
name
,
char
*
buffer
,
size_t
*
size
)
{
int
uv_os_getenv
(
const
char
*
name
,
char
*
buffer
,
size_t
*
size
)
{
wchar_t
var
[
MAX_ENV_VAR_LENGTH
];
wchar_t
fastvar
[
512
];
wchar_t
*
var
;
DWORD
varlen
;
wchar_t
*
name_w
;
wchar_t
*
name_w
;
DWORD
bufsize
;
DWORD
bufsize
;
size_t
len
;
size_t
len
;
...
@@ -1475,25 +1528,52 @@ int uv_os_getenv(const char* name, char* buffer, size_t* size) {
...
@@ -1475,25 +1528,52 @@ int uv_os_getenv(const char* name, char* buffer, size_t* size) {
if
(
r
!=
0
)
if
(
r
!=
0
)
return
r
;
return
r
;
SetLastError
(
ERROR_SUCCESS
);
var
=
fastvar
;
len
=
GetEnvironmentVariableW
(
name_w
,
var
,
MAX_ENV_VAR_LENGTH
);
varlen
=
ARRAY_SIZE
(
fastvar
);
for
(;;)
{
SetLastError
(
ERROR_SUCCESS
);
len
=
GetEnvironmentVariableW
(
name_w
,
var
,
varlen
);
if
(
len
<
varlen
)
break
;
/* Try repeatedly because we might have been preempted by another thread
* modifying the environment variable just as we're trying to read it.
*/
if
(
var
!=
fastvar
)
uv__free
(
var
);
varlen
=
1
+
len
;
var
=
uv__malloc
(
varlen
*
sizeof
(
*
var
));
if
(
var
==
NULL
)
{
r
=
UV_ENOMEM
;
goto
fail
;
}
}
uv__free
(
name_w
);
uv__free
(
name_w
);
assert
(
len
<
MAX_ENV_VAR_LENGTH
);
/* len does not include the null */
name_w
=
NULL
;
if
(
len
==
0
)
{
if
(
len
==
0
)
{
r
=
GetLastError
();
r
=
GetLastError
();
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
{
return
uv_translate_sys_error
(
r
);
r
=
uv_translate_sys_error
(
r
);
goto
fail
;
}
}
}
/* Check how much space we need */
/* Check how much space we need */
bufsize
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
var
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
bufsize
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
var
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
if
(
bufsize
==
0
)
{
if
(
bufsize
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
r
=
uv_translate_sys_error
(
GetLastError
());
goto
fail
;
}
else
if
(
bufsize
>
*
size
)
{
}
else
if
(
bufsize
>
*
size
)
{
*
size
=
bufsize
;
*
size
=
bufsize
;
return
UV_ENOBUFS
;
r
=
UV_ENOBUFS
;
goto
fail
;
}
}
/* Convert to UTF-8 */
/* Convert to UTF-8 */
...
@@ -1506,11 +1586,23 @@ int uv_os_getenv(const char* name, char* buffer, size_t* size) {
...
@@ -1506,11 +1586,23 @@ int uv_os_getenv(const char* name, char* buffer, size_t* size) {
NULL
,
NULL
,
NULL
);
NULL
);
if
(
bufsize
==
0
)
if
(
bufsize
==
0
)
{
return
uv_translate_sys_error
(
GetLastError
());
r
=
uv_translate_sys_error
(
GetLastError
());
goto
fail
;
}
*
size
=
bufsize
-
1
;
*
size
=
bufsize
-
1
;
return
0
;
r
=
0
;
fail:
if
(
name_w
!=
NULL
)
uv__free
(
name_w
);
if
(
var
!=
fastvar
)
uv__free
(
var
);
return
r
;
}
}
...
...
deps/libuv/src/win/winapi.h
View file @
6026ec09
...
@@ -4152,6 +4152,10 @@ typedef const UNICODE_STRING *PCUNICODE_STRING;
...
@@ -4152,6 +4152,10 @@ typedef const UNICODE_STRING *PCUNICODE_STRING;
struct
{
struct
{
UCHAR
DataBuffer
[
1
];
UCHAR
DataBuffer
[
1
];
}
GenericReparseBuffer
;
}
GenericReparseBuffer
;
struct
{
ULONG
StringCount
;
WCHAR
StringList
[
1
];
}
AppExecLinkReparseBuffer
;
};
};
}
REPARSE_DATA_BUFFER
,
*
PREPARSE_DATA_BUFFER
;
}
REPARSE_DATA_BUFFER
,
*
PREPARSE_DATA_BUFFER
;
#endif
#endif
...
@@ -4517,6 +4521,9 @@ typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION {
...
@@ -4517,6 +4521,9 @@ typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION {
#ifndef IO_REPARSE_TAG_SYMLINK
#ifndef IO_REPARSE_TAG_SYMLINK
# define IO_REPARSE_TAG_SYMLINK (0xA000000CL)
# define IO_REPARSE_TAG_SYMLINK (0xA000000CL)
#endif
#endif
#ifndef IO_REPARSE_TAG_APPEXECLINK
# define IO_REPARSE_TAG_APPEXECLINK (0x8000001BL)
#endif
typedef
VOID
(
NTAPI
*
PIO_APC_ROUTINE
)
typedef
VOID
(
NTAPI
*
PIO_APC_ROUTINE
)
(
PVOID
ApcContext
,
(
PVOID
ApcContext
,
...
...
docs/changes/1621.feature
0 → 100644
View file @
6026ec09
Update
bundled
libuv
from
1.36.0
to
1.38.0.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment