@port-labs/jq-node-bindings 0.0.3 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (286) hide show
  1. package/binding.gyp +3 -3
  2. package/configure +8 -6
  3. package/deps/jq/.travis.yml +184 -35
  4. package/deps/jq/AUTHORS +31 -30
  5. package/deps/jq/COPYING +2 -2
  6. package/deps/jq/KEYS +8 -0
  7. package/deps/jq/Makefile.am +85 -70
  8. package/deps/jq/NEWS +5 -4
  9. package/deps/jq/README.md +18 -9
  10. package/deps/jq/appveyor.yml +53 -0
  11. package/deps/jq/compile-ios.sh +5 -5
  12. package/deps/jq/config/m4/check-math-func.m4 +7 -2
  13. package/deps/jq/configure.ac +130 -68
  14. package/deps/jq/docs/Rakefile +14 -135
  15. package/deps/jq/docs/Rakefile.manual +49 -0
  16. package/deps/jq/docs/Rakefile.website +76 -0
  17. package/deps/jq/docs/content/2.download/default.yml +115 -39
  18. package/deps/jq/docs/content/3.manual/manual.yml +641 -231
  19. package/deps/jq/docs/content/3.manual/v1.3/manual.yml +130 -130
  20. package/deps/jq/docs/content/3.manual/v1.4/manual.yml +160 -160
  21. package/deps/jq/docs/content/3.manual/v1.5/manual.yml +2878 -0
  22. package/deps/jq/docs/content/3.manual/v1.6/manual.yml +3287 -0
  23. package/deps/jq/docs/content/index/index.yml +28 -6
  24. package/deps/jq/docs/public/.htaccess +2 -2
  25. package/deps/jq/docs/public/css/base.scss +141 -59
  26. package/deps/jq/docs/public/js/manual-search.js +52 -0
  27. package/deps/jq/docs/site.yml +1 -10
  28. package/deps/jq/docs/templates/default.liquid +10 -10
  29. package/deps/jq/docs/templates/index.liquid +45 -32
  30. package/deps/jq/docs/templates/manual.liquid +67 -90
  31. package/deps/jq/docs/templates/shared/_footer.liquid +10 -5
  32. package/deps/jq/docs/templates/shared/_head.liquid +17 -12
  33. package/deps/jq/docs/templates/shared/_navbar.liquid +27 -0
  34. package/deps/jq/jq.1.prebuilt +523 -139
  35. package/deps/jq/modules/oniguruma/AUTHORS +1 -0
  36. package/deps/jq/modules/oniguruma/CMakeLists.txt +86 -0
  37. package/deps/jq/modules/oniguruma/COPYING +28 -0
  38. package/deps/jq/modules/oniguruma/ChangeLog +0 -0
  39. package/deps/jq/modules/oniguruma/HISTORY +2138 -0
  40. package/deps/jq/modules/oniguruma/Makefile.am +33 -0
  41. package/deps/jq/modules/oniguruma/NEWS +0 -0
  42. package/deps/jq/modules/oniguruma/README +189 -0
  43. package/deps/jq/modules/oniguruma/README.ja +195 -0
  44. package/deps/jq/modules/oniguruma/README.md +203 -0
  45. package/deps/jq/modules/oniguruma/cmake/dist.cmake +321 -0
  46. package/deps/jq/modules/oniguruma/compile +348 -0
  47. package/deps/jq/modules/oniguruma/config.guess +1754 -0
  48. package/deps/jq/modules/oniguruma/config.sub +1890 -0
  49. package/deps/jq/modules/oniguruma/configure.ac +87 -0
  50. package/deps/jq/modules/oniguruma/contributed/libfuzzer-onig.cpp +31 -0
  51. package/deps/jq/modules/oniguruma/depcomp +791 -0
  52. package/deps/jq/modules/oniguruma/dist.info +10 -0
  53. package/deps/jq/modules/oniguruma/doc/API +660 -0
  54. package/deps/jq/modules/oniguruma/doc/API.ja +667 -0
  55. package/deps/jq/modules/oniguruma/doc/FAQ +12 -0
  56. package/deps/jq/modules/oniguruma/doc/FAQ.ja +22 -0
  57. package/deps/jq/modules/oniguruma/doc/RE +436 -0
  58. package/deps/jq/modules/oniguruma/doc/RE.ja +448 -0
  59. package/deps/jq/modules/oniguruma/doc/UNICODE_PROPERTIES +698 -0
  60. package/deps/jq/modules/oniguruma/index.html +181 -0
  61. package/deps/jq/modules/oniguruma/index_ja.html +184 -0
  62. package/deps/jq/modules/oniguruma/install-sh +541 -0
  63. package/deps/jq/modules/oniguruma/m4/.whatever +0 -0
  64. package/deps/jq/modules/oniguruma/make_win32.bat +3 -0
  65. package/deps/jq/modules/oniguruma/make_win64.bat +3 -0
  66. package/deps/jq/modules/oniguruma/missing +215 -0
  67. package/deps/jq/modules/oniguruma/onig-config.in +78 -0
  68. package/deps/jq/modules/oniguruma/oniguruma.pc.cmake.in +13 -0
  69. package/deps/jq/modules/oniguruma/oniguruma.pc.in +14 -0
  70. package/deps/jq/modules/oniguruma/sample/CMakeLists.txt +28 -0
  71. package/deps/jq/modules/oniguruma/sample/Makefile.am +34 -0
  72. package/deps/jq/modules/oniguruma/sample/bug_fix.c +131 -0
  73. package/deps/jq/modules/oniguruma/sample/crnl.c +127 -0
  74. package/deps/jq/modules/oniguruma/sample/encode.c +308 -0
  75. package/deps/jq/modules/oniguruma/sample/listcap.c +110 -0
  76. package/deps/jq/modules/oniguruma/sample/names.c +75 -0
  77. package/deps/jq/modules/oniguruma/sample/posix.c +96 -0
  78. package/deps/jq/modules/oniguruma/sample/scan.c +88 -0
  79. package/deps/jq/modules/oniguruma/sample/simple.c +59 -0
  80. package/deps/jq/modules/oniguruma/sample/sql.c +76 -0
  81. package/deps/jq/modules/oniguruma/sample/syntax.c +76 -0
  82. package/deps/jq/modules/oniguruma/sample/user_property.c +87 -0
  83. package/deps/jq/modules/oniguruma/src/Makefile.am +58 -0
  84. package/deps/jq/modules/oniguruma/src/Makefile.windows +183 -0
  85. package/deps/jq/modules/oniguruma/src/ascii.c +61 -0
  86. package/deps/jq/modules/oniguruma/src/big5.c +190 -0
  87. package/deps/jq/modules/oniguruma/src/config.h.cmake.in +71 -0
  88. package/deps/jq/modules/oniguruma/src/config.h.win32 +84 -0
  89. package/deps/jq/modules/oniguruma/src/config.h.win64 +84 -0
  90. package/deps/jq/modules/oniguruma/src/cp1251.c +203 -0
  91. package/deps/jq/modules/oniguruma/src/euc_jp.c +310 -0
  92. package/deps/jq/modules/oniguruma/src/euc_jp_prop.c +158 -0
  93. package/deps/jq/modules/oniguruma/src/euc_jp_prop.gperf +27 -0
  94. package/deps/jq/modules/oniguruma/src/euc_kr.c +188 -0
  95. package/deps/jq/modules/oniguruma/src/euc_tw.c +171 -0
  96. package/deps/jq/modules/oniguruma/src/gb18030.c +538 -0
  97. package/deps/jq/modules/oniguruma/src/gperf_fold_key_conv.py +67 -0
  98. package/deps/jq/modules/oniguruma/src/gperf_unfold_key_conv.py +55 -0
  99. package/deps/jq/modules/oniguruma/src/iso8859_1.c +275 -0
  100. package/deps/jq/modules/oniguruma/src/iso8859_10.c +242 -0
  101. package/deps/jq/modules/oniguruma/src/iso8859_11.c +99 -0
  102. package/deps/jq/modules/oniguruma/src/iso8859_13.c +231 -0
  103. package/deps/jq/modules/oniguruma/src/iso8859_14.c +244 -0
  104. package/deps/jq/modules/oniguruma/src/iso8859_15.c +238 -0
  105. package/deps/jq/modules/oniguruma/src/iso8859_16.c +240 -0
  106. package/deps/jq/modules/oniguruma/src/iso8859_2.c +238 -0
  107. package/deps/jq/modules/oniguruma/src/iso8859_3.c +238 -0
  108. package/deps/jq/modules/oniguruma/src/iso8859_4.c +240 -0
  109. package/deps/jq/modules/oniguruma/src/iso8859_5.c +229 -0
  110. package/deps/jq/modules/oniguruma/src/iso8859_6.c +99 -0
  111. package/deps/jq/modules/oniguruma/src/iso8859_7.c +225 -0
  112. package/deps/jq/modules/oniguruma/src/iso8859_8.c +99 -0
  113. package/deps/jq/modules/oniguruma/src/iso8859_9.c +231 -0
  114. package/deps/jq/modules/oniguruma/src/koi8.c +253 -0
  115. package/deps/jq/modules/oniguruma/src/koi8_r.c +215 -0
  116. package/deps/jq/modules/oniguruma/src/make_unicode_fold.sh +22 -0
  117. package/deps/jq/modules/oniguruma/src/make_unicode_fold_data.py +306 -0
  118. package/deps/jq/modules/oniguruma/src/make_unicode_property.sh +18 -0
  119. package/deps/jq/modules/oniguruma/src/make_unicode_property_data.py +545 -0
  120. package/deps/jq/modules/oniguruma/src/mktable.c +1184 -0
  121. package/deps/jq/modules/oniguruma/src/onig_init.c +45 -0
  122. package/deps/jq/modules/oniguruma/src/oniggnu.h +85 -0
  123. package/deps/jq/modules/oniguruma/src/onigposix.h +169 -0
  124. package/deps/jq/modules/oniguruma/src/oniguruma.h +841 -0
  125. package/deps/jq/modules/oniguruma/src/regcomp.c +6300 -0
  126. package/deps/jq/modules/oniguruma/src/regenc.c +917 -0
  127. package/deps/jq/modules/oniguruma/src/regenc.h +243 -0
  128. package/deps/jq/modules/oniguruma/src/regerror.c +393 -0
  129. package/deps/jq/modules/oniguruma/src/regexec.c +3856 -0
  130. package/deps/jq/modules/oniguruma/src/regext.c +202 -0
  131. package/deps/jq/modules/oniguruma/src/reggnu.c +147 -0
  132. package/deps/jq/modules/oniguruma/src/regint.h +779 -0
  133. package/deps/jq/modules/oniguruma/src/regparse.c +5403 -0
  134. package/deps/jq/modules/oniguruma/src/regparse.h +351 -0
  135. package/deps/jq/modules/oniguruma/src/regposerr.c +105 -0
  136. package/deps/jq/modules/oniguruma/src/regposix.c +306 -0
  137. package/deps/jq/modules/oniguruma/src/regsyntax.c +315 -0
  138. package/deps/jq/modules/oniguruma/src/regtrav.c +76 -0
  139. package/deps/jq/modules/oniguruma/src/regversion.c +57 -0
  140. package/deps/jq/modules/oniguruma/src/sjis.c +341 -0
  141. package/deps/jq/modules/oniguruma/src/sjis_prop.c +158 -0
  142. package/deps/jq/modules/oniguruma/src/sjis_prop.gperf +27 -0
  143. package/deps/jq/modules/oniguruma/src/st.c +589 -0
  144. package/deps/jq/modules/oniguruma/src/st.h +68 -0
  145. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold1_key.c +2250 -0
  146. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold2_key.c +203 -0
  147. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold3_key.c +113 -0
  148. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold_data.c +1225 -0
  149. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_property_data.c +24742 -0
  150. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_property_data_posix.c +4846 -0
  151. package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_unfold_key.c +2571 -0
  152. package/deps/jq/modules/oniguruma/src/unicode.c +664 -0
  153. package/deps/jq/modules/oniguruma/src/unicode_fold1_key.c +2548 -0
  154. package/deps/jq/modules/oniguruma/src/unicode_fold2_key.c +203 -0
  155. package/deps/jq/modules/oniguruma/src/unicode_fold3_key.c +113 -0
  156. package/deps/jq/modules/oniguruma/src/unicode_fold_data.c +1366 -0
  157. package/deps/jq/modules/oniguruma/src/unicode_property_data.c +25306 -0
  158. package/deps/jq/modules/oniguruma/src/unicode_property_data_posix.c +4940 -0
  159. package/deps/jq/modules/oniguruma/src/unicode_unfold_key.c +2854 -0
  160. package/deps/jq/modules/oniguruma/src/utf16_be.c +235 -0
  161. package/deps/jq/modules/oniguruma/src/utf16_le.c +245 -0
  162. package/deps/jq/modules/oniguruma/src/utf32_be.c +194 -0
  163. package/deps/jq/modules/oniguruma/src/utf32_le.c +194 -0
  164. package/deps/jq/modules/oniguruma/src/utf8.c +335 -0
  165. package/deps/jq/modules/oniguruma/test/Makefile.am +28 -0
  166. package/deps/jq/modules/oniguruma/test/testc.c +874 -0
  167. package/deps/jq/modules/oniguruma/test/testu.c +916 -0
  168. package/deps/jq/modules/oniguruma/test-driver +153 -0
  169. package/deps/jq/modules/oniguruma/windows/testc.c +869 -0
  170. package/deps/jq/scripts/crosscompile +2 -1
  171. package/deps/jq/scripts/gen_utf8_tables.py +2 -3
  172. package/deps/jq/scripts/update-website +29 -0
  173. package/deps/jq/scripts/version +7 -2
  174. package/deps/jq/sig/jq-release.key +41 -0
  175. package/deps/jq/sig/v1.3/jq-linux-x86.asc +17 -0
  176. package/deps/jq/sig/v1.3/jq-linux-x86_64.asc +17 -0
  177. package/deps/jq/sig/v1.3/jq-osx-x86.asc +17 -0
  178. package/deps/jq/sig/v1.3/jq-osx-x86_64.asc +17 -0
  179. package/deps/jq/sig/v1.3/jq-win32.exe.asc +17 -0
  180. package/deps/jq/sig/v1.3/jq-win64.exe.asc +17 -0
  181. package/deps/jq/sig/v1.3/sha256sum.txt +6 -0
  182. package/deps/jq/sig/v1.4/jq-linux-x86.asc +17 -0
  183. package/deps/jq/sig/v1.4/jq-linux-x86_64.asc +17 -0
  184. package/deps/jq/sig/v1.4/jq-osx-x86.asc +17 -0
  185. package/deps/jq/sig/v1.4/jq-osx-x86_64.asc +17 -0
  186. package/deps/jq/sig/v1.4/jq-solaris11-32.asc +17 -0
  187. package/deps/jq/sig/v1.4/jq-solaris11-64.asc +17 -0
  188. package/deps/jq/sig/v1.4/jq-win32.exe.asc +17 -0
  189. package/deps/jq/sig/v1.4/jq-win64.exe.asc +17 -0
  190. package/deps/jq/sig/v1.4/sha256sum.txt +8 -0
  191. package/deps/jq/sig/v1.5/jq-linux32-no-oniguruma.asc +17 -0
  192. package/deps/jq/sig/v1.5/jq-linux32.asc +17 -0
  193. package/deps/jq/sig/v1.5/jq-linux64.asc +17 -0
  194. package/deps/jq/sig/v1.5/jq-osx-amd64.asc +17 -0
  195. package/deps/jq/sig/v1.5/jq-win32.exe.asc +17 -0
  196. package/deps/jq/sig/v1.5/jq-win64.exe.asc +17 -0
  197. package/deps/jq/sig/v1.5/sha256sum.txt +5 -0
  198. package/deps/jq/sig/v1.5rc1/jq-linux-x86_64-static.asc +17 -0
  199. package/deps/jq/sig/v1.5rc1/jq-win32.exe.asc +17 -0
  200. package/deps/jq/sig/v1.5rc1/jq-win64.exe.asc +17 -0
  201. package/deps/jq/sig/v1.5rc1/sha256sum.txt +3 -0
  202. package/deps/jq/sig/v1.5rc2/jq-linux-x86.asc +17 -0
  203. package/deps/jq/sig/v1.5rc2/jq-linux-x86_64.asc +17 -0
  204. package/deps/jq/sig/v1.5rc2/jq-osx-x86_64.asc +17 -0
  205. package/deps/jq/sig/v1.5rc2/jq-win32.exe.asc +17 -0
  206. package/deps/jq/sig/v1.5rc2/jq-win64.exe.asc +17 -0
  207. package/deps/jq/sig/v1.5rc2/sha256sum.txt +5 -0
  208. package/deps/jq/sig/v1.6/jq-linux32.asc +16 -0
  209. package/deps/jq/sig/v1.6/jq-linux64.asc +16 -0
  210. package/deps/jq/sig/v1.6/jq-osx-amd64.asc +16 -0
  211. package/deps/jq/sig/v1.6/jq-win32.exe.asc +16 -0
  212. package/deps/jq/sig/v1.6/jq-win64.exe.asc +16 -0
  213. package/deps/jq/sig/v1.6/sha256sum.txt +5 -0
  214. package/deps/jq/{builtin.c → src/builtin.c} +449 -344
  215. package/deps/jq/{builtin.h → src/builtin.h} +0 -0
  216. package/deps/jq/src/builtin.jq +311 -0
  217. package/deps/jq/{bytecode.c → src/bytecode.c} +0 -0
  218. package/deps/jq/{bytecode.h → src/bytecode.h} +0 -0
  219. package/deps/jq/{compile.c → src/compile.c} +213 -37
  220. package/deps/jq/{compile.h → src/compile.h} +7 -2
  221. package/deps/jq/{exec_stack.h → src/exec_stack.h} +0 -0
  222. package/deps/jq/{execute.c → src/execute.c} +127 -24
  223. package/deps/jq/{inject_errors.c → src/inject_errors.c} +0 -0
  224. package/deps/jq/{jq.h → src/jq.h} +13 -2
  225. package/deps/jq/{jq_parser.h → src/jq_parser.h} +0 -0
  226. package/deps/jq/{jq_test.c → src/jq_test.c} +1 -1
  227. package/deps/jq/{jv.c → src/jv.c} +24 -5
  228. package/deps/jq/{jv.h → src/jv.h} +46 -11
  229. package/deps/jq/{jv_alloc.c → src/jv_alloc.c} +0 -0
  230. package/deps/jq/{jv_alloc.h → src/jv_alloc.h} +0 -0
  231. package/deps/jq/{jv_aux.c → src/jv_aux.c} +38 -14
  232. package/deps/jq/{jv_dtoa.c → src/jv_dtoa.c} +4 -5
  233. package/deps/jq/{jv_dtoa.h → src/jv_dtoa.h} +0 -0
  234. package/deps/jq/src/jv_file.c +81 -0
  235. package/deps/jq/{jv_parse.c → src/jv_parse.c} +8 -2
  236. package/deps/jq/{jv_print.c → src/jv_print.c} +80 -27
  237. package/deps/jq/{jv_unicode.c → src/jv_unicode.c} +28 -4
  238. package/deps/jq/{jv_unicode.h → src/jv_unicode.h} +1 -0
  239. package/deps/jq/{jv_utf8_tables.h → src/jv_utf8_tables.h} +0 -0
  240. package/deps/jq/{lexer.c → src/lexer.c} +317 -292
  241. package/deps/jq/{lexer.h → src/lexer.h} +16 -12
  242. package/deps/jq/{lexer.l → src/lexer.l} +5 -4
  243. package/deps/jq/src/libm.h +291 -0
  244. package/deps/jq/{linker.c → src/linker.c} +5 -3
  245. package/deps/jq/{linker.h → src/linker.h} +0 -0
  246. package/deps/jq/{locfile.c → src/locfile.c} +1 -1
  247. package/deps/jq/{locfile.h → src/locfile.h} +0 -0
  248. package/deps/jq/{main.c → src/main.c} +202 -100
  249. package/deps/jq/{opcode_list.h → src/opcode_list.h} +4 -0
  250. package/deps/jq/{parser.c → src/parser.c} +1149 -1069
  251. package/deps/jq/{parser.h → src/parser.h} +28 -24
  252. package/deps/jq/{parser.y → src/parser.y} +108 -52
  253. package/deps/jq/{util.c → src/util.c} +12 -9
  254. package/deps/jq/{util.h → src/util.h} +0 -0
  255. package/deps/jq/tests/base64.test +35 -0
  256. package/deps/jq/tests/base64test +5 -0
  257. package/deps/jq/tests/jq-f-test.sh +4 -0
  258. package/deps/jq/tests/jq.test +305 -21
  259. package/deps/jq/tests/jqtest +1 -1
  260. package/deps/jq/tests/mantest +1 -1
  261. package/deps/jq/tests/onig.test +13 -0
  262. package/deps/jq/tests/onigtest +1 -1
  263. package/deps/jq/tests/optional.test +20 -0
  264. package/deps/jq/tests/optionaltest +5 -0
  265. package/deps/jq/tests/setup +7 -1
  266. package/deps/jq/tests/shtest +133 -29
  267. package/deps/jq/tests/utf8-truncate.jq +3 -0
  268. package/deps/jq/tests/utf8test +10 -0
  269. package/lib/index.js +7 -1
  270. package/package.json +3 -3
  271. package/test/santiy.test.js +24 -0
  272. package/deps/jq/docs/default_manpage.md +0 -22
  273. package/deps/jq/docs/public/bootstrap/css/bootstrap-responsive.css +0 -1058
  274. package/deps/jq/docs/public/bootstrap/css/bootstrap-responsive.min.css +0 -9
  275. package/deps/jq/docs/public/bootstrap/css/bootstrap.css +0 -5224
  276. package/deps/jq/docs/public/bootstrap/css/bootstrap.min.css +0 -9
  277. package/deps/jq/docs/public/bootstrap/img/glyphicons-halflings-white.png +0 -0
  278. package/deps/jq/docs/public/bootstrap/img/glyphicons-halflings.png +0 -0
  279. package/deps/jq/docs/public/bootstrap/js/bootstrap.js +0 -2027
  280. package/deps/jq/docs/public/bootstrap/js/bootstrap.min.js +0 -6
  281. package/deps/jq/docs/templates/shared/_header.liquid +0 -26
  282. package/deps/jq/jq.1.default +0 -39
  283. package/deps/jq/jv_file.c +0 -49
  284. package/deps/jq/libm.h +0 -160
  285. package/deps/jq/setup.sh +0 -33
  286. package/reports/jest-port-api.xml +0 -35
