racer 0.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/LICENSE +22 -0
- data/bin/racer +33 -0
- data/ext/libuv/AUTHORS +45 -0
- data/ext/libuv/LICENSE +42 -0
- data/ext/libuv/Makefile +119 -0
- data/ext/libuv/README.md +88 -0
- data/ext/libuv/build/gcc_version.py +20 -0
- data/ext/libuv/common.gypi +176 -0
- data/ext/libuv/config-mingw.mk +61 -0
- data/ext/libuv/config-unix.mk +171 -0
- data/ext/libuv/gyp_uv +64 -0
- data/ext/libuv/include/ares.h +591 -0
- data/ext/libuv/include/ares_version.h +24 -0
- data/ext/libuv/include/uv-private/eio.h +403 -0
- data/ext/libuv/include/uv-private/ev.h +838 -0
- data/ext/libuv/include/uv-private/ngx-queue.h +108 -0
- data/ext/libuv/include/uv-private/tree.h +768 -0
- data/ext/libuv/include/uv-private/uv-unix.h +310 -0
- data/ext/libuv/include/uv-private/uv-win.h +510 -0
- data/ext/libuv/include/uv.h +1796 -0
- data/ext/libuv/src/ares/AUTHORS +37 -0
- data/ext/libuv/src/ares/CHANGES +1218 -0
- data/ext/libuv/src/ares/CMakeLists.txt +22 -0
- data/ext/libuv/src/ares/NEWS +21 -0
- data/ext/libuv/src/ares/README +60 -0
- data/ext/libuv/src/ares/README.cares +13 -0
- data/ext/libuv/src/ares/README.msvc +142 -0
- data/ext/libuv/src/ares/README.node +21 -0
- data/ext/libuv/src/ares/RELEASE-NOTES +26 -0
- data/ext/libuv/src/ares/TODO +23 -0
- data/ext/libuv/src/ares/ares__close_sockets.c +66 -0
- data/ext/libuv/src/ares/ares__get_hostent.c +263 -0
- data/ext/libuv/src/ares/ares__read_line.c +71 -0
- data/ext/libuv/src/ares/ares__timeval.c +111 -0
- data/ext/libuv/src/ares/ares_cancel.c +63 -0
- data/ext/libuv/src/ares/ares_data.c +190 -0
- data/ext/libuv/src/ares/ares_data.h +65 -0
- data/ext/libuv/src/ares/ares_destroy.c +105 -0
- data/ext/libuv/src/ares/ares_dns.h +90 -0
- data/ext/libuv/src/ares/ares_expand_name.c +200 -0
- data/ext/libuv/src/ares/ares_expand_string.c +75 -0
- data/ext/libuv/src/ares/ares_fds.c +63 -0
- data/ext/libuv/src/ares/ares_free_hostent.c +42 -0
- data/ext/libuv/src/ares/ares_free_string.c +25 -0
- data/ext/libuv/src/ares/ares_getenv.c +30 -0
- data/ext/libuv/src/ares/ares_getenv.h +26 -0
- data/ext/libuv/src/ares/ares_gethostbyaddr.c +301 -0
- data/ext/libuv/src/ares/ares_gethostbyname.c +523 -0
- data/ext/libuv/src/ares/ares_getnameinfo.c +427 -0
- data/ext/libuv/src/ares/ares_getopt.c +122 -0
- data/ext/libuv/src/ares/ares_getopt.h +53 -0
- data/ext/libuv/src/ares/ares_getsock.c +72 -0
- data/ext/libuv/src/ares/ares_init.c +1809 -0
- data/ext/libuv/src/ares/ares_iphlpapi.h +221 -0
- data/ext/libuv/src/ares/ares_ipv6.h +78 -0
- data/ext/libuv/src/ares/ares_library_init.c +142 -0
- data/ext/libuv/src/ares/ares_library_init.h +42 -0
- data/ext/libuv/src/ares/ares_llist.c +86 -0
- data/ext/libuv/src/ares/ares_llist.h +42 -0
- data/ext/libuv/src/ares/ares_mkquery.c +195 -0
- data/ext/libuv/src/ares/ares_nowarn.c +181 -0
- data/ext/libuv/src/ares/ares_nowarn.h +55 -0
- data/ext/libuv/src/ares/ares_options.c +248 -0
- data/ext/libuv/src/ares/ares_parse_a_reply.c +263 -0
- data/ext/libuv/src/ares/ares_parse_aaaa_reply.c +259 -0
- data/ext/libuv/src/ares/ares_parse_mx_reply.c +170 -0
- data/ext/libuv/src/ares/ares_parse_ns_reply.c +182 -0
- data/ext/libuv/src/ares/ares_parse_ptr_reply.c +217 -0
- data/ext/libuv/src/ares/ares_parse_srv_reply.c +179 -0
- data/ext/libuv/src/ares/ares_parse_txt_reply.c +201 -0
- data/ext/libuv/src/ares/ares_platform.c +11035 -0
- data/ext/libuv/src/ares/ares_platform.h +43 -0
- data/ext/libuv/src/ares/ares_private.h +355 -0
- data/ext/libuv/src/ares/ares_process.c +1295 -0
- data/ext/libuv/src/ares/ares_query.c +183 -0
- data/ext/libuv/src/ares/ares_rules.h +144 -0
- data/ext/libuv/src/ares/ares_search.c +321 -0
- data/ext/libuv/src/ares/ares_send.c +134 -0
- data/ext/libuv/src/ares/ares_setup.h +199 -0
- data/ext/libuv/src/ares/ares_strcasecmp.c +66 -0
- data/ext/libuv/src/ares/ares_strcasecmp.h +30 -0
- data/ext/libuv/src/ares/ares_strdup.c +42 -0
- data/ext/libuv/src/ares/ares_strdup.h +26 -0
- data/ext/libuv/src/ares/ares_strerror.c +56 -0
- data/ext/libuv/src/ares/ares_timeout.c +80 -0
- data/ext/libuv/src/ares/ares_version.c +11 -0
- data/ext/libuv/src/ares/ares_writev.c +79 -0
- data/ext/libuv/src/ares/ares_writev.h +36 -0
- data/ext/libuv/src/ares/bitncmp.c +59 -0
- data/ext/libuv/src/ares/bitncmp.h +26 -0
- data/ext/libuv/src/ares/config_cygwin/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_darwin/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_freebsd/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_linux/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_netbsd/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_openbsd/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_sunos/ares_config.h +512 -0
- data/ext/libuv/src/ares/config_win32/ares_config.h +369 -0
- data/ext/libuv/src/ares/get_ver.awk +35 -0
- data/ext/libuv/src/ares/inet_net_pton.c +451 -0
- data/ext/libuv/src/ares/inet_net_pton.h +31 -0
- data/ext/libuv/src/ares/inet_ntop.c +208 -0
- data/ext/libuv/src/ares/inet_ntop.h +26 -0
- data/ext/libuv/src/ares/nameser.h +203 -0
- data/ext/libuv/src/ares/setup_once.h +504 -0
- data/ext/libuv/src/ares/windows_port.c +22 -0
- data/ext/libuv/src/cares.c +225 -0
- data/ext/libuv/src/fs-poll.c +237 -0
- data/ext/libuv/src/unix/async.c +119 -0
- data/ext/libuv/src/unix/core.c +647 -0
- data/ext/libuv/src/unix/cygwin.c +84 -0
- data/ext/libuv/src/unix/darwin.c +341 -0
- data/ext/libuv/src/unix/dl.c +83 -0
- data/ext/libuv/src/unix/eio/Changes +63 -0
- data/ext/libuv/src/unix/eio/LICENSE +36 -0
- data/ext/libuv/src/unix/eio/Makefile.am +15 -0
- data/ext/libuv/src/unix/eio/aclocal.m4 +8957 -0
- data/ext/libuv/src/unix/eio/autogen.sh +3 -0
- data/ext/libuv/src/unix/eio/config.h.in +86 -0
- data/ext/libuv/src/unix/eio/config_cygwin.h +80 -0
- data/ext/libuv/src/unix/eio/config_darwin.h +141 -0
- data/ext/libuv/src/unix/eio/config_freebsd.h +81 -0
- data/ext/libuv/src/unix/eio/config_linux.h +94 -0
- data/ext/libuv/src/unix/eio/config_netbsd.h +81 -0
- data/ext/libuv/src/unix/eio/config_openbsd.h +137 -0
- data/ext/libuv/src/unix/eio/config_sunos.h +84 -0
- data/ext/libuv/src/unix/eio/configure.ac +22 -0
- data/ext/libuv/src/unix/eio/demo.c +194 -0
- data/ext/libuv/src/unix/eio/ecb.h +370 -0
- data/ext/libuv/src/unix/eio/eio.3 +3428 -0
- data/ext/libuv/src/unix/eio/eio.c +2593 -0
- data/ext/libuv/src/unix/eio/eio.pod +969 -0
- data/ext/libuv/src/unix/eio/libeio.m4 +195 -0
- data/ext/libuv/src/unix/eio/xthread.h +164 -0
- data/ext/libuv/src/unix/error.c +104 -0
- data/ext/libuv/src/unix/ev/Changes +388 -0
- data/ext/libuv/src/unix/ev/LICENSE +36 -0
- data/ext/libuv/src/unix/ev/Makefile.am +18 -0
- data/ext/libuv/src/unix/ev/Makefile.in +771 -0
- data/ext/libuv/src/unix/ev/README +58 -0
- data/ext/libuv/src/unix/ev/aclocal.m4 +8957 -0
- data/ext/libuv/src/unix/ev/autogen.sh +6 -0
- data/ext/libuv/src/unix/ev/config.guess +1526 -0
- data/ext/libuv/src/unix/ev/config.h.in +125 -0
- data/ext/libuv/src/unix/ev/config.sub +1658 -0
- data/ext/libuv/src/unix/ev/config_cygwin.h +123 -0
- data/ext/libuv/src/unix/ev/config_darwin.h +122 -0
- data/ext/libuv/src/unix/ev/config_freebsd.h +120 -0
- data/ext/libuv/src/unix/ev/config_linux.h +141 -0
- data/ext/libuv/src/unix/ev/config_netbsd.h +120 -0
- data/ext/libuv/src/unix/ev/config_openbsd.h +126 -0
- data/ext/libuv/src/unix/ev/config_sunos.h +122 -0
- data/ext/libuv/src/unix/ev/configure +13037 -0
- data/ext/libuv/src/unix/ev/configure.ac +18 -0
- data/ext/libuv/src/unix/ev/depcomp +630 -0
- data/ext/libuv/src/unix/ev/ev++.h +816 -0
- data/ext/libuv/src/unix/ev/ev.3 +5311 -0
- data/ext/libuv/src/unix/ev/ev.c +3925 -0
- data/ext/libuv/src/unix/ev/ev.pod +5243 -0
- data/ext/libuv/src/unix/ev/ev_epoll.c +266 -0
- data/ext/libuv/src/unix/ev/ev_kqueue.c +235 -0
- data/ext/libuv/src/unix/ev/ev_poll.c +148 -0
- data/ext/libuv/src/unix/ev/ev_port.c +179 -0
- data/ext/libuv/src/unix/ev/ev_select.c +310 -0
- data/ext/libuv/src/unix/ev/ev_vars.h +203 -0
- data/ext/libuv/src/unix/ev/ev_win32.c +153 -0
- data/ext/libuv/src/unix/ev/ev_wrap.h +196 -0
- data/ext/libuv/src/unix/ev/event.c +402 -0
- data/ext/libuv/src/unix/ev/event.h +170 -0
- data/ext/libuv/src/unix/ev/install-sh +294 -0
- data/ext/libuv/src/unix/ev/libev.m4 +39 -0
- data/ext/libuv/src/unix/ev/ltmain.sh +8413 -0
- data/ext/libuv/src/unix/ev/missing +336 -0
- data/ext/libuv/src/unix/ev/mkinstalldirs +111 -0
- data/ext/libuv/src/unix/freebsd.c +312 -0
- data/ext/libuv/src/unix/fs.c +699 -0
- data/ext/libuv/src/unix/internal.h +180 -0
- data/ext/libuv/src/unix/kqueue.c +122 -0
- data/ext/libuv/src/unix/linux/core.c +474 -0
- data/ext/libuv/src/unix/linux/inotify.c +209 -0
- data/ext/libuv/src/unix/linux/syscalls.c +268 -0
- data/ext/libuv/src/unix/linux/syscalls.h +93 -0
- data/ext/libuv/src/unix/loop-watcher.c +63 -0
- data/ext/libuv/src/unix/loop.c +81 -0
- data/ext/libuv/src/unix/netbsd.c +108 -0
- data/ext/libuv/src/unix/openbsd.c +295 -0
- data/ext/libuv/src/unix/pipe.c +261 -0
- data/ext/libuv/src/unix/poll.c +116 -0
- data/ext/libuv/src/unix/process.c +447 -0
- data/ext/libuv/src/unix/stream.c +1026 -0
- data/ext/libuv/src/unix/sunos.c +483 -0
- data/ext/libuv/src/unix/tcp.c +328 -0
- data/ext/libuv/src/unix/thread.c +211 -0
- data/ext/libuv/src/unix/timer.c +138 -0
- data/ext/libuv/src/unix/tty.c +146 -0
- data/ext/libuv/src/unix/udp.c +661 -0
- data/ext/libuv/src/unix/uv-eio.c +107 -0
- data/ext/libuv/src/unix/uv-eio.h +13 -0
- data/ext/libuv/src/uv-common.c +384 -0
- data/ext/libuv/src/uv-common.h +171 -0
- data/ext/libuv/src/win/async.c +130 -0
- data/ext/libuv/src/win/core.c +283 -0
- data/ext/libuv/src/win/dl.c +86 -0
- data/ext/libuv/src/win/error.c +150 -0
- data/ext/libuv/src/win/fs-event.c +512 -0
- data/ext/libuv/src/win/fs.c +1856 -0
- data/ext/libuv/src/win/getaddrinfo.c +365 -0
- data/ext/libuv/src/win/handle-inl.h +145 -0
- data/ext/libuv/src/win/handle.c +150 -0
- data/ext/libuv/src/win/internal.h +337 -0
- data/ext/libuv/src/win/loop-watcher.c +123 -0
- data/ext/libuv/src/win/pipe.c +1675 -0
- data/ext/libuv/src/win/poll.c +618 -0
- data/ext/libuv/src/win/process-stdio.c +479 -0
- data/ext/libuv/src/win/process.c +1013 -0
- data/ext/libuv/src/win/req-inl.h +225 -0
- data/ext/libuv/src/win/req.c +25 -0
- data/ext/libuv/src/win/stream-inl.h +69 -0
- data/ext/libuv/src/win/stream.c +167 -0
- data/ext/libuv/src/win/tcp.c +1400 -0
- data/ext/libuv/src/win/thread.c +372 -0
- data/ext/libuv/src/win/threadpool.c +74 -0
- data/ext/libuv/src/win/timer.c +226 -0
- data/ext/libuv/src/win/tty.c +1801 -0
- data/ext/libuv/src/win/udp.c +718 -0
- data/ext/libuv/src/win/util.c +864 -0
- data/ext/libuv/src/win/winapi.c +132 -0
- data/ext/libuv/src/win/winapi.h +4443 -0
- data/ext/libuv/src/win/winsock.c +557 -0
- data/ext/libuv/src/win/winsock.h +171 -0
- data/ext/libuv/test/benchmark-ares.c +117 -0
- data/ext/libuv/test/benchmark-fs-stat.c +164 -0
- data/ext/libuv/test/benchmark-getaddrinfo.c +94 -0
- data/ext/libuv/test/benchmark-list.h +114 -0
- data/ext/libuv/test/benchmark-loop-count.c +88 -0
- data/ext/libuv/test/benchmark-million-timers.c +65 -0
- data/ext/libuv/test/benchmark-ping-pongs.c +213 -0
- data/ext/libuv/test/benchmark-pound.c +324 -0
- data/ext/libuv/test/benchmark-pump.c +462 -0
- data/ext/libuv/test/benchmark-sizes.c +42 -0
- data/ext/libuv/test/benchmark-spawn.c +162 -0
- data/ext/libuv/test/benchmark-tcp-write-batch.c +140 -0
- data/ext/libuv/test/benchmark-thread.c +64 -0
- data/ext/libuv/test/benchmark-udp-packet-storm.c +247 -0
- data/ext/libuv/test/blackhole-server.c +118 -0
- data/ext/libuv/test/dns-server.c +321 -0
- data/ext/libuv/test/echo-server.c +378 -0
- data/ext/libuv/test/fixtures/empty_file +0 -0
- data/ext/libuv/test/fixtures/load_error.node +1 -0
- data/ext/libuv/test/run-benchmarks.c +64 -0
- data/ext/libuv/test/run-tests.c +138 -0
- data/ext/libuv/test/runner-unix.c +290 -0
- data/ext/libuv/test/runner-unix.h +36 -0
- data/ext/libuv/test/runner-win.c +285 -0
- data/ext/libuv/test/runner-win.h +42 -0
- data/ext/libuv/test/runner.c +326 -0
- data/ext/libuv/test/runner.h +159 -0
- data/ext/libuv/test/task.h +109 -0
- data/ext/libuv/test/test-async.c +118 -0
- data/ext/libuv/test/test-callback-order.c +76 -0
- data/ext/libuv/test/test-callback-stack.c +203 -0
- data/ext/libuv/test/test-connection-fail.c +148 -0
- data/ext/libuv/test/test-counters-init.c +215 -0
- data/ext/libuv/test/test-cwd-and-chdir.c +64 -0
- data/ext/libuv/test/test-delayed-accept.c +197 -0
- data/ext/libuv/test/test-dlerror.c +58 -0
- data/ext/libuv/test/test-error.c +59 -0
- data/ext/libuv/test/test-fail-always.c +29 -0
- data/ext/libuv/test/test-fs-event.c +442 -0
- data/ext/libuv/test/test-fs-poll.c +146 -0
- data/ext/libuv/test/test-fs.c +1843 -0
- data/ext/libuv/test/test-get-currentexe.c +63 -0
- data/ext/libuv/test/test-get-loadavg.c +36 -0
- data/ext/libuv/test/test-get-memory.c +38 -0
- data/ext/libuv/test/test-getaddrinfo.c +122 -0
- data/ext/libuv/test/test-gethostbyname.c +189 -0
- data/ext/libuv/test/test-getsockname.c +342 -0
- data/ext/libuv/test/test-hrtime.c +54 -0
- data/ext/libuv/test/test-idle.c +81 -0
- data/ext/libuv/test/test-ipc-send-recv.c +209 -0
- data/ext/libuv/test/test-ipc.c +620 -0
- data/ext/libuv/test/test-list.h +421 -0
- data/ext/libuv/test/test-loop-handles.c +336 -0
- data/ext/libuv/test/test-multiple-listen.c +102 -0
- data/ext/libuv/test/test-mutexes.c +63 -0
- data/ext/libuv/test/test-pass-always.c +28 -0
- data/ext/libuv/test/test-ping-pong.c +253 -0
- data/ext/libuv/test/test-pipe-bind-error.c +140 -0
- data/ext/libuv/test/test-pipe-connect-error.c +96 -0
- data/ext/libuv/test/test-platform-output.c +87 -0
- data/ext/libuv/test/test-poll-close.c +77 -0
- data/ext/libuv/test/test-poll.c +573 -0
- data/ext/libuv/test/test-process-title.c +42 -0
- data/ext/libuv/test/test-ref.c +338 -0
- data/ext/libuv/test/test-run-once.c +48 -0
- data/ext/libuv/test/test-semaphore.c +111 -0
- data/ext/libuv/test/test-shutdown-close.c +103 -0
- data/ext/libuv/test/test-shutdown-eof.c +183 -0
- data/ext/libuv/test/test-spawn.c +847 -0
- data/ext/libuv/test/test-stdio-over-pipes.c +246 -0
- data/ext/libuv/test/test-tcp-bind-error.c +191 -0
- data/ext/libuv/test/test-tcp-bind6-error.c +154 -0
- data/ext/libuv/test/test-tcp-close-while-connecting.c +80 -0
- data/ext/libuv/test/test-tcp-close.c +129 -0
- data/ext/libuv/test/test-tcp-connect-error-after-write.c +95 -0
- data/ext/libuv/test/test-tcp-connect-error.c +70 -0
- data/ext/libuv/test/test-tcp-connect-timeout.c +85 -0
- data/ext/libuv/test/test-tcp-connect6-error.c +68 -0
- data/ext/libuv/test/test-tcp-flags.c +51 -0
- data/ext/libuv/test/test-tcp-shutdown-after-write.c +131 -0
- data/ext/libuv/test/test-tcp-write-error.c +168 -0
- data/ext/libuv/test/test-tcp-write-to-half-open-connection.c +135 -0
- data/ext/libuv/test/test-tcp-writealot.c +170 -0
- data/ext/libuv/test/test-thread.c +183 -0
- data/ext/libuv/test/test-threadpool.c +57 -0
- data/ext/libuv/test/test-timer-again.c +141 -0
- data/ext/libuv/test/test-timer.c +152 -0
- data/ext/libuv/test/test-tty.c +110 -0
- data/ext/libuv/test/test-udp-dgram-too-big.c +86 -0
- data/ext/libuv/test/test-udp-ipv6.c +156 -0
- data/ext/libuv/test/test-udp-multicast-join.c +139 -0
- data/ext/libuv/test/test-udp-multicast-ttl.c +86 -0
- data/ext/libuv/test/test-udp-options.c +86 -0
- data/ext/libuv/test/test-udp-send-and-recv.c +208 -0
- data/ext/libuv/test/test-util.c +97 -0
- data/ext/libuv/test/test-walk-handles.c +77 -0
- data/ext/libuv/uv.gyp +452 -0
- data/ext/libuv/vcbuild.bat +105 -0
- data/ext/racer/extconf.rb +20 -0
- data/ext/racer/http_parser.c +2059 -0
- data/ext/racer/http_parser.h +318 -0
- data/ext/racer/mkmf.log +22 -0
- data/ext/racer/racer.c +551 -0
- data/lib/racer.rb +2 -0
- data/lib/racer/version.rb +3 -0
- metadata +382 -0
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
/* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
|
|
2
|
+
*
|
|
3
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
4
|
+
* of this software and associated documentation files (the "Software"), to
|
|
5
|
+
* deal in the Software without restriction, including without limitation the
|
|
6
|
+
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
7
|
+
* sell copies of the Software, and to permit persons to whom the Software is
|
|
8
|
+
* furnished to do so, subject to the following conditions:
|
|
9
|
+
*
|
|
10
|
+
* The above copyright notice and this permission notice shall be included in
|
|
11
|
+
* all copies or substantial portions of the Software.
|
|
12
|
+
*
|
|
13
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
14
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
15
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
16
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
17
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
18
|
+
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
19
|
+
* IN THE SOFTWARE.
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
#ifndef UV_UNIX_INTERNAL_H_
|
|
23
|
+
#define UV_UNIX_INTERNAL_H_
|
|
24
|
+
|
|
25
|
+
#include "uv-common.h"
|
|
26
|
+
#include "uv-eio.h"
|
|
27
|
+
|
|
28
|
+
#include <assert.h>
|
|
29
|
+
#include <stdlib.h> /* abort */
|
|
30
|
+
|
|
31
|
+
#if __STRICT_ANSI__
|
|
32
|
+
# define inline __inline
|
|
33
|
+
#endif
|
|
34
|
+
|
|
35
|
+
#undef HAVE_FUTIMES
|
|
36
|
+
#undef HAVE_KQUEUE
|
|
37
|
+
#undef HAVE_PORTS_FS
|
|
38
|
+
|
|
39
|
+
#if __linux__
|
|
40
|
+
# include "linux/syscalls.h"
|
|
41
|
+
# define HAVE_FUTIMES 1 /* emulated with utimesat() */
|
|
42
|
+
#endif /* __linux__ */
|
|
43
|
+
|
|
44
|
+
#if defined(__sun)
|
|
45
|
+
# include <sys/port.h>
|
|
46
|
+
# include <port.h>
|
|
47
|
+
# ifdef PORT_SOURCE_FILE
|
|
48
|
+
# define HAVE_PORTS_FS 1
|
|
49
|
+
# endif
|
|
50
|
+
# define HAVE_FUTIMES 1
|
|
51
|
+
# define futimes(fd, tv) futimesat(fd, (void*)0, tv)
|
|
52
|
+
#endif /* __sun */
|
|
53
|
+
|
|
54
|
+
#if defined(__APPLE__) || defined(__FreeBSD__) || defined(__sun)
|
|
55
|
+
# define HAVE_FUTIMES 1
|
|
56
|
+
#endif
|
|
57
|
+
|
|
58
|
+
/* FIXME exact copy of the #ifdef guard in uv-unix.h */
|
|
59
|
+
#if defined(__APPLE__) \
|
|
60
|
+
|| defined(__FreeBSD__) \
|
|
61
|
+
|| defined(__OpenBSD__) \
|
|
62
|
+
|| defined(__NetBSD__)
|
|
63
|
+
# define HAVE_KQUEUE 1
|
|
64
|
+
#endif
|
|
65
|
+
|
|
66
|
+
#define UNREACHABLE() \
|
|
67
|
+
do { \
|
|
68
|
+
assert(0 && "unreachable code"); \
|
|
69
|
+
abort(); \
|
|
70
|
+
} \
|
|
71
|
+
while (0)
|
|
72
|
+
|
|
73
|
+
#define SAVE_ERRNO(block) \
|
|
74
|
+
do { \
|
|
75
|
+
int _saved_errno = errno; \
|
|
76
|
+
do { block; } while (0); \
|
|
77
|
+
errno = _saved_errno; \
|
|
78
|
+
} \
|
|
79
|
+
while (0)
|
|
80
|
+
|
|
81
|
+
#define UV__IO_READ EV_READ
|
|
82
|
+
#define UV__IO_WRITE EV_WRITE
|
|
83
|
+
#define UV__IO_ERROR EV_ERROR
|
|
84
|
+
|
|
85
|
+
/* flags */
|
|
86
|
+
enum {
|
|
87
|
+
UV_CLOSING = 0x01, /* uv_close() called but not finished. */
|
|
88
|
+
UV_CLOSED = 0x02, /* close(2) finished. */
|
|
89
|
+
UV_STREAM_READING = 0x04, /* uv_read_start() called. */
|
|
90
|
+
UV_STREAM_SHUTTING = 0x08, /* uv_shutdown() called but not complete. */
|
|
91
|
+
UV_STREAM_SHUT = 0x10, /* Write side closed. */
|
|
92
|
+
UV_STREAM_READABLE = 0x20, /* The stream is readable */
|
|
93
|
+
UV_STREAM_WRITABLE = 0x40, /* The stream is writable */
|
|
94
|
+
UV_STREAM_BLOCKING = 0x80, /* Synchronous writes. */
|
|
95
|
+
UV_TCP_NODELAY = 0x100, /* Disable Nagle. */
|
|
96
|
+
UV_TCP_KEEPALIVE = 0x200 /* Turn on keep-alive. */
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
inline static void uv__req_init(uv_loop_t* loop,
|
|
100
|
+
uv_req_t* req,
|
|
101
|
+
uv_req_type type) {
|
|
102
|
+
loop->counters.req_init++;
|
|
103
|
+
req->type = type;
|
|
104
|
+
uv__req_register(loop, req);
|
|
105
|
+
}
|
|
106
|
+
#define uv__req_init(loop, req, type) \
|
|
107
|
+
uv__req_init((loop), (uv_req_t*)(req), (type))
|
|
108
|
+
|
|
109
|
+
/* core */
|
|
110
|
+
void uv__handle_init(uv_loop_t* loop, uv_handle_t* handle, uv_handle_type type);
|
|
111
|
+
int uv__nonblock(int fd, int set);
|
|
112
|
+
int uv__cloexec(int fd, int set);
|
|
113
|
+
int uv__socket(int domain, int type, int protocol);
|
|
114
|
+
int uv__dup(int fd);
|
|
115
|
+
int uv_async_stop(uv_async_t* handle);
|
|
116
|
+
|
|
117
|
+
void uv__io_init(uv__io_t* handle, uv__io_cb cb, int fd, int events);
|
|
118
|
+
void uv__io_set(uv__io_t* handle, uv__io_cb cb, int fd, int events);
|
|
119
|
+
void uv__io_start(uv_loop_t* loop, uv__io_t* handle);
|
|
120
|
+
void uv__io_stop(uv_loop_t* loop, uv__io_t* handle);
|
|
121
|
+
void uv__io_feed(uv_loop_t* loop, uv__io_t* handle, int event);
|
|
122
|
+
int uv__io_active(uv__io_t* handle);
|
|
123
|
+
|
|
124
|
+
/* loop */
|
|
125
|
+
int uv__loop_init(uv_loop_t* loop, int default_loop);
|
|
126
|
+
void uv__loop_delete(uv_loop_t* loop);
|
|
127
|
+
void uv__run_idle(uv_loop_t* loop);
|
|
128
|
+
void uv__run_check(uv_loop_t* loop);
|
|
129
|
+
void uv__run_prepare(uv_loop_t* loop);
|
|
130
|
+
|
|
131
|
+
/* error */
|
|
132
|
+
uv_err_code uv_translate_sys_error(int sys_errno);
|
|
133
|
+
void uv_fatal_error(const int errorno, const char* syscall);
|
|
134
|
+
|
|
135
|
+
/* stream */
|
|
136
|
+
void uv__stream_init(uv_loop_t* loop, uv_stream_t* stream,
|
|
137
|
+
uv_handle_type type);
|
|
138
|
+
int uv__stream_open(uv_stream_t*, int fd, int flags);
|
|
139
|
+
void uv__stream_destroy(uv_stream_t* stream);
|
|
140
|
+
void uv__server_io(uv_loop_t* loop, uv__io_t* watcher, int events);
|
|
141
|
+
int uv__accept(int sockfd);
|
|
142
|
+
int uv__connect(uv_connect_t* req, uv_stream_t* stream, struct sockaddr* addr,
|
|
143
|
+
socklen_t addrlen, uv_connect_cb cb);
|
|
144
|
+
|
|
145
|
+
/* tcp */
|
|
146
|
+
int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb);
|
|
147
|
+
int uv__tcp_nodelay(uv_tcp_t* handle, int enable);
|
|
148
|
+
int uv__tcp_keepalive(uv_tcp_t* handle, int enable, unsigned int delay);
|
|
149
|
+
|
|
150
|
+
/* pipe */
|
|
151
|
+
int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb);
|
|
152
|
+
|
|
153
|
+
/* timer */
|
|
154
|
+
void uv__run_timers(uv_loop_t* loop);
|
|
155
|
+
unsigned int uv__next_timeout(uv_loop_t* loop);
|
|
156
|
+
|
|
157
|
+
/* various */
|
|
158
|
+
void uv__async_close(uv_async_t* handle);
|
|
159
|
+
void uv__check_close(uv_check_t* handle);
|
|
160
|
+
void uv__fs_event_close(uv_fs_event_t* handle);
|
|
161
|
+
void uv__idle_close(uv_idle_t* handle);
|
|
162
|
+
void uv__pipe_close(uv_pipe_t* handle);
|
|
163
|
+
void uv__poll_close(uv_poll_t* handle);
|
|
164
|
+
void uv__prepare_close(uv_prepare_t* handle);
|
|
165
|
+
void uv__process_close(uv_process_t* handle);
|
|
166
|
+
void uv__stream_close(uv_stream_t* handle);
|
|
167
|
+
void uv__timer_close(uv_timer_t* handle);
|
|
168
|
+
void uv__udp_close(uv_udp_t* handle);
|
|
169
|
+
void uv__udp_finish_close(uv_udp_t* handle);
|
|
170
|
+
|
|
171
|
+
#ifdef UV__O_NONBLOCK
|
|
172
|
+
# define UV__F_NONBLOCK UV__O_NONBLOCK
|
|
173
|
+
#else
|
|
174
|
+
# define UV__F_NONBLOCK 1
|
|
175
|
+
#endif
|
|
176
|
+
|
|
177
|
+
int uv__make_socketpair(int fds[2], int flags);
|
|
178
|
+
int uv__make_pipe(int fds[2], int flags);
|
|
179
|
+
|
|
180
|
+
#endif /* UV_UNIX_INTERNAL_H_ */
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
|
|
2
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
3
|
+
* of this software and associated documentation files (the "Software"), to
|
|
4
|
+
* deal in the Software without restriction, including without limitation the
|
|
5
|
+
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
6
|
+
* sell copies of the Software, and to permit persons to whom the Software is
|
|
7
|
+
* furnished to do so, subject to the following conditions:
|
|
8
|
+
*
|
|
9
|
+
* The above copyright notice and this permission notice shall be included in
|
|
10
|
+
* all copies or substantial portions of the Software.
|
|
11
|
+
*
|
|
12
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
13
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
14
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
15
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
16
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
17
|
+
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
18
|
+
* IN THE SOFTWARE.
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
#include "uv.h"
|
|
22
|
+
#include "internal.h"
|
|
23
|
+
|
|
24
|
+
#include <assert.h>
|
|
25
|
+
#include <stdlib.h>
|
|
26
|
+
#include <string.h>
|
|
27
|
+
#include <errno.h>
|
|
28
|
+
|
|
29
|
+
#include <sys/sysctl.h>
|
|
30
|
+
#include <sys/types.h>
|
|
31
|
+
#include <sys/event.h>
|
|
32
|
+
#include <unistd.h>
|
|
33
|
+
#include <fcntl.h>
|
|
34
|
+
#include <time.h>
|
|
35
|
+
|
|
36
|
+
static void uv__fs_event(EV_P_ ev_io* w, int revents);
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
static void uv__fs_event_start(uv_fs_event_t* handle) {
|
|
40
|
+
ev_io_init(&handle->event_watcher,
|
|
41
|
+
uv__fs_event,
|
|
42
|
+
handle->fd,
|
|
43
|
+
EV_LIBUV_KQUEUE_HACK);
|
|
44
|
+
ev_io_start(handle->loop->ev, &handle->event_watcher);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
static void uv__fs_event_stop(uv_fs_event_t* handle) {
|
|
49
|
+
ev_io_stop(handle->loop->ev, &handle->event_watcher);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
static void uv__fs_event(EV_P_ ev_io* w, int revents) {
|
|
54
|
+
uv_fs_event_t* handle;
|
|
55
|
+
int events;
|
|
56
|
+
|
|
57
|
+
assert(revents == EV_LIBUV_KQUEUE_HACK);
|
|
58
|
+
|
|
59
|
+
handle = container_of(w, uv_fs_event_t, event_watcher);
|
|
60
|
+
|
|
61
|
+
if (handle->fflags & (NOTE_ATTRIB | NOTE_EXTEND))
|
|
62
|
+
events = UV_CHANGE;
|
|
63
|
+
else
|
|
64
|
+
events = UV_RENAME;
|
|
65
|
+
|
|
66
|
+
handle->cb(handle, NULL, events, 0);
|
|
67
|
+
|
|
68
|
+
if (handle->fd == -1)
|
|
69
|
+
return;
|
|
70
|
+
|
|
71
|
+
/* File watcher operates in one-shot mode, re-arm it. */
|
|
72
|
+
uv__fs_event_stop(handle);
|
|
73
|
+
uv__fs_event_start(handle);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
/* Called by libev, don't touch. */
|
|
78
|
+
void uv__kqueue_hack(EV_P_ int fflags, ev_io *w) {
|
|
79
|
+
uv_fs_event_t* handle;
|
|
80
|
+
|
|
81
|
+
handle = container_of(w, uv_fs_event_t, event_watcher);
|
|
82
|
+
handle->fflags = fflags;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
int uv_fs_event_init(uv_loop_t* loop,
|
|
87
|
+
uv_fs_event_t* handle,
|
|
88
|
+
const char* filename,
|
|
89
|
+
uv_fs_event_cb cb,
|
|
90
|
+
int flags) {
|
|
91
|
+
int fd;
|
|
92
|
+
|
|
93
|
+
loop->counters.fs_event_init++;
|
|
94
|
+
|
|
95
|
+
/* We don't support any flags yet. */
|
|
96
|
+
assert(!flags);
|
|
97
|
+
|
|
98
|
+
/* TODO open asynchronously - but how do we report back errors? */
|
|
99
|
+
if ((fd = open(filename, O_RDONLY)) == -1) {
|
|
100
|
+
uv__set_sys_error(loop, errno);
|
|
101
|
+
return -1;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
uv__handle_init(loop, (uv_handle_t*)handle, UV_FS_EVENT);
|
|
105
|
+
uv__handle_start(handle); /* FIXME shouldn't start automatically */
|
|
106
|
+
handle->filename = strdup(filename);
|
|
107
|
+
handle->fflags = 0;
|
|
108
|
+
handle->cb = cb;
|
|
109
|
+
handle->fd = fd;
|
|
110
|
+
uv__fs_event_start(handle);
|
|
111
|
+
|
|
112
|
+
return 0;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
|
|
116
|
+
void uv__fs_event_close(uv_fs_event_t* handle) {
|
|
117
|
+
uv__fs_event_stop(handle);
|
|
118
|
+
uv__handle_stop(handle);
|
|
119
|
+
free(handle->filename);
|
|
120
|
+
close(handle->fd);
|
|
121
|
+
handle->fd = -1;
|
|
122
|
+
}
|
|
@@ -0,0 +1,474 @@
|
|
|
1
|
+
/* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
|
|
2
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
3
|
+
* of this software and associated documentation files (the "Software"), to
|
|
4
|
+
* deal in the Software without restriction, including without limitation the
|
|
5
|
+
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
6
|
+
* sell copies of the Software, and to permit persons to whom the Software is
|
|
7
|
+
* furnished to do so, subject to the following conditions:
|
|
8
|
+
*
|
|
9
|
+
* The above copyright notice and this permission notice shall be included in
|
|
10
|
+
* all copies or substantial portions of the Software.
|
|
11
|
+
*
|
|
12
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
13
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
14
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
15
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
16
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
17
|
+
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
18
|
+
* IN THE SOFTWARE.
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
#include "uv.h"
|
|
22
|
+
#include "../internal.h"
|
|
23
|
+
|
|
24
|
+
#include <stdint.h>
|
|
25
|
+
#include <stdio.h>
|
|
26
|
+
#include <stdlib.h>
|
|
27
|
+
#include <string.h>
|
|
28
|
+
#include <assert.h>
|
|
29
|
+
#include <errno.h>
|
|
30
|
+
|
|
31
|
+
#include <net/if.h>
|
|
32
|
+
#include <sys/param.h>
|
|
33
|
+
#include <sys/sysinfo.h>
|
|
34
|
+
#include <unistd.h>
|
|
35
|
+
#include <fcntl.h>
|
|
36
|
+
#include <time.h>
|
|
37
|
+
|
|
38
|
+
#define HAVE_IFADDRS_H 1
|
|
39
|
+
#ifdef __UCLIBC__
|
|
40
|
+
# if __UCLIBC_MAJOR__ < 0 || __UCLIBC_MINOR__ < 9 || __UCLIBC_SUBLEVEL__ < 32
|
|
41
|
+
# undef HAVE_IFADDRS_H
|
|
42
|
+
# endif
|
|
43
|
+
#endif
|
|
44
|
+
#ifdef HAVE_IFADDRS_H
|
|
45
|
+
# include <ifaddrs.h>
|
|
46
|
+
#endif
|
|
47
|
+
|
|
48
|
+
#undef NANOSEC
|
|
49
|
+
#define NANOSEC ((uint64_t) 1e9)
|
|
50
|
+
|
|
51
|
+
/* This is rather annoying: CLOCK_BOOTTIME lives in <linux/time.h> but we can't
|
|
52
|
+
* include that file because it conflicts with <time.h>. We'll just have to
|
|
53
|
+
* define it ourselves.
|
|
54
|
+
*/
|
|
55
|
+
#ifndef CLOCK_BOOTTIME
|
|
56
|
+
# define CLOCK_BOOTTIME 7
|
|
57
|
+
#endif
|
|
58
|
+
|
|
59
|
+
static char buf[MAXPATHLEN + 1];
|
|
60
|
+
|
|
61
|
+
static struct {
|
|
62
|
+
char *str;
|
|
63
|
+
size_t len;
|
|
64
|
+
} process_title;
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
/*
|
|
68
|
+
* There's probably some way to get time from Linux than gettimeofday(). What
|
|
69
|
+
* it is, I don't know.
|
|
70
|
+
*/
|
|
71
|
+
uint64_t uv_hrtime() {
|
|
72
|
+
struct timespec ts;
|
|
73
|
+
clock_gettime(CLOCK_MONOTONIC, &ts);
|
|
74
|
+
return (ts.tv_sec * NANOSEC + ts.tv_nsec);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
void uv_loadavg(double avg[3]) {
|
|
79
|
+
struct sysinfo info;
|
|
80
|
+
|
|
81
|
+
if (sysinfo(&info) < 0) return;
|
|
82
|
+
|
|
83
|
+
avg[0] = (double) info.loads[0] / 65536.0;
|
|
84
|
+
avg[1] = (double) info.loads[1] / 65536.0;
|
|
85
|
+
avg[2] = (double) info.loads[2] / 65536.0;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
int uv_exepath(char* buffer, size_t* size) {
|
|
90
|
+
ssize_t n;
|
|
91
|
+
|
|
92
|
+
if (!buffer || !size) {
|
|
93
|
+
return -1;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
n = readlink("/proc/self/exe", buffer, *size - 1);
|
|
97
|
+
if (n <= 0) return -1;
|
|
98
|
+
buffer[n] = '\0';
|
|
99
|
+
*size = n;
|
|
100
|
+
|
|
101
|
+
return 0;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
uint64_t uv_get_free_memory(void) {
|
|
106
|
+
return (uint64_t) sysconf(_SC_PAGESIZE) * sysconf(_SC_AVPHYS_PAGES);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
uint64_t uv_get_total_memory(void) {
|
|
111
|
+
return (uint64_t) sysconf(_SC_PAGESIZE) * sysconf(_SC_PHYS_PAGES);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
char** uv_setup_args(int argc, char** argv) {
|
|
116
|
+
char **new_argv;
|
|
117
|
+
char **new_env;
|
|
118
|
+
size_t size;
|
|
119
|
+
int envc;
|
|
120
|
+
char *s;
|
|
121
|
+
int i;
|
|
122
|
+
|
|
123
|
+
for (envc = 0; environ[envc]; envc++);
|
|
124
|
+
|
|
125
|
+
s = envc ? environ[envc - 1] : argv[argc - 1];
|
|
126
|
+
|
|
127
|
+
process_title.str = argv[0];
|
|
128
|
+
process_title.len = s + strlen(s) + 1 - argv[0];
|
|
129
|
+
|
|
130
|
+
size = process_title.len;
|
|
131
|
+
size += (argc + 1) * sizeof(char **);
|
|
132
|
+
size += (envc + 1) * sizeof(char **);
|
|
133
|
+
|
|
134
|
+
if ((s = (char *) malloc(size)) == NULL) {
|
|
135
|
+
process_title.str = NULL;
|
|
136
|
+
process_title.len = 0;
|
|
137
|
+
return argv;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
new_argv = (char **) s;
|
|
141
|
+
new_env = new_argv + argc + 1;
|
|
142
|
+
s = (char *) (new_env + envc + 1);
|
|
143
|
+
memcpy(s, process_title.str, process_title.len);
|
|
144
|
+
|
|
145
|
+
for (i = 0; i < argc; i++)
|
|
146
|
+
new_argv[i] = s + (argv[i] - argv[0]);
|
|
147
|
+
new_argv[argc] = NULL;
|
|
148
|
+
|
|
149
|
+
s += environ[0] - argv[0];
|
|
150
|
+
|
|
151
|
+
for (i = 0; i < envc; i++)
|
|
152
|
+
new_env[i] = s + (environ[i] - environ[0]);
|
|
153
|
+
new_env[envc] = NULL;
|
|
154
|
+
|
|
155
|
+
environ = new_env;
|
|
156
|
+
return new_argv;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
|
|
160
|
+
uv_err_t uv_set_process_title(const char* title) {
|
|
161
|
+
/* No need to terminate, last char is always '\0'. */
|
|
162
|
+
if (process_title.len)
|
|
163
|
+
strncpy(process_title.str, title, process_title.len - 1);
|
|
164
|
+
|
|
165
|
+
return uv_ok_;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
|
|
169
|
+
uv_err_t uv_get_process_title(char* buffer, size_t size) {
|
|
170
|
+
if (process_title.str) {
|
|
171
|
+
strncpy(buffer, process_title.str, size);
|
|
172
|
+
} else {
|
|
173
|
+
if (size > 0) {
|
|
174
|
+
buffer[0] = '\0';
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
return uv_ok_;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
uv_err_t uv_resident_set_memory(size_t* rss) {
|
|
183
|
+
FILE* f;
|
|
184
|
+
int itmp;
|
|
185
|
+
char ctmp;
|
|
186
|
+
unsigned int utmp;
|
|
187
|
+
size_t page_size = getpagesize();
|
|
188
|
+
char *cbuf;
|
|
189
|
+
int foundExeEnd;
|
|
190
|
+
|
|
191
|
+
f = fopen("/proc/self/stat", "r");
|
|
192
|
+
if (!f) return uv__new_sys_error(errno);
|
|
193
|
+
|
|
194
|
+
/* PID */
|
|
195
|
+
if (fscanf(f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
196
|
+
/* Exec file */
|
|
197
|
+
cbuf = buf;
|
|
198
|
+
foundExeEnd = 0;
|
|
199
|
+
if (fscanf (f, "%c", cbuf++) == 0) goto error;
|
|
200
|
+
while (1) {
|
|
201
|
+
if (fscanf(f, "%c", cbuf) == 0) goto error;
|
|
202
|
+
if (*cbuf == ')') {
|
|
203
|
+
foundExeEnd = 1;
|
|
204
|
+
} else if (foundExeEnd && *cbuf == ' ') {
|
|
205
|
+
*cbuf = 0;
|
|
206
|
+
break;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
cbuf++;
|
|
210
|
+
}
|
|
211
|
+
/* State */
|
|
212
|
+
if (fscanf (f, "%c ", &ctmp) == 0) goto error; /* coverity[secure_coding] */
|
|
213
|
+
/* Parent process */
|
|
214
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
215
|
+
/* Process group */
|
|
216
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
217
|
+
/* Session id */
|
|
218
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
219
|
+
/* TTY */
|
|
220
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
221
|
+
/* TTY owner process group */
|
|
222
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
223
|
+
/* Flags */
|
|
224
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
225
|
+
/* Minor faults (no memory page) */
|
|
226
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
227
|
+
/* Minor faults, children */
|
|
228
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
229
|
+
/* Major faults (memory page faults) */
|
|
230
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
231
|
+
/* Major faults, children */
|
|
232
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
233
|
+
/* utime */
|
|
234
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
235
|
+
/* stime */
|
|
236
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
237
|
+
/* utime, children */
|
|
238
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
239
|
+
/* stime, children */
|
|
240
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
241
|
+
/* jiffies remaining in current time slice */
|
|
242
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
243
|
+
/* 'nice' value */
|
|
244
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
245
|
+
/* jiffies until next timeout */
|
|
246
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
247
|
+
/* jiffies until next SIGALRM */
|
|
248
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
249
|
+
/* start time (jiffies since system boot) */
|
|
250
|
+
if (fscanf (f, "%d ", &itmp) == 0) goto error; /* coverity[secure_coding] */
|
|
251
|
+
|
|
252
|
+
/* Virtual memory size */
|
|
253
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
254
|
+
|
|
255
|
+
/* Resident set size */
|
|
256
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
257
|
+
*rss = (size_t) utmp * page_size;
|
|
258
|
+
|
|
259
|
+
/* rlim */
|
|
260
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
261
|
+
/* Start of text */
|
|
262
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
263
|
+
/* End of text */
|
|
264
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
265
|
+
/* Start of stack */
|
|
266
|
+
if (fscanf (f, "%u ", &utmp) == 0) goto error; /* coverity[secure_coding] */
|
|
267
|
+
|
|
268
|
+
fclose (f);
|
|
269
|
+
return uv_ok_;
|
|
270
|
+
|
|
271
|
+
error:
|
|
272
|
+
fclose (f);
|
|
273
|
+
return uv__new_sys_error(errno);
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
|
|
277
|
+
uv_err_t uv_uptime(double* uptime) {
|
|
278
|
+
static volatile int no_clock_boottime;
|
|
279
|
+
struct timespec now;
|
|
280
|
+
int r;
|
|
281
|
+
|
|
282
|
+
/* Try CLOCK_BOOTTIME first, fall back to CLOCK_MONOTONIC if not available
|
|
283
|
+
* (pre-2.6.39 kernels). CLOCK_MONOTONIC doesn't increase when the system
|
|
284
|
+
* is suspended.
|
|
285
|
+
*/
|
|
286
|
+
if (no_clock_boottime) {
|
|
287
|
+
retry: r = clock_gettime(CLOCK_MONOTONIC, &now);
|
|
288
|
+
}
|
|
289
|
+
else if ((r = clock_gettime(CLOCK_BOOTTIME, &now)) && errno == EINVAL) {
|
|
290
|
+
no_clock_boottime = 1;
|
|
291
|
+
goto retry;
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
if (r)
|
|
295
|
+
return uv__new_sys_error(errno);
|
|
296
|
+
|
|
297
|
+
*uptime = now.tv_sec;
|
|
298
|
+
*uptime += (double)now.tv_nsec / 1000000000.0;
|
|
299
|
+
return uv_ok_;
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
|
|
303
|
+
uv_err_t uv_cpu_info(uv_cpu_info_t** cpu_infos, int* count) {
|
|
304
|
+
unsigned int ticks = (unsigned int)sysconf(_SC_CLK_TCK),
|
|
305
|
+
multiplier = ((uint64_t)1000L / ticks), cpuspeed;
|
|
306
|
+
int numcpus = 0, i = 0;
|
|
307
|
+
unsigned long ticks_user, ticks_sys, ticks_idle, ticks_nice, ticks_intr;
|
|
308
|
+
char line[512], speedPath[256], model[512];
|
|
309
|
+
FILE *fpStat = fopen("/proc/stat", "r");
|
|
310
|
+
FILE *fpModel = fopen("/proc/cpuinfo", "r");
|
|
311
|
+
FILE *fpSpeed;
|
|
312
|
+
uv_cpu_info_t* cpu_info;
|
|
313
|
+
|
|
314
|
+
if (fpModel) {
|
|
315
|
+
while (fgets(line, 511, fpModel) != NULL) {
|
|
316
|
+
if (strncmp(line, "model name", 10) == 0) {
|
|
317
|
+
numcpus++;
|
|
318
|
+
if (numcpus == 1) {
|
|
319
|
+
char *p = strchr(line, ':') + 2;
|
|
320
|
+
strcpy(model, p);
|
|
321
|
+
model[strlen(model)-1] = 0;
|
|
322
|
+
}
|
|
323
|
+
} else if (strncmp(line, "cpu MHz", 7) == 0) {
|
|
324
|
+
if (numcpus == 1) {
|
|
325
|
+
sscanf(line, "%*s %*s : %u", &cpuspeed);
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
fclose(fpModel);
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
*cpu_infos = (uv_cpu_info_t*)malloc(numcpus * sizeof(uv_cpu_info_t));
|
|
333
|
+
if (!(*cpu_infos)) {
|
|
334
|
+
return uv__new_artificial_error(UV_ENOMEM);
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
*count = numcpus;
|
|
338
|
+
|
|
339
|
+
cpu_info = *cpu_infos;
|
|
340
|
+
|
|
341
|
+
if (fpStat) {
|
|
342
|
+
while (fgets(line, 511, fpStat) != NULL) {
|
|
343
|
+
if (strncmp(line, "cpu ", 4) == 0) {
|
|
344
|
+
continue;
|
|
345
|
+
} else if (strncmp(line, "cpu", 3) != 0) {
|
|
346
|
+
break;
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
sscanf(line, "%*s %lu %lu %lu %lu %*s %lu",
|
|
350
|
+
&ticks_user, &ticks_nice, &ticks_sys, &ticks_idle, &ticks_intr);
|
|
351
|
+
snprintf(speedPath, sizeof(speedPath),
|
|
352
|
+
"/sys/devices/system/cpu/cpu%u/cpufreq/cpuinfo_max_freq", i);
|
|
353
|
+
|
|
354
|
+
fpSpeed = fopen(speedPath, "r");
|
|
355
|
+
|
|
356
|
+
if (fpSpeed) {
|
|
357
|
+
if (fgets(line, 511, fpSpeed) != NULL) {
|
|
358
|
+
sscanf(line, "%u", &cpuspeed);
|
|
359
|
+
cpuspeed /= 1000;
|
|
360
|
+
}
|
|
361
|
+
fclose(fpSpeed);
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
cpu_info->cpu_times.user = ticks_user * multiplier;
|
|
365
|
+
cpu_info->cpu_times.nice = ticks_nice * multiplier;
|
|
366
|
+
cpu_info->cpu_times.sys = ticks_sys * multiplier;
|
|
367
|
+
cpu_info->cpu_times.idle = ticks_idle * multiplier;
|
|
368
|
+
cpu_info->cpu_times.irq = ticks_intr * multiplier;
|
|
369
|
+
|
|
370
|
+
cpu_info->model = strdup(model);
|
|
371
|
+
cpu_info->speed = cpuspeed;
|
|
372
|
+
|
|
373
|
+
cpu_info++;
|
|
374
|
+
}
|
|
375
|
+
fclose(fpStat);
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
return uv_ok_;
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
|
|
382
|
+
void uv_free_cpu_info(uv_cpu_info_t* cpu_infos, int count) {
|
|
383
|
+
int i;
|
|
384
|
+
|
|
385
|
+
for (i = 0; i < count; i++) {
|
|
386
|
+
free(cpu_infos[i].model);
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
free(cpu_infos);
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
|
|
393
|
+
uv_err_t uv_interface_addresses(uv_interface_address_t** addresses,
|
|
394
|
+
int* count) {
|
|
395
|
+
#ifndef HAVE_IFADDRS_H
|
|
396
|
+
return uv__new_artificial_error(UV_ENOSYS);
|
|
397
|
+
#else
|
|
398
|
+
struct ifaddrs *addrs, *ent;
|
|
399
|
+
char ip[INET6_ADDRSTRLEN];
|
|
400
|
+
uv_interface_address_t* address;
|
|
401
|
+
|
|
402
|
+
if (getifaddrs(&addrs) != 0) {
|
|
403
|
+
return uv__new_sys_error(errno);
|
|
404
|
+
}
|
|
405
|
+
|
|
406
|
+
*count = 0;
|
|
407
|
+
|
|
408
|
+
/* Count the number of interfaces */
|
|
409
|
+
for (ent = addrs; ent != NULL; ent = ent->ifa_next) {
|
|
410
|
+
if (!(ent->ifa_flags & IFF_UP && ent->ifa_flags & IFF_RUNNING) ||
|
|
411
|
+
(ent->ifa_addr == NULL) ||
|
|
412
|
+
(ent->ifa_addr->sa_family == PF_PACKET)) {
|
|
413
|
+
continue;
|
|
414
|
+
}
|
|
415
|
+
|
|
416
|
+
(*count)++;
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
*addresses = (uv_interface_address_t*)
|
|
420
|
+
malloc(*count * sizeof(uv_interface_address_t));
|
|
421
|
+
if (!(*addresses)) {
|
|
422
|
+
return uv__new_artificial_error(UV_ENOMEM);
|
|
423
|
+
}
|
|
424
|
+
|
|
425
|
+
address = *addresses;
|
|
426
|
+
|
|
427
|
+
for (ent = addrs; ent != NULL; ent = ent->ifa_next) {
|
|
428
|
+
bzero(&ip, sizeof (ip));
|
|
429
|
+
if (!(ent->ifa_flags & IFF_UP && ent->ifa_flags & IFF_RUNNING)) {
|
|
430
|
+
continue;
|
|
431
|
+
}
|
|
432
|
+
|
|
433
|
+
if (ent->ifa_addr == NULL) {
|
|
434
|
+
continue;
|
|
435
|
+
}
|
|
436
|
+
|
|
437
|
+
/*
|
|
438
|
+
* On Linux getifaddrs returns information related to the raw underlying
|
|
439
|
+
* devices. We're not interested in this information.
|
|
440
|
+
*/
|
|
441
|
+
if (ent->ifa_addr->sa_family == PF_PACKET) {
|
|
442
|
+
continue;
|
|
443
|
+
}
|
|
444
|
+
|
|
445
|
+
address->name = strdup(ent->ifa_name);
|
|
446
|
+
|
|
447
|
+
if (ent->ifa_addr->sa_family == AF_INET6) {
|
|
448
|
+
address->address.address6 = *((struct sockaddr_in6 *)ent->ifa_addr);
|
|
449
|
+
} else {
|
|
450
|
+
address->address.address4 = *((struct sockaddr_in *)ent->ifa_addr);
|
|
451
|
+
}
|
|
452
|
+
|
|
453
|
+
address->is_internal = ent->ifa_flags & IFF_LOOPBACK ? 1 : 0;
|
|
454
|
+
|
|
455
|
+
address++;
|
|
456
|
+
}
|
|
457
|
+
|
|
458
|
+
freeifaddrs(addrs);
|
|
459
|
+
|
|
460
|
+
return uv_ok_;
|
|
461
|
+
#endif
|
|
462
|
+
}
|
|
463
|
+
|
|
464
|
+
|
|
465
|
+
void uv_free_interface_addresses(uv_interface_address_t* addresses,
|
|
466
|
+
int count) {
|
|
467
|
+
int i;
|
|
468
|
+
|
|
469
|
+
for (i = 0; i < count; i++) {
|
|
470
|
+
free(addresses[i].name);
|
|
471
|
+
}
|
|
472
|
+
|
|
473
|
+
free(addresses);
|
|
474
|
+
}
|