webruby 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1364) hide show
  1. checksums.yaml +7 -0
  2. data/bin/webruby +36 -0
  3. data/driver/driver.c +50 -0
  4. data/driver/main.c +40 -0
  5. data/lib/webruby/app.rb +13 -0
  6. data/lib/webruby/config.rb +61 -0
  7. data/lib/webruby/environment.rb +32 -0
  8. data/lib/webruby/rake/files.rake +66 -0
  9. data/lib/webruby/rake/general.rake +22 -0
  10. data/lib/webruby/rake/mruby.rake +44 -0
  11. data/lib/webruby/utility.rb +132 -0
  12. data/lib/webruby.rb +10 -0
  13. data/modules/emscripten/AUTHORS +89 -0
  14. data/modules/emscripten/LICENSE +68 -0
  15. data/modules/emscripten/README.markdown +14 -0
  16. data/modules/emscripten/cmake/Platform/Emscripten.cmake +61 -0
  17. data/modules/emscripten/cmake/Platform/Emscripten_unix.cmake +24 -0
  18. data/modules/emscripten/em++ +12 -0
  19. data/modules/emscripten/em++.bat +2 -0
  20. data/modules/emscripten/em-config +24 -0
  21. data/modules/emscripten/em-config.bat +2 -0
  22. data/modules/emscripten/emar +24 -0
  23. data/modules/emscripten/emar.bat +2 -0
  24. data/modules/emscripten/emcc +1744 -0
  25. data/modules/emscripten/emcc.bat +2 -0
  26. data/modules/emscripten/emcc.py +5 -0
  27. data/modules/emscripten/emconfigure +27 -0
  28. data/modules/emscripten/emconfigure.bat +2 -0
  29. data/modules/emscripten/emlibtool +11 -0
  30. data/modules/emscripten/emlibtool.bat +2 -0
  31. data/modules/emscripten/emlink.py +293 -0
  32. data/modules/emscripten/emmake +29 -0
  33. data/modules/emscripten/emmake.bat +2 -0
  34. data/modules/emscripten/emranlib +9 -0
  35. data/modules/emscripten/emranlib.bat +2 -0
  36. data/modules/emscripten/emscons +20 -0
  37. data/modules/emscripten/emscripten.py +835 -0
  38. data/modules/emscripten/patches/README +4 -0
  39. data/modules/emscripten/patches/series +2 -0
  40. data/modules/emscripten/scons-tools/closure.py +28 -0
  41. data/modules/emscripten/scons-tools/emscripten.py +359 -0
  42. data/modules/emscripten/scons-tools/llvm.py +33 -0
  43. data/modules/emscripten/src/analyzer.js +1695 -0
  44. data/modules/emscripten/src/compiler.html +48 -0
  45. data/modules/emscripten/src/compiler.js +298 -0
  46. data/modules/emscripten/src/corruptionCheck.js +98 -0
  47. data/modules/emscripten/src/determinstic.js +20 -0
  48. data/modules/emscripten/src/embind/embind.js +1677 -0
  49. data/modules/emscripten/src/embind/emval.js +283 -0
  50. data/modules/emscripten/src/experimental/allow_loopvars_from_memsetcpy_inasm.diff +97 -0
  51. data/modules/emscripten/src/experimental/batching.diff +44 -0
  52. data/modules/emscripten/src/experimental/functypeopt.diff +113 -0
  53. data/modules/emscripten/src/experimental/multiple_heaps.diff +175 -0
  54. data/modules/emscripten/src/experimental/noncallgraphprofiling.diff +197 -0
  55. data/modules/emscripten/src/experimental/optimize_memcpy_for_ta1.diff +124 -0
  56. data/modules/emscripten/src/experimental/remove__label__s.diff +140 -0
  57. data/modules/emscripten/src/experimental/renderer_cache_hash.diff +99 -0
  58. data/modules/emscripten/src/experimental/sdl_key_forwarding.diff +57 -0
  59. data/modules/emscripten/src/experimental/simplifyGeneratedFunctionsDetection.diff +336 -0
  60. data/modules/emscripten/src/experimental/stringCache.diff +147 -0
  61. data/modules/emscripten/src/fastLong.js +299 -0
  62. data/modules/emscripten/src/framework.js +257 -0
  63. data/modules/emscripten/src/gl-matrix.js +1952 -0
  64. data/modules/emscripten/src/headless.js +904 -0
  65. data/modules/emscripten/src/intertyper.js +1050 -0
  66. data/modules/emscripten/src/jsifier.js +1827 -0
  67. data/modules/emscripten/src/library.js +8270 -0
  68. data/modules/emscripten/src/library_browser.js +911 -0
  69. data/modules/emscripten/src/library_egl.js +491 -0
  70. data/modules/emscripten/src/library_gc.js +236 -0
  71. data/modules/emscripten/src/library_gl.js +4452 -0
  72. data/modules/emscripten/src/library_glfw.js +576 -0
  73. data/modules/emscripten/src/library_glut.js +449 -0
  74. data/modules/emscripten/src/library_jansson.js +320 -0
  75. data/modules/emscripten/src/library_openal.js +602 -0
  76. data/modules/emscripten/src/library_sdl.js +2024 -0
  77. data/modules/emscripten/src/library_strtok_r.c +97 -0
  78. data/modules/emscripten/src/library_xlib.js +23 -0
  79. data/modules/emscripten/src/long.js +1609 -0
  80. data/modules/emscripten/src/modules.js +491 -0
  81. data/modules/emscripten/src/parseTools.js +2474 -0
  82. data/modules/emscripten/src/postamble.js +170 -0
  83. data/modules/emscripten/src/postamble_sharedlib.js +16 -0
  84. data/modules/emscripten/src/preamble.js +914 -0
  85. data/modules/emscripten/src/preamble_sharedlib.js +25 -0
  86. data/modules/emscripten/src/relooper/README.markdown +14 -0
  87. data/modules/emscripten/src/relooper/Relooper.cpp +1236 -0
  88. data/modules/emscripten/src/relooper/Relooper.h +250 -0
  89. data/modules/emscripten/src/relooper/doit.sh +70 -0
  90. data/modules/emscripten/src/relooper/emscripten/glue.js +57 -0
  91. data/modules/emscripten/src/relooper/emscripten/test.js +44 -0
  92. data/modules/emscripten/src/relooper/fuzzer.py +116 -0
  93. data/modules/emscripten/src/relooper/ministring.h +35 -0
  94. data/modules/emscripten/src/relooper/paper.pdf +0 -0
  95. data/modules/emscripten/src/relooper/test.cpp +262 -0
  96. data/modules/emscripten/src/relooper/test.txt +155 -0
  97. data/modules/emscripten/src/relooper/test2.c +44 -0
  98. data/modules/emscripten/src/relooper/test2.txt +12 -0
  99. data/modules/emscripten/src/relooper/test3.c +42 -0
  100. data/modules/emscripten/src/relooper/test3.txt +27 -0
  101. data/modules/emscripten/src/relooper/test4.cpp +40 -0
  102. data/modules/emscripten/src/relooper/test4.txt +23 -0
  103. data/modules/emscripten/src/relooper/test5.cpp +40 -0
  104. data/modules/emscripten/src/relooper/test5.txt +32 -0
  105. data/modules/emscripten/src/relooper/test6.cpp +31 -0
  106. data/modules/emscripten/src/relooper/test6.txt +12 -0
  107. data/modules/emscripten/src/relooper/test_dead.cpp +28 -0
  108. data/modules/emscripten/src/relooper/test_dead.txt +9 -0
  109. data/modules/emscripten/src/relooper/test_debug.cpp +30 -0
  110. data/modules/emscripten/src/relooper/test_debug.txt +128 -0
  111. data/modules/emscripten/src/relooper/test_fuzz1.cpp +52 -0
  112. data/modules/emscripten/src/relooper/test_fuzz1.txt +32 -0
  113. data/modules/emscripten/src/relooper/test_fuzz2.cpp +34 -0
  114. data/modules/emscripten/src/relooper/test_fuzz2.txt +13 -0
  115. data/modules/emscripten/src/relooper/test_fuzz3.cpp +36 -0
  116. data/modules/emscripten/src/relooper/test_fuzz3.txt +9 -0
  117. data/modules/emscripten/src/relooper/test_fuzz4.cpp +38 -0
  118. data/modules/emscripten/src/relooper/test_fuzz4.txt +19 -0
  119. data/modules/emscripten/src/relooper/test_fuzz5.cpp +57 -0
  120. data/modules/emscripten/src/relooper/test_fuzz5.txt +52 -0
  121. data/modules/emscripten/src/relooper/test_fuzz6.cpp +322 -0
  122. data/modules/emscripten/src/relooper/test_fuzz6.txt +108 -0
  123. data/modules/emscripten/src/relooper/test_inf.cpp +813 -0
  124. data/modules/emscripten/src/relooper/test_inf.txt +385 -0
  125. data/modules/emscripten/src/relooper/testit.sh +62 -0
  126. data/modules/emscripten/src/relooper/updateit.sh +17 -0
  127. data/modules/emscripten/src/relooper.js +11516 -0
  128. data/modules/emscripten/src/relooper.js.raw.js +11511 -0
  129. data/modules/emscripten/src/runtime.js +546 -0
  130. data/modules/emscripten/src/settings.js +1284 -0
  131. data/modules/emscripten/src/shell.html +92 -0
  132. data/modules/emscripten/src/shell.js +153 -0
  133. data/modules/emscripten/src/shell_sharedlib.js +12 -0
  134. data/modules/emscripten/src/socket.io.js +3870 -0
  135. data/modules/emscripten/src/utility.js +379 -0
  136. data/modules/emscripten/src/wrtcp.js +821 -0
  137. data/modules/emscripten/system/include/AL/al.h +172 -0
  138. data/modules/emscripten/system/include/AL/alc.h +84 -0
  139. data/modules/emscripten/system/include/EGL/egl.h +329 -0
  140. data/modules/emscripten/system/include/EGL/eglext.h +398 -0
  141. data/modules/emscripten/system/include/EGL/eglplatform.h +141 -0
  142. data/modules/emscripten/system/include/GL/freeglut_std.h +628 -0
  143. data/modules/emscripten/system/include/GL/gl.h +2241 -0
  144. data/modules/emscripten/system/include/GL/glew.h +6 -0
  145. data/modules/emscripten/system/include/GL/glext.h +11127 -0
  146. data/modules/emscripten/system/include/GL/glfw.h +518 -0
  147. data/modules/emscripten/system/include/GL/glu.h +353 -0
  148. data/modules/emscripten/system/include/GL/glut.h +21 -0
  149. data/modules/emscripten/system/include/GLES/gl.h +770 -0
  150. data/modules/emscripten/system/include/GLES/glext.h +1278 -0
  151. data/modules/emscripten/system/include/GLES/glplatform.h +30 -0
  152. data/modules/emscripten/system/include/GLES2/gl2.h +621 -0
  153. data/modules/emscripten/system/include/GLES2/gl2ext.h +803 -0
  154. data/modules/emscripten/system/include/GLES2/gl2platform.h +30 -0
  155. data/modules/emscripten/system/include/KHR/khrplatform.h +277 -0
  156. data/modules/emscripten/system/include/SDL/COPYING +19 -0
  157. data/modules/emscripten/system/include/SDL/SDL.h +162 -0
  158. data/modules/emscripten/system/include/SDL/SDL_assert.h +241 -0
  159. data/modules/emscripten/system/include/SDL/SDL_atomic.h +318 -0
  160. data/modules/emscripten/system/include/SDL/SDL_audio.h +509 -0
  161. data/modules/emscripten/system/include/SDL/SDL_blendmode.h +60 -0
  162. data/modules/emscripten/system/include/SDL/SDL_clipboard.h +75 -0
  163. data/modules/emscripten/system/include/SDL/SDL_compat.h +365 -0
  164. data/modules/emscripten/system/include/SDL/SDL_config.h +48 -0
  165. data/modules/emscripten/system/include/SDL/SDL_config.h.in +297 -0
  166. data/modules/emscripten/system/include/SDL/SDL_config_android.h +133 -0
  167. data/modules/emscripten/system/include/SDL/SDL_config_iphoneos.h +148 -0
  168. data/modules/emscripten/system/include/SDL/SDL_config_macosx.h +172 -0
  169. data/modules/emscripten/system/include/SDL/SDL_config_minimal.h +74 -0
  170. data/modules/emscripten/system/include/SDL/SDL_config_nintendods.h +129 -0
  171. data/modules/emscripten/system/include/SDL/SDL_config_pandora.h +125 -0
  172. data/modules/emscripten/system/include/SDL/SDL_config_windows.h +207 -0
  173. data/modules/emscripten/system/include/SDL/SDL_config_wiz.h +119 -0
  174. data/modules/emscripten/system/include/SDL/SDL_copying.h +20 -0
  175. data/modules/emscripten/system/include/SDL/SDL_cpuinfo.h +150 -0
  176. data/modules/emscripten/system/include/SDL/SDL_endian.h +248 -0
  177. data/modules/emscripten/system/include/SDL/SDL_error.h +77 -0
  178. data/modules/emscripten/system/include/SDL/SDL_events.h +639 -0
  179. data/modules/emscripten/system/include/SDL/SDL_gesture.h +91 -0
  180. data/modules/emscripten/system/include/SDL/SDL_gfxPrimitives.h +246 -0
  181. data/modules/emscripten/system/include/SDL/SDL_haptic.h +1200 -0
  182. data/modules/emscripten/system/include/SDL/SDL_hints.h +206 -0
  183. data/modules/emscripten/system/include/SDL/SDL_image.h +138 -0
  184. data/modules/emscripten/system/include/SDL/SDL_input.h +87 -0
  185. data/modules/emscripten/system/include/SDL/SDL_joystick.h +208 -0
  186. data/modules/emscripten/system/include/SDL/SDL_keyboard.h +169 -0
  187. data/modules/emscripten/system/include/SDL/SDL_keycode.h +344 -0
  188. data/modules/emscripten/system/include/SDL/SDL_loadso.h +85 -0
  189. data/modules/emscripten/system/include/SDL/SDL_log.h +211 -0
  190. data/modules/emscripten/system/include/SDL/SDL_main.h +98 -0
  191. data/modules/emscripten/system/include/SDL/SDL_mixer.h +634 -0
  192. data/modules/emscripten/system/include/SDL/SDL_mouse.h +213 -0
  193. data/modules/emscripten/system/include/SDL/SDL_mutex.h +248 -0
  194. data/modules/emscripten/system/include/SDL/SDL_name.h +11 -0
  195. data/modules/emscripten/system/include/SDL/SDL_opengl.h +11116 -0
  196. data/modules/emscripten/system/include/SDL/SDL_opengles.h +38 -0
  197. data/modules/emscripten/system/include/SDL/SDL_opengles2.h +38 -0
  198. data/modules/emscripten/system/include/SDL/SDL_pixels.h +423 -0
  199. data/modules/emscripten/system/include/SDL/SDL_platform.h +160 -0
  200. data/modules/emscripten/system/include/SDL/SDL_power.h +79 -0
  201. data/modules/emscripten/system/include/SDL/SDL_quit.h +58 -0
  202. data/modules/emscripten/system/include/SDL/SDL_rect.h +136 -0
  203. data/modules/emscripten/system/include/SDL/SDL_render.h +615 -0
  204. data/modules/emscripten/system/include/SDL/SDL_revision.h +2 -0
  205. data/modules/emscripten/system/include/SDL/SDL_revision.h.orig +2 -0
  206. data/modules/emscripten/system/include/SDL/SDL_rotozoom.h +123 -0
  207. data/modules/emscripten/system/include/SDL/SDL_rwops.h +220 -0
  208. data/modules/emscripten/system/include/SDL/SDL_scancode.h +398 -0
  209. data/modules/emscripten/system/include/SDL/SDL_shape.h +147 -0
  210. data/modules/emscripten/system/include/SDL/SDL_stdinc.h +764 -0
  211. data/modules/emscripten/system/include/SDL/SDL_surface.h +499 -0
  212. data/modules/emscripten/system/include/SDL/SDL_syswm.h +241 -0
  213. data/modules/emscripten/system/include/SDL/SDL_thread.h +182 -0
  214. data/modules/emscripten/system/include/SDL/SDL_timer.h +108 -0
  215. data/modules/emscripten/system/include/SDL/SDL_touch.h +124 -0
  216. data/modules/emscripten/system/include/SDL/SDL_ttf.h +249 -0
  217. data/modules/emscripten/system/include/SDL/SDL_types.h +29 -0
  218. data/modules/emscripten/system/include/SDL/SDL_version.h +166 -0
  219. data/modules/emscripten/system/include/SDL/SDL_video.h +820 -0
  220. data/modules/emscripten/system/include/SDL/begin_code.h +135 -0
  221. data/modules/emscripten/system/include/SDL/close_code.h +37 -0
  222. data/modules/emscripten/system/include/X11/X.h +717 -0
  223. data/modules/emscripten/system/include/X11/Xatom.h +79 -0
  224. data/modules/emscripten/system/include/X11/Xfuncproto.h +127 -0
  225. data/modules/emscripten/system/include/X11/Xlib.h +4023 -0
  226. data/modules/emscripten/system/include/X11/Xosdefs.h +116 -0
  227. data/modules/emscripten/system/include/X11/Xutil.h +826 -0
  228. data/modules/emscripten/system/include/X11/keysym.h +73 -0
  229. data/modules/emscripten/system/include/X11/keysymdef.h +2389 -0
  230. data/modules/emscripten/system/include/bsd/float.h +91 -0
  231. data/modules/emscripten/system/include/bsd/readme.txt +2 -0
  232. data/modules/emscripten/system/include/bsd/sys/mman.h +180 -0
  233. data/modules/emscripten/system/include/bsd/sys/utsname.h +70 -0
  234. data/modules/emscripten/system/include/dlfcn.h +31 -0
  235. data/modules/emscripten/system/include/emscripten/bind.h +1210 -0
  236. data/modules/emscripten/system/include/emscripten/emscripten.h +388 -0
  237. data/modules/emscripten/system/include/emscripten/val.h +311 -0
  238. data/modules/emscripten/system/include/emscripten/wire.h +393 -0
  239. data/modules/emscripten/system/include/err.h +95 -0
  240. data/modules/emscripten/system/include/execinfo.h +44 -0
  241. data/modules/emscripten/system/include/features.h +3 -0
  242. data/modules/emscripten/system/include/gc.h +70 -0
  243. data/modules/emscripten/system/include/gfx/png.h +3798 -0
  244. data/modules/emscripten/system/include/gfx/pngconf.h +1665 -0
  245. data/modules/emscripten/system/include/gfx/tiff.h +654 -0
  246. data/modules/emscripten/system/include/gfx/tiffconf.h +104 -0
  247. data/modules/emscripten/system/include/gfx/tiffio.h +526 -0
  248. data/modules/emscripten/system/include/gfx/tiffvers.h +9 -0
  249. data/modules/emscripten/system/include/jansson.h +323 -0
  250. data/modules/emscripten/system/include/jansson_config.h +54 -0
  251. data/modules/emscripten/system/include/libc/_ansi.h +135 -0
  252. data/modules/emscripten/system/include/libc/_syslist.h +40 -0
  253. data/modules/emscripten/system/include/libc/alloca.h +21 -0
  254. data/modules/emscripten/system/include/libc/ar.h +69 -0
  255. data/modules/emscripten/system/include/libc/argz.h +33 -0
  256. data/modules/emscripten/system/include/libc/assert.h +46 -0
  257. data/modules/emscripten/system/include/libc/complex.h +124 -0
  258. data/modules/emscripten/system/include/libc/ctype.h +196 -0
  259. data/modules/emscripten/system/include/libc/dirent.h +16 -0
  260. data/modules/emscripten/system/include/libc/endian.h +3 -0
  261. data/modules/emscripten/system/include/libc/envlock.h +15 -0
  262. data/modules/emscripten/system/include/libc/envz.h +16 -0
  263. data/modules/emscripten/system/include/libc/errno.h +11 -0
  264. data/modules/emscripten/system/include/libc/fastmath.h +13 -0
  265. data/modules/emscripten/system/include/libc/fcntl.h +1 -0
  266. data/modules/emscripten/system/include/libc/fnmatch.h +55 -0
  267. data/modules/emscripten/system/include/libc/getopt.h +196 -0
  268. data/modules/emscripten/system/include/libc/glob.h +89 -0
  269. data/modules/emscripten/system/include/libc/grp.h +94 -0
  270. data/modules/emscripten/system/include/libc/iconv.h +62 -0
  271. data/modules/emscripten/system/include/libc/ieeefp.h +256 -0
  272. data/modules/emscripten/system/include/libc/ifaddrs.h +64 -0
  273. data/modules/emscripten/system/include/libc/inttypes.h +290 -0
  274. data/modules/emscripten/system/include/libc/iso646.h +43 -0
  275. data/modules/emscripten/system/include/libc/langinfo.h +316 -0
  276. data/modules/emscripten/system/include/libc/libgen.h +23 -0
  277. data/modules/emscripten/system/include/libc/limits.h +155 -0
  278. data/modules/emscripten/system/include/libc/locale.h +80 -0
  279. data/modules/emscripten/system/include/libc/machine/_default_types.h +121 -0
  280. data/modules/emscripten/system/include/libc/machine/_types.h +8 -0
  281. data/modules/emscripten/system/include/libc/machine/ansi.h +1 -0
  282. data/modules/emscripten/system/include/libc/machine/endian.h +31 -0
  283. data/modules/emscripten/system/include/libc/machine/fastmath.h +100 -0
  284. data/modules/emscripten/system/include/libc/machine/ieeefp.h +376 -0
  285. data/modules/emscripten/system/include/libc/machine/malloc.h +8 -0
  286. data/modules/emscripten/system/include/libc/machine/param.h +1 -0
  287. data/modules/emscripten/system/include/libc/machine/setjmp-dj.h +43 -0
  288. data/modules/emscripten/system/include/libc/machine/setjmp.h +361 -0
  289. data/modules/emscripten/system/include/libc/machine/stdlib.h +8 -0
  290. data/modules/emscripten/system/include/libc/machine/termios.h +1 -0
  291. data/modules/emscripten/system/include/libc/machine/time.h +19 -0
  292. data/modules/emscripten/system/include/libc/machine/types.h +30 -0
  293. data/modules/emscripten/system/include/libc/malloc.h +169 -0
  294. data/modules/emscripten/system/include/libc/math.h +594 -0
  295. data/modules/emscripten/system/include/libc/newlib.h +2 -0
  296. data/modules/emscripten/system/include/libc/paths.h +7 -0
  297. data/modules/emscripten/system/include/libc/process.h +44 -0
  298. data/modules/emscripten/system/include/libc/pthread.h +362 -0
  299. data/modules/emscripten/system/include/libc/pwd.h +78 -0
  300. data/modules/emscripten/system/include/libc/readme.txt +3 -0
  301. data/modules/emscripten/system/include/libc/reent.h +183 -0
  302. data/modules/emscripten/system/include/libc/regdef.h +7 -0
  303. data/modules/emscripten/system/include/libc/regex.h +102 -0
  304. data/modules/emscripten/system/include/libc/sched.h +97 -0
  305. data/modules/emscripten/system/include/libc/search.h +59 -0
  306. data/modules/emscripten/system/include/libc/setjmp.h +20 -0
  307. data/modules/emscripten/system/include/libc/signal.h +30 -0
  308. data/modules/emscripten/system/include/libc/stdarg.h +50 -0
  309. data/modules/emscripten/system/include/libc/stddef.h +64 -0
  310. data/modules/emscripten/system/include/libc/stdint.h +493 -0
  311. data/modules/emscripten/system/include/libc/stdio.h +694 -0
  312. data/modules/emscripten/system/include/libc/stdlib.h +230 -0
  313. data/modules/emscripten/system/include/libc/string.h +105 -0
  314. data/modules/emscripten/system/include/libc/strings.h +35 -0
  315. data/modules/emscripten/system/include/libc/sys/_default_fcntl.h +223 -0
  316. data/modules/emscripten/system/include/libc/sys/_types.h +93 -0
  317. data/modules/emscripten/system/include/libc/sys/cdefs.h +123 -0
  318. data/modules/emscripten/system/include/libc/sys/config.h +255 -0
  319. data/modules/emscripten/system/include/libc/sys/custom_file.h +2 -0
  320. data/modules/emscripten/system/include/libc/sys/dir.h +10 -0
  321. data/modules/emscripten/system/include/libc/sys/dirent.h +58 -0
  322. data/modules/emscripten/system/include/libc/sys/errno.h +190 -0
  323. data/modules/emscripten/system/include/libc/sys/fcntl.h +4 -0
  324. data/modules/emscripten/system/include/libc/sys/features.h +212 -0
  325. data/modules/emscripten/system/include/libc/sys/file.h +2 -0
  326. data/modules/emscripten/system/include/libc/sys/iconvnls.h +77 -0
  327. data/modules/emscripten/system/include/libc/sys/lock.h +24 -0
  328. data/modules/emscripten/system/include/libc/sys/param.h +25 -0
  329. data/modules/emscripten/system/include/libc/sys/queue.h +471 -0
  330. data/modules/emscripten/system/include/libc/sys/reent.h +843 -0
  331. data/modules/emscripten/system/include/libc/sys/resource.h +59 -0
  332. data/modules/emscripten/system/include/libc/sys/sched.h +67 -0
  333. data/modules/emscripten/system/include/libc/sys/signal.h +314 -0
  334. data/modules/emscripten/system/include/libc/sys/stat.h +222 -0
  335. data/modules/emscripten/system/include/libc/sys/stdio.h +27 -0
  336. data/modules/emscripten/system/include/libc/sys/string.h +2 -0
  337. data/modules/emscripten/system/include/libc/sys/syslimits.h +65 -0
  338. data/modules/emscripten/system/include/libc/sys/termios.h +280 -0
  339. data/modules/emscripten/system/include/libc/sys/time.h +85 -0
  340. data/modules/emscripten/system/include/libc/sys/timeb.h +39 -0
  341. data/modules/emscripten/system/include/libc/sys/times.h +28 -0
  342. data/modules/emscripten/system/include/libc/sys/ttydefaults.h +97 -0
  343. data/modules/emscripten/system/include/libc/sys/types.h +481 -0
  344. data/modules/emscripten/system/include/libc/sys/unistd.h +514 -0
  345. data/modules/emscripten/system/include/libc/sys/utime.h +26 -0
  346. data/modules/emscripten/system/include/libc/sys/wait.h +40 -0
  347. data/modules/emscripten/system/include/libc/tar.h +39 -0
  348. data/modules/emscripten/system/include/libc/termios.h +7 -0
  349. data/modules/emscripten/system/include/libc/time.h +273 -0
  350. data/modules/emscripten/system/include/libc/unctrl.h +46 -0
  351. data/modules/emscripten/system/include/libc/unistd.h +6 -0
  352. data/modules/emscripten/system/include/libc/utime.h +12 -0
  353. data/modules/emscripten/system/include/libc/utmp.h +8 -0
  354. data/modules/emscripten/system/include/libc/wchar.h +194 -0
  355. data/modules/emscripten/system/include/libc/wctype.h +47 -0
  356. data/modules/emscripten/system/include/libc/wordexp.h +53 -0
  357. data/modules/emscripten/system/include/libcxx/CREDITS.TXT +91 -0
  358. data/modules/emscripten/system/include/libcxx/LICENSE.txt +76 -0
  359. data/modules/emscripten/system/include/libcxx/__bit_reference +1268 -0
  360. data/modules/emscripten/system/include/libcxx/__config +485 -0
  361. data/modules/emscripten/system/include/libcxx/__debug +193 -0
  362. data/modules/emscripten/system/include/libcxx/__functional_03 +2130 -0
  363. data/modules/emscripten/system/include/libcxx/__functional_base +437 -0
  364. data/modules/emscripten/system/include/libcxx/__functional_base_03 +1087 -0
  365. data/modules/emscripten/system/include/libcxx/__hash_table +1945 -0
  366. data/modules/emscripten/system/include/libcxx/__locale +1435 -0
  367. data/modules/emscripten/system/include/libcxx/__mutex_base +438 -0
  368. data/modules/emscripten/system/include/libcxx/__split_buffer +654 -0
  369. data/modules/emscripten/system/include/libcxx/__sso_allocator +77 -0
  370. data/modules/emscripten/system/include/libcxx/__std_stream +317 -0
  371. data/modules/emscripten/system/include/libcxx/__tree +2293 -0
  372. data/modules/emscripten/system/include/libcxx/__tuple +305 -0
  373. data/modules/emscripten/system/include/libcxx/__tuple_03 +27 -0
  374. data/modules/emscripten/system/include/libcxx/__undef_min_max +19 -0
  375. data/modules/emscripten/system/include/libcxx/algorithm +5458 -0
  376. data/modules/emscripten/system/include/libcxx/array +341 -0
  377. data/modules/emscripten/system/include/libcxx/atomic +1521 -0
  378. data/modules/emscripten/system/include/libcxx/bitset +1081 -0
  379. data/modules/emscripten/system/include/libcxx/cassert +25 -0
  380. data/modules/emscripten/system/include/libcxx/ccomplex +29 -0
  381. data/modules/emscripten/system/include/libcxx/cctype +164 -0
  382. data/modules/emscripten/system/include/libcxx/cerrno +393 -0
  383. data/modules/emscripten/system/include/libcxx/cfenv +82 -0
  384. data/modules/emscripten/system/include/libcxx/cfloat +78 -0
  385. data/modules/emscripten/system/include/libcxx/chrono +898 -0
  386. data/modules/emscripten/system/include/libcxx/cinttypes +259 -0
  387. data/modules/emscripten/system/include/libcxx/ciso646 +25 -0
  388. data/modules/emscripten/system/include/libcxx/climits +48 -0
  389. data/modules/emscripten/system/include/libcxx/clocale +53 -0
  390. data/modules/emscripten/system/include/libcxx/cmath +1683 -0
  391. data/modules/emscripten/system/include/libcxx/codecvt +547 -0
  392. data/modules/emscripten/system/include/libcxx/complex +1526 -0
  393. data/modules/emscripten/system/include/libcxx/complex.h +35 -0
  394. data/modules/emscripten/system/include/libcxx/condition_variable +256 -0
  395. data/modules/emscripten/system/include/libcxx/csetjmp +52 -0
  396. data/modules/emscripten/system/include/libcxx/csignal +58 -0
  397. data/modules/emscripten/system/include/libcxx/cstdarg +48 -0
  398. data/modules/emscripten/system/include/libcxx/cstdbool +32 -0
  399. data/modules/emscripten/system/include/libcxx/cstddef +103 -0
  400. data/modules/emscripten/system/include/libcxx/cstdint +191 -0
  401. data/modules/emscripten/system/include/libcxx/cstdio +175 -0
  402. data/modules/emscripten/system/include/libcxx/cstdlib +172 -0
  403. data/modules/emscripten/system/include/libcxx/cstring +112 -0
  404. data/modules/emscripten/system/include/libcxx/ctgmath +29 -0
  405. data/modules/emscripten/system/include/libcxx/ctime +72 -0
  406. data/modules/emscripten/system/include/libcxx/cwchar +208 -0
  407. data/modules/emscripten/system/include/libcxx/cwctype +213 -0
  408. data/modules/emscripten/system/include/libcxx/deque +2846 -0
  409. data/modules/emscripten/system/include/libcxx/exception +250 -0
  410. data/modules/emscripten/system/include/libcxx/ext/__hash +46 -0
  411. data/modules/emscripten/system/include/libcxx/ext/hash_map +1003 -0
  412. data/modules/emscripten/system/include/libcxx/ext/hash_set +657 -0
  413. data/modules/emscripten/system/include/libcxx/forward_list +1636 -0
  414. data/modules/emscripten/system/include/libcxx/fstream +1415 -0
  415. data/modules/emscripten/system/include/libcxx/functional +2063 -0
  416. data/modules/emscripten/system/include/libcxx/future +2505 -0
  417. data/modules/emscripten/system/include/libcxx/initializer_list +105 -0
  418. data/modules/emscripten/system/include/libcxx/iomanip +504 -0
  419. data/modules/emscripten/system/include/libcxx/ios +988 -0
  420. data/modules/emscripten/system/include/libcxx/iosfwd +194 -0
  421. data/modules/emscripten/system/include/libcxx/iostream +60 -0
  422. data/modules/emscripten/system/include/libcxx/istream +1713 -0
  423. data/modules/emscripten/system/include/libcxx/iterator +1869 -0
  424. data/modules/emscripten/system/include/libcxx/limits +809 -0
  425. data/modules/emscripten/system/include/libcxx/list +2275 -0
  426. data/modules/emscripten/system/include/libcxx/locale +4591 -0
  427. data/modules/emscripten/system/include/libcxx/map +1924 -0
  428. data/modules/emscripten/system/include/libcxx/memory +5437 -0
  429. data/modules/emscripten/system/include/libcxx/mutex +566 -0
  430. data/modules/emscripten/system/include/libcxx/new +117 -0
  431. data/modules/emscripten/system/include/libcxx/numeric +197 -0
  432. data/modules/emscripten/system/include/libcxx/ostream +1286 -0
  433. data/modules/emscripten/system/include/libcxx/queue +717 -0
  434. data/modules/emscripten/system/include/libcxx/random +6750 -0
  435. data/modules/emscripten/system/include/libcxx/ratio +487 -0
  436. data/modules/emscripten/system/include/libcxx/readme.txt +1 -0
  437. data/modules/emscripten/system/include/libcxx/regex +6439 -0
  438. data/modules/emscripten/system/include/libcxx/scoped_allocator +578 -0
  439. data/modules/emscripten/system/include/libcxx/set +1025 -0
  440. data/modules/emscripten/system/include/libcxx/sstream +888 -0
  441. data/modules/emscripten/system/include/libcxx/stack +292 -0
  442. data/modules/emscripten/system/include/libcxx/stdexcept +162 -0
  443. data/modules/emscripten/system/include/libcxx/streambuf +564 -0
  444. data/modules/emscripten/system/include/libcxx/string +3987 -0
  445. data/modules/emscripten/system/include/libcxx/strstream +400 -0
  446. data/modules/emscripten/system/include/libcxx/support/solaris/floatingpoint.h +5 -0
  447. data/modules/emscripten/system/include/libcxx/support/solaris/wchar.h +38 -0
  448. data/modules/emscripten/system/include/libcxx/support/solaris/xlocale.h +146 -0
  449. data/modules/emscripten/system/include/libcxx/support/win32/limits_win32.h +79 -0
  450. data/modules/emscripten/system/include/libcxx/support/win32/locale_win32.h +116 -0
  451. data/modules/emscripten/system/include/libcxx/support/win32/math_win32.h +113 -0
  452. data/modules/emscripten/system/include/libcxx/support/win32/support.h +115 -0
  453. data/modules/emscripten/system/include/libcxx/system_error +636 -0
  454. data/modules/emscripten/system/include/libcxx/tgmath.h +29 -0
  455. data/modules/emscripten/system/include/libcxx/thread +459 -0
  456. data/modules/emscripten/system/include/libcxx/tuple +1092 -0
  457. data/modules/emscripten/system/include/libcxx/type_traits +3040 -0
  458. data/modules/emscripten/system/include/libcxx/typeindex +103 -0
  459. data/modules/emscripten/system/include/libcxx/typeinfo +124 -0
  460. data/modules/emscripten/system/include/libcxx/unordered_map +1864 -0
  461. data/modules/emscripten/system/include/libcxx/unordered_set +1144 -0
  462. data/modules/emscripten/system/include/libcxx/utility +583 -0
  463. data/modules/emscripten/system/include/libcxx/valarray +4779 -0
  464. data/modules/emscripten/system/include/libcxx/vector +3228 -0
  465. data/modules/emscripten/system/include/memory.h +10 -0
  466. data/modules/emscripten/system/include/mntent.h +23 -0
  467. data/modules/emscripten/system/include/net/arpa/inet.h +32 -0
  468. data/modules/emscripten/system/include/net/arpa/nameser.h +535 -0
  469. data/modules/emscripten/system/include/net/arpa/nameser_compat.h +187 -0
  470. data/modules/emscripten/system/include/net/if.h +87 -0
  471. data/modules/emscripten/system/include/net/netinet/in.h +166 -0
  472. data/modules/emscripten/system/include/net/netinet/tcp.h +246 -0
  473. data/modules/emscripten/system/include/net/resolv.h +389 -0
  474. data/modules/emscripten/system/include/netdb.h +94 -0
  475. data/modules/emscripten/system/include/nl_types.h +19 -0
  476. data/modules/emscripten/system/include/poll.h +3 -0
  477. data/modules/emscripten/system/include/pty.h +6 -0
  478. data/modules/emscripten/system/include/semaphore.h +31 -0
  479. data/modules/emscripten/system/include/spawn.h +105 -0
  480. data/modules/emscripten/system/include/stdbool.h +16 -0
  481. data/modules/emscripten/system/include/sys/bitypes.h +3 -0
  482. data/modules/emscripten/system/include/sys/io.h +14 -0
  483. data/modules/emscripten/system/include/sys/ioctl.h +26 -0
  484. data/modules/emscripten/system/include/sys/poll.h +31 -0
  485. data/modules/emscripten/system/include/sys/select.h +14 -0
  486. data/modules/emscripten/system/include/sys/socket.h +101 -0
  487. data/modules/emscripten/system/include/sys/socketvar.h +3 -0
  488. data/modules/emscripten/system/include/sys/statvfs.h +32 -0
  489. data/modules/emscripten/system/include/sys/sysctl.h +14 -0
  490. data/modules/emscripten/system/include/sys/uio.h +22 -0
  491. data/modules/emscripten/system/include/sys/un.h +66 -0
  492. data/modules/emscripten/system/include/sysexits.h +108 -0
  493. data/modules/emscripten/system/include/unwind.h +154 -0
  494. data/modules/emscripten/system/include/xlocale.h +47 -0
  495. data/modules/emscripten/system/include/zconf.h +428 -0
  496. data/modules/emscripten/system/include/zlib.h +1613 -0
  497. data/modules/emscripten/system/lib/compiler-rt/LICENSE.TXT +97 -0
  498. data/modules/emscripten/system/lib/compiler-rt/divdi3.c +47 -0
  499. data/modules/emscripten/system/lib/compiler-rt/int_endianness.h +116 -0
  500. data/modules/emscripten/system/lib/compiler-rt/int_lib.h +46 -0
  501. data/modules/emscripten/system/lib/compiler-rt/int_math.h +67 -0
  502. data/modules/emscripten/system/lib/compiler-rt/int_types.h +140 -0
  503. data/modules/emscripten/system/lib/compiler-rt/int_util.h +29 -0
  504. data/modules/emscripten/system/lib/compiler-rt/muldi3.c +56 -0
  505. data/modules/emscripten/system/lib/compiler-rt/readme.txt +20 -0
  506. data/modules/emscripten/system/lib/compiler-rt/udivdi3.c +36 -0
  507. data/modules/emscripten/system/lib/compiler-rt/udivmoddi4.c +251 -0
  508. data/modules/emscripten/system/lib/debugging.cpp +24 -0
  509. data/modules/emscripten/system/lib/dlmalloc.c +6299 -0
  510. data/modules/emscripten/system/lib/embind/bind.cpp +63 -0
  511. data/modules/emscripten/system/lib/libc/gen/err.c +49 -0
  512. data/modules/emscripten/system/lib/libc/gen/errx.c +49 -0
  513. data/modules/emscripten/system/lib/libc/gen/verr.c +58 -0
  514. data/modules/emscripten/system/lib/libc/gen/verrx.c +51 -0
  515. data/modules/emscripten/system/lib/libc/gen/vwarn.c +55 -0
  516. data/modules/emscripten/system/lib/libc/gen/vwarnx.c +48 -0
  517. data/modules/emscripten/system/lib/libc/gen/warn.c +49 -0
  518. data/modules/emscripten/system/lib/libc/gen/warnx.c +49 -0
  519. data/modules/emscripten/system/lib/libc/musl/COPYRIGHT +92 -0
  520. data/modules/emscripten/system/lib/libc/musl/readme.txt +1 -0
  521. data/modules/emscripten/system/lib/libc/musl/src/ctype/alpha.h +125 -0
  522. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswalnum.c +7 -0
  523. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswalpha.c +14 -0
  524. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswblank.c +8 -0
  525. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswcntrl.c +10 -0
  526. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswctype.c +63 -0
  527. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswdigit.c +9 -0
  528. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswgraph.c +7 -0
  529. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswlower.c +6 -0
  530. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswprint.c +19 -0
  531. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswpunct.c +12 -0
  532. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswspace.c +19 -0
  533. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswupper.c +6 -0
  534. data/modules/emscripten/system/lib/libc/musl/src/ctype/iswxdigit.c +7 -0
  535. data/modules/emscripten/system/lib/libc/musl/src/ctype/nonspacing.h +62 -0
  536. data/modules/emscripten/system/lib/libc/musl/src/ctype/punct.h +109 -0
  537. data/modules/emscripten/system/lib/libc/musl/src/ctype/towctrans.c +268 -0
  538. data/modules/emscripten/system/lib/libc/musl/src/ctype/wcswidth.c +8 -0
  539. data/modules/emscripten/system/lib/libc/musl/src/ctype/wctrans.c +16 -0
  540. data/modules/emscripten/system/lib/libc/musl/src/ctype/wcwidth.c +29 -0
  541. data/modules/emscripten/system/lib/libc/musl/src/ctype/wide.h +42 -0
  542. data/modules/emscripten/system/lib/libc/musl/src/internal/libc.c +22 -0
  543. data/modules/emscripten/system/lib/libc/musl/src/internal/libc.h +71 -0
  544. data/modules/emscripten/system/lib/libc/musl/src/multibyte/btowc.c +7 -0
  545. data/modules/emscripten/system/lib/libc/musl/src/multibyte/internal.c +38 -0
  546. data/modules/emscripten/system/lib/libc/musl/src/multibyte/internal.h +22 -0
  547. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mblen.c +17 -0
  548. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbrlen.c +18 -0
  549. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbrtowc.c +57 -0
  550. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbsinit.c +17 -0
  551. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbsnrtowcs.c +65 -0
  552. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbsrtowcs.c +100 -0
  553. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbstowcs.c +7 -0
  554. data/modules/emscripten/system/lib/libc/musl/src/multibyte/mbtowc.c +53 -0
  555. data/modules/emscripten/system/lib/libc/musl/src/multibyte/wcrtomb.c +38 -0
  556. data/modules/emscripten/system/lib/libc/musl/src/multibyte/wcsnrtombs.c +52 -0
  557. data/modules/emscripten/system/lib/libc/musl/src/multibyte/wcsrtombs.c +58 -0
  558. data/modules/emscripten/system/lib/libc/musl/src/multibyte/wcstombs.c +7 -0
  559. data/modules/emscripten/system/lib/libc/musl/src/multibyte/wctob.c +8 -0
  560. data/modules/emscripten/system/lib/libc/musl/src/multibyte/wctomb.c +18 -0
  561. data/modules/emscripten/system/lib/libc/musl/src/string/wcpcpy.c +6 -0
  562. data/modules/emscripten/system/lib/libc/musl/src/string/wcpncpy.c +6 -0
  563. data/modules/emscripten/system/lib/libc/musl/src/string/wcscasecmp.c +7 -0
  564. data/modules/emscripten/system/lib/libc/musl/src/string/wcscasecmp_l.c +6 -0
  565. data/modules/emscripten/system/lib/libc/musl/src/string/wcscat.c +7 -0
  566. data/modules/emscripten/system/lib/libc/musl/src/string/wcschr.c +8 -0
  567. data/modules/emscripten/system/lib/libc/musl/src/string/wcscmp.c +7 -0
  568. data/modules/emscripten/system/lib/libc/musl/src/string/wcscpy.c +8 -0
  569. data/modules/emscripten/system/lib/libc/musl/src/string/wcscspn.c +10 -0
  570. data/modules/emscripten/system/lib/libc/musl/src/string/wcsdup.c +11 -0
  571. data/modules/emscripten/system/lib/libc/musl/src/string/wcslen.c +8 -0
  572. data/modules/emscripten/system/lib/libc/musl/src/string/wcsncasecmp.c +9 -0
  573. data/modules/emscripten/system/lib/libc/musl/src/string/wcsncasecmp_l.c +6 -0
  574. data/modules/emscripten/system/lib/libc/musl/src/string/wcsncat.c +10 -0
  575. data/modules/emscripten/system/lib/libc/musl/src/string/wcsncmp.c +7 -0
  576. data/modules/emscripten/system/lib/libc/musl/src/string/wcsncpy.c +9 -0
  577. data/modules/emscripten/system/lib/libc/musl/src/string/wcsnlen.c +8 -0
  578. data/modules/emscripten/system/lib/libc/musl/src/string/wcspbrk.c +7 -0
  579. data/modules/emscripten/system/lib/libc/musl/src/string/wcsrchr.c +8 -0
  580. data/modules/emscripten/system/lib/libc/musl/src/string/wcsspn.c +8 -0
  581. data/modules/emscripten/system/lib/libc/musl/src/string/wcsstr.c +108 -0
  582. data/modules/emscripten/system/lib/libc/musl/src/string/wcstok.c +12 -0
  583. data/modules/emscripten/system/lib/libc/musl/src/string/wcswcs.c +6 -0
  584. data/modules/emscripten/system/lib/libc/musl/src/string/wmemchr.c +8 -0
  585. data/modules/emscripten/system/lib/libc/musl/src/string/wmemcmp.c +8 -0
  586. data/modules/emscripten/system/lib/libc/musl/src/string/wmemcpy.c +9 -0
  587. data/modules/emscripten/system/lib/libc/musl/src/string/wmemmove.c +12 -0
  588. data/modules/emscripten/system/lib/libc/musl/src/string/wmemset.c +9 -0
  589. data/modules/emscripten/system/lib/libc/stdlib/getopt_long.c +511 -0
  590. data/modules/emscripten/system/lib/libc/stdlib/strtod.c +305 -0
  591. data/modules/emscripten/system/lib/libc.symbols +81 -0
  592. data/modules/emscripten/system/lib/libcextra.symbols +61 -0
  593. data/modules/emscripten/system/lib/libcxx/CREDITS.TXT +91 -0
  594. data/modules/emscripten/system/lib/libcxx/LICENSE.txt +76 -0
  595. data/modules/emscripten/system/lib/libcxx/algorithm.cpp +83 -0
  596. data/modules/emscripten/system/lib/libcxx/bind.cpp +30 -0
  597. data/modules/emscripten/system/lib/libcxx/chrono.cpp +132 -0
  598. data/modules/emscripten/system/lib/libcxx/condition_variable.cpp +81 -0
  599. data/modules/emscripten/system/lib/libcxx/debug.cpp +504 -0
  600. data/modules/emscripten/system/lib/libcxx/exception.cpp +226 -0
  601. data/modules/emscripten/system/lib/libcxx/future.cpp +285 -0
  602. data/modules/emscripten/system/lib/libcxx/hash.cpp +564 -0
  603. data/modules/emscripten/system/lib/libcxx/ios.cpp +455 -0
  604. data/modules/emscripten/system/lib/libcxx/iostream.cpp +68 -0
  605. data/modules/emscripten/system/lib/libcxx/locale.cpp +6093 -0
  606. data/modules/emscripten/system/lib/libcxx/memory.cpp +223 -0
  607. data/modules/emscripten/system/lib/libcxx/mutex.cpp +250 -0
  608. data/modules/emscripten/system/lib/libcxx/new.cpp +205 -0
  609. data/modules/emscripten/system/lib/libcxx/random.cpp +48 -0
  610. data/modules/emscripten/system/lib/libcxx/readme.txt +1 -0
  611. data/modules/emscripten/system/lib/libcxx/regex.cpp +325 -0
  612. data/modules/emscripten/system/lib/libcxx/stdexcept.cpp +196 -0
  613. data/modules/emscripten/system/lib/libcxx/string.cpp +687 -0
  614. data/modules/emscripten/system/lib/libcxx/strstream.cpp +329 -0
  615. data/modules/emscripten/system/lib/libcxx/support/solaris/README +4 -0
  616. data/modules/emscripten/system/lib/libcxx/support/solaris/mbsnrtowcs.inc +76 -0
  617. data/modules/emscripten/system/lib/libcxx/support/solaris/wcsnrtombs.inc +93 -0
  618. data/modules/emscripten/system/lib/libcxx/support/solaris/xlocale.c +245 -0
  619. data/modules/emscripten/system/lib/libcxx/support/win32/locale_win32.cpp +94 -0
  620. data/modules/emscripten/system/lib/libcxx/support/win32/support.cpp +70 -0
  621. data/modules/emscripten/system/lib/libcxx/symbols +2927 -0
  622. data/modules/emscripten/system/lib/libcxx/system_error.cpp +201 -0
  623. data/modules/emscripten/system/lib/libcxx/thread.cpp +208 -0
  624. data/modules/emscripten/system/lib/libcxx/typeinfo.cpp +60 -0
  625. data/modules/emscripten/system/lib/libcxx/utility.cpp +17 -0
  626. data/modules/emscripten/system/lib/libcxx/valarray.cpp +54 -0
  627. data/modules/emscripten/system/lib/libcxxabi/CREDITS.TXT +38 -0
  628. data/modules/emscripten/system/lib/libcxxabi/LICENSE.TXT +76 -0
  629. data/modules/emscripten/system/lib/libcxxabi/include/cxa_demangle.h +167 -0
  630. data/modules/emscripten/system/lib/libcxxabi/include/cxxabi.h +175 -0
  631. data/modules/emscripten/system/lib/libcxxabi/lib/buildit +99 -0
  632. data/modules/emscripten/system/lib/libcxxabi/readme.txt +1 -0
  633. data/modules/emscripten/system/lib/libcxxabi/src/abort_message.cpp +50 -0
  634. data/modules/emscripten/system/lib/libcxxabi/src/abort_message.h +33 -0
  635. data/modules/emscripten/system/lib/libcxxabi/src/cxa_aux_runtime.cpp +34 -0
  636. data/modules/emscripten/system/lib/libcxxabi/src/cxa_demangle.cpp +11036 -0
  637. data/modules/emscripten/system/lib/libcxxabi/src/cxa_exception.cpp +622 -0
  638. data/modules/emscripten/system/lib/libcxxabi/src/cxa_exception.hpp +123 -0
  639. data/modules/emscripten/system/lib/libcxxabi/src/cxa_exception_storage.cpp +91 -0
  640. data/modules/emscripten/system/lib/libcxxabi/src/cxa_guard.cpp +231 -0
  641. data/modules/emscripten/system/lib/libcxxabi/src/cxa_handlers.cpp +125 -0
  642. data/modules/emscripten/system/lib/libcxxabi/src/cxa_handlers.hpp +54 -0
  643. data/modules/emscripten/system/lib/libcxxabi/src/cxa_new_delete.cpp +242 -0
  644. data/modules/emscripten/system/lib/libcxxabi/src/cxa_personality.cpp +1055 -0
  645. data/modules/emscripten/system/lib/libcxxabi/src/cxa_unexpected.cpp +27 -0
  646. data/modules/emscripten/system/lib/libcxxabi/src/cxa_vector.cpp +367 -0
  647. data/modules/emscripten/system/lib/libcxxabi/src/cxa_virtual.cpp +31 -0
  648. data/modules/emscripten/system/lib/libcxxabi/src/exception.cpp +41 -0
  649. data/modules/emscripten/system/lib/libcxxabi/src/fallback_malloc.ipp +174 -0
  650. data/modules/emscripten/system/lib/libcxxabi/src/private_typeinfo.cpp +1146 -0
  651. data/modules/emscripten/system/lib/libcxxabi/src/private_typeinfo.h +248 -0
  652. data/modules/emscripten/system/lib/libcxxabi/src/stdexcept.cpp +169 -0
  653. data/modules/emscripten/system/lib/libcxxabi/src/typeinfo.cpp +53 -0
  654. data/modules/emscripten/system/lib/libcxxabi/symbols +236 -0
  655. data/modules/emscripten/system/lib/sdl.cpp +13 -0
  656. data/modules/emscripten/system/lib/sdl.symbols +1 -0
  657. data/modules/emscripten/tests/hello_world.js +92 -0
  658. data/modules/emscripten/third_party/CppHeaderParser/CppHeaderParser/CppHeaderParser.py +2347 -0
  659. data/modules/emscripten/third_party/CppHeaderParser/CppHeaderParser/__init__.py +4 -0
  660. data/modules/emscripten/third_party/CppHeaderParser/CppHeaderParser/doc/CppHeaderParser.html +657 -0
  661. data/modules/emscripten/third_party/CppHeaderParser/CppHeaderParser/examples/SampleClass.h +147 -0
  662. data/modules/emscripten/third_party/CppHeaderParser/CppHeaderParser/examples/readSampleClass.py +74 -0
  663. data/modules/emscripten/third_party/CppHeaderParser/PKG-INFO +249 -0
  664. data/modules/emscripten/third_party/CppHeaderParser/README.html +544 -0
  665. data/modules/emscripten/third_party/CppHeaderParser/README.txt +226 -0
  666. data/modules/emscripten/third_party/CppHeaderParser/setup.py +43 -0
  667. data/modules/emscripten/third_party/ansidecl.h +371 -0
  668. data/modules/emscripten/third_party/closure-compiler/COPYING +202 -0
  669. data/modules/emscripten/third_party/closure-compiler/README +292 -0
  670. data/modules/emscripten/third_party/closure-compiler/compiler.jar +0 -0
  671. data/modules/emscripten/third_party/closure-compiler/readme.txt +3 -0
  672. data/modules/emscripten/third_party/cp-demangle.h +161 -0
  673. data/modules/emscripten/third_party/demangle.h +549 -0
  674. data/modules/emscripten/third_party/demangler.py +49 -0
  675. data/modules/emscripten/third_party/gcc_demangler.c +4226 -0
  676. data/modules/emscripten/third_party/gcc_demangler.js +21282 -0
  677. data/modules/emscripten/third_party/jni/emjvm.cpp +133 -0
  678. data/modules/emscripten/third_party/jni/emjvm.h +8 -0
  679. data/modules/emscripten/third_party/jni/emjvm.js +185 -0
  680. data/modules/emscripten/third_party/jni/jni.h +1154 -0
  681. data/modules/emscripten/third_party/libiberty.h +634 -0
  682. data/modules/emscripten/third_party/lzma.js/README.markdown +37 -0
  683. data/modules/emscripten/third_party/lzma.js/doit.sh +37 -0
  684. data/modules/emscripten/third_party/lzma.js/lzip/AUTHORS +7 -0
  685. data/modules/emscripten/third_party/lzma.js/lzip/COPYING +676 -0
  686. data/modules/emscripten/third_party/lzma.js/lzip/ChangeLog +201 -0
  687. data/modules/emscripten/third_party/lzma.js/lzip/INSTALL +56 -0
  688. data/modules/emscripten/third_party/lzma.js/lzip/Makefile +160 -0
  689. data/modules/emscripten/third_party/lzma.js/lzip/Makefile.in +138 -0
  690. data/modules/emscripten/third_party/lzma.js/lzip/NEWS +22 -0
  691. data/modules/emscripten/third_party/lzma.js/lzip/README +77 -0
  692. data/modules/emscripten/third_party/lzma.js/lzip/arg_parser.cc +204 -0
  693. data/modules/emscripten/third_party/lzma.js/lzip/arg_parser.h +106 -0
  694. data/modules/emscripten/third_party/lzma.js/lzip/configure +192 -0
  695. data/modules/emscripten/third_party/lzma.js/lzip/decoder.cc +252 -0
  696. data/modules/emscripten/third_party/lzma.js/lzip/decoder.h +268 -0
  697. data/modules/emscripten/third_party/lzma.js/lzip/encoder.cc +643 -0
  698. data/modules/emscripten/third_party/lzma.js/lzip/encoder.h +582 -0
  699. data/modules/emscripten/third_party/lzma.js/lzip/fast_encoder.cc +378 -0
  700. data/modules/emscripten/third_party/lzma.js/lzip/fast_encoder.h +171 -0
  701. data/modules/emscripten/third_party/lzma.js/lzip/lzip.h +264 -0
  702. data/modules/emscripten/third_party/lzma.js/lzip/main.cc +545 -0
  703. data/modules/emscripten/third_party/lzma.js/lzma-decoder.js +27 -0
  704. data/modules/emscripten/third_party/lzma.js/lzma-full.js +27 -0
  705. data/modules/emscripten/third_party/lzma.js/native_test.sh +5 -0
  706. data/modules/emscripten/third_party/lzma.js/post.js +13 -0
  707. data/modules/emscripten/third_party/lzma.js/pre.js +13 -0
  708. data/modules/emscripten/third_party/lzma.js/test-decoder.js +39 -0
  709. data/modules/emscripten/third_party/lzma.js/test-full.html +9 -0
  710. data/modules/emscripten/third_party/lzma.js/test-full.js +78 -0
  711. data/modules/emscripten/third_party/ply/ANNOUNCE +40 -0
  712. data/modules/emscripten/third_party/ply/CHANGES +1093 -0
  713. data/modules/emscripten/third_party/ply/PKG-INFO +22 -0
  714. data/modules/emscripten/third_party/ply/README +271 -0
  715. data/modules/emscripten/third_party/ply/TODO +16 -0
  716. data/modules/emscripten/third_party/ply/doc/internal.html +874 -0
  717. data/modules/emscripten/third_party/ply/doc/makedoc.py +194 -0
  718. data/modules/emscripten/third_party/ply/doc/ply.html +3262 -0
  719. data/modules/emscripten/third_party/ply/example/BASIC/README +79 -0
  720. data/modules/emscripten/third_party/ply/example/BASIC/basic.py +71 -0
  721. data/modules/emscripten/third_party/ply/example/BASIC/basiclex.py +74 -0
  722. data/modules/emscripten/third_party/ply/example/BASIC/basiclog.py +79 -0
  723. data/modules/emscripten/third_party/ply/example/BASIC/basinterp.py +441 -0
  724. data/modules/emscripten/third_party/ply/example/BASIC/basparse.py +424 -0
  725. data/modules/emscripten/third_party/ply/example/BASIC/dim.bas +14 -0
  726. data/modules/emscripten/third_party/ply/example/BASIC/func.bas +5 -0
  727. data/modules/emscripten/third_party/ply/example/BASIC/gcd.bas +22 -0
  728. data/modules/emscripten/third_party/ply/example/BASIC/gosub.bas +13 -0
  729. data/modules/emscripten/third_party/ply/example/BASIC/hello.bas +4 -0
  730. data/modules/emscripten/third_party/ply/example/BASIC/linear.bas +17 -0
  731. data/modules/emscripten/third_party/ply/example/BASIC/maxsin.bas +12 -0
  732. data/modules/emscripten/third_party/ply/example/BASIC/powers.bas +13 -0
  733. data/modules/emscripten/third_party/ply/example/BASIC/rand.bas +4 -0
  734. data/modules/emscripten/third_party/ply/example/BASIC/sales.bas +20 -0
  735. data/modules/emscripten/third_party/ply/example/BASIC/sears.bas +18 -0
  736. data/modules/emscripten/third_party/ply/example/BASIC/sqrt1.bas +5 -0
  737. data/modules/emscripten/third_party/ply/example/BASIC/sqrt2.bas +4 -0
  738. data/modules/emscripten/third_party/ply/example/GardenSnake/GardenSnake.py +709 -0
  739. data/modules/emscripten/third_party/ply/example/GardenSnake/README +5 -0
  740. data/modules/emscripten/third_party/ply/example/README +10 -0
  741. data/modules/emscripten/third_party/ply/example/ansic/README +2 -0
  742. data/modules/emscripten/third_party/ply/example/ansic/clex.py +164 -0
  743. data/modules/emscripten/third_party/ply/example/ansic/cparse.py +863 -0
  744. data/modules/emscripten/third_party/ply/example/calc/calc.py +107 -0
  745. data/modules/emscripten/third_party/ply/example/calcdebug/calc.py +113 -0
  746. data/modules/emscripten/third_party/ply/example/classcalc/calc.py +157 -0
  747. data/modules/emscripten/third_party/ply/example/cleanup.sh +2 -0
  748. data/modules/emscripten/third_party/ply/example/closurecalc/calc.py +130 -0
  749. data/modules/emscripten/third_party/ply/example/hedit/hedit.py +48 -0
  750. data/modules/emscripten/third_party/ply/example/newclasscalc/calc.py +160 -0
  751. data/modules/emscripten/third_party/ply/example/optcalc/README +9 -0
  752. data/modules/emscripten/third_party/ply/example/optcalc/calc.py +119 -0
  753. data/modules/emscripten/third_party/ply/example/unicalc/calc.py +117 -0
  754. data/modules/emscripten/third_party/ply/example/yply/README +41 -0
  755. data/modules/emscripten/third_party/ply/example/yply/ylex.py +112 -0
  756. data/modules/emscripten/third_party/ply/example/yply/yparse.py +217 -0
  757. data/modules/emscripten/third_party/ply/example/yply/yply.py +53 -0
  758. data/modules/emscripten/third_party/ply/ply/__init__.py +4 -0
  759. data/modules/emscripten/third_party/ply/ply/cpp.py +898 -0
  760. data/modules/emscripten/third_party/ply/ply/ctokens.py +133 -0
  761. data/modules/emscripten/third_party/ply/ply/lex.py +1058 -0
  762. data/modules/emscripten/third_party/ply/ply/yacc.py +3276 -0
  763. data/modules/emscripten/third_party/ply/setup.py +31 -0
  764. data/modules/emscripten/third_party/ply/test/README +7 -0
  765. data/modules/emscripten/third_party/ply/test/calclex.py +49 -0
  766. data/modules/emscripten/third_party/ply/test/cleanup.sh +4 -0
  767. data/modules/emscripten/third_party/ply/test/lex_closure.py +54 -0
  768. data/modules/emscripten/third_party/ply/test/lex_doc1.py +26 -0
  769. data/modules/emscripten/third_party/ply/test/lex_dup1.py +29 -0
  770. data/modules/emscripten/third_party/ply/test/lex_dup2.py +33 -0
  771. data/modules/emscripten/third_party/ply/test/lex_dup3.py +31 -0
  772. data/modules/emscripten/third_party/ply/test/lex_empty.py +20 -0
  773. data/modules/emscripten/third_party/ply/test/lex_error1.py +24 -0
  774. data/modules/emscripten/third_party/ply/test/lex_error2.py +26 -0
  775. data/modules/emscripten/third_party/ply/test/lex_error3.py +27 -0
  776. data/modules/emscripten/third_party/ply/test/lex_error4.py +27 -0
  777. data/modules/emscripten/third_party/ply/test/lex_hedit.py +47 -0
  778. data/modules/emscripten/third_party/ply/test/lex_ignore.py +31 -0
  779. data/modules/emscripten/third_party/ply/test/lex_ignore2.py +29 -0
  780. data/modules/emscripten/third_party/ply/test/lex_literal1.py +25 -0
  781. data/modules/emscripten/third_party/ply/test/lex_literal2.py +25 -0
  782. data/modules/emscripten/third_party/ply/test/lex_many_tokens.py +27 -0
  783. data/modules/emscripten/third_party/ply/test/lex_module.py +10 -0
  784. data/modules/emscripten/third_party/ply/test/lex_module_import.py +42 -0
  785. data/modules/emscripten/third_party/ply/test/lex_object.py +55 -0
  786. data/modules/emscripten/third_party/ply/test/lex_opt_alias.py +54 -0
  787. data/modules/emscripten/third_party/ply/test/lex_optimize.py +50 -0
  788. data/modules/emscripten/third_party/ply/test/lex_optimize2.py +50 -0
  789. data/modules/emscripten/third_party/ply/test/lex_optimize3.py +52 -0
  790. data/modules/emscripten/third_party/ply/test/lex_re1.py +27 -0
  791. data/modules/emscripten/third_party/ply/test/lex_re2.py +27 -0
  792. data/modules/emscripten/third_party/ply/test/lex_re3.py +29 -0
  793. data/modules/emscripten/third_party/ply/test/lex_rule1.py +27 -0
  794. data/modules/emscripten/third_party/ply/test/lex_rule2.py +29 -0
  795. data/modules/emscripten/third_party/ply/test/lex_rule3.py +27 -0
  796. data/modules/emscripten/third_party/ply/test/lex_state1.py +40 -0
  797. data/modules/emscripten/third_party/ply/test/lex_state2.py +40 -0
  798. data/modules/emscripten/third_party/ply/test/lex_state3.py +42 -0
  799. data/modules/emscripten/third_party/ply/test/lex_state4.py +41 -0
  800. data/modules/emscripten/third_party/ply/test/lex_state5.py +40 -0
  801. data/modules/emscripten/third_party/ply/test/lex_state_noerror.py +39 -0
  802. data/modules/emscripten/third_party/ply/test/lex_state_norule.py +40 -0
  803. data/modules/emscripten/third_party/ply/test/lex_state_try.py +45 -0
  804. data/modules/emscripten/third_party/ply/test/lex_token1.py +19 -0
  805. data/modules/emscripten/third_party/ply/test/lex_token2.py +22 -0
  806. data/modules/emscripten/third_party/ply/test/lex_token3.py +24 -0
  807. data/modules/emscripten/third_party/ply/test/lex_token4.py +26 -0
  808. data/modules/emscripten/third_party/ply/test/lex_token5.py +31 -0
  809. data/modules/emscripten/third_party/ply/test/lex_token_dup.py +29 -0
  810. data/modules/emscripten/third_party/ply/test/testlex.py +606 -0
  811. data/modules/emscripten/third_party/ply/test/testyacc.py +347 -0
  812. data/modules/emscripten/third_party/ply/test/yacc_badargs.py +68 -0
  813. data/modules/emscripten/third_party/ply/test/yacc_badid.py +77 -0
  814. data/modules/emscripten/third_party/ply/test/yacc_badprec.py +64 -0
  815. data/modules/emscripten/third_party/ply/test/yacc_badprec2.py +68 -0
  816. data/modules/emscripten/third_party/ply/test/yacc_badprec3.py +68 -0
  817. data/modules/emscripten/third_party/ply/test/yacc_badrule.py +68 -0
  818. data/modules/emscripten/third_party/ply/test/yacc_badtok.py +68 -0
  819. data/modules/emscripten/third_party/ply/test/yacc_dup.py +68 -0
  820. data/modules/emscripten/third_party/ply/test/yacc_error1.py +68 -0
  821. data/modules/emscripten/third_party/ply/test/yacc_error2.py +68 -0
  822. data/modules/emscripten/third_party/ply/test/yacc_error3.py +67 -0
  823. data/modules/emscripten/third_party/ply/test/yacc_error4.py +72 -0
  824. data/modules/emscripten/third_party/ply/test/yacc_inf.py +56 -0
  825. data/modules/emscripten/third_party/ply/test/yacc_literal.py +69 -0
  826. data/modules/emscripten/third_party/ply/test/yacc_misplaced.py +68 -0
  827. data/modules/emscripten/third_party/ply/test/yacc_missing1.py +68 -0
  828. data/modules/emscripten/third_party/ply/test/yacc_nested.py +33 -0
  829. data/modules/emscripten/third_party/ply/test/yacc_nodoc.py +67 -0
  830. data/modules/emscripten/third_party/ply/test/yacc_noerror.py +66 -0
  831. data/modules/emscripten/third_party/ply/test/yacc_nop.py +68 -0
  832. data/modules/emscripten/third_party/ply/test/yacc_notfunc.py +66 -0
  833. data/modules/emscripten/third_party/ply/test/yacc_notok.py +67 -0
  834. data/modules/emscripten/third_party/ply/test/yacc_prec1.py +68 -0
  835. data/modules/emscripten/third_party/ply/test/yacc_rr.py +72 -0
  836. data/modules/emscripten/third_party/ply/test/yacc_rr_unused.py +30 -0
  837. data/modules/emscripten/third_party/ply/test/yacc_simple.py +68 -0
  838. data/modules/emscripten/third_party/ply/test/yacc_sr.py +63 -0
  839. data/modules/emscripten/third_party/ply/test/yacc_term1.py +68 -0
  840. data/modules/emscripten/third_party/ply/test/yacc_unused.py +77 -0
  841. data/modules/emscripten/third_party/ply/test/yacc_unused_rule.py +72 -0
  842. data/modules/emscripten/third_party/ply/test/yacc_uprec.py +63 -0
  843. data/modules/emscripten/third_party/ply/test/yacc_uprec2.py +63 -0
  844. data/modules/emscripten/third_party/readme.txt +7 -0
  845. data/modules/emscripten/third_party/websockify/CHANGES.txt +23 -0
  846. data/modules/emscripten/third_party/websockify/LICENSE.txt +16 -0
  847. data/modules/emscripten/third_party/websockify/MANIFEST.in +1 -0
  848. data/modules/emscripten/third_party/websockify/Makefile +11 -0
  849. data/modules/emscripten/third_party/websockify/README.md +168 -0
  850. data/modules/emscripten/third_party/websockify/Windows/Windows Service Readme.txt +39 -0
  851. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/Program.cs +24 -0
  852. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/ProjectInstaller.Designer.cs +61 -0
  853. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/ProjectInstaller.cs +19 -0
  854. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/ProjectInstaller.resx +129 -0
  855. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/Properties/AssemblyInfo.cs +36 -0
  856. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/Service1.Designer.cs +37 -0
  857. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/Service1.cs +41 -0
  858. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/noVNC Websocket.csproj +75 -0
  859. data/modules/emscripten/third_party/websockify/Windows/noVNC Websocket Service Project/noVNC Websocket.sln +20 -0
  860. data/modules/emscripten/third_party/websockify/docs/LICENSE.GPL-3 +621 -0
  861. data/modules/emscripten/third_party/websockify/docs/LICENSE.LGPL-3 +165 -0
  862. data/modules/emscripten/third_party/websockify/docs/LICENSE.MPL-2.0 +373 -0
  863. data/modules/emscripten/third_party/websockify/docs/TODO +9 -0
  864. data/modules/emscripten/third_party/websockify/docs/flash_policy.txt +4 -0
  865. data/modules/emscripten/third_party/websockify/docs/latency_results.txt +114 -0
  866. data/modules/emscripten/third_party/websockify/docs/notes +17 -0
  867. data/modules/emscripten/third_party/websockify/docs/release.txt +9 -0
  868. data/modules/emscripten/third_party/websockify/docs/websockify.1 +110 -0
  869. data/modules/emscripten/third_party/websockify/include/VT100.js +919 -0
  870. data/modules/emscripten/third_party/websockify/include/base64.js +114 -0
  871. data/modules/emscripten/third_party/websockify/include/keysym.js +99 -0
  872. data/modules/emscripten/third_party/websockify/include/util.js +359 -0
  873. data/modules/emscripten/third_party/websockify/include/web-socket-js/README.txt +109 -0
  874. data/modules/emscripten/third_party/websockify/include/web-socket-js/WebSocketMain.swf +0 -0
  875. data/modules/emscripten/third_party/websockify/include/web-socket-js/swfobject.js +4 -0
  876. data/modules/emscripten/third_party/websockify/include/web-socket-js/web_socket.js +391 -0
  877. data/modules/emscripten/third_party/websockify/include/websock.js +422 -0
  878. data/modules/emscripten/third_party/websockify/include/webutil.js +216 -0
  879. data/modules/emscripten/third_party/websockify/include/wsirc.js +235 -0
  880. data/modules/emscripten/third_party/websockify/include/wstelnet.js +335 -0
  881. data/modules/emscripten/third_party/websockify/other/Makefile +14 -0
  882. data/modules/emscripten/third_party/websockify/other/README.md +51 -0
  883. data/modules/emscripten/third_party/websockify/other/launch.sh +108 -0
  884. data/modules/emscripten/third_party/websockify/other/project.clj +13 -0
  885. data/modules/emscripten/third_party/websockify/other/websocket.c +802 -0
  886. data/modules/emscripten/third_party/websockify/other/websocket.h +84 -0
  887. data/modules/emscripten/third_party/websockify/other/websocket.rb +456 -0
  888. data/modules/emscripten/third_party/websockify/other/websockify.c +385 -0
  889. data/modules/emscripten/third_party/websockify/other/websockify.clj +233 -0
  890. data/modules/emscripten/third_party/websockify/other/websockify.js +196 -0
  891. data/modules/emscripten/third_party/websockify/other/websockify.rb +171 -0
  892. data/modules/emscripten/third_party/websockify/other/wswrap +22 -0
  893. data/modules/emscripten/third_party/websockify/rebind +18 -0
  894. data/modules/emscripten/third_party/websockify/rebind.c +94 -0
  895. data/modules/emscripten/third_party/websockify/run +5 -0
  896. data/modules/emscripten/third_party/websockify/setup.py +30 -0
  897. data/modules/emscripten/third_party/websockify/tests/b64_vs_utf8.py +29 -0
  898. data/modules/emscripten/third_party/websockify/tests/base64.html +91 -0
  899. data/modules/emscripten/third_party/websockify/tests/base64.js +12 -0
  900. data/modules/emscripten/third_party/websockify/tests/echo.html +148 -0
  901. data/modules/emscripten/third_party/websockify/tests/echo.py +75 -0
  902. data/modules/emscripten/third_party/websockify/tests/echo.rb +62 -0
  903. data/modules/emscripten/third_party/websockify/tests/latency.html +290 -0
  904. data/modules/emscripten/third_party/websockify/tests/latency.py +75 -0
  905. data/modules/emscripten/third_party/websockify/tests/load.html +250 -0
  906. data/modules/emscripten/third_party/websockify/tests/load.py +167 -0
  907. data/modules/emscripten/third_party/websockify/tests/plain_echo.html +168 -0
  908. data/modules/emscripten/third_party/websockify/tests/simple.html +68 -0
  909. data/modules/emscripten/third_party/websockify/tests/utf8-list.py +22 -0
  910. data/modules/emscripten/third_party/websockify/websockify/__init__.py +2 -0
  911. data/modules/emscripten/third_party/websockify/websockify/websocket.py +982 -0
  912. data/modules/emscripten/third_party/websockify/websockify/websocketproxy.py +393 -0
  913. data/modules/emscripten/third_party/websockify/websockify.py +5 -0
  914. data/modules/emscripten/third_party/websockify/wsirc.html +99 -0
  915. data/modules/emscripten/third_party/websockify/wstelnet.html +74 -0
  916. data/modules/emscripten/tools/__init__.py +0 -0
  917. data/modules/emscripten/tools/__init__.pyc +0 -0
  918. data/modules/emscripten/tools/autodebugger.py +289 -0
  919. data/modules/emscripten/tools/autodebugger_c.py +37 -0
  920. data/modules/emscripten/tools/autodebugger_indenter.py +18 -0
  921. data/modules/emscripten/tools/autodebugger_js.py +47 -0
  922. data/modules/emscripten/tools/autodediffer.py +60 -0
  923. data/modules/emscripten/tools/bindings_generator.py +832 -0
  924. data/modules/emscripten/tools/bisect_pair.py +88 -0
  925. data/modules/emscripten/tools/cache.py +198 -0
  926. data/modules/emscripten/tools/cache.pyc +0 -0
  927. data/modules/emscripten/tools/clean_webconsole.py +34 -0
  928. data/modules/emscripten/tools/crunch-worker.js +124 -0
  929. data/modules/emscripten/tools/diff_autodebugger.py +15 -0
  930. data/modules/emscripten/tools/eliminator/asm-eliminator-test-output.js +5129 -0
  931. data/modules/emscripten/tools/eliminator/asm-eliminator-test.js +6861 -0
  932. data/modules/emscripten/tools/eliminator/eliminator-test-output.js +6122 -0
  933. data/modules/emscripten/tools/eliminator/eliminator-test.js +8856 -0
  934. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/README.html +888 -0
  935. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/README.org +463 -0
  936. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/bin/uglifyjs +317 -0
  937. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/docstyle.css +75 -0
  938. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/lib/object-ast.js +75 -0
  939. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/lib/parse-js.js +1363 -0
  940. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/lib/process.js +2005 -0
  941. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/lib/squeeze-more.js +51 -0
  942. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/package.json +22 -0
  943. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/beautify.js +28 -0
  944. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/testparser.js +402 -0
  945. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/array1.js +1 -0
  946. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/array2.js +1 -0
  947. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/array3.js +1 -0
  948. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/array4.js +1 -0
  949. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/assignment.js +1 -0
  950. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/concatstring.js +1 -0
  951. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/const.js +1 -0
  952. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/empty-blocks.js +1 -0
  953. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/forstatement.js +1 -0
  954. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/if.js +1 -0
  955. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/ifreturn.js +1 -0
  956. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/ifreturn2.js +1 -0
  957. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue10.js +1 -0
  958. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue11.js +1 -0
  959. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue13.js +1 -0
  960. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue14.js +1 -0
  961. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue16.js +1 -0
  962. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue17.js +1 -0
  963. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue20.js +1 -0
  964. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue21.js +1 -0
  965. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue25.js +1 -0
  966. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue27.js +1 -0
  967. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue28.js +1 -0
  968. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue29.js +1 -0
  969. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue30.js +1 -0
  970. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue34.js +1 -0
  971. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue4.js +1 -0
  972. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue48.js +1 -0
  973. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue50.js +1 -0
  974. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue53.js +1 -0
  975. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue54.1.js +1 -0
  976. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue68.js +1 -0
  977. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue69.js +1 -0
  978. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/issue9.js +1 -0
  979. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/mangle.js +1 -0
  980. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/strict-equals.js +1 -0
  981. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/var.js +1 -0
  982. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/expected/with.js +1 -0
  983. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/array1.js +3 -0
  984. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/array2.js +4 -0
  985. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/array3.js +4 -0
  986. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/array4.js +6 -0
  987. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/assignment.js +20 -0
  988. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/concatstring.js +3 -0
  989. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/const.js +5 -0
  990. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/empty-blocks.js +4 -0
  991. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/forstatement.js +10 -0
  992. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/if.js +6 -0
  993. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/ifreturn.js +9 -0
  994. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/ifreturn2.js +16 -0
  995. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue10.js +1 -0
  996. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue11.js +3 -0
  997. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue13.js +1 -0
  998. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue14.js +1 -0
  999. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue16.js +1 -0
  1000. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue17.js +4 -0
  1001. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue20.js +1 -0
  1002. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue21.js +6 -0
  1003. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue25.js +7 -0
  1004. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue27.js +1 -0
  1005. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue28.js +3 -0
  1006. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue29.js +1 -0
  1007. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue30.js +3 -0
  1008. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue34.js +3 -0
  1009. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue4.js +3 -0
  1010. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue48.js +1 -0
  1011. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue50.js +9 -0
  1012. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue53.js +1 -0
  1013. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue54.1.js +3 -0
  1014. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue68.js +5 -0
  1015. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue69.js +1 -0
  1016. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/issue9.js +4 -0
  1017. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/mangle.js +5 -0
  1018. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/strict-equals.js +3 -0
  1019. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/var.js +3 -0
  1020. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/compress/test/with.js +2 -0
  1021. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/test/unit/scripts.js +55 -0
  1022. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/tmp/hoist.js +33 -0
  1023. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/tmp/instrument.js +97 -0
  1024. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/tmp/instrument2.js +138 -0
  1025. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/tmp/test.js +16 -0
  1026. data/modules/emscripten/tools/eliminator/node_modules/uglify-js/uglify-js.js +17 -0
  1027. data/modules/emscripten/tools/eliminator/safe-eliminator-test-output.js +85 -0
  1028. data/modules/emscripten/tools/eliminator/safe-eliminator-test.js +103 -0
  1029. data/modules/emscripten/tools/emconfiguren.py +19 -0
  1030. data/modules/emscripten/tools/emmaken.py +230 -0
  1031. data/modules/emscripten/tools/emmakenxx.py +18 -0
  1032. data/modules/emscripten/tools/exec_llvm.py +50 -0
  1033. data/modules/emscripten/tools/file2json.py +49 -0
  1034. data/modules/emscripten/tools/file_packager.py +649 -0
  1035. data/modules/emscripten/tools/find_bigfuncs.py +23 -0
  1036. data/modules/emscripten/tools/find_bigis.py +18 -0
  1037. data/modules/emscripten/tools/fix_closure.py +88 -0
  1038. data/modules/emscripten/tools/ie7_fix.py +14 -0
  1039. data/modules/emscripten/tools/js-optimizer.js +3440 -0
  1040. data/modules/emscripten/tools/js_optimizer.py +341 -0
  1041. data/modules/emscripten/tools/js_optimizer.pyc +0 -0
  1042. data/modules/emscripten/tools/jsrun.py +27 -0
  1043. data/modules/emscripten/tools/jsrun.pyc +0 -0
  1044. data/modules/emscripten/tools/ll-strip.py +56 -0
  1045. data/modules/emscripten/tools/make_file.py +19 -0
  1046. data/modules/emscripten/tools/make_minigzip.py +13 -0
  1047. data/modules/emscripten/tools/namespacer.py +95 -0
  1048. data/modules/emscripten/tools/nativize_llvm.py +34 -0
  1049. data/modules/emscripten/tools/node_modules/source-map/CHANGELOG.md +58 -0
  1050. data/modules/emscripten/tools/node_modules/source-map/LICENSE +28 -0
  1051. data/modules/emscripten/tools/node_modules/source-map/Makefile.dryice.js +166 -0
  1052. data/modules/emscripten/tools/node_modules/source-map/README.md +347 -0
  1053. data/modules/emscripten/tools/node_modules/source-map/build/assert-shim.js +56 -0
  1054. data/modules/emscripten/tools/node_modules/source-map/build/mini-require.js +152 -0
  1055. data/modules/emscripten/tools/node_modules/source-map/build/prefix-source-map.jsm +20 -0
  1056. data/modules/emscripten/tools/node_modules/source-map/build/prefix-utils.jsm +18 -0
  1057. data/modules/emscripten/tools/node_modules/source-map/build/suffix-browser.js +8 -0
  1058. data/modules/emscripten/tools/node_modules/source-map/build/suffix-source-map.jsm +6 -0
  1059. data/modules/emscripten/tools/node_modules/source-map/build/suffix-utils.jsm +21 -0
  1060. data/modules/emscripten/tools/node_modules/source-map/build/test-prefix.js +8 -0
  1061. data/modules/emscripten/tools/node_modules/source-map/build/test-suffix.js +3 -0
  1062. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/array-set.js +96 -0
  1063. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/base64-vlq.js +144 -0
  1064. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/base64.js +42 -0
  1065. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/binary-search.js +81 -0
  1066. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/source-map-consumer.js +430 -0
  1067. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/source-map-generator.js +381 -0
  1068. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/source-node.js +353 -0
  1069. data/modules/emscripten/tools/node_modules/source-map/lib/source-map/util.js +117 -0
  1070. data/modules/emscripten/tools/node_modules/source-map/lib/source-map.js +8 -0
  1071. data/modules/emscripten/tools/node_modules/source-map/node_modules/amdefine/LICENSE +58 -0
  1072. data/modules/emscripten/tools/node_modules/source-map/node_modules/amdefine/README.md +119 -0
  1073. data/modules/emscripten/tools/node_modules/source-map/node_modules/amdefine/amdefine.js +299 -0
  1074. data/modules/emscripten/tools/node_modules/source-map/node_modules/amdefine/package.json +33 -0
  1075. data/modules/emscripten/tools/node_modules/source-map/package.json +74 -0
  1076. data/modules/emscripten/tools/node_modules/source-map/test/run-tests.js +73 -0
  1077. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-api.js +26 -0
  1078. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-array-set.js +71 -0
  1079. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-base64-vlq.js +24 -0
  1080. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-base64.js +35 -0
  1081. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-binary-search.js +54 -0
  1082. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-dog-fooding.js +72 -0
  1083. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-source-map-consumer.js +306 -0
  1084. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-source-map-generator.js +391 -0
  1085. data/modules/emscripten/tools/node_modules/source-map/test/source-map/test-source-node.js +282 -0
  1086. data/modules/emscripten/tools/node_modules/source-map/test/source-map/util.js +152 -0
  1087. data/modules/emscripten/tools/reproduceriter.js +216 -0
  1088. data/modules/emscripten/tools/reproduceriter.py +160 -0
  1089. data/modules/emscripten/tools/response_file.py +28 -0
  1090. data/modules/emscripten/tools/response_file.pyc +0 -0
  1091. data/modules/emscripten/tools/scan_js.py +20 -0
  1092. data/modules/emscripten/tools/scan_ll.py +18 -0
  1093. data/modules/emscripten/tools/scons/site_scons/site_tools/emscripten/__init__.py +3 -0
  1094. data/modules/emscripten/tools/scons/site_scons/site_tools/emscripten/emscripten.py +46 -0
  1095. data/modules/emscripten/tools/settings_template_readonly.py +47 -0
  1096. data/modules/emscripten/tools/shared.py +1437 -0
  1097. data/modules/emscripten/tools/shared.pyc +0 -0
  1098. data/modules/emscripten/tools/source-maps/sourcemap2json.js +15 -0
  1099. data/modules/emscripten/tools/source-maps/sourcemapper.js +177 -0
  1100. data/modules/emscripten/tools/split.py +97 -0
  1101. data/modules/emscripten/tools/tempfiles.py +40 -0
  1102. data/modules/emscripten/tools/tempfiles.pyc +0 -0
  1103. data/modules/emscripten/tools/test-js-optimizer-asm-last-output.js +75 -0
  1104. data/modules/emscripten/tools/test-js-optimizer-asm-last.js +91 -0
  1105. data/modules/emscripten/tools/test-js-optimizer-asm-outline-output.js +570 -0
  1106. data/modules/emscripten/tools/test-js-optimizer-asm-outline.js +606 -0
  1107. data/modules/emscripten/tools/test-js-optimizer-asm-pre-output.js +540 -0
  1108. data/modules/emscripten/tools/test-js-optimizer-asm-pre.js +550 -0
  1109. data/modules/emscripten/tools/test-js-optimizer-asm-regs-min-output.js +36 -0
  1110. data/modules/emscripten/tools/test-js-optimizer-asm-regs-min.js +37 -0
  1111. data/modules/emscripten/tools/test-js-optimizer-asm-regs-output.js +106 -0
  1112. data/modules/emscripten/tools/test-js-optimizer-asm-regs.js +110 -0
  1113. data/modules/emscripten/tools/test-js-optimizer-asm-relocate-output.js +9 -0
  1114. data/modules/emscripten/tools/test-js-optimizer-asm-relocate.js +12 -0
  1115. data/modules/emscripten/tools/test-js-optimizer-output.js +291 -0
  1116. data/modules/emscripten/tools/test-js-optimizer-regs-output.js +232 -0
  1117. data/modules/emscripten/tools/test-js-optimizer-regs.js +237 -0
  1118. data/modules/emscripten/tools/test-js-optimizer-t2-output.js +91 -0
  1119. data/modules/emscripten/tools/test-js-optimizer-t2.js +92 -0
  1120. data/modules/emscripten/tools/test-js-optimizer-t2c-output.js +17 -0
  1121. data/modules/emscripten/tools/test-js-optimizer-t2c.js +18 -0
  1122. data/modules/emscripten/tools/test-js-optimizer-t3-output.js +49 -0
  1123. data/modules/emscripten/tools/test-js-optimizer-t3.js +50 -0
  1124. data/modules/emscripten/tools/test-js-optimizer.js +401 -0
  1125. data/modules/mruby/AUTHORS +18 -0
  1126. data/modules/mruby/CONTRIBUTING.md +65 -0
  1127. data/modules/mruby/ChangeLog +15 -0
  1128. data/modules/mruby/INSTALL +29 -0
  1129. data/modules/mruby/LEGAL +6 -0
  1130. data/modules/mruby/MITL +20 -0
  1131. data/modules/mruby/Makefile +18 -0
  1132. data/modules/mruby/NEWS +13 -0
  1133. data/modules/mruby/README.md +116 -0
  1134. data/modules/mruby/Rakefile +114 -0
  1135. data/modules/mruby/TODO +11 -0
  1136. data/modules/mruby/benchmark/ao-render.rb +315 -0
  1137. data/modules/mruby/benchmark/bm_so_lists.rb +47 -0
  1138. data/modules/mruby/benchmark/fib39.rb +8 -0
  1139. data/modules/mruby/build_config.rb +88 -0
  1140. data/modules/mruby/doc/compile/README.md +376 -0
  1141. data/modules/mruby/doc/mrbgems/README.md +254 -0
  1142. data/modules/mruby/examples/mrbgems/c_and_ruby_extension_example/README.md +4 -0
  1143. data/modules/mruby/examples/mrbgems/c_and_ruby_extension_example/mrbgem.rake +23 -0
  1144. data/modules/mruby/examples/mrbgems/c_and_ruby_extension_example/mrblib/example.rb +5 -0
  1145. data/modules/mruby/examples/mrbgems/c_and_ruby_extension_example/src/example.c +20 -0
  1146. data/modules/mruby/examples/mrbgems/c_and_ruby_extension_example/test/example.rb +7 -0
  1147. data/modules/mruby/examples/mrbgems/c_extension_example/README.md +4 -0
  1148. data/modules/mruby/examples/mrbgems/c_extension_example/mrbgem.rake +23 -0
  1149. data/modules/mruby/examples/mrbgems/c_extension_example/src/example.c +20 -0
  1150. data/modules/mruby/examples/mrbgems/c_extension_example/test/example.c +7 -0
  1151. data/modules/mruby/examples/mrbgems/c_extension_example/test/example.rb +3 -0
  1152. data/modules/mruby/examples/mrbgems/ruby_extension_example/README.md +4 -0
  1153. data/modules/mruby/examples/mrbgems/ruby_extension_example/mrbgem.rake +23 -0
  1154. data/modules/mruby/examples/mrbgems/ruby_extension_example/mrblib/example.rb +5 -0
  1155. data/modules/mruby/examples/mrbgems/ruby_extension_example/test/example.rb +3 -0
  1156. data/modules/mruby/examples/targets/ArduinoDue.rb +65 -0
  1157. data/modules/mruby/examples/targets/chipKitMax32.rb +68 -0
  1158. data/modules/mruby/include/mrbconf.h +87 -0
  1159. data/modules/mruby/include/mruby/array.h +63 -0
  1160. data/modules/mruby/include/mruby/class.h +75 -0
  1161. data/modules/mruby/include/mruby/compile.h +176 -0
  1162. data/modules/mruby/include/mruby/data.h +53 -0
  1163. data/modules/mruby/include/mruby/dump.h +151 -0
  1164. data/modules/mruby/include/mruby/gc.h +17 -0
  1165. data/modules/mruby/include/mruby/hash.h +54 -0
  1166. data/modules/mruby/include/mruby/irep.h +40 -0
  1167. data/modules/mruby/include/mruby/khash.h +257 -0
  1168. data/modules/mruby/include/mruby/numeric.h +32 -0
  1169. data/modules/mruby/include/mruby/proc.h +62 -0
  1170. data/modules/mruby/include/mruby/range.h +35 -0
  1171. data/modules/mruby/include/mruby/string.h +78 -0
  1172. data/modules/mruby/include/mruby/value.h +483 -0
  1173. data/modules/mruby/include/mruby/variable.h +78 -0
  1174. data/modules/mruby/include/mruby.h +388 -0
  1175. data/modules/mruby/minirake +477 -0
  1176. data/modules/mruby/mrbgems/default.gembox +61 -0
  1177. data/modules/mruby/mrbgems/full-core.gembox +9 -0
  1178. data/modules/mruby/mrbgems/mruby-array-ext/mrbgem.rake +4 -0
  1179. data/modules/mruby/mrbgems/mruby-array-ext/mrblib/array.rb +204 -0
  1180. data/modules/mruby/mrbgems/mruby-array-ext/src/array.c +140 -0
  1181. data/modules/mruby/mrbgems/mruby-array-ext/test/array.rb +109 -0
  1182. data/modules/mruby/mrbgems/mruby-bin-mirb/mrbgem.rake +5 -0
  1183. data/modules/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c +365 -0
  1184. data/modules/mruby/mrbgems/mruby-bin-mruby/mrbgem.rake +5 -0
  1185. data/modules/mruby/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c +243 -0
  1186. data/modules/mruby/mrbgems/mruby-enum-ext/mrbgem.rake +4 -0
  1187. data/modules/mruby/mrbgems/mruby-enum-ext/mrblib/enum.rb +164 -0
  1188. data/modules/mruby/mrbgems/mruby-enum-ext/test/enum.rb +44 -0
  1189. data/modules/mruby/mrbgems/mruby-eval/mrbgem.rake +4 -0
  1190. data/modules/mruby/mrbgems/mruby-eval/src/eval.c +23 -0
  1191. data/modules/mruby/mrbgems/mruby-fiber/mrbgem.rake +4 -0
  1192. data/modules/mruby/mrbgems/mruby-fiber/src/fiber.c +251 -0
  1193. data/modules/mruby/mrbgems/mruby-fiber/test/fiber.rb +64 -0
  1194. data/modules/mruby/mrbgems/mruby-hash-ext/mrbgem.rake +4 -0
  1195. data/modules/mruby/mrbgems/mruby-hash-ext/mrblib/hash.rb +13 -0
  1196. data/modules/mruby/mrbgems/mruby-hash-ext/src/hash-ext.c +62 -0
  1197. data/modules/mruby/mrbgems/mruby-hash-ext/test/hash.rb +26 -0
  1198. data/modules/mruby/mrbgems/mruby-math/mrbgem.rake +4 -0
  1199. data/modules/mruby/mrbgems/mruby-math/src/math.c +685 -0
  1200. data/modules/mruby/mrbgems/mruby-math/test/math.rb +136 -0
  1201. data/modules/mruby/mrbgems/mruby-numeric-ext/mrbgem.rake +4 -0
  1202. data/modules/mruby/mrbgems/mruby-numeric-ext/src/numeric_ext.c +31 -0
  1203. data/modules/mruby/mrbgems/mruby-numeric-ext/test/numeric.rb +10 -0
  1204. data/modules/mruby/mrbgems/mruby-object-ext/mrbgem.rake +4 -0
  1205. data/modules/mruby/mrbgems/mruby-object-ext/src/object.c +108 -0
  1206. data/modules/mruby/mrbgems/mruby-object-ext/test/nil.rb +11 -0
  1207. data/modules/mruby/mrbgems/mruby-object-ext/test/object.rb +9 -0
  1208. data/modules/mruby/mrbgems/mruby-objectspace/mrbgem.rake +4 -0
  1209. data/modules/mruby/mrbgems/mruby-objectspace/src/mruby_objectspace.c +117 -0
  1210. data/modules/mruby/mrbgems/mruby-objectspace/test/objectspace.rb +38 -0
  1211. data/modules/mruby/mrbgems/mruby-print/mrbgem.rake +4 -0
  1212. data/modules/mruby/mrbgems/mruby-print/mrblib/print.rb +64 -0
  1213. data/modules/mruby/mrbgems/mruby-print/src/print.c +44 -0
  1214. data/modules/mruby/mrbgems/mruby-proc-ext/mrbgem.rake +4 -0
  1215. data/modules/mruby/mrbgems/mruby-proc-ext/mrblib/proc.rb +40 -0
  1216. data/modules/mruby/mrbgems/mruby-proc-ext/src/proc.c +97 -0
  1217. data/modules/mruby/mrbgems/mruby-proc-ext/test/proc.rb +41 -0
  1218. data/modules/mruby/mrbgems/mruby-random/mrbgem.rake +4 -0
  1219. data/modules/mruby/mrbgems/mruby-random/src/mt19937ar.c +193 -0
  1220. data/modules/mruby/mrbgems/mruby-random/src/mt19937ar.h +48 -0
  1221. data/modules/mruby/mrbgems/mruby-random/src/random.c +231 -0
  1222. data/modules/mruby/mrbgems/mruby-random/src/random.h +12 -0
  1223. data/modules/mruby/mrbgems/mruby-random/test/random.rb +32 -0
  1224. data/modules/mruby/mrbgems/mruby-range-ext/mrbgem.rake +4 -0
  1225. data/modules/mruby/mrbgems/mruby-range-ext/src/range.c +141 -0
  1226. data/modules/mruby/mrbgems/mruby-range-ext/test/range.rb +20 -0
  1227. data/modules/mruby/mrbgems/mruby-sprintf/mrbgem.rake +4 -0
  1228. data/modules/mruby/mrbgems/mruby-sprintf/src/kernel.c +30 -0
  1229. data/modules/mruby/mrbgems/mruby-sprintf/src/sprintf.c +1102 -0
  1230. data/modules/mruby/mrbgems/mruby-sprintf/test/sprintf.rb +3 -0
  1231. data/modules/mruby/mrbgems/mruby-string-ext/mrbgem.rake +4 -0
  1232. data/modules/mruby/mrbgems/mruby-string-ext/mrblib/string.rb +52 -0
  1233. data/modules/mruby/mrbgems/mruby-string-ext/src/string.c +175 -0
  1234. data/modules/mruby/mrbgems/mruby-string-ext/test/string.rb +112 -0
  1235. data/modules/mruby/mrbgems/mruby-struct/mrbgem.rake +4 -0
  1236. data/modules/mruby/mrbgems/mruby-struct/mrblib/struct.rb +50 -0
  1237. data/modules/mruby/mrbgems/mruby-struct/src/struct.c +818 -0
  1238. data/modules/mruby/mrbgems/mruby-struct/test/struct.rb +77 -0
  1239. data/modules/mruby/mrbgems/mruby-symbol-ext/mrbgem.rake +4 -0
  1240. data/modules/mruby/mrbgems/mruby-symbol-ext/mrblib/symbol.rb +9 -0
  1241. data/modules/mruby/mrbgems/mruby-symbol-ext/src/symbol.c +55 -0
  1242. data/modules/mruby/mrbgems/mruby-symbol-ext/test/symbol.rb +12 -0
  1243. data/modules/mruby/mrbgems/mruby-time/mrbgem.rake +4 -0
  1244. data/modules/mruby/mrbgems/mruby-time/src/time.c +749 -0
  1245. data/modules/mruby/mrbgems/mruby-time/test/time.rb +201 -0
  1246. data/modules/mruby/mrbgems/mruby-toplevel-ext/mrbgem.rake +4 -0
  1247. data/modules/mruby/mrbgems/mruby-toplevel-ext/mrblib/toplevel.rb +11 -0
  1248. data/modules/mruby/mrbgems/mruby-toplevel-ext/test/toplevel.rb +24 -0
  1249. data/modules/mruby/mrblib/array.rb +111 -0
  1250. data/modules/mruby/mrblib/class.rb +26 -0
  1251. data/modules/mruby/mrblib/compar.rb +104 -0
  1252. data/modules/mruby/mrblib/enum.rb +398 -0
  1253. data/modules/mruby/mrblib/error.rb +66 -0
  1254. data/modules/mruby/mrblib/hash.rb +193 -0
  1255. data/modules/mruby/mrblib/init_mrblib.c +14 -0
  1256. data/modules/mruby/mrblib/kernel.rb +46 -0
  1257. data/modules/mruby/mrblib/mrblib.rake +18 -0
  1258. data/modules/mruby/mrblib/numeric.rb +101 -0
  1259. data/modules/mruby/mrblib/print.rb +18 -0
  1260. data/modules/mruby/mrblib/range.rb +40 -0
  1261. data/modules/mruby/mrblib/string.rb +145 -0
  1262. data/modules/mruby/src/array.c +1150 -0
  1263. data/modules/mruby/src/backtrace.c +73 -0
  1264. data/modules/mruby/src/class.c +1942 -0
  1265. data/modules/mruby/src/codegen.c +2864 -0
  1266. data/modules/mruby/src/compar.c +13 -0
  1267. data/modules/mruby/src/crc.c +38 -0
  1268. data/modules/mruby/src/dump.c +542 -0
  1269. data/modules/mruby/src/enum.c +14 -0
  1270. data/modules/mruby/src/error.c +454 -0
  1271. data/modules/mruby/src/error.h +18 -0
  1272. data/modules/mruby/src/etc.c +204 -0
  1273. data/modules/mruby/src/gc.c +1542 -0
  1274. data/modules/mruby/src/hash.c +1261 -0
  1275. data/modules/mruby/src/init.c +62 -0
  1276. data/modules/mruby/src/kernel.c +1105 -0
  1277. data/modules/mruby/src/keywords +50 -0
  1278. data/modules/mruby/src/lex.def +212 -0
  1279. data/modules/mruby/src/load.c +629 -0
  1280. data/modules/mruby/src/mruby_core.rake +28 -0
  1281. data/modules/mruby/src/node.h +117 -0
  1282. data/modules/mruby/src/numeric.c +1418 -0
  1283. data/modules/mruby/src/object.c +593 -0
  1284. data/modules/mruby/src/opcode.h +160 -0
  1285. data/modules/mruby/src/parse.y +6050 -0
  1286. data/modules/mruby/src/pool.c +190 -0
  1287. data/modules/mruby/src/print.c +71 -0
  1288. data/modules/mruby/src/proc.c +209 -0
  1289. data/modules/mruby/src/range.c +442 -0
  1290. data/modules/mruby/src/re.h +13 -0
  1291. data/modules/mruby/src/state.c +200 -0
  1292. data/modules/mruby/src/string.c +2580 -0
  1293. data/modules/mruby/src/symbol.c +456 -0
  1294. data/modules/mruby/src/value_array.h +27 -0
  1295. data/modules/mruby/src/variable.c +1147 -0
  1296. data/modules/mruby/src/vm.c +2129 -0
  1297. data/modules/mruby/tasks/libmruby.rake +18 -0
  1298. data/modules/mruby/tasks/mrbgem_spec.rake +297 -0
  1299. data/modules/mruby/tasks/mrbgems.rake +85 -0
  1300. data/modules/mruby/tasks/mrbgems_test.rake +88 -0
  1301. data/modules/mruby/tasks/mruby_build.rake +211 -0
  1302. data/modules/mruby/tasks/mruby_build_commands.rake +287 -0
  1303. data/modules/mruby/tasks/mruby_build_gem.rake +67 -0
  1304. data/modules/mruby/tasks/ruby_ext.rake +70 -0
  1305. data/modules/mruby/tasks/toolchains/androideabi.rake +126 -0
  1306. data/modules/mruby/tasks/toolchains/clang.rake +8 -0
  1307. data/modules/mruby/tasks/toolchains/gcc.rake +21 -0
  1308. data/modules/mruby/tasks/toolchains/vs2010.rake +3 -0
  1309. data/modules/mruby/tasks/toolchains/vs2012.rake +44 -0
  1310. data/modules/mruby/test/README.md +7 -0
  1311. data/modules/mruby/test/assert.rb +238 -0
  1312. data/modules/mruby/test/driver.c +118 -0
  1313. data/modules/mruby/test/init_mrbtest.c +24 -0
  1314. data/modules/mruby/test/mrbtest.rake +47 -0
  1315. data/modules/mruby/test/report.rb +4 -0
  1316. data/modules/mruby/test/t/argumenterror.rb +21 -0
  1317. data/modules/mruby/test/t/array.rb +309 -0
  1318. data/modules/mruby/test/t/basicobject.rb +11 -0
  1319. data/modules/mruby/test/t/bs_block.rb +489 -0
  1320. data/modules/mruby/test/t/bs_literal.rb +38 -0
  1321. data/modules/mruby/test/t/class.rb +219 -0
  1322. data/modules/mruby/test/t/comparable.rb +72 -0
  1323. data/modules/mruby/test/t/enumerable.rb +108 -0
  1324. data/modules/mruby/test/t/exception.rb +337 -0
  1325. data/modules/mruby/test/t/false.rb +33 -0
  1326. data/modules/mruby/test/t/float.rb +145 -0
  1327. data/modules/mruby/test/t/gc.rb +45 -0
  1328. data/modules/mruby/test/t/hash.rb +310 -0
  1329. data/modules/mruby/test/t/indexerror.rb +10 -0
  1330. data/modules/mruby/test/t/integer.rb +222 -0
  1331. data/modules/mruby/test/t/kernel.rb +425 -0
  1332. data/modules/mruby/test/t/literals.rb +287 -0
  1333. data/modules/mruby/test/t/localjumperror.rb +13 -0
  1334. data/modules/mruby/test/t/methods.rb +109 -0
  1335. data/modules/mruby/test/t/module.rb +344 -0
  1336. data/modules/mruby/test/t/nameerror.rb +32 -0
  1337. data/modules/mruby/test/t/nil.rb +29 -0
  1338. data/modules/mruby/test/t/nomethoderror.rb +13 -0
  1339. data/modules/mruby/test/t/numeric.rb +29 -0
  1340. data/modules/mruby/test/t/object.rb +11 -0
  1341. data/modules/mruby/test/t/proc.rb +56 -0
  1342. data/modules/mruby/test/t/range.rb +82 -0
  1343. data/modules/mruby/test/t/rangeerror.rb +10 -0
  1344. data/modules/mruby/test/t/regexperror.rb +4 -0
  1345. data/modules/mruby/test/t/runtimeerror.rb +6 -0
  1346. data/modules/mruby/test/t/standarderror.rb +10 -0
  1347. data/modules/mruby/test/t/string.rb +483 -0
  1348. data/modules/mruby/test/t/symbol.rb +27 -0
  1349. data/modules/mruby/test/t/syntax.rb +67 -0
  1350. data/modules/mruby/test/t/true.rb +33 -0
  1351. data/modules/mruby/test/t/typeerror.rb +11 -0
  1352. data/modules/mruby/tools/mrbc/mrbc.c +318 -0
  1353. data/modules/mruby/tools/mrbc/mrbc.rake +14 -0
  1354. data/modules/mruby/travis_config.rb +6 -0
  1355. data/modules/mrubymix/LICENSE +21 -0
  1356. data/modules/mrubymix/README.md +6 -0
  1357. data/modules/mrubymix/bin/mrubymix +29 -0
  1358. data/modules/mrubymix/lib/mrubymix.rb +93 -0
  1359. data/modules/mrubymix/mrubymix.gemspec +13 -0
  1360. data/scripts/gen_gems_config.rb +185 -0
  1361. data/scripts/gen_post.rb +104 -0
  1362. data/templates/minimal/Rakefile +36 -0
  1363. data/templates/minimal/app/app.rb +3 -0
  1364. metadata +1408 -0