@@ -0,0 +1,589 @@
1
+ /* This is a public domain general purpose hash table package written by Peter Moore @ UCB. */
2
+
3
+ /* static char sccsid[] = "@(#) st.c 5.1 89/12/14 Crucible"; */
4
+
5
+ #include <stdio.h>
6
+ #include <stdlib.h>
7
+ #include <string.h>
8
+
9
+ #ifdef _WIN32
10
+ #include <malloc.h>
11
+ #endif
12
+
13
+ #include "regint.h"
14
+ #include "st.h"
15
+
16
+ typedef struct st_table_entry st_table_entry;
17
+
18
+ struct st_table_entry {
19
+ unsigned int hash;
20
+ st_data_t key;
21
+ st_data_t record;
22
+ st_table_entry *next;
23
+ };
24
+
25
+ #define ST_DEFAULT_MAX_DENSITY 5
26
+ #define ST_DEFAULT_INIT_TABLE_SIZE 11
27
+
28
+ /*
29
+ * DEFAULT_MAX_DENSITY is the default for the largest we allow the
30
+ * average number of items per bin before increasing the number of
31
+ * bins
32
+ *
33
+ * DEFAULT_INIT_TABLE_SIZE is the default for the number of bins
34
+ * allocated initially
35
+ *
36
+ */
37
+
38
+ static int numcmp(long, long);
39
+ static int numhash(long);
40
+ static struct st_hash_type type_numhash = {
41
+ numcmp,
42
+ numhash,
43
+ };
44
+
45
+ /* extern int strcmp(const char *, const char *); */
46
+ static int strhash(const char *);
47
+ static struct st_hash_type type_strhash = {
48
+ strcmp,
49
+ strhash,
50
+ };
51
+
52
+ static void rehash(st_table *);
53
+
54
+ #define alloc(type) (type*)xmalloc((unsigned)sizeof(type))
55
+ #define Calloc(n,s) (char*)xcalloc((n),(s))
56
+
57
+ #define EQUAL(table,x,y) ((x)==(y) || (*table->type->compare)((x),(y)) == 0)
58
+
59
+ #define do_hash(key,table) (unsigned int)(*(table)->type->hash)((key))
60
+ #define do_hash_bin(key,table) (do_hash(key, table)%(table)->num_bins)
61
+
62
+ /*
63
+ * MINSIZE is the minimum size of a dictionary.
64
+ */
65
+
66
+ #define MINSIZE 8
67
+
68
+ /*
69
+ Table of prime numbers 2^n+a, 2<=n<=30.
70
+ */
71
+ static const long primes[] = {
72
+ 8 + 3,
73
+ 16 + 3,
74
+ 32 + 5,
75
+ 64 + 3,
76
+ 128 + 3,
77
+ 256 + 27,
78
+ 512 + 9,
79
+ 1024 + 9,
80
+ 2048 + 5,
81
+ 4096 + 3,
82
+ 8192 + 27,
83
+ 16384 + 43,
84
+ 32768 + 3,
85
+ 65536 + 45,
86
+ 131072 + 29,
87
+ 262144 + 3,
88
+ 524288 + 21,
89
+ 1048576 + 7,
90
+ 2097152 + 17,
91
+ 4194304 + 15,
92
+ 8388608 + 9,
93
+ 16777216 + 43,
94
+ 33554432 + 35,
95
+ 67108864 + 15,
96
+ 134217728 + 29,
97
+ 268435456 + 3,
98
+ 536870912 + 11,
99
+ 1073741824 + 85,
100
+ 0
101
+ };
102
+
103
+ static int
104
+ new_size(size)
105
+ int size;
106
+ {
107
+ int i;
108
+
109
+ #if 0
110
+ for (i=3; i<31; i++) {
111
+ if ((1<<i) > size) return 1<<i;
112
+ }
113
+ return -1;
114
+ #else
115
+ int newsize;
116
+
117
+ for (i = 0, newsize = MINSIZE;
118
+ i < (int )(sizeof(primes)/sizeof(primes[0]));
119
+ i++, newsize <<= 1)
120
+ {
121
+ if (newsize > size) return primes[i];
122
+ }
123
+ /* Ran out of polynomials */
124
+ return -1; /* should raise exception */
125
+ #endif
126
+ }
127
+
128
+ #ifdef HASH_LOG
129
+ static int collision = 0;
130
+ static int init_st = 0;
131
+
132
+ static void
133
+ stat_col(void)
134
+ {
135
+ FILE *f = fopen("/tmp/col", "w");
136
+ if (f == 0) return ;
137
+
138
+ (void) fprintf(f, "collision: %d\n", collision);
139
+ (void) fclose(f);
140
+ }
141
+ #endif
142
+
143
+ st_table*
144
+ st_init_table_with_size(type, size)
145
+ struct st_hash_type *type;
146
+ int size;
147
+ {
148
+ st_table *tbl;
149
+
150
+ #ifdef HASH_LOG
151
+ if (init_st == 0) {
152
+ init_st = 1;
153
+ atexit(stat_col);
154
+ }
155
+ #endif
156
+
157
+ size = new_size(size); /* round up to prime number */
158
+
159
+ tbl = alloc(st_table);
160
+ if (tbl == 0) return 0;
161
+
162
+ tbl->type = type;
163
+ tbl->num_entries = 0;
164
+ tbl->num_bins = size;
165
+ tbl->bins = (st_table_entry **)Calloc(size, sizeof(st_table_entry*));
166
+ if (tbl->bins == 0) {
167
+ free(tbl);
168
+ return 0;
169
+ }
170
+
171
+ return tbl;
172
+ }
173
+
174
+ st_table*
175
+ st_init_table(type)
176
+ struct st_hash_type *type;
177
+ {
178
+ return st_init_table_with_size(type, 0);
179
+ }
180
+
181
+ st_table*
182
+ st_init_numtable(void)
183
+ {
184
+ return st_init_table(&type_numhash);
185
+ }
186
+
187
+ st_table*
188
+ st_init_numtable_with_size(size)
189
+ int size;
190
+ {
191
+ return st_init_table_with_size(&type_numhash, size);
192
+ }
193
+
194
+ st_table*
195
+ st_init_strtable(void)
196
+ {
197
+ return st_init_table(&type_strhash);
198
+ }
199
+
200
+ st_table*
201
+ st_init_strtable_with_size(size)
202
+ int size;
203
+ {
204
+ return st_init_table_with_size(&type_strhash, size);
205
+ }
206
+
207
+ void
208
+ st_free_table(table)
209
+ st_table *table;
210
+ {
211
+ register st_table_entry *ptr, *next;
212
+ int i;
213
+
214
+ for(i = 0; i < table->num_bins; i++) {
215
+ ptr = table->bins[i];
216
+ while (ptr != 0) {
217
+ next = ptr->next;
218
+ free(ptr);
219
+ ptr = next;
220
+ }
221
+ }
222
+ free(table->bins);
223
+ free(table);
224
+ }
225
+
226
+ #define PTR_NOT_EQUAL(table, ptr, hash_val, key) \
227
+ ((ptr) != 0 && (ptr->hash != (hash_val) || !EQUAL((table), (key), (ptr)->key)))
228
+
229
+ #ifdef HASH_LOG
230
+ #define COLLISION collision++
231
+ #else
232
+ #define COLLISION
233
+ #endif
234
+
235
+ #define FIND_ENTRY(table, ptr, hash_val, bin_pos) do {\
236
+ bin_pos = hash_val%(table)->num_bins;\
237
+ ptr = (table)->bins[bin_pos];\
238
+ if (PTR_NOT_EQUAL(table, ptr, hash_val, key)) {\
239
+ COLLISION;\
240
+ while (PTR_NOT_EQUAL(table, ptr->next, hash_val, key)) {\
241
+ ptr = ptr->next;\
242
+ }\
243
+ ptr = ptr->next;\
244
+ }\
245
+ } while (0)
246
+
247
+ int
248
+ st_lookup(table, key, value)
249
+ st_table *table;
250
+ register st_data_t key;
251
+ st_data_t *value;
252
+ {
253
+ unsigned int hash_val, bin_pos;
254
+ register st_table_entry *ptr;
255
+
256
+ hash_val = do_hash(key, table);
257
+ FIND_ENTRY(table, ptr, hash_val, bin_pos);
258
+
259
+ if (ptr == 0) {
260
+ return 0;
261
+ }
262
+ else {
263
+ if (value != 0) *value = ptr->record;
264
+ return 1;
265
+ }
266
+ }
267
+
268
+ #define ADD_DIRECT(table, key, value, hash_val, bin_pos)\
269
+ do {\
270
+ st_table_entry *entry;\
271
+ if (table->num_entries/(table->num_bins) > ST_DEFAULT_MAX_DENSITY) {\
272
+ rehash(table);\
273
+ bin_pos = hash_val % table->num_bins;\
274
+ }\
275
+ \
276
+ entry = alloc(st_table_entry);\
277
+ \
278
+ entry->hash = hash_val;\
279
+ entry->key = key;\
280
+ entry->record = value;\
281
+ entry->next = table->bins[bin_pos];\
282
+ table->bins[bin_pos] = entry;\
283
+ table->num_entries++;\
284
+ } while (0)
285
+
286
+ int
287
+ st_insert(table, key, value)
288
+ register st_table *table;
289
+ register st_data_t key;
290
+ st_data_t value;
291
+ {
292
+ unsigned int hash_val, bin_pos;
293
+ register st_table_entry *ptr;
294
+
295
+ hash_val = do_hash(key, table);
296
+ FIND_ENTRY(table, ptr, hash_val, bin_pos);
297
+
298
+ if (ptr == 0) {
299
+ ADD_DIRECT(table, key, value, hash_val, bin_pos);
300
+ return 0;
301
+ }
302
+ else {
303
+ ptr->record = value;
304
+ return 1;
305
+ }
306
+ }
307
+
308
+ void
309
+ st_add_direct(table, key, value)
310
+ st_table *table;
311
+ st_data_t key;
312
+ st_data_t value;
313
+ {
314
+ unsigned int hash_val, bin_pos;
315
+
316
+ hash_val = do_hash(key, table);
317
+ bin_pos = hash_val % table->num_bins;
318
+ ADD_DIRECT(table, key, value, hash_val, bin_pos);
319
+ }
320
+
321
+ static void
322
+ rehash(table)
323
+ register st_table *table;
324
+ {
325
+ register st_table_entry *ptr, *next, **new_bins;
326
+ int i, old_num_bins = table->num_bins, new_num_bins;
327
+ unsigned int hash_val;
328
+
329
+ new_num_bins = new_size(old_num_bins+1);
330
+ new_bins = (st_table_entry**)Calloc(new_num_bins, sizeof(st_table_entry*));
331
+ if (new_bins == 0) {
332
+ return ;
333
+ }
334
+
335
+ for(i = 0; i < old_num_bins; i++) {
336
+ ptr = table->bins[i];
337
+ while (ptr != 0) {
338
+ next = ptr->next;
339
+ hash_val = ptr->hash % new_num_bins;
340
+ ptr->next = new_bins[hash_val];
341
+ new_bins[hash_val] = ptr;
342
+ ptr = next;
343
+ }
344
+ }
345
+ free(table->bins);
346
+ table->num_bins = new_num_bins;
347
+ table->bins = new_bins;
348
+ }
349
+
350
+ st_table*
351
+ st_copy(old_table)
352
+ st_table *old_table;
353
+ {
354
+ st_table *new_table;
355
+ st_table_entry *ptr, *entry;
356
+ int i, num_bins = old_table->num_bins;
357
+
358
+ new_table = alloc(st_table);
359
+ if (new_table == 0) {
360
+ return 0;
361
+ }
362
+
363
+ *new_table = *old_table;
364
+ new_table->bins = (st_table_entry**)
365
+ Calloc((unsigned)num_bins, sizeof(st_table_entry*));
366
+
367
+ if (new_table->bins == 0) {
368
+ free(new_table);
369
+ return 0;
370
+ }
371
+
372
+ for(i = 0; i < num_bins; i++) {
373
+ new_table->bins[i] = 0;
374
+ ptr = old_table->bins[i];
375
+ while (ptr != 0) {
376
+ entry = alloc(st_table_entry);
377
+ if (entry == 0) {
378
+ free(new_table->bins);
379
+ free(new_table);
380
+ return 0;
381
+ }
382
+ *entry = *ptr;
383
+ entry->next = new_table->bins[i];
384
+ new_table->bins[i] = entry;
385
+ ptr = ptr->next;
386
+ }
387
+ }
388
+ return new_table;
389
+ }
390
+
391
+ int
392
+ st_delete(table, key, value)
393
+ register st_table *table;
394
+ register st_data_t *key;
395
+ st_data_t *value;
396
+ {
397
+ unsigned int hash_val;
398
+ st_table_entry *tmp;
399
+ register st_table_entry *ptr;
400
+
401
+ hash_val = do_hash_bin(*key, table);
402
+ ptr = table->bins[hash_val];
403
+
404
+ if (ptr == 0) {
405
+ if (value != 0) *value = 0;
406
+ return 0;
407
+ }
408
+
409
+ if (EQUAL(table, *key, ptr->key)) {
410
+ table->bins[hash_val] = ptr->next;
411
+ table->num_entries--;
412
+ if (value != 0) *value = ptr->record;
413
+ *key = ptr->key;
414
+ free(ptr);
415
+ return 1;
416
+ }
417
+
418
+ for(; ptr->next != 0; ptr = ptr->next) {
419
+ if (EQUAL(table, ptr->next->key, *key)) {
420
+ tmp = ptr->next;
421
+ ptr->next = ptr->next->next;
422
+ table->num_entries--;
423
+ if (value != 0) *value = tmp->record;
424
+ *key = tmp->key;
425
+ free(tmp);
426
+ return 1;
427
+ }
428
+ }
429
+
430
+ return 0;
431
+ }
432
+
433
+ int
434
+ st_delete_safe(table, key, value, never)
435
+ register st_table *table;
436
+ register st_data_t *key;
437
+ st_data_t *value;
438
+ st_data_t never;
439
+ {
440
+ unsigned int hash_val;
441
+ register st_table_entry *ptr;
442
+
443
+ hash_val = do_hash_bin(*key, table);
444
+ ptr = table->bins[hash_val];
445
+
446
+ if (ptr == 0) {
447
+ if (value != 0) *value = 0;
448
+ return 0;
449
+ }
450
+
451
+ for(; ptr != 0; ptr = ptr->next) {
452
+ if ((ptr->key != never) && EQUAL(table, ptr->key, *key)) {
453
+ table->num_entries--;
454
+ *key = ptr->key;
455
+ if (value != 0) *value = ptr->record;
456
+ ptr->key = ptr->record = never;
457
+ return 1;
458
+ }
459
+ }
460
+
461
+ return 0;
462
+ }
463
+
464
+ static int
465
+ #if defined(__GNUC__)
466
+ delete_never(st_data_t key __attribute__ ((unused)), st_data_t value,
467
+ st_data_t never)
468
+ #else
469
+ delete_never(key, value, never)
470
+ st_data_t key, value, never;
471
+ #endif
472
+ {
473
+ if (value == never) return ST_DELETE;
474
+ return ST_CONTINUE;
475
+ }
476
+
477
+ void
478
+ st_cleanup_safe(table, never)
479
+ st_table *table;
480
+ st_data_t never;
481
+ {
482
+ int num_entries = table->num_entries;
483
+
484
+ st_foreach(table, delete_never, never);
485
+ table->num_entries = num_entries;
486
+ }
487
+
488
+ int
489
+ st_foreach(table, func, arg)
490
+ st_table *table;
491
+ int (*func)();
492
+ st_data_t arg;
493
+ {
494
+ st_table_entry *ptr, *last, *tmp;
495
+ enum st_retval retval;
496
+ int i;
497
+
498
+ for(i = 0; i < table->num_bins; i++) {
499
+ last = 0;
500
+ for(ptr = table->bins[i]; ptr != 0;) {
501
+ retval = (*func)(ptr->key, ptr->record, arg);
502
+ switch (retval) {
503
+ case ST_CHECK: /* check if hash is modified during iteration */
504
+ tmp = 0;
505
+ if (i < table->num_bins) {
506
+ for (tmp = table->bins[i]; tmp; tmp=tmp->next) {
507
+ if (tmp == ptr) break;
508
+ }
509
+ }
510
+ if (!tmp) {
511
+ /* call func with error notice */
512
+ return 1;
513
+ }
514
+ /* fall through */
515
+ case ST_CONTINUE:
516
+ last = ptr;
517
+ ptr = ptr->next;
518
+ break;
519
+ case ST_STOP:
520
+ return 0;
521
+ case ST_DELETE:
522
+ tmp = ptr;
523
+ if (last == 0) {
524
+ table->bins[i] = ptr->next;
525
+ }
526
+ else {
527
+ last->next = ptr->next;
528
+ }
529
+ ptr = ptr->next;
530
+ free(tmp);
531
+ table->num_entries--;
532
+ }
533
+ }
534
+ }
535
+ return 0;
536
+ }
537
+
538
+ static int
539
+ strhash(string)
540
+ register const char *string;
541
+ {
542
+ register int c;
543
+
544
+ #ifdef HASH_ELFHASH
545
+ register unsigned int h = 0, g;
546
+
547
+ while ((c = *string++) != '\0') {
548
+ h = ( h << 4 ) + c;
549
+ if ( g = h & 0xF0000000 )
550
+ h ^= g >> 24;
551
+ h &= ~g;
552
+ }
553
+ return h;
554
+ #elif HASH_PERL
555
+ register int val = 0;
556
+
557
+ while ((c = *string++) != '\0') {
558
+ val += c;
559
+ val += (val << 10);
560
+ val ^= (val >> 6);
561
+ }
562
+ val += (val << 3);
563
+ val ^= (val >> 11);
564
+
565
+ return val + (val << 15);
566
+ #else
567
+ register int val = 0;
568
+
569
+ while ((c = *string++) != '\0') {
570
+ val = val*997 + c;
571
+ }
572
+
573
+ return val + (val>>5);
574
+ #endif
575
+ }
576
+
577
+ static int
578
+ numcmp(x, y)
579
+ long x, y;
580
+ {
581
+ return x != y;
582
+ }
583
+
584
+ static int
585
+ numhash(n)
586
+ long n;
587
+ {
588
+ return n;
589
+ }
@@ -0,0 +1,68 @@
1
+ /* This is a public domain general purpose hash table package written by Peter Moore @ UCB. */
2
+
3
+ /* @(#) st.h 5.1 89/12/14 */
4
+
5
+ #ifndef ST_INCLUDED
6
+
7
+ #define ST_INCLUDED
8
+
9
+ #ifdef _WIN32
10
+ # include <windows.h>
11
+ typedef ULONG_PTR st_data_t;
12
+ #else
13
+ typedef unsigned long st_data_t;
14
+ #endif
15
+ #define ST_DATA_T_DEFINED
16
+
17
+ typedef struct st_table st_table;
18
+
19
+ struct st_hash_type {
20
+ int (*compare)();
21
+ int (*hash)();
22
+ };
23
+
24
+ struct st_table {
25
+ struct st_hash_type *type;
26
+ int num_bins;
27
+ int num_entries;
28
+ struct st_table_entry **bins;
29
+ };
30
+
31
+ #define st_is_member(table,key) st_lookup(table,key,(st_data_t *)0)
32
+
33
+ enum st_retval {ST_CONTINUE, ST_STOP, ST_DELETE, ST_CHECK};
34
+
35
+ #ifndef _
36
+ # define _(args) args
37
+ #endif
38
+ #ifndef ANYARGS
39
+ # ifdef __cplusplus
40
+ # define ANYARGS ...
41
+ # else
42
+ # define ANYARGS
43
+ # endif
44
+ #endif
45
+
46
+ st_table *st_init_table _((struct st_hash_type *));
47
+ st_table *st_init_table_with_size _((struct st_hash_type *, int));
48
+ st_table *st_init_numtable _((void));
49
+ st_table *st_init_numtable_with_size _((int));
50
+ st_table *st_init_strtable _((void));
51
+ st_table *st_init_strtable_with_size _((int));
52
+ int st_delete _((st_table *, st_data_t *, st_data_t *));
53
+ int st_delete_safe _((st_table *, st_data_t *, st_data_t *, st_data_t));
54
+ int st_insert _((st_table *, st_data_t, st_data_t));
55
+ int st_lookup _((st_table *, st_data_t, st_data_t *));
56
+ int st_foreach _((st_table *, int (*)(ANYARGS), st_data_t));
57
+ void st_add_direct _((st_table *, st_data_t, st_data_t));
58
+ void st_free_table _((st_table *));
59
+ void st_cleanup_safe _((st_table *, st_data_t));
60
+ st_table *st_copy _((st_table *));
61
+
62
+ #define ST_NUMCMP ((int (*)()) 0)
63
+ #define ST_NUMHASH ((int (*)()) -2)
64
+
65
+ #define st_numcmp ST_NUMCMP
66
+ #define st_numhash ST_NUMHASH
67
+
68
+ #endif /* ST_INCLUDED */