racer 0.1.3
Sign up to get free protection for your applications and to get access to all the features.
- 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
|
+
}
|