rbuv 0.0.1 → 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (233) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +5 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +5 -0
  5. data/Gemfile +0 -1
  6. data/README.md +6 -1
  7. data/Rakefile +42 -0
  8. data/deps/libuv/.gitignore +34 -0
  9. data/deps/libuv/.mailmap +16 -0
  10. data/deps/libuv/AUTHORS +81 -0
  11. data/deps/libuv/ChangeLog +45 -0
  12. data/deps/libuv/LICENSE +41 -0
  13. data/deps/libuv/Makefile +53 -0
  14. data/deps/libuv/README.md +118 -0
  15. data/deps/libuv/build.mk +164 -0
  16. data/deps/libuv/checksparse.sh +230 -0
  17. data/deps/libuv/common.gypi +197 -0
  18. data/deps/libuv/config-mingw.mk +48 -0
  19. data/deps/libuv/config-unix.mk +167 -0
  20. data/deps/libuv/gyp_uv +98 -0
  21. data/deps/libuv/include/uv-private/ngx-queue.h +129 -0
  22. data/deps/libuv/include/uv-private/stdint-msvc2008.h +247 -0
  23. data/deps/libuv/include/uv-private/tree.h +768 -0
  24. data/deps/libuv/include/uv-private/uv-bsd.h +34 -0
  25. data/deps/libuv/include/uv-private/uv-darwin.h +61 -0
  26. data/deps/libuv/include/uv-private/uv-linux.h +34 -0
  27. data/deps/libuv/include/uv-private/uv-sunos.h +44 -0
  28. data/deps/libuv/include/uv-private/uv-unix.h +332 -0
  29. data/deps/libuv/include/uv-private/uv-win.h +585 -0
  30. data/deps/libuv/include/uv.h +1987 -0
  31. data/deps/libuv/src/fs-poll.c +248 -0
  32. data/deps/libuv/src/inet.c +298 -0
  33. data/deps/libuv/src/unix/aix.c +393 -0
  34. data/deps/libuv/src/unix/async.c +281 -0
  35. data/deps/libuv/src/unix/core.c +714 -0
  36. data/deps/libuv/src/unix/cygwin.c +93 -0
  37. data/deps/libuv/src/unix/darwin-proctitle.m +78 -0
  38. data/deps/libuv/src/unix/darwin.c +431 -0
  39. data/deps/libuv/src/unix/dl.c +83 -0
  40. data/deps/libuv/src/unix/error.c +109 -0
  41. data/deps/libuv/src/unix/freebsd.c +343 -0
  42. data/deps/libuv/src/unix/fs.c +869 -0
  43. data/deps/libuv/src/unix/fsevents.c +299 -0
  44. data/deps/libuv/src/unix/getaddrinfo.c +159 -0
  45. data/deps/libuv/src/unix/internal.h +259 -0
  46. data/deps/libuv/src/unix/kqueue.c +347 -0
  47. data/deps/libuv/src/unix/linux-core.c +724 -0
  48. data/deps/libuv/src/unix/linux-inotify.c +236 -0
  49. data/deps/libuv/src/unix/linux-syscalls.c +388 -0
  50. data/deps/libuv/src/unix/linux-syscalls.h +150 -0
  51. data/deps/libuv/src/unix/loop-watcher.c +64 -0
  52. data/deps/libuv/src/unix/loop.c +114 -0
  53. data/deps/libuv/src/unix/netbsd.c +353 -0
  54. data/deps/libuv/src/unix/openbsd.c +304 -0
  55. data/deps/libuv/src/unix/pipe.c +261 -0
  56. data/deps/libuv/src/unix/poll.c +108 -0
  57. data/deps/libuv/src/unix/process.c +501 -0
  58. data/deps/libuv/src/unix/proctitle.c +103 -0
  59. data/deps/libuv/src/unix/signal.c +455 -0
  60. data/deps/libuv/src/unix/stream.c +1380 -0
  61. data/deps/libuv/src/unix/sunos.c +647 -0
  62. data/deps/libuv/src/unix/tcp.c +357 -0
  63. data/deps/libuv/src/unix/thread.c +431 -0
  64. data/deps/libuv/src/unix/threadpool.c +286 -0
  65. data/deps/libuv/src/unix/timer.c +153 -0
  66. data/deps/libuv/src/unix/tty.c +179 -0
  67. data/deps/libuv/src/unix/udp.c +715 -0
  68. data/deps/libuv/src/uv-common.c +431 -0
  69. data/deps/libuv/src/uv-common.h +204 -0
  70. data/deps/libuv/src/version.c +60 -0
  71. data/deps/libuv/src/win/async.c +99 -0
  72. data/deps/libuv/src/win/atomicops-inl.h +56 -0
  73. data/deps/libuv/src/win/core.c +310 -0
  74. data/deps/libuv/src/win/dl.c +86 -0
  75. data/deps/libuv/src/win/error.c +164 -0
  76. data/deps/libuv/src/win/fs-event.c +506 -0
  77. data/deps/libuv/src/win/fs.c +1951 -0
  78. data/deps/libuv/src/win/getaddrinfo.c +365 -0
  79. data/deps/libuv/src/win/handle-inl.h +164 -0
  80. data/deps/libuv/src/win/handle.c +153 -0
  81. data/deps/libuv/src/win/internal.h +346 -0
  82. data/deps/libuv/src/win/loop-watcher.c +124 -0
  83. data/deps/libuv/src/win/pipe.c +1656 -0
  84. data/deps/libuv/src/win/poll.c +615 -0
  85. data/deps/libuv/src/win/process-stdio.c +503 -0
  86. data/deps/libuv/src/win/process.c +1048 -0
  87. data/deps/libuv/src/win/req-inl.h +224 -0
  88. data/deps/libuv/src/win/req.c +25 -0
  89. data/deps/libuv/src/win/signal.c +354 -0
  90. data/deps/libuv/src/win/stream-inl.h +67 -0
  91. data/deps/libuv/src/win/stream.c +198 -0
  92. data/deps/libuv/src/win/tcp.c +1422 -0
  93. data/deps/libuv/src/win/thread.c +666 -0
  94. data/deps/libuv/src/win/threadpool.c +82 -0
  95. data/deps/libuv/src/win/timer.c +230 -0
  96. data/deps/libuv/src/win/tty.c +1857 -0
  97. data/deps/libuv/src/win/udp.c +744 -0
  98. data/deps/libuv/src/win/util.c +946 -0
  99. data/deps/libuv/src/win/winapi.c +152 -0
  100. data/deps/libuv/src/win/winapi.h +4476 -0
  101. data/deps/libuv/src/win/winsock.c +560 -0
  102. data/deps/libuv/src/win/winsock.h +171 -0
  103. data/deps/libuv/test/benchmark-async-pummel.c +119 -0
  104. data/deps/libuv/test/benchmark-async.c +139 -0
  105. data/deps/libuv/test/benchmark-fs-stat.c +136 -0
  106. data/deps/libuv/test/benchmark-getaddrinfo.c +91 -0
  107. data/deps/libuv/test/benchmark-list.h +163 -0
  108. data/deps/libuv/test/benchmark-loop-count.c +90 -0
  109. data/deps/libuv/test/benchmark-million-async.c +112 -0
  110. data/deps/libuv/test/benchmark-million-timers.c +77 -0
  111. data/deps/libuv/test/benchmark-multi-accept.c +432 -0
  112. data/deps/libuv/test/benchmark-ping-pongs.c +212 -0
  113. data/deps/libuv/test/benchmark-pound.c +325 -0
  114. data/deps/libuv/test/benchmark-pump.c +459 -0
  115. data/deps/libuv/test/benchmark-sizes.c +45 -0
  116. data/deps/libuv/test/benchmark-spawn.c +163 -0
  117. data/deps/libuv/test/benchmark-tcp-write-batch.c +141 -0
  118. data/deps/libuv/test/benchmark-thread.c +64 -0
  119. data/deps/libuv/test/benchmark-udp-pummel.c +238 -0
  120. data/deps/libuv/test/blackhole-server.c +118 -0
  121. data/deps/libuv/test/dns-server.c +329 -0
  122. data/deps/libuv/test/echo-server.c +384 -0
  123. data/deps/libuv/test/fixtures/empty_file +0 -0
  124. data/deps/libuv/test/fixtures/load_error.node +1 -0
  125. data/deps/libuv/test/run-benchmarks.c +64 -0
  126. data/deps/libuv/test/run-tests.c +159 -0
  127. data/deps/libuv/test/runner-unix.c +328 -0
  128. data/deps/libuv/test/runner-unix.h +36 -0
  129. data/deps/libuv/test/runner-win.c +318 -0
  130. data/deps/libuv/test/runner-win.h +43 -0
  131. data/deps/libuv/test/runner.c +394 -0
  132. data/deps/libuv/test/runner.h +165 -0
  133. data/deps/libuv/test/task.h +122 -0
  134. data/deps/libuv/test/test-active.c +83 -0
  135. data/deps/libuv/test/test-async.c +136 -0
  136. data/deps/libuv/test/test-barrier.c +98 -0
  137. data/deps/libuv/test/test-callback-order.c +77 -0
  138. data/deps/libuv/test/test-callback-stack.c +204 -0
  139. data/deps/libuv/test/test-condvar.c +173 -0
  140. data/deps/libuv/test/test-connection-fail.c +150 -0
  141. data/deps/libuv/test/test-cwd-and-chdir.c +64 -0
  142. data/deps/libuv/test/test-delayed-accept.c +189 -0
  143. data/deps/libuv/test/test-dlerror.c +58 -0
  144. data/deps/libuv/test/test-embed.c +136 -0
  145. data/deps/libuv/test/test-error.c +59 -0
  146. data/deps/libuv/test/test-fail-always.c +29 -0
  147. data/deps/libuv/test/test-fs-event.c +504 -0
  148. data/deps/libuv/test/test-fs-poll.c +148 -0
  149. data/deps/libuv/test/test-fs.c +1899 -0
  150. data/deps/libuv/test/test-get-currentexe.c +63 -0
  151. data/deps/libuv/test/test-get-loadavg.c +36 -0
  152. data/deps/libuv/test/test-get-memory.c +38 -0
  153. data/deps/libuv/test/test-getaddrinfo.c +120 -0
  154. data/deps/libuv/test/test-getsockname.c +344 -0
  155. data/deps/libuv/test/test-hrtime.c +54 -0
  156. data/deps/libuv/test/test-idle.c +82 -0
  157. data/deps/libuv/test/test-ipc-send-recv.c +218 -0
  158. data/deps/libuv/test/test-ipc.c +625 -0
  159. data/deps/libuv/test/test-list.h +492 -0
  160. data/deps/libuv/test/test-loop-handles.c +337 -0
  161. data/deps/libuv/test/test-loop-stop.c +73 -0
  162. data/deps/libuv/test/test-multiple-listen.c +103 -0
  163. data/deps/libuv/test/test-mutexes.c +63 -0
  164. data/deps/libuv/test/test-pass-always.c +28 -0
  165. data/deps/libuv/test/test-ping-pong.c +250 -0
  166. data/deps/libuv/test/test-pipe-bind-error.c +144 -0
  167. data/deps/libuv/test/test-pipe-connect-error.c +98 -0
  168. data/deps/libuv/test/test-platform-output.c +87 -0
  169. data/deps/libuv/test/test-poll-close.c +73 -0
  170. data/deps/libuv/test/test-poll.c +575 -0
  171. data/deps/libuv/test/test-process-title.c +49 -0
  172. data/deps/libuv/test/test-ref.c +415 -0
  173. data/deps/libuv/test/test-run-nowait.c +46 -0
  174. data/deps/libuv/test/test-run-once.c +49 -0
  175. data/deps/libuv/test/test-semaphore.c +111 -0
  176. data/deps/libuv/test/test-shutdown-close.c +105 -0
  177. data/deps/libuv/test/test-shutdown-eof.c +184 -0
  178. data/deps/libuv/test/test-signal-multiple-loops.c +270 -0
  179. data/deps/libuv/test/test-signal.c +152 -0
  180. data/deps/libuv/test/test-spawn.c +938 -0
  181. data/deps/libuv/test/test-stdio-over-pipes.c +250 -0
  182. data/deps/libuv/test/test-tcp-bind-error.c +198 -0
  183. data/deps/libuv/test/test-tcp-bind6-error.c +159 -0
  184. data/deps/libuv/test/test-tcp-close-while-connecting.c +81 -0
  185. data/deps/libuv/test/test-tcp-close.c +130 -0
  186. data/deps/libuv/test/test-tcp-connect-error-after-write.c +96 -0
  187. data/deps/libuv/test/test-tcp-connect-error.c +71 -0
  188. data/deps/libuv/test/test-tcp-connect-timeout.c +86 -0
  189. data/deps/libuv/test/test-tcp-connect6-error.c +69 -0
  190. data/deps/libuv/test/test-tcp-flags.c +52 -0
  191. data/deps/libuv/test/test-tcp-open.c +175 -0
  192. data/deps/libuv/test/test-tcp-read-stop.c +73 -0
  193. data/deps/libuv/test/test-tcp-shutdown-after-write.c +132 -0
  194. data/deps/libuv/test/test-tcp-unexpected-read.c +114 -0
  195. data/deps/libuv/test/test-tcp-write-to-half-open-connection.c +136 -0
  196. data/deps/libuv/test/test-tcp-writealot.c +171 -0
  197. data/deps/libuv/test/test-thread.c +183 -0
  198. data/deps/libuv/test/test-threadpool-cancel.c +311 -0
  199. data/deps/libuv/test/test-threadpool.c +77 -0
  200. data/deps/libuv/test/test-timer-again.c +142 -0
  201. data/deps/libuv/test/test-timer.c +266 -0
  202. data/deps/libuv/test/test-tty.c +111 -0
  203. data/deps/libuv/test/test-udp-dgram-too-big.c +87 -0
  204. data/deps/libuv/test/test-udp-ipv6.c +158 -0
  205. data/deps/libuv/test/test-udp-multicast-join.c +140 -0
  206. data/deps/libuv/test/test-udp-multicast-ttl.c +87 -0
  207. data/deps/libuv/test/test-udp-open.c +154 -0
  208. data/deps/libuv/test/test-udp-options.c +87 -0
  209. data/deps/libuv/test/test-udp-send-and-recv.c +210 -0
  210. data/deps/libuv/test/test-util.c +97 -0
  211. data/deps/libuv/test/test-walk-handles.c +78 -0
  212. data/deps/libuv/uv.gyp +431 -0
  213. data/deps/libuv/vcbuild.bat +128 -0
  214. data/ext/rbuv/debug.h +27 -0
  215. data/ext/rbuv/error.c +7 -0
  216. data/ext/rbuv/error.h +10 -0
  217. data/ext/rbuv/extconf.rb +35 -0
  218. data/ext/rbuv/handle.c +40 -0
  219. data/ext/rbuv/handle.h +14 -0
  220. data/ext/rbuv/libuv.mk +12 -0
  221. data/ext/rbuv/loop.c +50 -0
  222. data/ext/rbuv/loop.h +13 -0
  223. data/ext/rbuv/rbuv.c +15 -0
  224. data/ext/rbuv/rbuv.h +27 -0
  225. data/ext/rbuv/timer.c +133 -0
  226. data/ext/rbuv/timer.h +13 -0
  227. data/lib/rbuv/timer.rb +7 -0
  228. data/lib/rbuv/version.rb +1 -1
  229. data/lib/rbuv.rb +24 -2
  230. data/rbuv.gemspec +5 -1
  231. data/spec/spec_helper.rb +22 -0
  232. data/spec/timer_spec.rb +144 -0
  233. metadata +278 -9
