koffi 0.9.0 → 0.9.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (439) hide show
  1. package/CMakeLists.txt +2 -36
  2. package/package.json +8 -4
  3. package/vendor/dragonbox/CMakeLists.txt +123 -0
  4. package/vendor/dragonbox/LICENSE-Apache2-LLVM +218 -0
  5. package/vendor/dragonbox/LICENSE-Boost +23 -0
  6. package/vendor/dragonbox/README.md +277 -0
  7. package/vendor/dragonbox/cmake/dragonboxConfig.cmake +1 -0
  8. package/vendor/dragonbox/include/dragonbox/dragonbox.h +2670 -0
  9. package/vendor/dragonbox/include/dragonbox/dragonbox_to_chars.h +108 -0
  10. package/vendor/dragonbox/other_files/Dragonbox.pdf +0 -0
  11. package/vendor/dragonbox/other_files/Dragonbox_old.pdf +0 -0
  12. package/vendor/dragonbox/other_files/milo_benchmark.png +0 -0
  13. package/vendor/dragonbox/other_files/unknown_win64_vc2019.html +540 -0
  14. package/vendor/dragonbox/other_files/unknown_win64_vc2019_randomdigit_time.png +0 -0
  15. package/vendor/dragonbox/source/dragonbox_to_chars.cpp +303 -0
  16. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/CMakeLists.txt +24 -0
  17. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.cpp +238 -0
  18. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.h +95 -0
  19. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/grisu_exact.h +2666 -0
  20. package/vendor/dragonbox/subproject/3rdparty/ryu/CMakeLists.txt +16 -0
  21. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/common.h +114 -0
  22. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s.c +509 -0
  23. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_full_table.h +367 -0
  24. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_intrinsics.h +357 -0
  25. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/digit_table.h +35 -0
  26. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s.c +345 -0
  27. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_full_table.h +55 -0
  28. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_intrinsics.h +128 -0
  29. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/ryu.h +46 -0
  30. package/vendor/dragonbox/subproject/3rdparty/schubfach/CMakeLists.txt +22 -0
  31. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.cc +699 -0
  32. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.h +31 -0
  33. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.cc +1354 -0
  34. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.h +31 -0
  35. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/example_shaded_plots.m +68 -0
  36. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/license.txt +25 -0
  37. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution.m +92 -0
  38. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution_prctile.m +121 -0
  39. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_histogram_shaded.m +99 -0
  40. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_shaded.m +93 -0
  41. package/vendor/dragonbox/subproject/benchmark/CMakeLists.txt +65 -0
  42. package/vendor/dragonbox/subproject/benchmark/include/benchmark.h +40 -0
  43. package/vendor/dragonbox/subproject/benchmark/matlab/plot_benchmarks.m +22 -0
  44. package/vendor/dragonbox/subproject/benchmark/matlab/plot_digit_benchmark.m +78 -0
  45. package/vendor/dragonbox/subproject/benchmark/matlab/plot_uniform_benchmark.m +95 -0
  46. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_clang.png +0 -0
  47. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_msvc.png +0 -0
  48. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_clang.png +0 -0
  49. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_msvc.png +0 -0
  50. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_clang.png +0 -0
  51. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_msvc.png +0 -0
  52. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_clang.png +0 -0
  53. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_msvc.png +0 -0
  54. package/vendor/dragonbox/subproject/benchmark/source/benchmark.cpp +238 -0
  55. package/vendor/dragonbox/subproject/benchmark/source/dragonbox.cpp +30 -0
  56. package/vendor/dragonbox/subproject/benchmark/source/grisu_exact.cpp +36 -0
  57. package/vendor/dragonbox/subproject/benchmark/source/ryu.cpp +27 -0
  58. package/vendor/dragonbox/subproject/benchmark/source/schubfach.cpp +31 -0
  59. package/vendor/dragonbox/subproject/common/CMakeLists.txt +42 -0
  60. package/vendor/dragonbox/subproject/common/include/best_rational_approx.h +97 -0
  61. package/vendor/dragonbox/subproject/common/include/big_uint.h +218 -0
  62. package/vendor/dragonbox/subproject/common/include/continued_fractions.h +174 -0
  63. package/vendor/dragonbox/subproject/common/include/good_rational_approx.h +267 -0
  64. package/vendor/dragonbox/subproject/common/include/random_float.h +182 -0
  65. package/vendor/dragonbox/subproject/common/include/rational_continued_fractions.h +57 -0
  66. package/vendor/dragonbox/subproject/common/source/big_uint.cpp +602 -0
  67. package/vendor/dragonbox/subproject/meta/CMakeLists.txt +41 -0
  68. package/vendor/dragonbox/subproject/meta/results/binary32_generated_cache.txt +82 -0
  69. package/vendor/dragonbox/subproject/meta/results/binary64_compressed_cache_error_table.txt +10 -0
  70. package/vendor/dragonbox/subproject/meta/results/binary64_generated_cache.txt +623 -0
  71. package/vendor/dragonbox/subproject/meta/source/generate_cache.cpp +126 -0
  72. package/vendor/dragonbox/subproject/meta/source/live_test.cpp +81 -0
  73. package/vendor/dragonbox/subproject/meta/source/perf_test.cpp +104 -0
  74. package/vendor/dragonbox/subproject/meta/source/sandbox.cpp +20 -0
  75. package/vendor/dragonbox/subproject/test/CMakeLists.txt +70 -0
  76. package/vendor/dragonbox/subproject/test/results/binary32.csv +255 -0
  77. package/vendor/dragonbox/subproject/test/results/binary64.csv +2047 -0
  78. package/vendor/dragonbox/subproject/test/results/plot_required_bits.m +18 -0
  79. package/vendor/dragonbox/subproject/test/source/test_all_shorter_interval_cases.cpp +88 -0
  80. package/vendor/dragonbox/subproject/test/source/uniform_random_test.cpp +95 -0
  81. package/vendor/dragonbox/subproject/test/source/verify_cache_precision.cpp +338 -0
  82. package/vendor/dragonbox/subproject/test/source/verify_compressed_cache.cpp +154 -0
  83. package/vendor/dragonbox/subproject/test/source/verify_fast_multiplication.cpp +168 -0
  84. package/vendor/dragonbox/subproject/test/source/verify_log_computation.cpp +251 -0
  85. package/vendor/dragonbox/subproject/test/source/verify_magic_division.cpp +113 -0
  86. package/vendor/libcc/libcc.cc +7651 -0
  87. package/vendor/libcc/libcc.hh +4312 -0
  88. package/vendor/node-addon-api/CHANGELOG.md +859 -0
  89. package/vendor/node-addon-api/CODE_OF_CONDUCT.md +4 -0
  90. package/vendor/node-addon-api/CONTRIBUTING.md +93 -0
  91. package/vendor/node-addon-api/LICENSE.md +13 -0
  92. package/vendor/node-addon-api/README.md +293 -0
  93. package/vendor/node-addon-api/appveyor.yml +37 -0
  94. package/vendor/node-addon-api/benchmark/README.md +47 -0
  95. package/vendor/node-addon-api/benchmark/binding.gyp +25 -0
  96. package/vendor/node-addon-api/benchmark/function_args.cc +217 -0
  97. package/vendor/node-addon-api/benchmark/function_args.js +60 -0
  98. package/vendor/node-addon-api/benchmark/index.js +34 -0
  99. package/vendor/node-addon-api/benchmark/property_descriptor.cc +91 -0
  100. package/vendor/node-addon-api/benchmark/property_descriptor.js +37 -0
  101. package/vendor/node-addon-api/common.gypi +21 -0
  102. package/vendor/node-addon-api/doc/addon.md +163 -0
  103. package/vendor/node-addon-api/doc/array.md +81 -0
  104. package/vendor/node-addon-api/doc/array_buffer.md +155 -0
  105. package/vendor/node-addon-api/doc/async_context.md +86 -0
  106. package/vendor/node-addon-api/doc/async_operations.md +31 -0
  107. package/vendor/node-addon-api/doc/async_worker.md +427 -0
  108. package/vendor/node-addon-api/doc/async_worker_variants.md +557 -0
  109. package/vendor/node-addon-api/doc/bigint.md +97 -0
  110. package/vendor/node-addon-api/doc/boolean.md +68 -0
  111. package/vendor/node-addon-api/doc/buffer.md +150 -0
  112. package/vendor/node-addon-api/doc/callback_scope.md +54 -0
  113. package/vendor/node-addon-api/doc/callbackinfo.md +97 -0
  114. package/vendor/node-addon-api/doc/checker-tool.md +32 -0
  115. package/vendor/node-addon-api/doc/class_property_descriptor.md +115 -0
  116. package/vendor/node-addon-api/doc/cmake-js.md +68 -0
  117. package/vendor/node-addon-api/doc/conversion-tool.md +28 -0
  118. package/vendor/node-addon-api/doc/creating_a_release.md +62 -0
  119. package/vendor/node-addon-api/doc/dataview.md +248 -0
  120. package/vendor/node-addon-api/doc/date.md +68 -0
  121. package/vendor/node-addon-api/doc/env.md +196 -0
  122. package/vendor/node-addon-api/doc/error.md +120 -0
  123. package/vendor/node-addon-api/doc/error_handling.md +254 -0
  124. package/vendor/node-addon-api/doc/escapable_handle_scope.md +80 -0
  125. package/vendor/node-addon-api/doc/external.md +63 -0
  126. package/vendor/node-addon-api/doc/function.md +402 -0
  127. package/vendor/node-addon-api/doc/function_reference.md +238 -0
  128. package/vendor/node-addon-api/doc/generator.md +13 -0
  129. package/vendor/node-addon-api/doc/handle_scope.md +63 -0
  130. package/vendor/node-addon-api/doc/hierarchy.md +91 -0
  131. package/vendor/node-addon-api/doc/instance_wrap.md +408 -0
  132. package/vendor/node-addon-api/doc/maybe.md +76 -0
  133. package/vendor/node-addon-api/doc/memory_management.md +27 -0
  134. package/vendor/node-addon-api/doc/name.md +29 -0
  135. package/vendor/node-addon-api/doc/node-gyp.md +82 -0
  136. package/vendor/node-addon-api/doc/number.md +163 -0
  137. package/vendor/node-addon-api/doc/object.md +432 -0
  138. package/vendor/node-addon-api/doc/object_lifetime_management.md +83 -0
  139. package/vendor/node-addon-api/doc/object_reference.md +117 -0
  140. package/vendor/node-addon-api/doc/object_wrap.md +561 -0
  141. package/vendor/node-addon-api/doc/prebuild_tools.md +16 -0
  142. package/vendor/node-addon-api/doc/promises.md +79 -0
  143. package/vendor/node-addon-api/doc/property_descriptor.md +286 -0
  144. package/vendor/node-addon-api/doc/propertylvalue.md +50 -0
  145. package/vendor/node-addon-api/doc/range_error.md +59 -0
  146. package/vendor/node-addon-api/doc/reference.md +113 -0
  147. package/vendor/node-addon-api/doc/setup.md +110 -0
  148. package/vendor/node-addon-api/doc/string.md +93 -0
  149. package/vendor/node-addon-api/doc/symbol.md +61 -0
  150. package/vendor/node-addon-api/doc/threadsafe.md +121 -0
  151. package/vendor/node-addon-api/doc/threadsafe_function.md +290 -0
  152. package/vendor/node-addon-api/doc/type_error.md +59 -0
  153. package/vendor/node-addon-api/doc/typed_array.md +78 -0
  154. package/vendor/node-addon-api/doc/typed_array_of.md +137 -0
  155. package/vendor/node-addon-api/doc/typed_threadsafe_function.md +306 -0
  156. package/vendor/node-addon-api/doc/value.md +340 -0
  157. package/vendor/node-addon-api/doc/version_management.md +43 -0
  158. package/vendor/node-addon-api/except.gypi +25 -0
  159. package/vendor/node-addon-api/index.js +11 -0
  160. package/vendor/node-addon-api/napi-inl.deprecated.h +192 -0
  161. package/vendor/node-addon-api/napi-inl.h +6209 -0
  162. package/vendor/node-addon-api/napi.h +2983 -0
  163. package/vendor/node-addon-api/node_api.gyp +9 -0
  164. package/vendor/node-addon-api/noexcept.gypi +26 -0
  165. package/vendor/node-addon-api/nothing.c +0 -0
  166. package/vendor/node-addon-api/package-support.json +21 -0
  167. package/vendor/node-addon-api/package.json +399 -0
  168. package/vendor/node-addon-api/test/README.md +91 -0
  169. package/vendor/node-addon-api/test/addon.cc +36 -0
  170. package/vendor/node-addon-api/test/addon.js +11 -0
  171. package/vendor/node-addon-api/test/addon_build/index.js +49 -0
  172. package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +17 -0
  173. package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +62 -0
  174. package/vendor/node-addon-api/test/addon_build/tpl/index.js +9 -0
  175. package/vendor/node-addon-api/test/addon_build/tpl/package.json +11 -0
  176. package/vendor/node-addon-api/test/addon_data.cc +99 -0
  177. package/vendor/node-addon-api/test/addon_data.js +46 -0
  178. package/vendor/node-addon-api/test/array_buffer.cc +243 -0
  179. package/vendor/node-addon-api/test/array_buffer.js +69 -0
  180. package/vendor/node-addon-api/test/async_context.cc +21 -0
  181. package/vendor/node-addon-api/test/async_context.js +86 -0
  182. package/vendor/node-addon-api/test/async_progress_queue_worker.cc +83 -0
  183. package/vendor/node-addon-api/test/async_progress_queue_worker.js +46 -0
  184. package/vendor/node-addon-api/test/async_progress_worker.cc +134 -0
  185. package/vendor/node-addon-api/test/async_progress_worker.js +61 -0
  186. package/vendor/node-addon-api/test/async_worker.cc +106 -0
  187. package/vendor/node-addon-api/test/async_worker.js +179 -0
  188. package/vendor/node-addon-api/test/async_worker_nocallback.js +13 -0
  189. package/vendor/node-addon-api/test/async_worker_persistent.cc +63 -0
  190. package/vendor/node-addon-api/test/async_worker_persistent.js +24 -0
  191. package/vendor/node-addon-api/test/basic_types/array.cc +40 -0
  192. package/vendor/node-addon-api/test/basic_types/array.js +35 -0
  193. package/vendor/node-addon-api/test/basic_types/boolean.cc +38 -0
  194. package/vendor/node-addon-api/test/basic_types/boolean.js +35 -0
  195. package/vendor/node-addon-api/test/basic_types/number.cc +99 -0
  196. package/vendor/node-addon-api/test/basic_types/number.js +114 -0
  197. package/vendor/node-addon-api/test/basic_types/value.cc +120 -0
  198. package/vendor/node-addon-api/test/basic_types/value.js +133 -0
  199. package/vendor/node-addon-api/test/bigint.cc +91 -0
  200. package/vendor/node-addon-api/test/bigint.js +53 -0
  201. package/vendor/node-addon-api/test/binding-swallowexcept.cc +12 -0
  202. package/vendor/node-addon-api/test/binding.cc +171 -0
  203. package/vendor/node-addon-api/test/binding.gyp +117 -0
  204. package/vendor/node-addon-api/test/buffer.cc +183 -0
  205. package/vendor/node-addon-api/test/buffer.js +69 -0
  206. package/vendor/node-addon-api/test/callbackscope.cc +22 -0
  207. package/vendor/node-addon-api/test/callbackscope.js +49 -0
  208. package/vendor/node-addon-api/test/common/index.js +113 -0
  209. package/vendor/node-addon-api/test/common/test_helper.h +61 -0
  210. package/vendor/node-addon-api/test/dataview/dataview.cc +48 -0
  211. package/vendor/node-addon-api/test/dataview/dataview.js +35 -0
  212. package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +115 -0
  213. package/vendor/node-addon-api/test/dataview/dataview_read_write.js +90 -0
  214. package/vendor/node-addon-api/test/date.cc +44 -0
  215. package/vendor/node-addon-api/test/date.js +18 -0
  216. package/vendor/node-addon-api/test/env_cleanup.cc +88 -0
  217. package/vendor/node-addon-api/test/env_cleanup.js +56 -0
  218. package/vendor/node-addon-api/test/error.cc +287 -0
  219. package/vendor/node-addon-api/test/error.js +81 -0
  220. package/vendor/node-addon-api/test/error_handling_for_primitives.cc +13 -0
  221. package/vendor/node-addon-api/test/error_handling_for_primitives.js +29 -0
  222. package/vendor/node-addon-api/test/error_terminating_environment.js +94 -0
  223. package/vendor/node-addon-api/test/external.cc +81 -0
  224. package/vendor/node-addon-api/test/external.js +88 -0
  225. package/vendor/node-addon-api/test/function.cc +295 -0
  226. package/vendor/node-addon-api/test/function.js +121 -0
  227. package/vendor/node-addon-api/test/function_reference.cc +202 -0
  228. package/vendor/node-addon-api/test/function_reference.js +157 -0
  229. package/vendor/node-addon-api/test/globalObject/global_object.cc +61 -0
  230. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +31 -0
  231. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +61 -0
  232. package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +40 -0
  233. package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +57 -0
  234. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +28 -0
  235. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +48 -0
  236. package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +31 -0
  237. package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +58 -0
  238. package/vendor/node-addon-api/test/handlescope.cc +60 -0
  239. package/vendor/node-addon-api/test/handlescope.js +14 -0
  240. package/vendor/node-addon-api/test/index.js +136 -0
  241. package/vendor/node-addon-api/test/maybe/check.cc +23 -0
  242. package/vendor/node-addon-api/test/maybe/index.js +38 -0
  243. package/vendor/node-addon-api/test/memory_management.cc +17 -0
  244. package/vendor/node-addon-api/test/memory_management.js +9 -0
  245. package/vendor/node-addon-api/test/movable_callbacks.cc +23 -0
  246. package/vendor/node-addon-api/test/movable_callbacks.js +21 -0
  247. package/vendor/node-addon-api/test/name.cc +108 -0
  248. package/vendor/node-addon-api/test/name.js +59 -0
  249. package/vendor/node-addon-api/test/napi_child.js +14 -0
  250. package/vendor/node-addon-api/test/object/delete_property.cc +38 -0
  251. package/vendor/node-addon-api/test/object/delete_property.js +41 -0
  252. package/vendor/node-addon-api/test/object/finalizer.cc +29 -0
  253. package/vendor/node-addon-api/test/object/finalizer.js +28 -0
  254. package/vendor/node-addon-api/test/object/get_property.cc +34 -0
  255. package/vendor/node-addon-api/test/object/get_property.js +40 -0
  256. package/vendor/node-addon-api/test/object/has_own_property.cc +34 -0
  257. package/vendor/node-addon-api/test/object/has_own_property.js +34 -0
  258. package/vendor/node-addon-api/test/object/has_property.cc +38 -0
  259. package/vendor/node-addon-api/test/object/has_property.js +37 -0
  260. package/vendor/node-addon-api/test/object/object.cc +348 -0
  261. package/vendor/node-addon-api/test/object/object.js +217 -0
  262. package/vendor/node-addon-api/test/object/object_deprecated.cc +66 -0
  263. package/vendor/node-addon-api/test/object/object_deprecated.js +47 -0
  264. package/vendor/node-addon-api/test/object/object_freeze_seal.cc +25 -0
  265. package/vendor/node-addon-api/test/object/object_freeze_seal.js +61 -0
  266. package/vendor/node-addon-api/test/object/set_property.cc +37 -0
  267. package/vendor/node-addon-api/test/object/set_property.js +29 -0
  268. package/vendor/node-addon-api/test/object/subscript_operator.cc +42 -0
  269. package/vendor/node-addon-api/test/object/subscript_operator.js +17 -0
  270. package/vendor/node-addon-api/test/object_reference.cc +219 -0
  271. package/vendor/node-addon-api/test/object_reference.js +259 -0
  272. package/vendor/node-addon-api/test/objectwrap.cc +268 -0
  273. package/vendor/node-addon-api/test/objectwrap.js +284 -0
  274. package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +26 -0
  275. package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +18 -0
  276. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +30 -0
  277. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +13 -0
  278. package/vendor/node-addon-api/test/objectwrap_removewrap.cc +45 -0
  279. package/vendor/node-addon-api/test/objectwrap_removewrap.js +40 -0
  280. package/vendor/node-addon-api/test/objectwrap_worker_thread.js +19 -0
  281. package/vendor/node-addon-api/test/promise.cc +29 -0
  282. package/vendor/node-addon-api/test/promise.js +18 -0
  283. package/vendor/node-addon-api/test/reference.cc +24 -0
  284. package/vendor/node-addon-api/test/reference.js +14 -0
  285. package/vendor/node-addon-api/test/run_script.cc +56 -0
  286. package/vendor/node-addon-api/test/run_script.js +45 -0
  287. package/vendor/node-addon-api/test/symbol.cc +79 -0
  288. package/vendor/node-addon-api/test/symbol.js +73 -0
  289. package/vendor/node-addon-api/test/testUtil.js +54 -0
  290. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +195 -0
  291. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +188 -0
  292. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +63 -0
  293. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +12 -0
  294. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +115 -0
  295. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +14 -0
  296. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +26 -0
  297. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +7 -0
  298. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +225 -0
  299. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +59 -0
  300. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +42 -0
  301. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +53 -0
  302. package/vendor/node-addon-api/test/thunking_manual.cc +140 -0
  303. package/vendor/node-addon-api/test/thunking_manual.js +17 -0
  304. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +215 -0
  305. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +188 -0
  306. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +68 -0
  307. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +12 -0
  308. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +127 -0
  309. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +14 -0
  310. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +28 -0
  311. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +7 -0
  312. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +237 -0
  313. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +59 -0
  314. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +53 -0
  315. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +53 -0
  316. package/vendor/node-addon-api/test/typedarray-bigint.js +58 -0
  317. package/vendor/node-addon-api/test/typedarray.cc +216 -0
  318. package/vendor/node-addon-api/test/typedarray.js +69 -0
  319. package/vendor/node-addon-api/test/version_management.cc +27 -0
  320. package/vendor/node-addon-api/test/version_management.js +31 -0
  321. package/vendor/node-addon-api/tools/README.md +73 -0
  322. package/vendor/node-addon-api/tools/check-napi.js +100 -0
  323. package/vendor/node-addon-api/tools/clang-format.js +68 -0
  324. package/vendor/node-addon-api/tools/conversion.js +309 -0
  325. package/vendor/node-addon-api/tools/eslint-format.js +71 -0
  326. package/build/ALL_BUILD.vcxproj +0 -190
  327. package/build/ALL_BUILD.vcxproj.filters +0 -8
  328. package/build/CMakeCache.txt +0 -429
  329. package/build/CMakeFiles/3.23.0-rc1/CMakeASMCompiler.cmake +0 -20
  330. package/build/CMakeFiles/3.23.0-rc1/CMakeASM_MASMCompiler.cmake +0 -20
  331. package/build/CMakeFiles/3.23.0-rc1/CMakeCCompiler.cmake +0 -72
  332. package/build/CMakeFiles/3.23.0-rc1/CMakeCXXCompiler.cmake +0 -83
  333. package/build/CMakeFiles/3.23.0-rc1/CMakeDetermineCompilerABI_C.bin +0 -0
  334. package/build/CMakeFiles/3.23.0-rc1/CMakeDetermineCompilerABI_CXX.bin +0 -0
  335. package/build/CMakeFiles/3.23.0-rc1/CMakeRCCompiler.cmake +0 -6
  336. package/build/CMakeFiles/3.23.0-rc1/CMakeSystem.cmake +0 -15
  337. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/CMakeCCompilerId.c +0 -828
  338. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/CompilerIdC.exe +0 -0
  339. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/CompilerIdC.vcxproj +0 -71
  340. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CMakeCCompilerId.obj +0 -0
  341. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.exe.recipe +0 -11
  342. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/CL.command.1.tlog +0 -0
  343. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/CL.read.1.tlog +0 -0
  344. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/CL.write.1.tlog +0 -0
  345. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/CompilerIdC.lastbuildstate +0 -2
  346. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/link.command.1.tlog +0 -0
  347. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/link.read.1.tlog +0 -0
  348. package/build/CMakeFiles/3.23.0-rc1/CompilerIdC/Debug/CompilerIdC.tlog/link.write.1.tlog +0 -0
  349. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/CMakeCXXCompilerId.cpp +0 -816
  350. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/CompilerIdCXX.exe +0 -0
  351. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/CompilerIdCXX.vcxproj +0 -71
  352. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CMakeCXXCompilerId.obj +0 -0
  353. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.exe.recipe +0 -11
  354. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/CL.command.1.tlog +0 -0
  355. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/CL.read.1.tlog +0 -0
  356. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/CL.write.1.tlog +0 -0
  357. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/CompilerIdCXX.lastbuildstate +0 -2
  358. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/link.command.1.tlog +0 -0
  359. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/link.read.1.tlog +0 -0
  360. package/build/CMakeFiles/3.23.0-rc1/CompilerIdCXX/Debug/CompilerIdCXX.tlog/link.write.1.tlog +0 -0
  361. package/build/CMakeFiles/3.23.0-rc1/VCTargetsPath.txt +0 -1
  362. package/build/CMakeFiles/3.23.0-rc1/VCTargetsPath.vcxproj +0 -31
  363. package/build/CMakeFiles/3.23.0-rc1/x64/Debug/VCTargetsPath.recipe +0 -11
  364. package/build/CMakeFiles/3.23.0-rc1/x64/Debug/VCTargetsPath.tlog/VCTargetsPath.lastbuildstate +0 -2
  365. package/build/CMakeFiles/41bcd16856091d4a38fd1f71fbe2f202/generate.stamp.rule +0 -1
  366. package/build/CMakeFiles/CMakeError.log +0 -108
  367. package/build/CMakeFiles/CMakeOutput.log +0 -413
  368. package/build/CMakeFiles/TargetDirectories.txt +0 -4
  369. package/build/CMakeFiles/cmake.check_cache +0 -1
  370. package/build/CMakeFiles/generate.stamp +0 -1
  371. package/build/CMakeFiles/generate.stamp.depend +0 -28
  372. package/build/CMakeFiles/generate.stamp.list +0 -1
  373. package/build/Raylib.dir/Release/Raylib.dll.recipe +0 -14
  374. package/build/Raylib.dir/Release/Raylib.tlog/CL.command.1.tlog +0 -0
  375. package/build/Raylib.dir/Release/Raylib.tlog/CL.read.1.tlog +0 -0
  376. package/build/Raylib.dir/Release/Raylib.tlog/CL.write.1.tlog +0 -0
  377. package/build/Raylib.dir/Release/Raylib.tlog/CustomBuild.command.1.tlog +0 -10
  378. package/build/Raylib.dir/Release/Raylib.tlog/CustomBuild.read.1.tlog +0 -27
  379. package/build/Raylib.dir/Release/Raylib.tlog/CustomBuild.write.1.tlog +0 -2
  380. package/build/Raylib.dir/Release/Raylib.tlog/Raylib.lastbuildstate +0 -2
  381. package/build/Raylib.dir/Release/Raylib.tlog/Raylib.write.1u.tlog +0 -0
  382. package/build/Raylib.dir/Release/Raylib.tlog/link.command.1.tlog +0 -0
  383. package/build/Raylib.dir/Release/Raylib.tlog/link.read.1.tlog +0 -0
  384. package/build/Raylib.dir/Release/Raylib.tlog/link.write.1.tlog +0 -0
  385. package/build/Raylib.dir/Release/raudio.obj +0 -0
  386. package/build/Raylib.dir/Release/rcore.obj +0 -0
  387. package/build/Raylib.dir/Release/rglfw.obj +0 -0
  388. package/build/Raylib.dir/Release/rmodels.obj +0 -0
  389. package/build/Raylib.dir/Release/rshapes.obj +0 -0
  390. package/build/Raylib.dir/Release/rtext.obj +0 -0
  391. package/build/Raylib.dir/Release/rtextures.obj +0 -0
  392. package/build/Raylib.dir/Release/utils.obj +0 -0
  393. package/build/Raylib.vcxproj +0 -358
  394. package/build/Raylib.vcxproj.filters +0 -37
  395. package/build/Release/Raylib.dll +0 -0
  396. package/build/Release/Raylib.exp +0 -0
  397. package/build/Release/Raylib.lib +0 -0
  398. package/build/Release/koffi.exp +0 -0
  399. package/build/Release/koffi.lib +0 -0
  400. package/build/Release/koffi.node +0 -0
  401. package/build/ZERO_CHECK.vcxproj +0 -176
  402. package/build/ZERO_CHECK.vcxproj.filters +0 -13
  403. package/build/cmake_install.cmake +0 -44
  404. package/build/koffi.dir/Release/call_arm64.obj +0 -0
  405. package/build/koffi.dir/Release/call_x64_sysv.obj +0 -0
  406. package/build/koffi.dir/Release/call_x64_win.obj +0 -0
  407. package/build/koffi.dir/Release/call_x64_win_fwd.obj +0 -0
  408. package/build/koffi.dir/Release/call_x86.obj +0 -0
  409. package/build/koffi.dir/Release/ffi.obj +0 -0
  410. package/build/koffi.dir/Release/koffi.node.recipe +0 -14
  411. package/build/koffi.dir/Release/koffi.tlog/CL.command.1.tlog +0 -0
  412. package/build/koffi.dir/Release/koffi.tlog/CL.read.1.tlog +0 -0
  413. package/build/koffi.dir/Release/koffi.tlog/CL.write.1.tlog +0 -0
  414. package/build/koffi.dir/Release/koffi.tlog/CustomBuild.command.1.tlog +0 -10
  415. package/build/koffi.dir/Release/koffi.tlog/CustomBuild.read.1.tlog +0 -27
  416. package/build/koffi.dir/Release/koffi.tlog/CustomBuild.write.1.tlog +0 -2
  417. package/build/koffi.dir/Release/koffi.tlog/Masm.read.1u.tlog +0 -0
  418. package/build/koffi.dir/Release/koffi.tlog/Masm.write.1u.tlog +0 -0
  419. package/build/koffi.dir/Release/koffi.tlog/koffi.lastbuildstate +0 -2
  420. package/build/koffi.dir/Release/koffi.tlog/koffi.write.1u.tlog +0 -0
  421. package/build/koffi.dir/Release/koffi.tlog/link.command.1.tlog +0 -0
  422. package/build/koffi.dir/Release/koffi.tlog/link.read.1.tlog +0 -0
  423. package/build/koffi.dir/Release/koffi.tlog/link.write.1.tlog +0 -0
  424. package/build/koffi.dir/Release/libcc.obj +0 -0
  425. package/build/koffi.dir/Release/util.obj +0 -0
  426. package/build/koffi.dir/Release/win_delay_load_hook.obj +0 -0
  427. package/build/koffi.sln +0 -67
  428. package/build/koffi.vcxproj +0 -363
  429. package/build/koffi.vcxproj.filters +0 -40
  430. package/build/x64/Release/ALL_BUILD/ALL_BUILD.recipe +0 -20
  431. package/build/x64/Release/ALL_BUILD/ALL_BUILD.tlog/ALL_BUILD.lastbuildstate +0 -2
  432. package/build/x64/Release/ALL_BUILD/ALL_BUILD.tlog/CustomBuild.command.1.tlog +0 -10
  433. package/build/x64/Release/ALL_BUILD/ALL_BUILD.tlog/CustomBuild.read.1.tlog +0 -27
  434. package/build/x64/Release/ALL_BUILD/ALL_BUILD.tlog/CustomBuild.write.1.tlog +0 -2
  435. package/build/x64/Release/ZERO_CHECK/ZERO_CHECK.recipe +0 -11
  436. package/build/x64/Release/ZERO_CHECK/ZERO_CHECK.tlog/CustomBuild.command.1.tlog +0 -10
  437. package/build/x64/Release/ZERO_CHECK/ZERO_CHECK.tlog/CustomBuild.read.1.tlog +0 -28
  438. package/build/x64/Release/ZERO_CHECK/ZERO_CHECK.tlog/CustomBuild.write.1.tlog +0 -2
  439. package/build/x64/Release/ZERO_CHECK/ZERO_CHECK.tlog/ZERO_CHECK.lastbuildstate +0 -2