@@ -0,0 +1,1945 @@
1
+ // -*- C++ -*-
2
+ //===----------------------------------------------------------------------===//
3
+ //
4
+ // The LLVM Compiler Infrastructure
5
+ //
6
+ // This file is dual licensed under the MIT and the University of Illinois Open
7
+ // Source Licenses. See LICENSE.TXT for details.
8
+ //
9
+ //===----------------------------------------------------------------------===//
10
+
11
+ #ifndef _LIBCPP__HASH_TABLE
12
+ #define _LIBCPP__HASH_TABLE
13
+
14
+ #include <__config>
15
+ #include <initializer_list>
16
+ #include <memory>
17
+ #include <iterator>
18
+ #include <algorithm>
19
+ #include <cmath>
20
+
21
+ #include <__undef_min_max>
22
+
23
+ #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
24
+ #pragma GCC system_header
25
+ #endif
26
+
27
+ _LIBCPP_BEGIN_NAMESPACE_STD
28
+
29
+ _LIBCPP_FUNC_VIS
30
+ size_t __next_prime(size_t __n);
31
+
32
+ template <class _NodePtr>
33
+ struct __hash_node_base
34
+ {
35
+ typedef __hash_node_base __first_node;
36
+ // typedef _NodePtr pointer;
37
+
38
+ _NodePtr __next_;
39
+
40
+ _LIBCPP_INLINE_VISIBILITY __hash_node_base() _NOEXCEPT : __next_(nullptr) {}
41
+ };
42
+
43
+ template <class _Tp, class _VoidPtr>
44
+ struct __hash_node
45
+ : public __hash_node_base
46
+ <
47
+ typename pointer_traits<_VoidPtr>::template
48
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
49
+ rebind<__hash_node<_Tp, _VoidPtr> >
50
+ #else
51
+ rebind<__hash_node<_Tp, _VoidPtr> >::other
52
+ #endif
53
+ >
54
+ {
55
+ typedef _Tp value_type;
56
+
57
+ size_t __hash_;
58
+ value_type __value_;
59
+ };
60
+
61
+ inline _LIBCPP_INLINE_VISIBILITY
62
+ bool
63
+ __is_power2(size_t __bc)
64
+ {
65
+ return __bc > 2 && !(__bc & (__bc - 1));
66
+ }
67
+
68
+ inline _LIBCPP_INLINE_VISIBILITY
69
+ size_t
70
+ __constrain_hash(size_t __h, size_t __bc)
71
+ {
72
+ return !(__bc & (__bc - 1)) ? __h & (__bc - 1) : __h % __bc;
73
+ }
74
+
75
+ inline _LIBCPP_INLINE_VISIBILITY
76
+ size_t
77
+ __next_pow2(size_t __n)
78
+ {
79
+ return size_t(1) << (std::numeric_limits<size_t>::digits - __clz(__n-1));
80
+ }
81
+
82
+ template <class _Tp, class _Hash, class _Equal, class _Alloc> class __hash_table;
83
+ template <class _ConstNodePtr> class _LIBCPP_TYPE_VIS __hash_const_iterator;
84
+ template <class _HashIterator> class _LIBCPP_TYPE_VIS __hash_map_iterator;
85
+ template <class _HashIterator> class _LIBCPP_TYPE_VIS __hash_map_const_iterator;
86
+ template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc>
87
+ class _LIBCPP_TYPE_VIS unordered_map;
88
+
89
+ template <class _NodePtr>
90
+ class _LIBCPP_TYPE_VIS __hash_iterator
91
+ {
92
+ typedef _NodePtr __node_pointer;
93
+
94
+ __node_pointer __node_;
95
+
96
+ public:
97
+ typedef forward_iterator_tag iterator_category;
98
+ typedef typename pointer_traits<__node_pointer>::element_type::value_type value_type;
99
+ typedef typename pointer_traits<__node_pointer>::difference_type difference_type;
100
+ typedef value_type& reference;
101
+ typedef typename pointer_traits<__node_pointer>::template
102
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
103
+ rebind<value_type>
104
+ #else
105
+ rebind<value_type>::other
106
+ #endif
107
+ pointer;
108
+
109
+ _LIBCPP_INLINE_VISIBILITY __hash_iterator() _NOEXCEPT {}
110
+
111
+ _LIBCPP_INLINE_VISIBILITY
112
+ reference operator*() const {return __node_->__value_;}
113
+ _LIBCPP_INLINE_VISIBILITY
114
+ pointer operator->() const {return _VSTD::addressof(__node_->__value_);}
115
+
116
+ _LIBCPP_INLINE_VISIBILITY
117
+ __hash_iterator& operator++()
118
+ {
119
+ __node_ = __node_->__next_;
120
+ return *this;
121
+ }
122
+
123
+ _LIBCPP_INLINE_VISIBILITY
124
+ __hash_iterator operator++(int)
125
+ {
126
+ __hash_iterator __t(*this);
127
+ ++(*this);
128
+ return __t;
129
+ }
130
+
131
+ friend _LIBCPP_INLINE_VISIBILITY
132
+ bool operator==(const __hash_iterator& __x, const __hash_iterator& __y)
133
+ {return __x.__node_ == __y.__node_;}
134
+ friend _LIBCPP_INLINE_VISIBILITY
135
+ bool operator!=(const __hash_iterator& __x, const __hash_iterator& __y)
136
+ {return __x.__node_ != __y.__node_;}
137
+
138
+ private:
139
+ _LIBCPP_INLINE_VISIBILITY
140
+ __hash_iterator(__node_pointer __node) _NOEXCEPT
141
+ : __node_(__node)
142
+ {}
143
+
144
+ template <class, class, class, class> friend class __hash_table;
145
+ template <class> friend class _LIBCPP_TYPE_VIS __hash_const_iterator;
146
+ template <class> friend class _LIBCPP_TYPE_VIS __hash_map_iterator;
147
+ template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS unordered_map;
148
+ template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS unordered_multimap;
149
+ };
150
+
151
+ template <class _ConstNodePtr>
152
+ class _LIBCPP_TYPE_VIS __hash_const_iterator
153
+ {
154
+ typedef _ConstNodePtr __node_pointer;
155
+
156
+ __node_pointer __node_;
157
+
158
+ typedef typename remove_const<
159
+ typename pointer_traits<__node_pointer>::element_type
160
+ >::type __node;
161
+
162
+ public:
163
+ typedef forward_iterator_tag iterator_category;
164
+ typedef typename __node::value_type value_type;
165
+ typedef typename pointer_traits<__node_pointer>::difference_type difference_type;
166
+ typedef const value_type& reference;
167
+ typedef typename pointer_traits<__node_pointer>::template
168
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
169
+ rebind<const value_type>
170
+ #else
171
+ rebind<const value_type>::other
172
+ #endif
173
+ pointer;
174
+ typedef typename pointer_traits<__node_pointer>::template
175
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
176
+ rebind<__node>
177
+ #else
178
+ rebind<__node>::other
179
+ #endif
180
+ __non_const_node_pointer;
181
+ typedef __hash_iterator<__non_const_node_pointer> __non_const_iterator;
182
+
183
+ _LIBCPP_INLINE_VISIBILITY __hash_const_iterator() _NOEXCEPT {}
184
+ _LIBCPP_INLINE_VISIBILITY
185
+ __hash_const_iterator(const __non_const_iterator& __x) _NOEXCEPT
186
+ : __node_(__x.__node_)
187
+ {}
188
+
189
+ _LIBCPP_INLINE_VISIBILITY
190
+ reference operator*() const {return __node_->__value_;}
191
+ _LIBCPP_INLINE_VISIBILITY
192
+ pointer operator->() const {return _VSTD::addressof(__node_->__value_);}
193
+
194
+ _LIBCPP_INLINE_VISIBILITY
195
+ __hash_const_iterator& operator++()
196
+ {
197
+ __node_ = __node_->__next_;
198
+ return *this;
199
+ }
200
+
201
+ _LIBCPP_INLINE_VISIBILITY
202
+ __hash_const_iterator operator++(int)
203
+ {
204
+ __hash_const_iterator __t(*this);
205
+ ++(*this);
206
+ return __t;
207
+ }
208
+
209
+ friend _LIBCPP_INLINE_VISIBILITY
210
+ bool operator==(const __hash_const_iterator& __x, const __hash_const_iterator& __y)
211
+ {return __x.__node_ == __y.__node_;}
212
+ friend _LIBCPP_INLINE_VISIBILITY
213
+ bool operator!=(const __hash_const_iterator& __x, const __hash_const_iterator& __y)
214
+ {return __x.__node_ != __y.__node_;}
215
+
216
+ private:
217
+ _LIBCPP_INLINE_VISIBILITY
218
+ __hash_const_iterator(__node_pointer __node) _NOEXCEPT
219
+ : __node_(__node)
220
+ {}
221
+
222
+ template <class, class, class, class> friend class __hash_table;
223
+ template <class> friend class _LIBCPP_TYPE_VIS __hash_map_const_iterator;
224
+ template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS unordered_map;
225
+ template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS unordered_multimap;
226
+ };
227
+
228
+ template <class _ConstNodePtr> class _LIBCPP_TYPE_VIS __hash_const_local_iterator;
229
+
230
+ template <class _NodePtr>
231
+ class _LIBCPP_TYPE_VIS __hash_local_iterator
232
+ {
233
+ typedef _NodePtr __node_pointer;
234
+
235
+ __node_pointer __node_;
236
+ size_t __bucket_;
237
+ size_t __bucket_count_;
238
+
239
+ typedef pointer_traits<__node_pointer> __pointer_traits;
240
+ public:
241
+ typedef forward_iterator_tag iterator_category;
242
+ typedef typename __pointer_traits::element_type::value_type value_type;
243
+ typedef typename __pointer_traits::difference_type difference_type;
244
+ typedef value_type& reference;
245
+ typedef typename __pointer_traits::template
246
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
247
+ rebind<value_type>
248
+ #else
249
+ rebind<value_type>::other
250
+ #endif
251
+ pointer;
252
+
253
+ _LIBCPP_INLINE_VISIBILITY __hash_local_iterator() _NOEXCEPT {}
254
+
255
+ _LIBCPP_INLINE_VISIBILITY
256
+ reference operator*() const {return __node_->__value_;}
257
+ _LIBCPP_INLINE_VISIBILITY
258
+ pointer operator->() const {return &__node_->__value_;}
259
+
260
+ _LIBCPP_INLINE_VISIBILITY
261
+ __hash_local_iterator& operator++()
262
+ {
263
+ __node_ = __node_->__next_;
264
+ if (__node_ != nullptr && __constrain_hash(__node_->__hash_, __bucket_count_) != __bucket_)
265
+ __node_ = nullptr;
266
+ return *this;
267
+ }
268
+
269
+ _LIBCPP_INLINE_VISIBILITY
270
+ __hash_local_iterator operator++(int)
271
+ {
272
+ __hash_local_iterator __t(*this);
273
+ ++(*this);
274
+ return __t;
275
+ }
276
+
277
+ friend _LIBCPP_INLINE_VISIBILITY
278
+ bool operator==(const __hash_local_iterator& __x, const __hash_local_iterator& __y)
279
+ {return __x.__node_ == __y.__node_;}
280
+ friend _LIBCPP_INLINE_VISIBILITY
281
+ bool operator!=(const __hash_local_iterator& __x, const __hash_local_iterator& __y)
282
+ {return __x.__node_ != __y.__node_;}
283
+
284
+ private:
285
+ _LIBCPP_INLINE_VISIBILITY
286
+ __hash_local_iterator(__node_pointer __node, size_t __bucket,
287
+ size_t __bucket_count) _NOEXCEPT
288
+ : __node_(__node),
289
+ __bucket_(__bucket),
290
+ __bucket_count_(__bucket_count)
291
+ {
292
+ if (__node_ != nullptr)
293
+ __node_ = __node_->__next_;
294
+ }
295
+
296
+ template <class, class, class, class> friend class __hash_table;
297
+ template <class> friend class _LIBCPP_TYPE_VIS __hash_const_local_iterator;
298
+ template <class> friend class _LIBCPP_TYPE_VIS __hash_map_iterator;
299
+ };
300
+
301
+ template <class _ConstNodePtr>
302
+ class _LIBCPP_TYPE_VIS __hash_const_local_iterator
303
+ {
304
+ typedef _ConstNodePtr __node_pointer;
305
+
306
+ __node_pointer __node_;
307
+ size_t __bucket_;
308
+ size_t __bucket_count_;
309
+
310
+ typedef pointer_traits<__node_pointer> __pointer_traits;
311
+ typedef typename __pointer_traits::element_type __node;
312
+ typedef typename remove_const<__node>::type __non_const_node;
313
+ typedef typename pointer_traits<__node_pointer>::template
314
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
315
+ rebind<__non_const_node>
316
+ #else
317
+ rebind<__non_const_node>::other
318
+ #endif
319
+ __non_const_node_pointer;
320
+ typedef __hash_local_iterator<__non_const_node_pointer>
321
+ __non_const_iterator;
322
+ public:
323
+ typedef forward_iterator_tag iterator_category;
324
+ typedef typename remove_const<
325
+ typename __pointer_traits::element_type::value_type
326
+ >::type value_type;
327
+ typedef typename __pointer_traits::difference_type difference_type;
328
+ typedef const value_type& reference;
329
+ typedef typename __pointer_traits::template
330
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
331
+ rebind<const value_type>
332
+ #else
333
+ rebind<const value_type>::other
334
+ #endif
335
+ pointer;
336
+
337
+ _LIBCPP_INLINE_VISIBILITY __hash_const_local_iterator() _NOEXCEPT {}
338
+ _LIBCPP_INLINE_VISIBILITY
339
+ __hash_const_local_iterator(const __non_const_iterator& __x) _NOEXCEPT
340
+ : __node_(__x.__node_),
341
+ __bucket_(__x.__bucket_),
342
+ __bucket_count_(__x.__bucket_count_)
343
+ {}
344
+
345
+ _LIBCPP_INLINE_VISIBILITY
346
+ reference operator*() const {return __node_->__value_;}
347
+ _LIBCPP_INLINE_VISIBILITY
348
+ pointer operator->() const {return &__node_->__value_;}
349
+
350
+ _LIBCPP_INLINE_VISIBILITY
351
+ __hash_const_local_iterator& operator++()
352
+ {
353
+ __node_ = __node_->__next_;
354
+ if (__node_ != nullptr && __constrain_hash(__node_->__hash_, __bucket_count_) != __bucket_)
355
+ __node_ = nullptr;
356
+ return *this;
357
+ }
358
+
359
+ _LIBCPP_INLINE_VISIBILITY
360
+ __hash_const_local_iterator operator++(int)
361
+ {
362
+ __hash_const_local_iterator __t(*this);
363
+ ++(*this);
364
+ return __t;
365
+ }
366
+
367
+ friend _LIBCPP_INLINE_VISIBILITY
368
+ bool operator==(const __hash_const_local_iterator& __x, const __hash_const_local_iterator& __y)
369
+ {return __x.__node_ == __y.__node_;}
370
+ friend _LIBCPP_INLINE_VISIBILITY
371
+ bool operator!=(const __hash_const_local_iterator& __x, const __hash_const_local_iterator& __y)
372
+ {return __x.__node_ != __y.__node_;}
373
+
374
+ private:
375
+ _LIBCPP_INLINE_VISIBILITY
376
+ __hash_const_local_iterator(__node_pointer __node, size_t __bucket,
377
+ size_t __bucket_count) _NOEXCEPT
378
+ : __node_(__node),
379
+ __bucket_(__bucket),
380
+ __bucket_count_(__bucket_count)
381
+ {
382
+ if (__node_ != nullptr)
383
+ __node_ = __node_->__next_;
384
+ }
385
+
386
+ template <class, class, class, class> friend class __hash_table;
387
+ template <class> friend class _LIBCPP_TYPE_VIS __hash_map_const_iterator;
388
+ };
389
+
390
+ template <class _Alloc>
391
+ class __bucket_list_deallocator
392
+ {
393
+ typedef _Alloc allocator_type;
394
+ typedef allocator_traits<allocator_type> __alloc_traits;
395
+ typedef typename __alloc_traits::size_type size_type;
396
+
397
+ __compressed_pair<size_type, allocator_type> __data_;
398
+ public:
399
+ typedef typename __alloc_traits::pointer pointer;
400
+
401
+ _LIBCPP_INLINE_VISIBILITY
402
+ __bucket_list_deallocator()
403
+ _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value)
404
+ : __data_(0) {}
405
+
406
+ _LIBCPP_INLINE_VISIBILITY
407
+ __bucket_list_deallocator(const allocator_type& __a, size_type __size)
408
+ _NOEXCEPT_(is_nothrow_copy_constructible<allocator_type>::value)
409
+ : __data_(__size, __a) {}
410
+
411
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
412
+
413
+ _LIBCPP_INLINE_VISIBILITY
414
+ __bucket_list_deallocator(__bucket_list_deallocator&& __x)
415
+ _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value)
416
+ : __data_(_VSTD::move(__x.__data_))
417
+ {
418
+ __x.size() = 0;
419
+ }
420
+
421
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
422
+
423
+ _LIBCPP_INLINE_VISIBILITY
424
+ size_type& size() _NOEXCEPT {return __data_.first();}
425
+ _LIBCPP_INLINE_VISIBILITY
426
+ size_type size() const _NOEXCEPT {return __data_.first();}
427
+
428
+ _LIBCPP_INLINE_VISIBILITY
429
+ allocator_type& __alloc() _NOEXCEPT {return __data_.second();}
430
+ _LIBCPP_INLINE_VISIBILITY
431
+ const allocator_type& __alloc() const _NOEXCEPT {return __data_.second();}
432
+
433
+ _LIBCPP_INLINE_VISIBILITY
434
+ void operator()(pointer __p) _NOEXCEPT
435
+ {
436
+ __alloc_traits::deallocate(__alloc(), __p, size());
437
+ }
438
+ };
439
+
440
+ template <class _Alloc> class __hash_map_node_destructor;
441
+
442
+ template <class _Alloc>
443
+ class __hash_node_destructor
444
+ {
445
+ typedef _Alloc allocator_type;
446
+ typedef allocator_traits<allocator_type> __alloc_traits;
447
+ typedef typename __alloc_traits::value_type::value_type value_type;
448
+ public:
449
+ typedef typename __alloc_traits::pointer pointer;
450
+ private:
451
+
452
+ allocator_type& __na_;
453
+
454
+ __hash_node_destructor& operator=(const __hash_node_destructor&);
455
+
456
+ public:
457
+ bool __value_constructed;
458
+
459
+ _LIBCPP_INLINE_VISIBILITY
460
+ explicit __hash_node_destructor(allocator_type& __na,
461
+ bool __constructed = false) _NOEXCEPT
462
+ : __na_(__na),
463
+ __value_constructed(__constructed)
464
+ {}
465
+
466
+ _LIBCPP_INLINE_VISIBILITY
467
+ void operator()(pointer __p) _NOEXCEPT
468
+ {
469
+ if (__value_constructed)
470
+ __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_));
471
+ if (__p)
472
+ __alloc_traits::deallocate(__na_, __p, 1);
473
+ }
474
+
475
+ template <class> friend class __hash_map_node_destructor;
476
+ };
477
+
478
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
479
+ class __hash_table
480
+ {
481
+ public:
482
+ typedef _Tp value_type;
483
+ typedef _Hash hasher;
484
+ typedef _Equal key_equal;
485
+ typedef _Alloc allocator_type;
486
+
487
+ private:
488
+ typedef allocator_traits<allocator_type> __alloc_traits;
489
+ public:
490
+ typedef value_type& reference;
491
+ typedef const value_type& const_reference;
492
+ typedef typename __alloc_traits::pointer pointer;
493
+ typedef typename __alloc_traits::const_pointer const_pointer;
494
+ typedef typename __alloc_traits::size_type size_type;
495
+ typedef typename __alloc_traits::difference_type difference_type;
496
+ public:
497
+ // Create __node
498
+ typedef __hash_node<value_type, typename __alloc_traits::void_pointer> __node;
499
+ typedef typename __alloc_traits::template
500
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
501
+ rebind_alloc<__node>
502
+ #else
503
+ rebind_alloc<__node>::other
504
+ #endif
505
+ __node_allocator;
506
+ typedef allocator_traits<__node_allocator> __node_traits;
507
+ typedef typename __node_traits::pointer __node_pointer;
508
+ typedef typename __node_traits::const_pointer __node_const_pointer;
509
+ typedef __hash_node_base<__node_pointer> __first_node;
510
+
511
+ private:
512
+
513
+ typedef typename __node_traits::template
514
+ #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES
515
+ rebind_alloc<__node_pointer>
516
+ #else
517
+ rebind_alloc<__node_pointer>::other
518
+ #endif
519
+ __pointer_allocator;
520
+ typedef __bucket_list_deallocator<__pointer_allocator> __bucket_list_deleter;
521
+ typedef unique_ptr<__node_pointer[], __bucket_list_deleter> __bucket_list;
522
+ typedef allocator_traits<__pointer_allocator> __pointer_alloc_traits;
523
+ typedef typename __bucket_list_deleter::pointer __node_pointer_pointer;
524
+
525
+ // --- Member data begin ---
526
+ __bucket_list __bucket_list_;
527
+ __compressed_pair<__first_node, __node_allocator> __p1_;
528
+ __compressed_pair<size_type, hasher> __p2_;
529
+ __compressed_pair<float, key_equal> __p3_;
530
+ // --- Member data end ---
531
+
532
+ _LIBCPP_INLINE_VISIBILITY
533
+ size_type& size() _NOEXCEPT {return __p2_.first();}
534
+ public:
535
+ _LIBCPP_INLINE_VISIBILITY
536
+ size_type size() const _NOEXCEPT {return __p2_.first();}
537
+
538
+ _LIBCPP_INLINE_VISIBILITY
539
+ hasher& hash_function() _NOEXCEPT {return __p2_.second();}
540
+ _LIBCPP_INLINE_VISIBILITY
541
+ const hasher& hash_function() const _NOEXCEPT {return __p2_.second();}
542
+
543
+ _LIBCPP_INLINE_VISIBILITY
544
+ float& max_load_factor() _NOEXCEPT {return __p3_.first();}
545
+ _LIBCPP_INLINE_VISIBILITY
546
+ float max_load_factor() const _NOEXCEPT {return __p3_.first();}
547
+
548
+ _LIBCPP_INLINE_VISIBILITY
549
+ key_equal& key_eq() _NOEXCEPT {return __p3_.second();}
550
+ _LIBCPP_INLINE_VISIBILITY
551
+ const key_equal& key_eq() const _NOEXCEPT {return __p3_.second();}
552
+
553
+ _LIBCPP_INLINE_VISIBILITY
554
+ __node_allocator& __node_alloc() _NOEXCEPT {return __p1_.second();}
555
+ _LIBCPP_INLINE_VISIBILITY
556
+ const __node_allocator& __node_alloc() const _NOEXCEPT
557
+ {return __p1_.second();}
558
+
559
+ public:
560
+ typedef __hash_iterator<__node_pointer> iterator;
561
+ typedef __hash_const_iterator<__node_const_pointer> const_iterator;
562
+ typedef __hash_local_iterator<__node_pointer> local_iterator;
563
+ typedef __hash_const_local_iterator<__node_const_pointer> const_local_iterator;
564
+
565
+ __hash_table()
566
+ _NOEXCEPT_(
567
+ is_nothrow_default_constructible<__bucket_list>::value &&
568
+ is_nothrow_default_constructible<__first_node>::value &&
569
+ is_nothrow_default_constructible<__node_allocator>::value &&
570
+ is_nothrow_default_constructible<hasher>::value &&
571
+ is_nothrow_default_constructible<key_equal>::value);
572
+ __hash_table(const hasher& __hf, const key_equal& __eql);
573
+ __hash_table(const hasher& __hf, const key_equal& __eql,
574
+ const allocator_type& __a);
575
+ explicit __hash_table(const allocator_type& __a);
576
+ __hash_table(const __hash_table& __u);
577
+ __hash_table(const __hash_table& __u, const allocator_type& __a);
578
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
579
+ __hash_table(__hash_table&& __u)
580
+ _NOEXCEPT_(
581
+ is_nothrow_move_constructible<__bucket_list>::value &&
582
+ is_nothrow_move_constructible<__first_node>::value &&
583
+ is_nothrow_move_constructible<__node_allocator>::value &&
584
+ is_nothrow_move_constructible<hasher>::value &&
585
+ is_nothrow_move_constructible<key_equal>::value);
586
+ __hash_table(__hash_table&& __u, const allocator_type& __a);
587
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
588
+ ~__hash_table();
589
+
590
+ __hash_table& operator=(const __hash_table& __u);
591
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
592
+ __hash_table& operator=(__hash_table&& __u)
593
+ _NOEXCEPT_(
594
+ __node_traits::propagate_on_container_move_assignment::value &&
595
+ is_nothrow_move_assignable<__node_allocator>::value &&
596
+ is_nothrow_move_assignable<hasher>::value &&
597
+ is_nothrow_move_assignable<key_equal>::value);
598
+ #endif
599
+ template <class _InputIterator>
600
+ void __assign_unique(_InputIterator __first, _InputIterator __last);
601
+ template <class _InputIterator>
602
+ void __assign_multi(_InputIterator __first, _InputIterator __last);
603
+
604
+ _LIBCPP_INLINE_VISIBILITY
605
+ size_type max_size() const _NOEXCEPT
606
+ {
607
+ return allocator_traits<__pointer_allocator>::max_size(
608
+ __bucket_list_.get_deleter().__alloc());
609
+ }
610
+
611
+ pair<iterator, bool> __node_insert_unique(__node_pointer __nd);
612
+ iterator __node_insert_multi(__node_pointer __nd);
613
+ iterator __node_insert_multi(const_iterator __p,
614
+ __node_pointer __nd);
615
+
616
+ #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS)
617
+ template <class... _Args>
618
+ pair<iterator, bool> __emplace_unique(_Args&&... __args);
619
+ template <class... _Args>
620
+ iterator __emplace_multi(_Args&&... __args);
621
+ template <class... _Args>
622
+ iterator __emplace_hint_multi(const_iterator __p, _Args&&... __args);
623
+ #endif // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS)
624
+
625
+ pair<iterator, bool> __insert_unique(const value_type& __x);
626
+
627
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
628
+ template <class _Pp>
629
+ pair<iterator, bool> __insert_unique(_Pp&& __x);
630
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
631
+
632
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
633
+ template <class _Pp>
634
+ iterator __insert_multi(_Pp&& __x);
635
+ template <class _Pp>
636
+ iterator __insert_multi(const_iterator __p, _Pp&& __x);
637
+ #else // _LIBCPP_HAS_NO_RVALUE_REFERENCES
638
+ iterator __insert_multi(const value_type& __x);
639
+ iterator __insert_multi(const_iterator __p, const value_type& __x);
640
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
641
+
642
+ void clear() _NOEXCEPT;
643
+ void rehash(size_type __n);
644
+ _LIBCPP_INLINE_VISIBILITY void reserve(size_type __n)
645
+ {rehash(static_cast<size_type>(ceil(__n / max_load_factor())));}
646
+
647
+ _LIBCPP_INLINE_VISIBILITY
648
+ size_type bucket_count() const _NOEXCEPT
649
+ {
650
+ return __bucket_list_.get_deleter().size();
651
+ }
652
+
653
+ iterator begin() _NOEXCEPT;
654
+ iterator end() _NOEXCEPT;
655
+ const_iterator begin() const _NOEXCEPT;
656
+ const_iterator end() const _NOEXCEPT;
657
+
658
+ template <class _Key>
659
+ _LIBCPP_INLINE_VISIBILITY
660
+ size_type bucket(const _Key& __k) const
661
+ {return __constrain_hash(hash_function()(__k), bucket_count());}
662
+
663
+ template <class _Key>
664
+ iterator find(const _Key& __x);
665
+ template <class _Key>
666
+ const_iterator find(const _Key& __x) const;
667
+
668
+ typedef __hash_node_destructor<__node_allocator> _Dp;
669
+ typedef unique_ptr<__node, _Dp> __node_holder;
670
+
671
+ iterator erase(const_iterator __p);
672
+ iterator erase(const_iterator __first, const_iterator __last);
673
+ template <class _Key>
674
+ size_type __erase_unique(const _Key& __k);
675
+ template <class _Key>
676
+ size_type __erase_multi(const _Key& __k);
677
+ __node_holder remove(const_iterator __p) _NOEXCEPT;
678
+
679
+ template <class _Key>
680
+ size_type __count_unique(const _Key& __k) const;
681
+ template <class _Key>
682
+ size_type __count_multi(const _Key& __k) const;
683
+
684
+ template <class _Key>
685
+ pair<iterator, iterator>
686
+ __equal_range_unique(const _Key& __k);
687
+ template <class _Key>
688
+ pair<const_iterator, const_iterator>
689
+ __equal_range_unique(const _Key& __k) const;
690
+
691
+ template <class _Key>
692
+ pair<iterator, iterator>
693
+ __equal_range_multi(const _Key& __k);
694
+ template <class _Key>
695
+ pair<const_iterator, const_iterator>
696
+ __equal_range_multi(const _Key& __k) const;
697
+
698
+ void swap(__hash_table& __u)
699
+ _NOEXCEPT_(
700
+ (!allocator_traits<__pointer_allocator>::propagate_on_container_swap::value ||
701
+ __is_nothrow_swappable<__pointer_allocator>::value) &&
702
+ (!__node_traits::propagate_on_container_swap::value ||
703
+ __is_nothrow_swappable<__node_allocator>::value) &&
704
+ __is_nothrow_swappable<hasher>::value &&
705
+ __is_nothrow_swappable<key_equal>::value);
706
+
707
+ _LIBCPP_INLINE_VISIBILITY
708
+ size_type max_bucket_count() const _NOEXCEPT
709
+ {return __bucket_list_.get_deleter().__alloc().max_size();}
710
+ size_type bucket_size(size_type __n) const;
711
+ _LIBCPP_INLINE_VISIBILITY float load_factor() const _NOEXCEPT
712
+ {
713
+ size_type __bc = bucket_count();
714
+ return __bc != 0 ? (float)size() / __bc : 0.f;
715
+ }
716
+ _LIBCPP_INLINE_VISIBILITY void max_load_factor(float __mlf) _NOEXCEPT
717
+ {max_load_factor() = _VSTD::max(__mlf, load_factor());}
718
+
719
+ _LIBCPP_INLINE_VISIBILITY local_iterator begin(size_type __n)
720
+ {return local_iterator(__bucket_list_[__n], __n, bucket_count());}
721
+ _LIBCPP_INLINE_VISIBILITY local_iterator end(size_type __n)
722
+ {return local_iterator(nullptr, __n, bucket_count());}
723
+ _LIBCPP_INLINE_VISIBILITY const_local_iterator cbegin(size_type __n) const
724
+ {return const_local_iterator(__bucket_list_[__n], __n, bucket_count());}
725
+ _LIBCPP_INLINE_VISIBILITY const_local_iterator cend(size_type __n) const
726
+ {return const_local_iterator(nullptr, __n, bucket_count());}
727
+ private:
728
+ void __rehash(size_type __n);
729
+
730
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
731
+ #ifndef _LIBCPP_HAS_NO_VARIADICS
732
+ template <class ..._Args>
733
+ __node_holder __construct_node(_Args&& ...__args);
734
+ #endif // _LIBCPP_HAS_NO_VARIADICS
735
+ __node_holder __construct_node(value_type&& __v, size_t __hash);
736
+ #else // _LIBCPP_HAS_NO_RVALUE_REFERENCES
737
+ __node_holder __construct_node(const value_type& __v);
738
+ #endif
739
+ __node_holder __construct_node(const value_type& __v, size_t __hash);
740
+
741
+ _LIBCPP_INLINE_VISIBILITY
742
+ void __copy_assign_alloc(const __hash_table& __u)
743
+ {__copy_assign_alloc(__u, integral_constant<bool,
744
+ __node_traits::propagate_on_container_copy_assignment::value>());}
745
+ void __copy_assign_alloc(const __hash_table& __u, true_type);
746
+ _LIBCPP_INLINE_VISIBILITY
747
+ void __copy_assign_alloc(const __hash_table&, false_type) {}
748
+
749
+ void __move_assign(__hash_table& __u, false_type);
750
+ void __move_assign(__hash_table& __u, true_type)
751
+ _NOEXCEPT_(
752
+ is_nothrow_move_assignable<__node_allocator>::value &&
753
+ is_nothrow_move_assignable<hasher>::value &&
754
+ is_nothrow_move_assignable<key_equal>::value);
755
+ _LIBCPP_INLINE_VISIBILITY
756
+ void __move_assign_alloc(__hash_table& __u)
757
+ _NOEXCEPT_(
758
+ !__node_traits::propagate_on_container_move_assignment::value ||
759
+ (is_nothrow_move_assignable<__pointer_allocator>::value &&
760
+ is_nothrow_move_assignable<__node_allocator>::value))
761
+ {__move_assign_alloc(__u, integral_constant<bool,
762
+ __node_traits::propagate_on_container_move_assignment::value>());}
763
+ _LIBCPP_INLINE_VISIBILITY
764
+ void __move_assign_alloc(__hash_table& __u, true_type)
765
+ _NOEXCEPT_(
766
+ is_nothrow_move_assignable<__pointer_allocator>::value &&
767
+ is_nothrow_move_assignable<__node_allocator>::value)
768
+ {
769
+ __bucket_list_.get_deleter().__alloc() =
770
+ _VSTD::move(__u.__bucket_list_.get_deleter().__alloc());
771
+ __node_alloc() = _VSTD::move(__u.__node_alloc());
772
+ }
773
+ _LIBCPP_INLINE_VISIBILITY
774
+ void __move_assign_alloc(__hash_table&, false_type) _NOEXCEPT {}
775
+
776
+ template <class _Ap>
777
+ _LIBCPP_INLINE_VISIBILITY
778
+ static
779
+ void
780
+ __swap_alloc(_Ap& __x, _Ap& __y)
781
+ _NOEXCEPT_(
782
+ !allocator_traits<_Ap>::propagate_on_container_swap::value ||
783
+ __is_nothrow_swappable<_Ap>::value)
784
+ {
785
+ __swap_alloc(__x, __y,
786
+ integral_constant<bool,
787
+ allocator_traits<_Ap>::propagate_on_container_swap::value
788
+ >());
789
+ }
790
+
791
+ template <class _Ap>
792
+ _LIBCPP_INLINE_VISIBILITY
793
+ static
794
+ void
795
+ __swap_alloc(_Ap& __x, _Ap& __y, true_type)
796
+ _NOEXCEPT_(__is_nothrow_swappable<_Ap>::value)
797
+ {
798
+ using _VSTD::swap;
799
+ swap(__x, __y);
800
+ }
801
+
802
+ template <class _Ap>
803
+ _LIBCPP_INLINE_VISIBILITY
804
+ static
805
+ void
806
+ __swap_alloc(_Ap&, _Ap&, false_type) _NOEXCEPT {}
807
+
808
+ void __deallocate(__node_pointer __np) _NOEXCEPT;
809
+ __node_pointer __detach() _NOEXCEPT;
810
+ };
811
+
812
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
813
+ inline _LIBCPP_INLINE_VISIBILITY
814
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table()
815
+ _NOEXCEPT_(
816
+ is_nothrow_default_constructible<__bucket_list>::value &&
817
+ is_nothrow_default_constructible<__first_node>::value &&
818
+ is_nothrow_default_constructible<hasher>::value &&
819
+ is_nothrow_default_constructible<key_equal>::value)
820
+ : __p2_(0),
821
+ __p3_(1.0f)
822
+ {
823
+ }
824
+
825
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
826
+ inline _LIBCPP_INLINE_VISIBILITY
827
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(const hasher& __hf,
828
+ const key_equal& __eql)
829
+ : __bucket_list_(nullptr, __bucket_list_deleter()),
830
+ __p1_(),
831
+ __p2_(0, __hf),
832
+ __p3_(1.0f, __eql)
833
+ {
834
+ }
835
+
836
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
837
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(const hasher& __hf,
838
+ const key_equal& __eql,
839
+ const allocator_type& __a)
840
+ : __bucket_list_(nullptr, __bucket_list_deleter(__pointer_allocator(__a), 0)),
841
+ __p1_(__node_allocator(__a)),
842
+ __p2_(0, __hf),
843
+ __p3_(1.0f, __eql)
844
+ {
845
+ }
846
+
847
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
848
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(const allocator_type& __a)
849
+ : __bucket_list_(nullptr, __bucket_list_deleter(__pointer_allocator(__a), 0)),
850
+ __p1_(__node_allocator(__a)),
851
+ __p2_(0),
852
+ __p3_(1.0f)
853
+ {
854
+ }
855
+
856
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
857
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(const __hash_table& __u)
858
+ : __bucket_list_(nullptr,
859
+ __bucket_list_deleter(allocator_traits<__pointer_allocator>::
860
+ select_on_container_copy_construction(
861
+ __u.__bucket_list_.get_deleter().__alloc()), 0)),
862
+ __p1_(allocator_traits<__node_allocator>::
863
+ select_on_container_copy_construction(__u.__node_alloc())),
864
+ __p2_(0, __u.hash_function()),
865
+ __p3_(__u.__p3_)
866
+ {
867
+ }
868
+
869
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
870
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(const __hash_table& __u,
871
+ const allocator_type& __a)
872
+ : __bucket_list_(nullptr, __bucket_list_deleter(__pointer_allocator(__a), 0)),
873
+ __p1_(__node_allocator(__a)),
874
+ __p2_(0, __u.hash_function()),
875
+ __p3_(__u.__p3_)
876
+ {
877
+ }
878
+
879
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
880
+
881
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
882
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(__hash_table&& __u)
883
+ _NOEXCEPT_(
884
+ is_nothrow_move_constructible<__bucket_list>::value &&
885
+ is_nothrow_move_constructible<__first_node>::value &&
886
+ is_nothrow_move_constructible<hasher>::value &&
887
+ is_nothrow_move_constructible<key_equal>::value)
888
+ : __bucket_list_(_VSTD::move(__u.__bucket_list_)),
889
+ __p1_(_VSTD::move(__u.__p1_)),
890
+ __p2_(_VSTD::move(__u.__p2_)),
891
+ __p3_(_VSTD::move(__u.__p3_))
892
+ {
893
+ if (size() > 0)
894
+ {
895
+ __bucket_list_[__constrain_hash(__p1_.first().__next_->__hash_, bucket_count())] =
896
+ static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
897
+ __u.__p1_.first().__next_ = nullptr;
898
+ __u.size() = 0;
899
+ }
900
+ }
901
+
902
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
903
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(__hash_table&& __u,
904
+ const allocator_type& __a)
905
+ : __bucket_list_(nullptr, __bucket_list_deleter(__pointer_allocator(__a), 0)),
906
+ __p1_(__node_allocator(__a)),
907
+ __p2_(0, _VSTD::move(__u.hash_function())),
908
+ __p3_(_VSTD::move(__u.__p3_))
909
+ {
910
+ if (__a == allocator_type(__u.__node_alloc()))
911
+ {
912
+ __bucket_list_.reset(__u.__bucket_list_.release());
913
+ __bucket_list_.get_deleter().size() = __u.__bucket_list_.get_deleter().size();
914
+ __u.__bucket_list_.get_deleter().size() = 0;
915
+ if (__u.size() > 0)
916
+ {
917
+ __p1_.first().__next_ = __u.__p1_.first().__next_;
918
+ __u.__p1_.first().__next_ = nullptr;
919
+ __bucket_list_[__constrain_hash(__p1_.first().__next_->__hash_, bucket_count())] =
920
+ static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
921
+ size() = __u.size();
922
+ __u.size() = 0;
923
+ }
924
+ }
925
+ }
926
+
927
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
928
+
929
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
930
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::~__hash_table()
931
+ {
932
+ __deallocate(__p1_.first().__next_);
933
+ }
934
+
935
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
936
+ void
937
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__copy_assign_alloc(
938
+ const __hash_table& __u, true_type)
939
+ {
940
+ if (__node_alloc() != __u.__node_alloc())
941
+ {
942
+ clear();
943
+ __bucket_list_.reset();
944
+ __bucket_list_.get_deleter().size() = 0;
945
+ }
946
+ __bucket_list_.get_deleter().__alloc() = __u.__bucket_list_.get_deleter().__alloc();
947
+ __node_alloc() = __u.__node_alloc();
948
+ }
949
+
950
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
951
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>&
952
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::operator=(const __hash_table& __u)
953
+ {
954
+ if (this != &__u)
955
+ {
956
+ __copy_assign_alloc(__u);
957
+ hash_function() = __u.hash_function();
958
+ key_eq() = __u.key_eq();
959
+ max_load_factor() = __u.max_load_factor();
960
+ __assign_multi(__u.begin(), __u.end());
961
+ }
962
+ return *this;
963
+ }
964
+
965
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
966
+ void
967
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__deallocate(__node_pointer __np)
968
+ _NOEXCEPT
969
+ {
970
+ __node_allocator& __na = __node_alloc();
971
+ while (__np != nullptr)
972
+ {
973
+ __node_pointer __next = __np->__next_;
974
+ __node_traits::destroy(__na, _VSTD::addressof(__np->__value_));
975
+ __node_traits::deallocate(__na, __np, 1);
976
+ __np = __next;
977
+ }
978
+ }
979
+
980
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
981
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_pointer
982
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__detach() _NOEXCEPT
983
+ {
984
+ size_type __bc = bucket_count();
985
+ for (size_type __i = 0; __i < __bc; ++__i)
986
+ __bucket_list_[__i] = nullptr;
987
+ size() = 0;
988
+ __node_pointer __cache = __p1_.first().__next_;
989
+ __p1_.first().__next_ = nullptr;
990
+ return __cache;
991
+ }
992
+
993
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
994
+
995
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
996
+ void
997
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign(
998
+ __hash_table& __u, true_type)
999
+ _NOEXCEPT_(
1000
+ is_nothrow_move_assignable<__node_allocator>::value &&
1001
+ is_nothrow_move_assignable<hasher>::value &&
1002
+ is_nothrow_move_assignable<key_equal>::value)
1003
+ {
1004
+ clear();
1005
+ __bucket_list_.reset(__u.__bucket_list_.release());
1006
+ __bucket_list_.get_deleter().size() = __u.__bucket_list_.get_deleter().size();
1007
+ __u.__bucket_list_.get_deleter().size() = 0;
1008
+ __move_assign_alloc(__u);
1009
+ size() = __u.size();
1010
+ hash_function() = _VSTD::move(__u.hash_function());
1011
+ max_load_factor() = __u.max_load_factor();
1012
+ key_eq() = _VSTD::move(__u.key_eq());
1013
+ __p1_.first().__next_ = __u.__p1_.first().__next_;
1014
+ if (size() > 0)
1015
+ {
1016
+ __bucket_list_[__constrain_hash(__p1_.first().__next_->__hash_, bucket_count())] =
1017
+ static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
1018
+ __u.__p1_.first().__next_ = nullptr;
1019
+ __u.size() = 0;
1020
+ }
1021
+ }
1022
+
1023
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1024
+ void
1025
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign(
1026
+ __hash_table& __u, false_type)
1027
+ {
1028
+ if (__node_alloc() == __u.__node_alloc())
1029
+ __move_assign(__u, true_type());
1030
+ else
1031
+ {
1032
+ hash_function() = _VSTD::move(__u.hash_function());
1033
+ key_eq() = _VSTD::move(__u.key_eq());
1034
+ max_load_factor() = __u.max_load_factor();
1035
+ if (bucket_count() != 0)
1036
+ {
1037
+ __node_pointer __cache = __detach();
1038
+ #ifndef _LIBCPP_NO_EXCEPTIONS
1039
+ try
1040
+ {
1041
+ #endif // _LIBCPP_NO_EXCEPTIONS
1042
+ const_iterator __i = __u.begin();
1043
+ while (__cache != nullptr && __u.size() != 0)
1044
+ {
1045
+ __cache->__value_ = _VSTD::move(__u.remove(__i++)->__value_);
1046
+ __node_pointer __next = __cache->__next_;
1047
+ __node_insert_multi(__cache);
1048
+ __cache = __next;
1049
+ }
1050
+ #ifndef _LIBCPP_NO_EXCEPTIONS
1051
+ }
1052
+ catch (...)
1053
+ {
1054
+ __deallocate(__cache);
1055
+ throw;
1056
+ }
1057
+ #endif // _LIBCPP_NO_EXCEPTIONS
1058
+ __deallocate(__cache);
1059
+ }
1060
+ const_iterator __i = __u.begin();
1061
+ while (__u.size() != 0)
1062
+ {
1063
+ __node_holder __h =
1064
+ __construct_node(_VSTD::move(__u.remove(__i++)->__value_));
1065
+ __node_insert_multi(__h.get());
1066
+ __h.release();
1067
+ }
1068
+ }
1069
+ }
1070
+
1071
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1072
+ inline _LIBCPP_INLINE_VISIBILITY
1073
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>&
1074
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::operator=(__hash_table&& __u)
1075
+ _NOEXCEPT_(
1076
+ __node_traits::propagate_on_container_move_assignment::value &&
1077
+ is_nothrow_move_assignable<__node_allocator>::value &&
1078
+ is_nothrow_move_assignable<hasher>::value &&
1079
+ is_nothrow_move_assignable<key_equal>::value)
1080
+ {
1081
+ __move_assign(__u, integral_constant<bool,
1082
+ __node_traits::propagate_on_container_move_assignment::value>());
1083
+ return *this;
1084
+ }
1085
+
1086
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
1087
+
1088
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1089
+ template <class _InputIterator>
1090
+ void
1091
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__assign_unique(_InputIterator __first,
1092
+ _InputIterator __last)
1093
+ {
1094
+ if (bucket_count() != 0)
1095
+ {
1096
+ __node_pointer __cache = __detach();
1097
+ #ifndef _LIBCPP_NO_EXCEPTIONS
1098
+ try
1099
+ {
1100
+ #endif // _LIBCPP_NO_EXCEPTIONS
1101
+ for (; __cache != nullptr && __first != __last; ++__first)
1102
+ {
1103
+ __cache->__value_ = *__first;
1104
+ __node_pointer __next = __cache->__next_;
1105
+ __node_insert_unique(__cache);
1106
+ __cache = __next;
1107
+ }
1108
+ #ifndef _LIBCPP_NO_EXCEPTIONS
1109
+ }
1110
+ catch (...)
1111
+ {
1112
+ __deallocate(__cache);
1113
+ throw;
1114
+ }
1115
+ #endif // _LIBCPP_NO_EXCEPTIONS
1116
+ __deallocate(__cache);
1117
+ }
1118
+ for (; __first != __last; ++__first)
1119
+ __insert_unique(*__first);
1120
+ }
1121
+
1122
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1123
+ template <class _InputIterator>
1124
+ void
1125
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__assign_multi(_InputIterator __first,
1126
+ _InputIterator __last)
1127
+ {
1128
+ if (bucket_count() != 0)
1129
+ {
1130
+ __node_pointer __cache = __detach();
1131
+ #ifndef _LIBCPP_NO_EXCEPTIONS
1132
+ try
1133
+ {
1134
+ #endif // _LIBCPP_NO_EXCEPTIONS
1135
+ for (; __cache != nullptr && __first != __last; ++__first)
1136
+ {
1137
+ __cache->__value_ = *__first;
1138
+ __node_pointer __next = __cache->__next_;
1139
+ __node_insert_multi(__cache);
1140
+ __cache = __next;
1141
+ }
1142
+ #ifndef _LIBCPP_NO_EXCEPTIONS
1143
+ }
1144
+ catch (...)
1145
+ {
1146
+ __deallocate(__cache);
1147
+ throw;
1148
+ }
1149
+ #endif // _LIBCPP_NO_EXCEPTIONS
1150
+ __deallocate(__cache);
1151
+ }
1152
+ for (; __first != __last; ++__first)
1153
+ __insert_multi(*__first);
1154
+ }
1155
+
1156
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1157
+ inline _LIBCPP_INLINE_VISIBILITY
1158
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1159
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() _NOEXCEPT
1160
+ {
1161
+ return iterator(__p1_.first().__next_);
1162
+ }
1163
+
1164
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1165
+ inline _LIBCPP_INLINE_VISIBILITY
1166
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1167
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() _NOEXCEPT
1168
+ {
1169
+ return iterator(nullptr);
1170
+ }
1171
+
1172
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1173
+ inline _LIBCPP_INLINE_VISIBILITY
1174
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator
1175
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() const _NOEXCEPT
1176
+ {
1177
+ return const_iterator(__p1_.first().__next_);
1178
+ }
1179
+
1180
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1181
+ inline _LIBCPP_INLINE_VISIBILITY
1182
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator
1183
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() const _NOEXCEPT
1184
+ {
1185
+ return const_iterator(nullptr);
1186
+ }
1187
+
1188
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1189
+ void
1190
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::clear() _NOEXCEPT
1191
+ {
1192
+ if (size() > 0)
1193
+ {
1194
+ __deallocate(__p1_.first().__next_);
1195
+ __p1_.first().__next_ = nullptr;
1196
+ size_type __bc = bucket_count();
1197
+ for (size_type __i = 0; __i < __bc; ++__i)
1198
+ __bucket_list_[__i] = nullptr;
1199
+ size() = 0;
1200
+ }
1201
+ }
1202
+
1203
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1204
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool>
1205
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_unique(__node_pointer __nd)
1206
+ {
1207
+ __nd->__hash_ = hash_function()(__nd->__value_);
1208
+ size_type __bc = bucket_count();
1209
+ bool __inserted = false;
1210
+ __node_pointer __ndptr;
1211
+ size_t __chash;
1212
+ if (__bc != 0)
1213
+ {
1214
+ __chash = __constrain_hash(__nd->__hash_, __bc);
1215
+ __ndptr = __bucket_list_[__chash];
1216
+ if (__ndptr != nullptr)
1217
+ {
1218
+ for (__ndptr = __ndptr->__next_; __ndptr != nullptr &&
1219
+ __constrain_hash(__ndptr->__hash_, __bc) == __chash;
1220
+ __ndptr = __ndptr->__next_)
1221
+ {
1222
+ if (key_eq()(__ndptr->__value_, __nd->__value_))
1223
+ goto __done;
1224
+ }
1225
+ }
1226
+ }
1227
+ {
1228
+ if (size()+1 > __bc * max_load_factor() || __bc == 0)
1229
+ {
1230
+ rehash(_VSTD::max<size_type>(2 * __bc + !__is_power2(__bc),
1231
+ size_type(ceil(float(size() + 1) / max_load_factor()))));
1232
+ __bc = bucket_count();
1233
+ __chash = __constrain_hash(__nd->__hash_, __bc);
1234
+ }
1235
+ // insert_after __bucket_list_[__chash], or __first_node if bucket is null
1236
+ __node_pointer __pn = __bucket_list_[__chash];
1237
+ if (__pn == nullptr)
1238
+ {
1239
+ __pn = static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
1240
+ __nd->__next_ = __pn->__next_;
1241
+ __pn->__next_ = __nd;
1242
+ // fix up __bucket_list_
1243
+ __bucket_list_[__chash] = __pn;
1244
+ if (__nd->__next_ != nullptr)
1245
+ __bucket_list_[__constrain_hash(__nd->__next_->__hash_, __bc)] = __nd;
1246
+ }
1247
+ else
1248
+ {
1249
+ __nd->__next_ = __pn->__next_;
1250
+ __pn->__next_ = __nd;
1251
+ }
1252
+ __ndptr = __nd;
1253
+ // increment size
1254
+ ++size();
1255
+ __inserted = true;
1256
+ }
1257
+ __done:
1258
+ return pair<iterator, bool>(iterator(__ndptr), __inserted);
1259
+ }
1260
+
1261
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1262
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1263
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_multi(__node_pointer __cp)
1264
+ {
1265
+ __cp->__hash_ = hash_function()(__cp->__value_);
1266
+ size_type __bc = bucket_count();
1267
+ if (size()+1 > __bc * max_load_factor() || __bc == 0)
1268
+ {
1269
+ rehash(_VSTD::max<size_type>(2 * __bc + !__is_power2(__bc),
1270
+ size_type(ceil(float(size() + 1) / max_load_factor()))));
1271
+ __bc = bucket_count();
1272
+ }
1273
+ size_t __chash = __constrain_hash(__cp->__hash_, __bc);
1274
+ __node_pointer __pn = __bucket_list_[__chash];
1275
+ if (__pn == nullptr)
1276
+ {
1277
+ __pn = static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
1278
+ __cp->__next_ = __pn->__next_;
1279
+ __pn->__next_ = __cp;
1280
+ // fix up __bucket_list_
1281
+ __bucket_list_[__chash] = __pn;
1282
+ if (__cp->__next_ != nullptr)
1283
+ __bucket_list_[__constrain_hash(__cp->__next_->__hash_, __bc)] = __cp;
1284
+ }
1285
+ else
1286
+ {
1287
+ for (bool __found = false; __pn->__next_ != nullptr &&
1288
+ __constrain_hash(__pn->__next_->__hash_, __bc) == __chash;
1289
+ __pn = __pn->__next_)
1290
+ {
1291
+ // __found key_eq() action
1292
+ // false false loop
1293
+ // true true loop
1294
+ // false true set __found to true
1295
+ // true false break
1296
+ if (__found != (__pn->__next_->__hash_ == __cp->__hash_ &&
1297
+ key_eq()(__pn->__next_->__value_, __cp->__value_)))
1298
+ {
1299
+ if (!__found)
1300
+ __found = true;
1301
+ else
1302
+ break;
1303
+ }
1304
+ }
1305
+ __cp->__next_ = __pn->__next_;
1306
+ __pn->__next_ = __cp;
1307
+ if (__cp->__next_ != nullptr)
1308
+ {
1309
+ size_t __nhash = __constrain_hash(__cp->__next_->__hash_, __bc);
1310
+ if (__nhash != __chash)
1311
+ __bucket_list_[__nhash] = __cp;
1312
+ }
1313
+ }
1314
+ ++size();
1315
+ return iterator(__cp);
1316
+ }
1317
+
1318
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1319
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1320
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_multi(
1321
+ const_iterator __p, __node_pointer __cp)
1322
+ {
1323
+ if (__p != end() && key_eq()(*__p, __cp->__value_))
1324
+ {
1325
+ __node_pointer __np = const_cast<__node_pointer>(__p.__node_);
1326
+ __cp->__hash_ = __np->__hash_;
1327
+ size_type __bc = bucket_count();
1328
+ if (size()+1 > __bc * max_load_factor() || __bc == 0)
1329
+ {
1330
+ rehash(_VSTD::max<size_type>(2 * __bc + !__is_power2(__bc),
1331
+ size_type(ceil(float(size() + 1) / max_load_factor()))));
1332
+ __bc = bucket_count();
1333
+ }
1334
+ size_t __chash = __constrain_hash(__cp->__hash_, __bc);
1335
+ __node_pointer __pp = __bucket_list_[__chash];
1336
+ while (__pp->__next_ != __np)
1337
+ __pp = __pp->__next_;
1338
+ __cp->__next_ = __np;
1339
+ __pp->__next_ = __cp;
1340
+ ++size();
1341
+ return iterator(__cp);
1342
+ }
1343
+ return __node_insert_multi(__cp);
1344
+ }
1345
+
1346
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1347
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool>
1348
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_unique(const value_type& __x)
1349
+ {
1350
+ size_t __hash = hash_function()(__x);
1351
+ size_type __bc = bucket_count();
1352
+ bool __inserted = false;
1353
+ __node_pointer __nd;
1354
+ size_t __chash;
1355
+ if (__bc != 0)
1356
+ {
1357
+ __chash = __constrain_hash(__hash, __bc);
1358
+ __nd = __bucket_list_[__chash];
1359
+ if (__nd != nullptr)
1360
+ {
1361
+ for (__nd = __nd->__next_; __nd != nullptr &&
1362
+ __constrain_hash(__nd->__hash_, __bc) == __chash;
1363
+ __nd = __nd->__next_)
1364
+ {
1365
+ if (key_eq()(__nd->__value_, __x))
1366
+ goto __done;
1367
+ }
1368
+ }
1369
+ }
1370
+ {
1371
+ __node_holder __h = __construct_node(__x, __hash);
1372
+ if (size()+1 > __bc * max_load_factor() || __bc == 0)
1373
+ {
1374
+ rehash(_VSTD::max<size_type>(2 * __bc + !__is_power2(__bc),
1375
+ size_type(ceil(float(size() + 1) / max_load_factor()))));
1376
+ __bc = bucket_count();
1377
+ __chash = __constrain_hash(__hash, __bc);
1378
+ }
1379
+ // insert_after __bucket_list_[__chash], or __first_node if bucket is null
1380
+ __node_pointer __pn = __bucket_list_[__chash];
1381
+ if (__pn == nullptr)
1382
+ {
1383
+ __pn = static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
1384
+ __h->__next_ = __pn->__next_;
1385
+ __pn->__next_ = __h.get();
1386
+ // fix up __bucket_list_
1387
+ __bucket_list_[__chash] = __pn;
1388
+ if (__h->__next_ != nullptr)
1389
+ __bucket_list_[__constrain_hash(__h->__next_->__hash_, __bc)] = __h.get();
1390
+ }
1391
+ else
1392
+ {
1393
+ __h->__next_ = __pn->__next_;
1394
+ __pn->__next_ = __h.get();
1395
+ }
1396
+ __nd = __h.release();
1397
+ // increment size
1398
+ ++size();
1399
+ __inserted = true;
1400
+ }
1401
+ __done:
1402
+ return pair<iterator, bool>(iterator(__nd), __inserted);
1403
+ }
1404
+
1405
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
1406
+ #ifndef _LIBCPP_HAS_NO_VARIADICS
1407
+
1408
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1409
+ template <class... _Args>
1410
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool>
1411
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_unique(_Args&&... __args)
1412
+ {
1413
+ __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...);
1414
+ pair<iterator, bool> __r = __node_insert_unique(__h.get());
1415
+ if (__r.second)
1416
+ __h.release();
1417
+ return __r;
1418
+ }
1419
+
1420
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1421
+ template <class... _Args>
1422
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1423
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_multi(_Args&&... __args)
1424
+ {
1425
+ __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...);
1426
+ iterator __r = __node_insert_multi(__h.get());
1427
+ __h.release();
1428
+ return __r;
1429
+ }
1430
+
1431
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1432
+ template <class... _Args>
1433
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1434
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_hint_multi(
1435
+ const_iterator __p, _Args&&... __args)
1436
+ {
1437
+ __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...);
1438
+ iterator __r = __node_insert_multi(__p, __h.get());
1439
+ __h.release();
1440
+ return __r;
1441
+ }
1442
+
1443
+ #endif // _LIBCPP_HAS_NO_VARIADICS
1444
+
1445
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1446
+ template <class _Pp>
1447
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool>
1448
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_unique(_Pp&& __x)
1449
+ {
1450
+ __node_holder __h = __construct_node(_VSTD::forward<_Pp>(__x));
1451
+ pair<iterator, bool> __r = __node_insert_unique(__h.get());
1452
+ if (__r.second)
1453
+ __h.release();
1454
+ return __r;
1455
+ }
1456
+
1457
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
1458
+
1459
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
1460
+
1461
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1462
+ template <class _Pp>
1463
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1464
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(_Pp&& __x)
1465
+ {
1466
+ __node_holder __h = __construct_node(_VSTD::forward<_Pp>(__x));
1467
+ iterator __r = __node_insert_multi(__h.get());
1468
+ __h.release();
1469
+ return __r;
1470
+ }
1471
+
1472
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1473
+ template <class _Pp>
1474
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1475
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(const_iterator __p,
1476
+ _Pp&& __x)
1477
+ {
1478
+ __node_holder __h = __construct_node(_VSTD::forward<_Pp>(__x));
1479
+ iterator __r = __node_insert_multi(__p, __h.get());
1480
+ __h.release();
1481
+ return __r;
1482
+ }
1483
+
1484
+ #else // _LIBCPP_HAS_NO_RVALUE_REFERENCES
1485
+
1486
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1487
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1488
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(const value_type& __x)
1489
+ {
1490
+ __node_holder __h = __construct_node(__x);
1491
+ iterator __r = __node_insert_multi(__h.get());
1492
+ __h.release();
1493
+ return __r;
1494
+ }
1495
+
1496
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1497
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1498
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(const_iterator __p,
1499
+ const value_type& __x)
1500
+ {
1501
+ __node_holder __h = __construct_node(__x);
1502
+ iterator __r = __node_insert_multi(__p, __h.get());
1503
+ __h.release();
1504
+ return __r;
1505
+ }
1506
+
1507
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
1508
+
1509
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1510
+ void
1511
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::rehash(size_type __n)
1512
+ {
1513
+ if (__n == 1)
1514
+ __n = 2;
1515
+ else if (__n & (__n - 1))
1516
+ __n = __next_prime(__n);
1517
+ size_type __bc = bucket_count();
1518
+ if (__n > __bc)
1519
+ __rehash(__n);
1520
+ else if (__n < __bc)
1521
+ {
1522
+ __n = _VSTD::max<size_type>
1523
+ (
1524
+ __n,
1525
+ __is_power2(__bc) ? __next_pow2(size_t(ceil(float(size()) / max_load_factor()))) :
1526
+ __next_prime(size_t(ceil(float(size()) / max_load_factor())))
1527
+ );
1528
+ if (__n < __bc)
1529
+ __rehash(__n);
1530
+ }
1531
+ }
1532
+
1533
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1534
+ void
1535
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__rehash(size_type __nbc)
1536
+ {
1537
+ __pointer_allocator& __npa = __bucket_list_.get_deleter().__alloc();
1538
+ __bucket_list_.reset(__nbc > 0 ?
1539
+ __pointer_alloc_traits::allocate(__npa, __nbc) : nullptr);
1540
+ __bucket_list_.get_deleter().size() = __nbc;
1541
+ if (__nbc > 0)
1542
+ {
1543
+ for (size_type __i = 0; __i < __nbc; ++__i)
1544
+ __bucket_list_[__i] = nullptr;
1545
+ __node_pointer __pp(static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())));
1546
+ __node_pointer __cp = __pp->__next_;
1547
+ if (__cp != nullptr)
1548
+ {
1549
+ size_type __chash = __constrain_hash(__cp->__hash_, __nbc);
1550
+ __bucket_list_[__chash] = __pp;
1551
+ size_type __phash = __chash;
1552
+ for (__pp = __cp, __cp = __cp->__next_; __cp != nullptr;
1553
+ __cp = __pp->__next_)
1554
+ {
1555
+ __chash = __constrain_hash(__cp->__hash_, __nbc);
1556
+ if (__chash == __phash)
1557
+ __pp = __cp;
1558
+ else
1559
+ {
1560
+ if (__bucket_list_[__chash] == nullptr)
1561
+ {
1562
+ __bucket_list_[__chash] = __pp;
1563
+ __pp = __cp;
1564
+ __phash = __chash;
1565
+ }
1566
+ else
1567
+ {
1568
+ __node_pointer __np = __cp;
1569
+ for (; __np->__next_ != nullptr &&
1570
+ key_eq()(__cp->__value_, __np->__next_->__value_);
1571
+ __np = __np->__next_)
1572
+ ;
1573
+ __pp->__next_ = __np->__next_;
1574
+ __np->__next_ = __bucket_list_[__chash]->__next_;
1575
+ __bucket_list_[__chash]->__next_ = __cp;
1576
+
1577
+ }
1578
+ }
1579
+ }
1580
+ }
1581
+ }
1582
+ }
1583
+
1584
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1585
+ template <class _Key>
1586
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1587
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::find(const _Key& __k)
1588
+ {
1589
+ size_t __hash = hash_function()(__k);
1590
+ size_type __bc = bucket_count();
1591
+ if (__bc != 0)
1592
+ {
1593
+ size_t __chash = __constrain_hash(__hash, __bc);
1594
+ __node_pointer __nd = __bucket_list_[__chash];
1595
+ if (__nd != nullptr)
1596
+ {
1597
+ for (__nd = __nd->__next_; __nd != nullptr &&
1598
+ __constrain_hash(__nd->__hash_, __bc) == __chash;
1599
+ __nd = __nd->__next_)
1600
+ {
1601
+ if (key_eq()(__nd->__value_, __k))
1602
+ return iterator(__nd);
1603
+ }
1604
+ }
1605
+ }
1606
+ return end();
1607
+ }
1608
+
1609
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1610
+ template <class _Key>
1611
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator
1612
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::find(const _Key& __k) const
1613
+ {
1614
+ size_t __hash = hash_function()(__k);
1615
+ size_type __bc = bucket_count();
1616
+ if (__bc != 0)
1617
+ {
1618
+ size_t __chash = __constrain_hash(__hash, __bc);
1619
+ __node_const_pointer __nd = __bucket_list_[__chash];
1620
+ if (__nd != nullptr)
1621
+ {
1622
+ for (__nd = __nd->__next_; __nd != nullptr &&
1623
+ __constrain_hash(__nd->__hash_, __bc) == __chash;
1624
+ __nd = __nd->__next_)
1625
+ {
1626
+ if (key_eq()(__nd->__value_, __k))
1627
+ return const_iterator(__nd);
1628
+ }
1629
+ }
1630
+
1631
+ }
1632
+ return end();
1633
+ }
1634
+
1635
+ #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
1636
+ #ifndef _LIBCPP_HAS_NO_VARIADICS
1637
+
1638
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1639
+ template <class ..._Args>
1640
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder
1641
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(_Args&& ...__args)
1642
+ {
1643
+ __node_allocator& __na = __node_alloc();
1644
+ __node_holder __h(__node_traits::allocate(__na, 1), _Dp(__na));
1645
+ __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::forward<_Args>(__args)...);
1646
+ __h.get_deleter().__value_constructed = true;
1647
+ __h->__hash_ = hash_function()(__h->__value_);
1648
+ __h->__next_ = nullptr;
1649
+ return __h;
1650
+ }
1651
+
1652
+ #endif // _LIBCPP_HAS_NO_VARIADICS
1653
+
1654
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1655
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder
1656
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(value_type&& __v,
1657
+ size_t __hash)
1658
+ {
1659
+ __node_allocator& __na = __node_alloc();
1660
+ __node_holder __h(__node_traits::allocate(__na, 1), _Dp(__na));
1661
+ __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::move(__v));
1662
+ __h.get_deleter().__value_constructed = true;
1663
+ __h->__hash_ = __hash;
1664
+ __h->__next_ = nullptr;
1665
+ return _VSTD::move(__h);
1666
+ }
1667
+
1668
+ #else // _LIBCPP_HAS_NO_RVALUE_REFERENCES
1669
+
1670
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1671
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder
1672
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(const value_type& __v)
1673
+ {
1674
+ __node_allocator& __na = __node_alloc();
1675
+ __node_holder __h(__node_traits::allocate(__na, 1), _Dp(__na));
1676
+ __node_traits::construct(__na, _VSTD::addressof(__h->__value_), __v);
1677
+ __h.get_deleter().__value_constructed = true;
1678
+ __h->__hash_ = hash_function()(__h->__value_);
1679
+ __h->__next_ = nullptr;
1680
+ return _VSTD::move(__h);
1681
+ }
1682
+
1683
+ #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
1684
+
1685
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1686
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder
1687
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(const value_type& __v,
1688
+ size_t __hash)
1689
+ {
1690
+ __node_allocator& __na = __node_alloc();
1691
+ __node_holder __h(__node_traits::allocate(__na, 1), _Dp(__na));
1692
+ __node_traits::construct(__na, _VSTD::addressof(__h->__value_), __v);
1693
+ __h.get_deleter().__value_constructed = true;
1694
+ __h->__hash_ = __hash;
1695
+ __h->__next_ = nullptr;
1696
+ return _VSTD::move(__h);
1697
+ }
1698
+
1699
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1700
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1701
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::erase(const_iterator __p)
1702
+ {
1703
+ __node_pointer __np = const_cast<__node_pointer>(__p.__node_);
1704
+ iterator __r(__np);
1705
+ ++__r;
1706
+ remove(__p);
1707
+ return __r;
1708
+ }
1709
+
1710
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1711
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator
1712
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::erase(const_iterator __first,
1713
+ const_iterator __last)
1714
+ {
1715
+ for (const_iterator __p = __first; __first != __last; __p = __first)
1716
+ {
1717
+ ++__first;
1718
+ erase(__p);
1719
+ }
1720
+ __node_pointer __np = const_cast<__node_pointer>(__last.__node_);
1721
+ return iterator (__np);
1722
+ }
1723
+
1724
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1725
+ template <class _Key>
1726
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::size_type
1727
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__erase_unique(const _Key& __k)
1728
+ {
1729
+ iterator __i = find(__k);
1730
+ if (__i == end())
1731
+ return 0;
1732
+ erase(__i);
1733
+ return 1;
1734
+ }
1735
+
1736
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1737
+ template <class _Key>
1738
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::size_type
1739
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__erase_multi(const _Key& __k)
1740
+ {
1741
+ size_type __r = 0;
1742
+ iterator __i = find(__k);
1743
+ if (__i != end())
1744
+ {
1745
+ iterator __e = end();
1746
+ do
1747
+ {
1748
+ erase(__i++);
1749
+ ++__r;
1750
+ } while (__i != __e && key_eq()(*__i, __k));
1751
+ }
1752
+ return __r;
1753
+ }
1754
+
1755
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1756
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder
1757
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::remove(const_iterator __p) _NOEXCEPT
1758
+ {
1759
+ // current node
1760
+ __node_pointer __cn = const_cast<__node_pointer>(__p.__node_);
1761
+ size_type __bc = bucket_count();
1762
+ size_t __chash = __constrain_hash(__cn->__hash_, __bc);
1763
+ // find previous node
1764
+ __node_pointer __pn = __bucket_list_[__chash];
1765
+ for (; __pn->__next_ != __cn; __pn = __pn->__next_)
1766
+ ;
1767
+ // Fix up __bucket_list_
1768
+ // if __pn is not in same bucket (before begin is not in same bucket) &&
1769
+ // if __cn->__next_ is not in same bucket (nullptr is not in same bucket)
1770
+ if (__pn == _VSTD::addressof(__p1_.first()) || __constrain_hash(__pn->__hash_, __bc) != __chash)
1771
+ {
1772
+ if (__cn->__next_ == nullptr || __constrain_hash(__cn->__next_->__hash_, __bc) != __chash)
1773
+ __bucket_list_[__chash] = nullptr;
1774
+ }
1775
+ // if __cn->__next_ is not in same bucket (nullptr is in same bucket)
1776
+ if (__cn->__next_ != nullptr)
1777
+ {
1778
+ size_t __nhash = __constrain_hash(__cn->__next_->__hash_, __bc);
1779
+ if (__nhash != __chash)
1780
+ __bucket_list_[__nhash] = __pn;
1781
+ }
1782
+ // remove __cn
1783
+ __pn->__next_ = __cn->__next_;
1784
+ __cn->__next_ = nullptr;
1785
+ --size();
1786
+ return __node_holder(__cn, _Dp(__node_alloc(), true));
1787
+ }
1788
+
1789
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1790
+ template <class _Key>
1791
+ inline _LIBCPP_INLINE_VISIBILITY
1792
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::size_type
1793
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__count_unique(const _Key& __k) const
1794
+ {
1795
+ return static_cast<size_type>(find(__k) != end());
1796
+ }
1797
+
1798
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1799
+ template <class _Key>
1800
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::size_type
1801
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__count_multi(const _Key& __k) const
1802
+ {
1803
+ size_type __r = 0;
1804
+ const_iterator __i = find(__k);
1805
+ if (__i != end())
1806
+ {
1807
+ const_iterator __e = end();
1808
+ do
1809
+ {
1810
+ ++__i;
1811
+ ++__r;
1812
+ } while (__i != __e && key_eq()(*__i, __k));
1813
+ }
1814
+ return __r;
1815
+ }
1816
+
1817
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1818
+ template <class _Key>
1819
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator,
1820
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator>
1821
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__equal_range_unique(
1822
+ const _Key& __k)
1823
+ {
1824
+ iterator __i = find(__k);
1825
+ iterator __j = __i;
1826
+ if (__i != end())
1827
+ ++__j;
1828
+ return pair<iterator, iterator>(__i, __j);
1829
+ }
1830
+
1831
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1832
+ template <class _Key>
1833
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator,
1834
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator>
1835
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__equal_range_unique(
1836
+ const _Key& __k) const
1837
+ {
1838
+ const_iterator __i = find(__k);
1839
+ const_iterator __j = __i;
1840
+ if (__i != end())
1841
+ ++__j;
1842
+ return pair<const_iterator, const_iterator>(__i, __j);
1843
+ }
1844
+
1845
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1846
+ template <class _Key>
1847
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator,
1848
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator>
1849
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__equal_range_multi(
1850
+ const _Key& __k)
1851
+ {
1852
+ iterator __i = find(__k);
1853
+ iterator __j = __i;
1854
+ if (__i != end())
1855
+ {
1856
+ iterator __e = end();
1857
+ do
1858
+ {
1859
+ ++__j;
1860
+ } while (__j != __e && key_eq()(*__j, __k));
1861
+ }
1862
+ return pair<iterator, iterator>(__i, __j);
1863
+ }
1864
+
1865
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1866
+ template <class _Key>
1867
+ pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator,
1868
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator>
1869
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__equal_range_multi(
1870
+ const _Key& __k) const
1871
+ {
1872
+ const_iterator __i = find(__k);
1873
+ const_iterator __j = __i;
1874
+ if (__i != end())
1875
+ {
1876
+ const_iterator __e = end();
1877
+ do
1878
+ {
1879
+ ++__j;
1880
+ } while (__j != __e && key_eq()(*__j, __k));
1881
+ }
1882
+ return pair<const_iterator, const_iterator>(__i, __j);
1883
+ }
1884
+
1885
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1886
+ void
1887
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::swap(__hash_table& __u)
1888
+ _NOEXCEPT_(
1889
+ (!allocator_traits<__pointer_allocator>::propagate_on_container_swap::value ||
1890
+ __is_nothrow_swappable<__pointer_allocator>::value) &&
1891
+ (!__node_traits::propagate_on_container_swap::value ||
1892
+ __is_nothrow_swappable<__node_allocator>::value) &&
1893
+ __is_nothrow_swappable<hasher>::value &&
1894
+ __is_nothrow_swappable<key_equal>::value)
1895
+ {
1896
+ {
1897
+ __node_pointer_pointer __npp = __bucket_list_.release();
1898
+ __bucket_list_.reset(__u.__bucket_list_.release());
1899
+ __u.__bucket_list_.reset(__npp);
1900
+ }
1901
+ _VSTD::swap(__bucket_list_.get_deleter().size(), __u.__bucket_list_.get_deleter().size());
1902
+ __swap_alloc(__bucket_list_.get_deleter().__alloc(),
1903
+ __u.__bucket_list_.get_deleter().__alloc());
1904
+ __swap_alloc(__node_alloc(), __u.__node_alloc());
1905
+ _VSTD::swap(__p1_.first().__next_, __u.__p1_.first().__next_);
1906
+ __p2_.swap(__u.__p2_);
1907
+ __p3_.swap(__u.__p3_);
1908
+ if (size() > 0)
1909
+ __bucket_list_[__constrain_hash(__p1_.first().__next_->__hash_, bucket_count())] =
1910
+ static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()));
1911
+ if (__u.size() > 0)
1912
+ __u.__bucket_list_[__constrain_hash(__u.__p1_.first().__next_->__hash_, __u.bucket_count())] =
1913
+ static_cast<__node_pointer>(_VSTD::addressof(__u.__p1_.first()));
1914
+ }
1915
+
1916
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1917
+ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::size_type
1918
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>::bucket_size(size_type __n) const
1919
+ {
1920
+ __node_const_pointer __np = __bucket_list_[__n];
1921
+ size_type __bc = bucket_count();
1922
+ size_type __r = 0;
1923
+ if (__np != nullptr)
1924
+ {
1925
+ for (__np = __np->__next_; __np != nullptr &&
1926
+ __constrain_hash(__np->__hash_, __bc) == __n;
1927
+ __np = __np->__next_, ++__r)
1928
+ ;
1929
+ }
1930
+ return __r;
1931
+ }
1932
+
1933
+ template <class _Tp, class _Hash, class _Equal, class _Alloc>
1934
+ inline _LIBCPP_INLINE_VISIBILITY
1935
+ void
1936
+ swap(__hash_table<_Tp, _Hash, _Equal, _Alloc>& __x,
1937
+ __hash_table<_Tp, _Hash, _Equal, _Alloc>& __y)
1938
+ _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y)))
1939
+ {
1940
+ __x.swap(__y);
1941
+ }
1942
+
1943
+ _LIBCPP_END_NAMESPACE_STD
1944
+
1945
+ #endif // _LIBCPP__HASH_TABLE