@@ -0,0 +1,365 @@
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
+ #include <assert.h>
23
+ #include <malloc.h>
24
+
25
+ #include "uv.h"
26
+ #include "internal.h"
27
+ #include "req-inl.h"
28
+
29
+
30
+ /*
31
+ * MinGW is missing this
32
+ */
33
+ #if !defined(_MSC_VER) && !defined(__MINGW64_VERSION_MAJOR)
34
+ typedef struct addrinfoW {
35
+ int ai_flags;
36
+ int ai_family;
37
+ int ai_socktype;
38
+ int ai_protocol;
39
+ size_t ai_addrlen;
40
+ WCHAR* ai_canonname;
41
+ struct sockaddr* ai_addr;
42
+ struct addrinfoW* ai_next;
43
+ } ADDRINFOW, *PADDRINFOW;
44
+
45
+ DECLSPEC_IMPORT int WSAAPI GetAddrInfoW(const WCHAR* node,
46
+ const WCHAR* service,
47
+ const ADDRINFOW* hints,
48
+ PADDRINFOW* result);
49
+
50
+ DECLSPEC_IMPORT void WSAAPI FreeAddrInfoW(PADDRINFOW pAddrInfo);
51
+ #endif
52
+
53
+
54
+ /* adjust size value to be multiple of 4. Use to keep pointer aligned */
55
+ /* Do we need different versions of this for different architectures? */
56
+ #define ALIGNED_SIZE(X) ((((X) + 3) >> 2) << 2)
57
+
58
+
59
+ /*
60
+ * getaddrinfo error code mapping
61
+ * Falls back to uv_translate_sys_error if no match
62
+ */
63
+ static uv_err_code uv_translate_eai_error(int eai_errno) {
64
+ switch (eai_errno) {
65
+ case ERROR_SUCCESS: return UV_OK;
66
+ case EAI_BADFLAGS: return UV_EBADF;
67
+ case EAI_FAIL: return UV_EFAULT;
68
+ case EAI_FAMILY: return UV_EAIFAMNOSUPPORT;
69
+ case EAI_MEMORY: return UV_ENOMEM;
70
+ case EAI_NONAME: return UV_ENOENT;
71
+ case EAI_AGAIN: return UV_EAGAIN;
72
+ case EAI_SERVICE: return UV_EAISERVICE;
73
+ case EAI_SOCKTYPE: return UV_EAISOCKTYPE;
74
+ default: return uv_translate_sys_error(eai_errno);
75
+ }
76
+ }
77
+
78
+
79
+ /* getaddrinfo worker thread implementation */
80
+ static DWORD WINAPI getaddrinfo_thread_proc(void* parameter) {
81
+ uv_getaddrinfo_t* req = (uv_getaddrinfo_t*) parameter;
82
+ uv_loop_t* loop = req->loop;
83
+ int ret;
84
+
85
+ assert(req != NULL);
86
+
87
+ /* call OS function on this thread */
88
+ ret = GetAddrInfoW(req->node,
89
+ req->service,
90
+ req->hints,
91
+ &req->res);
92
+ req->retcode = ret;
93
+
94
+ /* post getaddrinfo completed */
95
+ POST_COMPLETION_FOR_REQ(loop, req);
96
+
97
+ return 0;
98
+ }
99
+
100
+
101
+ /*
102
+ * Called from uv_run when complete. Call user specified callback
103
+ * then free returned addrinfo
104
+ * Returned addrinfo strings are converted from UTF-16 to UTF-8.
105
+ *
106
+ * To minimize allocation we calculate total size required,
107
+ * and copy all structs and referenced strings into the one block.
108
+ * Each size calculation is adjusted to avoid unaligned pointers.
109
+ */
110
+ void uv_process_getaddrinfo_req(uv_loop_t* loop, uv_getaddrinfo_t* req) {
111
+ int addrinfo_len = 0;
112
+ int name_len = 0;
113
+ size_t addrinfo_struct_len = ALIGNED_SIZE(sizeof(struct addrinfo));
114
+ struct addrinfoW* addrinfow_ptr;
115
+ struct addrinfo* addrinfo_ptr;
116
+ char* alloc_ptr = NULL;
117
+ char* cur_ptr = NULL;
118
+ int status = 0;
119
+
120
+ /* release input parameter memory */
121
+ if (req->alloc != NULL) {
122
+ free(req->alloc);
123
+ req->alloc = NULL;
124
+ }
125
+
126
+ if (req->retcode == 0) {
127
+ /* convert addrinfoW to addrinfo */
128
+ /* first calculate required length */
129
+ addrinfow_ptr = req->res;
130
+ while (addrinfow_ptr != NULL) {
131
+ addrinfo_len += addrinfo_struct_len +
132
+ ALIGNED_SIZE(addrinfow_ptr->ai_addrlen);
133
+ if (addrinfow_ptr->ai_canonname != NULL) {
134
+ name_len = uv_utf16_to_utf8(addrinfow_ptr->ai_canonname, -1, NULL, 0);
135
+ if (name_len == 0) {
136
+ uv__set_sys_error(loop, GetLastError());
137
+ status = -1;
138
+ goto complete;
139
+ }
140
+ addrinfo_len += ALIGNED_SIZE(name_len);
141
+ }
142
+ addrinfow_ptr = addrinfow_ptr->ai_next;
143
+ }
144
+
145
+ /* allocate memory for addrinfo results */
146
+ alloc_ptr = (char*)malloc(addrinfo_len);
147
+
148
+ /* do conversions */
149
+ if (alloc_ptr != NULL) {
150
+ cur_ptr = alloc_ptr;
151
+ addrinfow_ptr = req->res;
152
+
153
+ while (addrinfow_ptr != NULL) {
154
+ /* copy addrinfo struct data */
155
+ assert(cur_ptr + addrinfo_struct_len <= alloc_ptr + addrinfo_len);
156
+ addrinfo_ptr = (struct addrinfo*)cur_ptr;
157
+ addrinfo_ptr->ai_family = addrinfow_ptr->ai_family;
158
+ addrinfo_ptr->ai_socktype = addrinfow_ptr->ai_socktype;
159
+ addrinfo_ptr->ai_protocol = addrinfow_ptr->ai_protocol;
160
+ addrinfo_ptr->ai_flags = addrinfow_ptr->ai_flags;
161
+ addrinfo_ptr->ai_addrlen = addrinfow_ptr->ai_addrlen;
162
+ addrinfo_ptr->ai_canonname = NULL;
163
+ addrinfo_ptr->ai_addr = NULL;
164
+ addrinfo_ptr->ai_next = NULL;
165
+
166
+ cur_ptr += addrinfo_struct_len;
167
+
168
+ /* copy sockaddr */
169
+ if (addrinfo_ptr->ai_addrlen > 0) {
170
+ assert(cur_ptr + addrinfo_ptr->ai_addrlen <=
171
+ alloc_ptr + addrinfo_len);
172
+ memcpy(cur_ptr, addrinfow_ptr->ai_addr, addrinfo_ptr->ai_addrlen);
173
+ addrinfo_ptr->ai_addr = (struct sockaddr*)cur_ptr;
174
+ cur_ptr += ALIGNED_SIZE(addrinfo_ptr->ai_addrlen);
175
+ }
176
+
177
+ /* convert canonical name to UTF-8 */
178
+ if (addrinfow_ptr->ai_canonname != NULL) {
179
+ name_len = uv_utf16_to_utf8(addrinfow_ptr->ai_canonname,
180
+ -1,
181
+ NULL,
182
+ 0);
183
+ assert(name_len > 0);
184
+ assert(cur_ptr + name_len <= alloc_ptr + addrinfo_len);
185
+ name_len = uv_utf16_to_utf8(addrinfow_ptr->ai_canonname,
186
+ -1,
187
+ cur_ptr,
188
+ name_len);
189
+ assert(name_len > 0);
190
+ addrinfo_ptr->ai_canonname = cur_ptr;
191
+ cur_ptr += ALIGNED_SIZE(name_len);
192
+ }
193
+ assert(cur_ptr <= alloc_ptr + addrinfo_len);
194
+
195
+ /* set next ptr */
196
+ addrinfow_ptr = addrinfow_ptr->ai_next;
197
+ if (addrinfow_ptr != NULL) {
198
+ addrinfo_ptr->ai_next = (struct addrinfo*)cur_ptr;
199
+ }
200
+ }
201
+ } else {
202
+ uv__set_artificial_error(loop, UV_ENOMEM);
203
+ status = -1;
204
+ }
205
+ } else {
206
+ /* GetAddrInfo failed */
207
+ uv__set_artificial_error(loop, uv_translate_eai_error(req->retcode));
208
+ status = -1;
209
+ }
210
+
211
+ /* return memory to system */
212
+ if (req->res != NULL) {
213
+ FreeAddrInfoW(req->res);
214
+ req->res = NULL;
215
+ }
216
+
217
+ complete:
218
+ uv__req_unregister(loop, req);
219
+
220
+ /* finally do callback with converted result */
221
+ req->getaddrinfo_cb(req, status, (struct addrinfo*)alloc_ptr);
222
+ }
223
+
224
+
225
+ void uv_freeaddrinfo(struct addrinfo* ai) {
226
+ char* alloc_ptr = (char*)ai;
227
+
228
+ /* release copied result memory */
229
+ if (alloc_ptr != NULL) {
230
+ free(alloc_ptr);
231
+ }
232
+ }
233
+
234
+
235
+ /*
236
+ * Entry point for getaddrinfo
237
+ * we convert the UTF-8 strings to UNICODE
238
+ * and save the UNICODE string pointers in the req
239
+ * We also copy hints so that caller does not need to keep memory until the
240
+ * callback.
241
+ * return UV_OK if a callback will be made
242
+ * return error code if validation fails
243
+ *
244
+ * To minimize allocation we calculate total size required,
245
+ * and copy all structs and referenced strings into the one block.
246
+ * Each size calculation is adjusted to avoid unaligned pointers.
247
+ */
248
+ int uv_getaddrinfo(uv_loop_t* loop,
249
+ uv_getaddrinfo_t* req,
250
+ uv_getaddrinfo_cb getaddrinfo_cb,
251
+ const char* node,
252
+ const char* service,
253
+ const struct addrinfo* hints) {
254
+ int nodesize = 0;
255
+ int servicesize = 0;
256
+ int hintssize = 0;
257
+ char* alloc_ptr = NULL;
258
+
259
+ if (req == NULL || getaddrinfo_cb == NULL ||
260
+ (node == NULL && service == NULL)) {
261
+ uv__set_sys_error(loop, WSAEINVAL);
262
+ goto error;
263
+ }
264
+
265
+ uv_req_init(loop, (uv_req_t*)req);
266
+
267
+ req->getaddrinfo_cb = getaddrinfo_cb;
268
+ req->res = NULL;
269
+ req->type = UV_GETADDRINFO;
270
+ req->loop = loop;
271
+
272
+ /* calculate required memory size for all input values */
273
+ if (node != NULL) {
274
+ nodesize = ALIGNED_SIZE(uv_utf8_to_utf16(node, NULL, 0) * sizeof(WCHAR));
275
+ if (nodesize == 0) {
276
+ uv__set_sys_error(loop, GetLastError());
277
+ goto error;
278
+ }
279
+ }
280
+
281
+ if (service != NULL) {
282
+ servicesize = ALIGNED_SIZE(uv_utf8_to_utf16(service, NULL, 0) *
283
+ sizeof(WCHAR));
284
+ if (servicesize == 0) {
285
+ uv__set_sys_error(loop, GetLastError());
286
+ goto error;
287
+ }
288
+ }
289
+ if (hints != NULL) {
290
+ hintssize = ALIGNED_SIZE(sizeof(struct addrinfoW));
291
+ }
292
+
293
+ /* allocate memory for inputs, and partition it as needed */
294
+ alloc_ptr = (char*)malloc(nodesize + servicesize + hintssize);
295
+ if (!alloc_ptr) {
296
+ uv__set_sys_error(loop, WSAENOBUFS);
297
+ goto error;
298
+ }
299
+
300
+ /* save alloc_ptr now so we can free if error */
301
+ req->alloc = (void*)alloc_ptr;
302
+
303
+ /* convert node string to UTF16 into allocated memory and save pointer in */
304
+ /* the reques. */
305
+ if (node != NULL) {
306
+ req->node = (WCHAR*)alloc_ptr;
307
+ if (uv_utf8_to_utf16(node,
308
+ (WCHAR*) alloc_ptr,
309
+ nodesize / sizeof(WCHAR)) == 0) {
310
+ uv__set_sys_error(loop, GetLastError());
311
+ goto error;
312
+ }
313
+ alloc_ptr += nodesize;
314
+ } else {
315
+ req->node = NULL;
316
+ }
317
+
318
+ /* convert service string to UTF16 into allocated memory and save pointer */
319
+ /* in the req. */
320
+ if (service != NULL) {
321
+ req->service = (WCHAR*)alloc_ptr;
322
+ if (uv_utf8_to_utf16(service,
323
+ (WCHAR*) alloc_ptr,
324
+ servicesize / sizeof(WCHAR)) == 0) {
325
+ uv__set_sys_error(loop, GetLastError());
326
+ goto error;
327
+ }
328
+ alloc_ptr += servicesize;
329
+ } else {
330
+ req->service = NULL;
331
+ }
332
+
333
+ /* copy hints to allocated memory and save pointer in req */
334
+ if (hints != NULL) {
335
+ req->hints = (struct addrinfoW*)alloc_ptr;
336
+ req->hints->ai_family = hints->ai_family;
337
+ req->hints->ai_socktype = hints->ai_socktype;
338
+ req->hints->ai_protocol = hints->ai_protocol;
339
+ req->hints->ai_flags = hints->ai_flags;
340
+ req->hints->ai_addrlen = 0;
341
+ req->hints->ai_canonname = NULL;
342
+ req->hints->ai_addr = NULL;
343
+ req->hints->ai_next = NULL;
344
+ } else {
345
+ req->hints = NULL;
346
+ }
347
+
348
+ /* Ask thread to run. Treat this as a long operation */
349
+ if (QueueUserWorkItem(&getaddrinfo_thread_proc,
350
+ req,
351
+ WT_EXECUTELONGFUNCTION) == 0) {
352
+ uv__set_sys_error(loop, GetLastError());
353
+ goto error;
354
+ }
355
+
356
+ uv__req_register(loop, req);
357
+
358
+ return 0;
359
+
360
+ error:
361
+ if (req != NULL && req->alloc != NULL) {
362
+ free(req->alloc);
363
+ }
364
+ return -1;
365
+ }
@@ -0,0 +1,164 @@
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_WIN_HANDLE_INL_H_
23
+ #define UV_WIN_HANDLE_INL_H_
24
+
25
+ #include <assert.h>
26
+
27
+ #include "uv.h"
28
+ #include "internal.h"
29
+
30
+
31
+ #define DECREASE_ACTIVE_COUNT(loop, handle) \
32
+ do { \
33
+ if (--(handle)->activecnt == 0 && \
34
+ !((handle)->flags & UV__HANDLE_CLOSING)) { \
35
+ uv__handle_stop((handle)); \
36
+ } \
37
+ assert((handle)->activecnt >= 0); \
38
+ } while (0)
39
+
40
+
41
+ #define INCREASE_ACTIVE_COUNT(loop, handle) \
42
+ do { \
43
+ if ((handle)->activecnt++ == 0) { \
44
+ uv__handle_start((handle)); \
45
+ } \
46
+ assert((handle)->activecnt > 0); \
47
+ } while (0)
48
+
49
+
50
+ #define DECREASE_PENDING_REQ_COUNT(handle) \
51
+ do { \
52
+ assert(handle->reqs_pending > 0); \
53
+ handle->reqs_pending--; \
54
+ \
55
+ if (handle->flags & UV__HANDLE_CLOSING && \
56
+ handle->reqs_pending == 0) { \
57
+ uv_want_endgame(loop, (uv_handle_t*)handle); \
58
+ } \
59
+ } while (0)
60
+
61
+
62
+ #define uv__handle_closing(handle) \
63
+ do { \
64
+ assert(!((handle)->flags & UV__HANDLE_CLOSING)); \
65
+ \
66
+ if (!(((handle)->flags & UV__HANDLE_ACTIVE) && \
67
+ ((handle)->flags & UV__HANDLE_REF))) \
68
+ uv__active_handle_add((uv_handle_t*) (handle)); \
69
+ \
70
+ (handle)->flags |= UV__HANDLE_CLOSING; \
71
+ (handle)->flags &= ~UV__HANDLE_ACTIVE; \
72
+ } while (0)
73
+
74
+
75
+ #define uv__handle_close(handle) \
76
+ do { \
77
+ ngx_queue_remove(&(handle)->handle_queue); \
78
+ uv__active_handle_rm((uv_handle_t*) (handle)); \
79
+ \
80
+ (handle)->flags |= UV_HANDLE_CLOSED; \
81
+ \
82
+ if ((handle)->close_cb) \
83
+ (handle)->close_cb((uv_handle_t*) (handle)); \
84
+ } while (0)
85
+
86
+
87
+ INLINE static void uv_want_endgame(uv_loop_t* loop, uv_handle_t* handle) {
88
+ if (!(handle->flags & UV_HANDLE_ENDGAME_QUEUED)) {
89
+ handle->flags |= UV_HANDLE_ENDGAME_QUEUED;
90
+
91
+ handle->endgame_next = loop->endgame_handles;
92
+ loop->endgame_handles = handle;
93
+ }
94
+ }
95
+
96
+
97
+ INLINE static void uv_process_endgames(uv_loop_t* loop) {
98
+ uv_handle_t* handle;
99
+
100
+ while (loop->endgame_handles) {
101
+ handle = loop->endgame_handles;
102
+ loop->endgame_handles = handle->endgame_next;
103
+
104
+ handle->flags &= ~UV_HANDLE_ENDGAME_QUEUED;
105
+
106
+ switch (handle->type) {
107
+ case UV_TCP:
108
+ uv_tcp_endgame(loop, (uv_tcp_t*) handle);
109
+ break;
110
+
111
+ case UV_NAMED_PIPE:
112
+ uv_pipe_endgame(loop, (uv_pipe_t*) handle);
113
+ break;
114
+
115
+ case UV_TTY:
116
+ uv_tty_endgame(loop, (uv_tty_t*) handle);
117
+ break;
118
+
119
+ case UV_UDP:
120
+ uv_udp_endgame(loop, (uv_udp_t*) handle);
121
+ break;
122
+
123
+ case UV_POLL:
124
+ uv_poll_endgame(loop, (uv_poll_t*) handle);
125
+ break;
126
+
127
+ case UV_TIMER:
128
+ uv_timer_endgame(loop, (uv_timer_t*) handle);
129
+ break;
130
+
131
+ case UV_PREPARE:
132
+ case UV_CHECK:
133
+ case UV_IDLE:
134
+ uv_loop_watcher_endgame(loop, handle);
135
+ break;
136
+
137
+ case UV_ASYNC:
138
+ uv_async_endgame(loop, (uv_async_t*) handle);
139
+ break;
140
+
141
+ case UV_SIGNAL:
142
+ uv_signal_endgame(loop, (uv_signal_t*) handle);
143
+ break;
144
+
145
+ case UV_PROCESS:
146
+ uv_process_endgame(loop, (uv_process_t*) handle);
147
+ break;
148
+
149
+ case UV_FS_EVENT:
150
+ uv_fs_event_endgame(loop, (uv_fs_event_t*) handle);
151
+ break;
152
+
153
+ case UV_FS_POLL:
154
+ uv__fs_poll_endgame(loop, (uv_fs_poll_t*) handle);
155
+ break;
156
+
157
+ default:
158
+ assert(0);
159
+ break;
160
+ }
161
+ }
162
+ }
163
+
164
+ #endif /* UV_WIN_HANDLE_INL_H_ */
@@ -0,0 +1,153 @@
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
+ #include <assert.h>
23
+ #include <io.h>
24
+
25
+ #include "uv.h"
26
+ #include "internal.h"
27
+ #include "handle-inl.h"
28
+
29
+
30
+ uv_handle_type uv_guess_handle(uv_file file) {
31
+ HANDLE handle;
32
+ DWORD mode;
33
+
34
+ if (file < 0) {
35
+ return UV_UNKNOWN_HANDLE;
36
+ }
37
+
38
+ handle = (HANDLE) _get_osfhandle(file);
39
+
40
+ switch (GetFileType(handle)) {
41
+ case FILE_TYPE_CHAR:
42
+ if (GetConsoleMode(handle, &mode)) {
43
+ return UV_TTY;
44
+ } else {
45
+ return UV_FILE;
46
+ }
47
+
48
+ case FILE_TYPE_PIPE:
49
+ return UV_NAMED_PIPE;
50
+
51
+ case FILE_TYPE_DISK:
52
+ return UV_FILE;
53
+
54
+ default:
55
+ return UV_UNKNOWN_HANDLE;
56
+ }
57
+ }
58
+
59
+
60
+ int uv_is_active(const uv_handle_t* handle) {
61
+ return (handle->flags & UV__HANDLE_ACTIVE) &&
62
+ !(handle->flags & UV__HANDLE_CLOSING);
63
+ }
64
+
65
+
66
+ void uv_close(uv_handle_t* handle, uv_close_cb cb) {
67
+ uv_loop_t* loop = handle->loop;
68
+
69
+ if (handle->flags & UV__HANDLE_CLOSING) {
70
+ assert(0);
71
+ return;
72
+ }
73
+
74
+ handle->close_cb = cb;
75
+
76
+ /* Handle-specific close actions */
77
+ switch (handle->type) {
78
+ case UV_TCP:
79
+ uv_tcp_close(loop, (uv_tcp_t*)handle);
80
+ return;
81
+
82
+ case UV_NAMED_PIPE:
83
+ uv_pipe_close(loop, (uv_pipe_t*) handle);
84
+ return;
85
+
86
+ case UV_TTY:
87
+ uv_tty_close((uv_tty_t*) handle);
88
+ return;
89
+
90
+ case UV_UDP:
91
+ uv_udp_close(loop, (uv_udp_t*) handle);
92
+ return;
93
+
94
+ case UV_POLL:
95
+ uv_poll_close(loop, (uv_poll_t*) handle);
96
+ return;
97
+
98
+ case UV_TIMER:
99
+ uv_timer_stop((uv_timer_t*)handle);
100
+ uv__handle_closing(handle);
101
+ uv_want_endgame(loop, handle);
102
+ return;
103
+
104
+ case UV_PREPARE:
105
+ uv_prepare_stop((uv_prepare_t*)handle);
106
+ uv__handle_closing(handle);
107
+ uv_want_endgame(loop, handle);
108
+ return;
109
+
110
+ case UV_CHECK:
111
+ uv_check_stop((uv_check_t*)handle);
112
+ uv__handle_closing(handle);
113
+ uv_want_endgame(loop, handle);
114
+ return;
115
+
116
+ case UV_IDLE:
117
+ uv_idle_stop((uv_idle_t*)handle);
118
+ uv__handle_closing(handle);
119
+ uv_want_endgame(loop, handle);
120
+ return;
121
+
122
+ case UV_ASYNC:
123
+ uv_async_close(loop, (uv_async_t*) handle);
124
+ return;
125
+
126
+ case UV_SIGNAL:
127
+ uv_signal_close(loop, (uv_signal_t*) handle);
128
+ return;
129
+
130
+ case UV_PROCESS:
131
+ uv_process_close(loop, (uv_process_t*) handle);
132
+ return;
133
+
134
+ case UV_FS_EVENT:
135
+ uv_fs_event_close(loop, (uv_fs_event_t*) handle);
136
+ return;
137
+
138
+ case UV_FS_POLL:
139
+ uv__fs_poll_close((uv_fs_poll_t*) handle);
140
+ uv__handle_closing(handle);
141
+ uv_want_endgame(loop, handle);
142
+ return;
143
+
144
+ default:
145
+ /* Not supported */
146
+ abort();
147
+ }
148
+ }
149
+
150
+
151
+ int uv_is_closing(const uv_handle_t* handle) {
152
+ return handle->flags & (UV__HANDLE_CLOSING | UV_HANDLE_CLOSED);
153
+ }