@@ -0,0 +1,9 @@
1
+ {
2
+ 'targets': [
3
+ {
4
+ 'target_name': 'nothing',
5
+ 'type': 'static_library',
6
+ 'sources': [ 'nothing.c' ]
7
+ }
8
+ ]
9
+ }
@@ -0,0 +1,26 @@
1
+ {
2
+ 'defines': [ 'NAPI_DISABLE_CPP_EXCEPTIONS' ],
3
+ 'cflags': [ '-fno-exceptions' ],
4
+ 'cflags_cc': [ '-fno-exceptions' ],
5
+ 'conditions': [
6
+ ["OS=='win'", {
7
+ # _HAS_EXCEPTIONS is already defined and set to 0 in common.gypi
8
+ #"defines": [
9
+ # "_HAS_EXCEPTIONS=0"
10
+ #],
11
+ "msvs_settings": {
12
+ "VCCLCompilerTool": {
13
+ 'ExceptionHandling': 0,
14
+ 'EnablePREfast': 'true',
15
+ },
16
+ },
17
+ }],
18
+ ["OS=='mac'", {
19
+ 'xcode_settings': {
20
+ 'CLANG_CXX_LIBRARY': 'libc++',
21
+ 'MACOSX_DEPLOYMENT_TARGET': '10.7',
22
+ 'GCC_ENABLE_CPP_EXCEPTIONS': 'NO',
23
+ },
24
+ }],
25
+ ],
26
+ }
File without changes
@@ -0,0 +1,21 @@
1
+ {
2
+ "versions": [
3
+ {
4
+ "version": "*",
5
+ "target": {
6
+ "node": "active"
7
+ },
8
+ "response": {
9
+ "type": "time-permitting",
10
+ "paid": false,
11
+ "contact": {
12
+ "name": "node-addon-api team",
13
+ "url": "https://github.com/nodejs/node-addon-api/issues"
14
+ }
15
+ },
16
+ "backing": [ { "project": "https://github.com/nodejs" },
17
+ { "foundation": "https://openjsf.org/" }
18
+ ]
19
+ }
20
+ ]
21
+ }
@@ -0,0 +1,399 @@
1
+ {
2
+ "bugs": {
3
+ "url": "https://github.com/nodejs/node-addon-api/issues"
4
+ },
5
+ "contributors": [
6
+ {
7
+ "name": "Abhishek Kumar Singh",
8
+ "url": "https://github.com/abhi11210646"
9
+ },
10
+ {
11
+ "name": "Alba Mendez",
12
+ "url": "https://github.com/jmendeth"
13
+ },
14
+ {
15
+ "name": "Alexander Floh",
16
+ "url": "https://github.com/alexanderfloh"
17
+ },
18
+ {
19
+ "name": "András Timár, Dr",
20
+ "url": "https://github.com/timarandras"
21
+ },
22
+ {
23
+ "name": "Andrew Petersen",
24
+ "url": "https://github.com/kirbysayshi"
25
+ },
26
+ {
27
+ "name": "Anisha Rohra",
28
+ "url": "https://github.com/anisha-rohra"
29
+ },
30
+ {
31
+ "name": "Anna Henningsen",
32
+ "url": "https://github.com/addaleax"
33
+ },
34
+ {
35
+ "name": "Arnaud Botella",
36
+ "url": "https://github.com/BotellaA"
37
+ },
38
+ {
39
+ "name": "Arunesh Chandra",
40
+ "url": "https://github.com/aruneshchandra"
41
+ },
42
+ {
43
+ "name": "Azlan Mukhtar",
44
+ "url": "https://github.com/azlan"
45
+ },
46
+ {
47
+ "name": "Ben Berman",
48
+ "url": "https://github.com/rivertam"
49
+ },
50
+ {
51
+ "name": "Benjamin Byholm",
52
+ "url": "https://github.com/kkoopa"
53
+ },
54
+ {
55
+ "name": "Bill Gallafent",
56
+ "url": "https://github.com/gallafent"
57
+ },
58
+ {
59
+ "name": "blagoev",
60
+ "url": "https://github.com/blagoev"
61
+ },
62
+ {
63
+ "name": "Bruce A. MacNaughton",
64
+ "url": "https://github.com/bmacnaughton"
65
+ },
66
+ {
67
+ "name": "Cory Mickelson",
68
+ "url": "https://github.com/corymickelson"
69
+ },
70
+ {
71
+ "name": "Daniel Bevenius",
72
+ "url": "https://github.com/danbev"
73
+ },
74
+ {
75
+ "name": "Darshan Sen",
76
+ "url": "https://github.com/RaisinTen"
77
+ },
78
+ {
79
+ "name": "David Halls",
80
+ "url": "https://github.com/davedoesdev"
81
+ },
82
+ {
83
+ "name": "Deepak Rajamohan",
84
+ "url": "https://github.com/deepakrkris"
85
+ },
86
+ {
87
+ "name": "Dmitry Ashkadov",
88
+ "url": "https://github.com/dmitryash"
89
+ },
90
+ {
91
+ "name": "Dongjin Na",
92
+ "url": "https://github.com/nadongguri"
93
+ },
94
+ {
95
+ "name": "Doni Rubiagatra",
96
+ "url": "https://github.com/rubiagatra"
97
+ },
98
+ {
99
+ "name": "Ferdinand Holzer",
100
+ "url": "https://github.com/fholzer"
101
+ },
102
+ {
103
+ "name": "Eric Bickle",
104
+ "url": "https://github.com/ebickle"
105
+ },
106
+ {
107
+ "name": "Gabriel Schulhof",
108
+ "url": "https://github.com/gabrielschulhof"
109
+ },
110
+ {
111
+ "name": "Guenter Sandner",
112
+ "url": "https://github.com/gms1"
113
+ },
114
+ {
115
+ "name": "Gus Caplan",
116
+ "url": "https://github.com/devsnek"
117
+ },
118
+ {
119
+ "name": "Helio Frota",
120
+ "url": "https://github.com/helio-frota"
121
+ },
122
+ {
123
+ "name": "Hitesh Kanwathirtha",
124
+ "url": "https://github.com/digitalinfinity"
125
+ },
126
+ {
127
+ "name": "ikokostya",
128
+ "url": "https://github.com/ikokostya"
129
+ },
130
+ {
131
+ "name": "Jack Xia",
132
+ "url": "https://github.com/JckXia"
133
+ },
134
+ {
135
+ "name": "Jake Barnes",
136
+ "url": "https://github.com/DuBistKomisch"
137
+ },
138
+ {
139
+ "name": "Jake Yoon",
140
+ "url": "https://github.com/yjaeseok"
141
+ },
142
+ {
143
+ "name": "Jason Ginchereau",
144
+ "url": "https://github.com/jasongin"
145
+ },
146
+ {
147
+ "name": "Jeroen Janssen",
148
+ "url": "https://github.com/japj"
149
+ },
150
+ {
151
+ "name": "Jim Schlight",
152
+ "url": "https://github.com/jschlight"
153
+ },
154
+ {
155
+ "name": "Jinho Bang",
156
+ "url": "https://github.com/romandev"
157
+ },
158
+ {
159
+ "name": "José Expósito",
160
+ "url": "https://github.com/JoseExposito"
161
+ },
162
+ {
163
+ "name": "joshgarde",
164
+ "url": "https://github.com/joshgarde"
165
+ },
166
+ {
167
+ "name": "Kasumi Hanazuki",
168
+ "url": "https://github.com/hanazuki"
169
+ },
170
+ {
171
+ "name": "Kelvin",
172
+ "url": "https://github.com/kelvinhammond"
173
+ },
174
+ {
175
+ "name": "Kevin Eady",
176
+ "url": "https://github.com/KevinEady"
177
+ },
178
+ {
179
+ "name": "Kévin VOYER",
180
+ "url": "https://github.com/kecsou"
181
+ },
182
+ {
183
+ "name": "kidneysolo",
184
+ "url": "https://github.com/kidneysolo"
185
+ },
186
+ {
187
+ "name": "Koki Nishihara",
188
+ "url": "https://github.com/Nishikoh"
189
+ },
190
+ {
191
+ "name": "Konstantin Tarkus",
192
+ "url": "https://github.com/koistya"
193
+ },
194
+ {
195
+ "name": "Kyle Farnung",
196
+ "url": "https://github.com/kfarnung"
197
+ },
198
+ {
199
+ "name": "legendecas",
200
+ "url": "https://github.com/legendecas"
201
+ },
202
+ {
203
+ "name": "LongYinan",
204
+ "url": "https://github.com/Brooooooklyn"
205
+ },
206
+ {
207
+ "name": "Lovell Fuller",
208
+ "url": "https://github.com/lovell"
209
+ },
210
+ {
211
+ "name": "Luciano Martorella",
212
+ "url": "https://github.com/lmartorella"
213
+ },
214
+ {
215
+ "name": "mastergberry",
216
+ "url": "https://github.com/mastergberry"
217
+ },
218
+ {
219
+ "name": "Mathias Küsel",
220
+ "url": "https://github.com/mathiask88"
221
+ },
222
+ {
223
+ "name": "Matteo Collina",
224
+ "url": "https://github.com/mcollina"
225
+ },
226
+ {
227
+ "name": "Michael Dawson",
228
+ "url": "https://github.com/mhdawson"
229
+ },
230
+ {
231
+ "name": "Michael Price",
232
+ "url": "https://github.com/mikepricedev"
233
+ },
234
+ {
235
+ "name": "Michele Campus",
236
+ "url": "https://github.com/kYroL01"
237
+ },
238
+ {
239
+ "name": "Mikhail Cheshkov",
240
+ "url": "https://github.com/mcheshkov"
241
+ },
242
+ {
243
+ "name": "nempoBu4",
244
+ "url": "https://github.com/nempoBu4"
245
+ },
246
+ {
247
+ "name": "Nicola Del Gobbo",
248
+ "url": "https://github.com/NickNaso"
249
+ },
250
+ {
251
+ "name": "Nick Soggin",
252
+ "url": "https://github.com/iSkore"
253
+ },
254
+ {
255
+ "name": "Nikolai Vavilov",
256
+ "url": "https://github.com/seishun"
257
+ },
258
+ {
259
+ "name": "Nurbol Alpysbayev",
260
+ "url": "https://github.com/anurbol"
261
+ },
262
+ {
263
+ "name": "pacop",
264
+ "url": "https://github.com/pacop"
265
+ },
266
+ {
267
+ "name": "Philipp Renoth",
268
+ "url": "https://github.com/DaAitch"
269
+ },
270
+ {
271
+ "name": "Rolf Timmermans",
272
+ "url": "https://github.com/rolftimmermans"
273
+ },
274
+ {
275
+ "name": "Ross Weir",
276
+ "url": "https://github.com/ross-weir"
277
+ },
278
+ {
279
+ "name": "Ryuichi Okumura",
280
+ "url": "https://github.com/okuryu"
281
+ },
282
+ {
283
+ "name": "Sampson Gao",
284
+ "url": "https://github.com/sampsongao"
285
+ },
286
+ {
287
+ "name": "Sam Roberts",
288
+ "url": "https://github.com/sam-github"
289
+ },
290
+ {
291
+ "name": "strager",
292
+ "url": "https://github.com/strager"
293
+ },
294
+ {
295
+ "name": "Taylor Woll",
296
+ "url": "https://github.com/boingoing"
297
+ },
298
+ {
299
+ "name": "Thomas Gentilhomme",
300
+ "url": "https://github.com/fraxken"
301
+ },
302
+ {
303
+ "name": "Tim Rach",
304
+ "url": "https://github.com/timrach"
305
+ },
306
+ {
307
+ "name": "Tobias Nießen",
308
+ "url": "https://github.com/tniessen"
309
+ },
310
+ {
311
+ "name": "todoroff",
312
+ "url": "https://github.com/todoroff"
313
+ },
314
+ {
315
+ "name": "Tux3",
316
+ "url": "https://github.com/tux3"
317
+ },
318
+ {
319
+ "name": "Vlad Velmisov",
320
+ "url": "https://github.com/Velmisov"
321
+ },
322
+ {
323
+ "name": "WenheLI",
324
+ "url": "https://github.com/WenheLI"
325
+ },
326
+
327
+ {
328
+ "name": "Yohei Kishimoto",
329
+ "url": "https://github.com/morokosi"
330
+ },
331
+ {
332
+ "name": "Yulong Wang",
333
+ "url": "https://github.com/fs-eire"
334
+ },
335
+ {
336
+ "name": "Ziqiu Zhao",
337
+ "url": "https://github.com/ZzqiZQute"
338
+ }
339
+ ],
340
+ "description": "Node.js API (Node-API)",
341
+ "devDependencies": {
342
+ "benchmark": "^2.1.4",
343
+ "bindings": "^1.5.0",
344
+ "clang-format": "^1.4.0",
345
+ "eslint": "^7.32.0",
346
+ "eslint-config-semistandard": "^16.0.0",
347
+ "eslint-config-standard": "^16.0.3",
348
+ "eslint-plugin-import": "^2.24.2",
349
+ "eslint-plugin-node": "^11.1.0",
350
+ "eslint-plugin-promise": "^5.1.0",
351
+ "fs-extra": "^9.0.1",
352
+ "path": "^0.12.7",
353
+ "pre-commit": "^1.2.2",
354
+ "safe-buffer": "^5.1.1"
355
+ },
356
+ "directories": {},
357
+ "gypfile": false,
358
+ "homepage": "https://github.com/nodejs/node-addon-api",
359
+ "keywords": [
360
+ "n-api",
361
+ "napi",
362
+ "addon",
363
+ "native",
364
+ "bindings",
365
+ "c",
366
+ "c++",
367
+ "nan",
368
+ "node-addon-api"
369
+ ],
370
+ "license": "MIT",
371
+ "main": "index.js",
372
+ "name": "node-addon-api",
373
+ "readme": "README.md",
374
+ "repository": {
375
+ "type": "git",
376
+ "url": "git://github.com/nodejs/node-addon-api.git"
377
+ },
378
+ "files": [
379
+ "*.{c,h,gyp,gypi}",
380
+ "package-support.json",
381
+ "tools/"
382
+ ],
383
+ "scripts": {
384
+ "prebenchmark": "node-gyp rebuild -C benchmark",
385
+ "benchmark": "node benchmark",
386
+ "pretest": "node-gyp rebuild -C test",
387
+ "test": "node test",
388
+ "predev": "node-gyp rebuild -C test --debug",
389
+ "dev": "node test",
390
+ "predev:incremental": "node-gyp configure build -C test --debug",
391
+ "dev:incremental": "node test",
392
+ "doc": "doxygen doc/Doxyfile",
393
+ "lint": "node tools/eslint-format && node tools/clang-format",
394
+ "lint:fix": "node tools/clang-format --fix && node tools/eslint-format --fix"
395
+ },
396
+ "pre-commit": "lint",
397
+ "version": "4.3.0",
398
+ "support": true
399
+ }
@@ -0,0 +1,91 @@
1
+ # Writing Tests
2
+
3
+ There are multiple flavors of node-addon-api test builds that cover different
4
+ build flags defined in `napi.h`:
5
+
6
+ 1. c++ exceptions enabled,
7
+ 2. c++ exceptions disabled,
8
+ 3. c++ exceptions disabled, and `NODE_ADDON_API_ENABLE_MAYBE` defined.
9
+
10
+ Functions in node-addon-api that call into JavaScript can have different
11
+ declared return types to reflect build flavor settings. For example,
12
+ `Napi::Object::Set` returns `bool` when `NODE_ADDON_API_ENABLE_MAYBE`
13
+ is not defined, and `Napi::Maybe<bool>` when `NODE_ADDON_API_ENABLE_MAYBE`
14
+ is defined. In source code, return type variants are defined as
15
+ `Napi::MaybeOrValue<>` to prevent the duplication of most of the code base.
16
+
17
+ To properly test these build flavors, all values returned by a function defined
18
+ to return `Napi::MaybeOrValue<>` should be tested by using one of the following
19
+ test helpers to handle possible JavaScript exceptions.
20
+
21
+ There are three test helper functions to conveniently convert
22
+ `Napi::MaybeOrValue<>` values to raw values.
23
+
24
+ ## MaybeUnwrap
25
+
26
+ ```cpp
27
+ template <typename T>
28
+ T MaybeUnwrap(MaybeOrValue<T> maybe);
29
+ ```
30
+
31
+ Converts `MaybeOrValue<T>` to `T` by checking that `MaybeOrValue` is NOT an
32
+ empty `Maybe`.
33
+
34
+ Returns the original value if `NODE_ADDON_API_ENABLE_MAYBE` is not defined.
35
+
36
+ Example:
37
+
38
+ ```cpp
39
+ Object obj = info[0].As<Object>();
40
+ // we are sure the parameters should not throw
41
+ Value value = MaybeUnwrap(obj->Get("foobar"));
42
+ ```
43
+
44
+ ## MaybeUnwrapOr
45
+
46
+ ```cpp
47
+ template <typename T>
48
+ T MaybeUnwrapOr(MaybeOrValue<T> maybe, const T& default_value = T());
49
+ ```
50
+
51
+ Converts `MaybeOrValue<T>` to `T` by getting the value that wrapped by the
52
+ `Maybe` or return the `default_value` if the `Maybe` is empty.
53
+
54
+ Returns the original value if `NODE_ADDON_API_ENABLE_MAYBE` is not defined.
55
+
56
+ Example:
57
+
58
+ ```cpp
59
+ Value CallWithArgs(const CallbackInfo& info) {
60
+ Function func = info[0].As<Function>();
61
+ // We don't care if the operation is throwing or not, just return it back to node-addon-api
62
+ return MaybeUnwrapOr(
63
+ func.Call(std::initializer_list<napi_value>{info[1], info[2], info[3]}));
64
+ }
65
+ ```
66
+
67
+ ## MaybeUnwrapTo
68
+
69
+ ```cpp
70
+ template <typename T>
71
+ bool MaybeUnwrapTo(MaybeOrValue<T> maybe, T* out);
72
+ ```
73
+
74
+ Converts `MaybeOrValue<T>` to `T` by getting the value that wrapped by the
75
+ e`Maybe` or return `false` if the Maybe is empty
76
+
77
+ Copies the `value` to `out` when `NODE_ADDON_API_ENABLE_MAYBE` is not defined
78
+
79
+ Example:
80
+
81
+ ```cpp
82
+ Object opts = info[0].As<Object>();
83
+ bool hasProperty = false;
84
+ // The check may throw, but we are going to suppress that.
85
+ if (MaybeUnwrapTo(opts.Has("blocking"), &hasProperty)) {
86
+ isBlocking = hasProperty &&
87
+ MaybeUnwrap(MaybeUnwrap(opts.Get("blocking")).ToBoolean());
88
+ } else {
89
+ env.GetAndClearPendingException();
90
+ }
91
+ ```
@@ -0,0 +1,36 @@
1
+ #if (NAPI_VERSION > 5)
2
+ #include <stdio.h>
3
+ #include "napi.h"
4
+
5
+ namespace {
6
+
7
+ class TestAddon : public Napi::Addon<TestAddon> {
8
+ public:
9
+ inline TestAddon(Napi::Env env, Napi::Object exports) {
10
+ DefineAddon(exports, {
11
+ InstanceMethod("increment", &TestAddon::Increment),
12
+ InstanceValue("subObject", DefineProperties(Napi::Object::New(env), {
13
+ InstanceMethod("decrement", &TestAddon::Decrement)
14
+ }))
15
+ });
16
+ }
17
+
18
+ private:
19
+ Napi::Value Increment(const Napi::CallbackInfo& info) {
20
+ return Napi::Number::New(info.Env(), ++value);
21
+ }
22
+
23
+ Napi::Value Decrement(const Napi::CallbackInfo& info) {
24
+ return Napi::Number::New(info.Env(), --value);
25
+ }
26
+
27
+ uint32_t value = 42;
28
+ };
29
+
30
+ } // end of anonymous namespace
31
+
32
+ Napi::Object InitAddon(Napi::Env env) {
33
+ return TestAddon::Init(env, Napi::Object::New(env));
34
+ }
35
+
36
+ #endif // (NAPI_VERSION > 5)
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const assert = require('assert');
4
+
5
+ module.exports = require('./common').runTest(test);
6
+
7
+ function test (binding) {
8
+ assert.strictEqual(binding.addon.increment(), 43);
9
+ assert.strictEqual(binding.addon.increment(), 44);
10
+ assert.strictEqual(binding.addon.subObject.decrement(), 43);
11
+ }
@@ -0,0 +1,49 @@
1
+ 'use strict';
2
+
3
+ const { promisify } = require('util');
4
+ const exec = promisify(require('child_process').exec);
5
+ const { copy, remove } = require('fs-extra');
6
+ const path = require('path');
7
+ const assert = require('assert')
8
+
9
+ const ADDONS_FOLDER = path.join(__dirname, 'addons');
10
+
11
+ const addons = [
12
+ 'echo addon',
13
+ 'echo-addon'
14
+ ]
15
+
16
+ async function beforeAll(addons) {
17
+ console.log(' >Preparing native addons to build')
18
+ for (const addon of addons) {
19
+ await remove(path.join(ADDONS_FOLDER, addon));
20
+ await copy(path.join(__dirname, 'tpl'), path.join(ADDONS_FOLDER, addon));
21
+ }
22
+ }
23
+
24
+ async function test(addon) {
25
+ console.log(` >Building addon: '${addon}'`);
26
+ const { stderr, stdout } = await exec('npm install', {
27
+ cwd: path.join(ADDONS_FOLDER, addon)
28
+ })
29
+ console.log(` >Running test for: '${addon}'`);
30
+ // Disabled the checks on stderr and stdout because of this issue on npm:
31
+ // Stop using process.umask(): https://github.com/npm/cli/issues/1103
32
+ // We should enable the following checks again after the resolution of
33
+ // the reported issue.
34
+ // assert.strictEqual(stderr, '');
35
+ // assert.ok(stderr.length === 0);
36
+ // assert.ok(stdout.length > 0);
37
+ const binding = require(`${ADDONS_FOLDER}/${addon}`);
38
+ assert.strictEqual(binding.except.echo('except'), 'except');
39
+ assert.strictEqual(binding.except.echo(101), 101);
40
+ assert.strictEqual(binding.noexcept.echo('noexcept'), 'noexcept');
41
+ assert.strictEqual(binding.noexcept.echo(103), 103);
42
+ }
43
+
44
+ module.exports = (async function() {
45
+ await beforeAll(addons);
46
+ for (const addon of addons) {
47
+ await test(addon);
48
+ }
49
+ })()
@@ -0,0 +1,17 @@
1
+ #include <napi.h>
2
+
3
+ Napi::Value Echo(const Napi::CallbackInfo& info) {
4
+ Napi::Env env = info.Env();
5
+ if (info.Length() != 1) {
6
+ Napi::TypeError::New(env, "Wrong number of arguments. One argument expected.")
7
+ .ThrowAsJavaScriptException();
8
+ }
9
+ return info[0].As<Napi::Value>();
10
+ }
11
+
12
+ Napi::Object Init(Napi::Env env, Napi::Object exports) {
13
+ exports.Set(Napi::String::New(env, "echo"), Napi::Function::New(env, Echo));
14
+ return exports;
15
+ }
16
+
17
+ NODE_API_MODULE(NODE_GYP_MODULE_NAME, Init)