koffi 2.16.0-beta.2 → 2.16.0

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 (425) hide show
  1. package/CHANGELOG.md +59 -0
  2. package/build/koffi/darwin_arm64/koffi.node +0 -0
  3. package/build/koffi/darwin_x64/koffi.node +0 -0
  4. package/build/koffi/freebsd_arm64/koffi.node +0 -0
  5. package/build/koffi/freebsd_ia32/koffi.node +0 -0
  6. package/build/koffi/freebsd_x64/koffi.node +0 -0
  7. package/build/koffi/linux_arm64/koffi.node +0 -0
  8. package/build/koffi/linux_armhf/koffi.node +0 -0
  9. package/build/koffi/linux_ia32/koffi.node +0 -0
  10. package/build/koffi/linux_loong64/koffi.node +0 -0
  11. package/build/koffi/linux_riscv64d/koffi.node +0 -0
  12. package/build/koffi/linux_x64/koffi.node +0 -0
  13. package/build/koffi/musl_arm64/koffi.node +0 -0
  14. package/build/koffi/musl_x64/koffi.node +0 -0
  15. package/build/koffi/openbsd_ia32/koffi.node +0 -0
  16. package/build/koffi/openbsd_x64/koffi.node +0 -0
  17. package/build/koffi/win32_arm64/koffi.exp +0 -0
  18. package/build/koffi/win32_arm64/koffi.lib +0 -0
  19. package/build/koffi/win32_arm64/koffi.node +0 -0
  20. package/build/koffi/win32_ia32/koffi.exp +0 -0
  21. package/build/koffi/win32_ia32/koffi.lib +0 -0
  22. package/build/koffi/win32_ia32/koffi.node +0 -0
  23. package/build/koffi/win32_x64/koffi.exp +0 -0
  24. package/build/koffi/win32_x64/koffi.lib +0 -0
  25. package/build/koffi/win32_x64/koffi.node +0 -0
  26. package/index.d.ts +9 -11
  27. package/index.js +6 -9
  28. package/indirect.js +6 -9
  29. package/lib/native/base/base.cc +1 -6
  30. package/package.json +3 -3
  31. package/src/cnoke/assets/FindCNoke.cmake +27 -16
  32. package/src/cnoke/assets/toolchains.json +126 -0
  33. package/src/cnoke/cnoke.js +27 -33
  34. package/src/cnoke/src/builder.js +124 -63
  35. package/src/cnoke/src/tools.js +1 -5
  36. package/src/koffi/CMakeLists.txt +32 -21
  37. package/src/koffi/src/{abi/arm32.cc → abi_arm32.cc} +235 -238
  38. package/src/koffi/src/{abi/arm32_asm.S → abi_arm32_asm.S} +19 -15
  39. package/src/koffi/src/{abi/arm64.cc → abi_arm64.cc} +253 -274
  40. package/src/koffi/src/{abi/arm64_asm.S → abi_arm64_asm.S} +16 -10
  41. package/src/koffi/src/{abi/arm64_asm.asm → abi_arm64_asm.asm} +17 -10
  42. package/src/koffi/src/{abi/loong64_asm.S → abi_loong64_asm.S} +16 -10
  43. package/src/koffi/src/{abi/riscv64.cc → abi_riscv64.cc} +233 -236
  44. package/src/koffi/src/{abi/riscv64_asm.S → abi_riscv64_asm.S} +16 -10
  45. package/src/koffi/src/{abi/x64_sysv.cc → abi_x64_sysv.cc} +208 -212
  46. package/src/koffi/src/{abi/x64_sysv_asm.S → abi_x64_sysv_asm.S} +17 -10
  47. package/src/koffi/src/{abi/x64_win.cc → abi_x64_win.cc} +175 -206
  48. package/src/koffi/src/{abi/x64_win_asm.S → abi_x64_win_asm.S} +49 -27
  49. package/src/koffi/src/{abi/x64_win_asm.asm → abi_x64_win_asm.asm} +54 -27
  50. package/src/koffi/src/{abi/x86.cc → abi_x86.cc} +187 -226
  51. package/src/koffi/src/{abi/x86_asm.S → abi_x86_asm.S} +36 -21
  52. package/src/koffi/src/{abi/x86_asm.asm → abi_x86_asm.asm} +31 -16
  53. package/src/koffi/src/call.cc +473 -287
  54. package/src/koffi/src/call.hh +15 -18
  55. package/src/koffi/src/ffi.cc +167 -183
  56. package/src/koffi/src/ffi.hh +59 -13
  57. package/src/koffi/src/init.js +1 -0
  58. package/src/koffi/src/util.cc +113 -159
  59. package/src/koffi/src/util.hh +23 -74
  60. package/src/koffi/src/win32.cc +13 -0
  61. package/src/koffi/src/win32.hh +7 -0
  62. package/src/koffi/tools/write_trampolines.js +77 -0
  63. package/doc/README.md +0 -27
  64. package/doc/assets.ini +0 -24
  65. package/doc/build.sh +0 -9
  66. package/doc/develop.sh +0 -15
  67. package/doc/pages/404.md +0 -17
  68. package/doc/pages.ini +0 -86
  69. package/doc/static/highlight.js +0 -8
  70. package/doc/static/koffi.css +0 -11
  71. package/doc/static/koffi.png +0 -0
  72. package/doc/static/logo.webp +0 -0
  73. package/doc/static/perf_linux.png +0 -0
  74. package/doc/static/perf_windows.png +0 -0
  75. package/doc/static/print.css +0 -10
  76. package/doc/templates/code.html +0 -48
  77. package/doc/templates/page.html +0 -47
  78. package/src/koffi/cmake/raylib.cmake +0 -85
  79. package/src/koffi/cmake/sqlite3.cmake +0 -9
  80. package/src/koffi/examples/electron-builder/README.md +0 -11
  81. package/src/koffi/examples/electron-builder/package.json +0 -21
  82. package/src/koffi/examples/electron-builder/src/app.js +0 -20
  83. package/src/koffi/examples/electron-builder/src/index.html +0 -143
  84. package/src/koffi/examples/electron-builder/src/preload.js +0 -5
  85. package/src/koffi/examples/electron-forge/README.md +0 -25
  86. package/src/koffi/examples/electron-forge/forge.config.js +0 -63
  87. package/src/koffi/examples/electron-forge/package.json +0 -39
  88. package/src/koffi/examples/electron-forge/src/index.css +0 -7
  89. package/src/koffi/examples/electron-forge/src/index.html +0 -143
  90. package/src/koffi/examples/electron-forge/src/main.js +0 -52
  91. package/src/koffi/examples/electron-forge/src/preload.js +0 -5
  92. package/src/koffi/examples/electron-forge/src/renderer.js +0 -31
  93. package/src/koffi/examples/electron-forge/webpack.main.config.js +0 -11
  94. package/src/koffi/examples/electron-forge/webpack.renderer.config.js +0 -13
  95. package/src/koffi/examples/electron-forge/webpack.rules.js +0 -35
  96. package/src/koffi/examples/node-esbuild/README.md +0 -19
  97. package/src/koffi/examples/node-esbuild/index.js +0 -2
  98. package/src/koffi/examples/node-esbuild/package.json +0 -16
  99. package/src/koffi/examples/nwjs/README.md +0 -20
  100. package/src/koffi/examples/nwjs/package.json +0 -11
  101. package/src/koffi/examples/nwjs/src/index.html +0 -145
  102. package/src/koffi/examples/nwjs/src/package.json +0 -10
  103. package/src/koffi/examples/yao-pkg/README.md +0 -17
  104. package/src/koffi/examples/yao-pkg/index.js +0 -2
  105. package/src/koffi/examples/yao-pkg/package.json +0 -22
  106. package/src/koffi/src/primitives.inc +0 -39
  107. package/src/koffi/src/trampolines/armasm.inc +0 -32771
  108. package/src/koffi/src/trampolines/gnu.inc +0 -24577
  109. package/src/koffi/src/trampolines/masm32.inc +0 -32769
  110. package/src/koffi/src/trampolines/masm64.inc +0 -32769
  111. package/src/koffi/src/trampolines/prototypes.inc +0 -16388
  112. package/vendor/node-addon-api/CHANGELOG.md +0 -1272
  113. package/vendor/node-addon-api/CODE_OF_CONDUCT.md +0 -4
  114. package/vendor/node-addon-api/CONTRIBUTING.md +0 -203
  115. package/vendor/node-addon-api/appveyor.yml +0 -37
  116. package/vendor/node-addon-api/benchmark/README.md +0 -47
  117. package/vendor/node-addon-api/benchmark/binding.gyp +0 -25
  118. package/vendor/node-addon-api/benchmark/function_args.cc +0 -250
  119. package/vendor/node-addon-api/benchmark/function_args.js +0 -60
  120. package/vendor/node-addon-api/benchmark/index.js +0 -34
  121. package/vendor/node-addon-api/benchmark/property_descriptor.cc +0 -84
  122. package/vendor/node-addon-api/benchmark/property_descriptor.js +0 -38
  123. package/vendor/node-addon-api/common.gypi +0 -21
  124. package/vendor/node-addon-api/doc/README.md +0 -145
  125. package/vendor/node-addon-api/doc/addon.md +0 -163
  126. package/vendor/node-addon-api/doc/array.md +0 -81
  127. package/vendor/node-addon-api/doc/array_buffer.md +0 -165
  128. package/vendor/node-addon-api/doc/async_context.md +0 -86
  129. package/vendor/node-addon-api/doc/async_operations.md +0 -31
  130. package/vendor/node-addon-api/doc/async_worker.md +0 -428
  131. package/vendor/node-addon-api/doc/async_worker_variants.md +0 -578
  132. package/vendor/node-addon-api/doc/basic_env.md +0 -200
  133. package/vendor/node-addon-api/doc/bigint.md +0 -97
  134. package/vendor/node-addon-api/doc/boolean.md +0 -68
  135. package/vendor/node-addon-api/doc/buffer.md +0 -245
  136. package/vendor/node-addon-api/doc/callback_scope.md +0 -54
  137. package/vendor/node-addon-api/doc/callbackinfo.md +0 -97
  138. package/vendor/node-addon-api/doc/checker-tool.md +0 -32
  139. package/vendor/node-addon-api/doc/class_property_descriptor.md +0 -123
  140. package/vendor/node-addon-api/doc/cmake-js.md +0 -87
  141. package/vendor/node-addon-api/doc/contributing/creating_a_release.md +0 -95
  142. package/vendor/node-addon-api/doc/conversion-tool.md +0 -28
  143. package/vendor/node-addon-api/doc/dataview.md +0 -248
  144. package/vendor/node-addon-api/doc/date.md +0 -68
  145. package/vendor/node-addon-api/doc/env.md +0 -87
  146. package/vendor/node-addon-api/doc/error.md +0 -120
  147. package/vendor/node-addon-api/doc/error_handling.md +0 -266
  148. package/vendor/node-addon-api/doc/escapable_handle_scope.md +0 -80
  149. package/vendor/node-addon-api/doc/external.md +0 -79
  150. package/vendor/node-addon-api/doc/external_buffer.md +0 -18
  151. package/vendor/node-addon-api/doc/finalization.md +0 -153
  152. package/vendor/node-addon-api/doc/function.md +0 -402
  153. package/vendor/node-addon-api/doc/function_reference.md +0 -238
  154. package/vendor/node-addon-api/doc/generator.md +0 -13
  155. package/vendor/node-addon-api/doc/handle_scope.md +0 -77
  156. package/vendor/node-addon-api/doc/hierarchy.md +0 -95
  157. package/vendor/node-addon-api/doc/instance_wrap.md +0 -408
  158. package/vendor/node-addon-api/doc/maybe.md +0 -76
  159. package/vendor/node-addon-api/doc/memory_management.md +0 -27
  160. package/vendor/node-addon-api/doc/name.md +0 -29
  161. package/vendor/node-addon-api/doc/node-gyp.md +0 -82
  162. package/vendor/node-addon-api/doc/number.md +0 -163
  163. package/vendor/node-addon-api/doc/object.md +0 -411
  164. package/vendor/node-addon-api/doc/object_lifetime_management.md +0 -83
  165. package/vendor/node-addon-api/doc/object_reference.md +0 -117
  166. package/vendor/node-addon-api/doc/object_wrap.md +0 -604
  167. package/vendor/node-addon-api/doc/prebuild_tools.md +0 -16
  168. package/vendor/node-addon-api/doc/promises.md +0 -130
  169. package/vendor/node-addon-api/doc/property_descriptor.md +0 -286
  170. package/vendor/node-addon-api/doc/propertylvalue.md +0 -50
  171. package/vendor/node-addon-api/doc/range_error.md +0 -59
  172. package/vendor/node-addon-api/doc/reference.md +0 -113
  173. package/vendor/node-addon-api/doc/setup.md +0 -115
  174. package/vendor/node-addon-api/doc/string.md +0 -93
  175. package/vendor/node-addon-api/doc/symbol.md +0 -61
  176. package/vendor/node-addon-api/doc/syntax_error.md +0 -66
  177. package/vendor/node-addon-api/doc/threadsafe.md +0 -121
  178. package/vendor/node-addon-api/doc/threadsafe_function.md +0 -290
  179. package/vendor/node-addon-api/doc/type_error.md +0 -59
  180. package/vendor/node-addon-api/doc/type_taggable.md +0 -40
  181. package/vendor/node-addon-api/doc/typed_array.md +0 -78
  182. package/vendor/node-addon-api/doc/typed_array_of.md +0 -137
  183. package/vendor/node-addon-api/doc/typed_threadsafe_function.md +0 -306
  184. package/vendor/node-addon-api/doc/value.md +0 -368
  185. package/vendor/node-addon-api/doc/version_management.md +0 -43
  186. package/vendor/node-addon-api/eslint.config.js +0 -5
  187. package/vendor/node-addon-api/except.gypi +0 -25
  188. package/vendor/node-addon-api/index.js +0 -14
  189. package/vendor/node-addon-api/node_addon_api.gyp +0 -42
  190. package/vendor/node-addon-api/node_api.gyp +0 -9
  191. package/vendor/node-addon-api/noexcept.gypi +0 -26
  192. package/vendor/node-addon-api/nothing.c +0 -0
  193. package/vendor/node-addon-api/package-support.json +0 -21
  194. package/vendor/node-addon-api/package.json +0 -480
  195. package/vendor/node-addon-api/release-please-config.json +0 -15
  196. package/vendor/node-addon-api/test/README.md +0 -91
  197. package/vendor/node-addon-api/test/addon.cc +0 -44
  198. package/vendor/node-addon-api/test/addon.js +0 -7
  199. package/vendor/node-addon-api/test/addon_build/index.js +0 -49
  200. package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +0 -18
  201. package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +0 -63
  202. package/vendor/node-addon-api/test/addon_build/tpl/index.js +0 -9
  203. package/vendor/node-addon-api/test/addon_build/tpl/package.json +0 -11
  204. package/vendor/node-addon-api/test/addon_data.cc +0 -98
  205. package/vendor/node-addon-api/test/addon_data.js +0 -24
  206. package/vendor/node-addon-api/test/array_buffer.cc +0 -243
  207. package/vendor/node-addon-api/test/array_buffer.js +0 -70
  208. package/vendor/node-addon-api/test/async_context.cc +0 -36
  209. package/vendor/node-addon-api/test/async_context.js +0 -122
  210. package/vendor/node-addon-api/test/async_progress_queue_worker.cc +0 -248
  211. package/vendor/node-addon-api/test/async_progress_queue_worker.js +0 -180
  212. package/vendor/node-addon-api/test/async_progress_worker.cc +0 -357
  213. package/vendor/node-addon-api/test/async_progress_worker.js +0 -200
  214. package/vendor/node-addon-api/test/async_worker.cc +0 -341
  215. package/vendor/node-addon-api/test/async_worker.js +0 -264
  216. package/vendor/node-addon-api/test/async_worker_nocallback.js +0 -19
  217. package/vendor/node-addon-api/test/async_worker_persistent.cc +0 -63
  218. package/vendor/node-addon-api/test/async_worker_persistent.js +0 -24
  219. package/vendor/node-addon-api/test/basic_types/array.cc +0 -40
  220. package/vendor/node-addon-api/test/basic_types/array.js +0 -34
  221. package/vendor/node-addon-api/test/basic_types/boolean.cc +0 -40
  222. package/vendor/node-addon-api/test/basic_types/boolean.js +0 -34
  223. package/vendor/node-addon-api/test/basic_types/number.cc +0 -105
  224. package/vendor/node-addon-api/test/basic_types/number.js +0 -115
  225. package/vendor/node-addon-api/test/basic_types/value.cc +0 -177
  226. package/vendor/node-addon-api/test/basic_types/value.js +0 -173
  227. package/vendor/node-addon-api/test/bigint.cc +0 -91
  228. package/vendor/node-addon-api/test/bigint.js +0 -53
  229. package/vendor/node-addon-api/test/binding-swallowexcept.cc +0 -12
  230. package/vendor/node-addon-api/test/binding.cc +0 -200
  231. package/vendor/node-addon-api/test/binding.gyp +0 -160
  232. package/vendor/node-addon-api/test/buffer.cc +0 -185
  233. package/vendor/node-addon-api/test/buffer.h +0 -26
  234. package/vendor/node-addon-api/test/buffer.js +0 -150
  235. package/vendor/node-addon-api/test/buffer_new_or_copy-inl.h +0 -68
  236. package/vendor/node-addon-api/test/buffer_no_external.cc +0 -24
  237. package/vendor/node-addon-api/test/callbackInfo.cc +0 -27
  238. package/vendor/node-addon-api/test/callbackInfo.js +0 -9
  239. package/vendor/node-addon-api/test/callbackscope.cc +0 -39
  240. package/vendor/node-addon-api/test/callbackscope.js +0 -49
  241. package/vendor/node-addon-api/test/child_processes/addon.js +0 -11
  242. package/vendor/node-addon-api/test/child_processes/addon_data.js +0 -24
  243. package/vendor/node-addon-api/test/child_processes/objectwrap_function.js +0 -22
  244. package/vendor/node-addon-api/test/child_processes/threadsafe_function_exception.js +0 -33
  245. package/vendor/node-addon-api/test/child_processes/typed_threadsafe_function_exception.js +0 -19
  246. package/vendor/node-addon-api/test/common/index.js +0 -246
  247. package/vendor/node-addon-api/test/common/test_helper.h +0 -71
  248. package/vendor/node-addon-api/test/dataview/dataview.cc +0 -48
  249. package/vendor/node-addon-api/test/dataview/dataview.js +0 -35
  250. package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +0 -115
  251. package/vendor/node-addon-api/test/dataview/dataview_read_write.js +0 -92
  252. package/vendor/node-addon-api/test/date.cc +0 -45
  253. package/vendor/node-addon-api/test/date.js +0 -18
  254. package/vendor/node-addon-api/test/env_cleanup.cc +0 -100
  255. package/vendor/node-addon-api/test/env_cleanup.js +0 -55
  256. package/vendor/node-addon-api/test/env_misc.cc +0 -25
  257. package/vendor/node-addon-api/test/env_misc.js +0 -12
  258. package/vendor/node-addon-api/test/error.cc +0 -436
  259. package/vendor/node-addon-api/test/error.js +0 -111
  260. package/vendor/node-addon-api/test/error_handling_for_primitives.cc +0 -13
  261. package/vendor/node-addon-api/test/error_handling_for_primitives.js +0 -29
  262. package/vendor/node-addon-api/test/error_terminating_environment.js +0 -99
  263. package/vendor/node-addon-api/test/except_all.cc +0 -22
  264. package/vendor/node-addon-api/test/except_all.js +0 -14
  265. package/vendor/node-addon-api/test/exports.js +0 -19
  266. package/vendor/node-addon-api/test/external.cc +0 -85
  267. package/vendor/node-addon-api/test/external.js +0 -85
  268. package/vendor/node-addon-api/test/finalizer_order.cc +0 -152
  269. package/vendor/node-addon-api/test/finalizer_order.js +0 -98
  270. package/vendor/node-addon-api/test/function.cc +0 -338
  271. package/vendor/node-addon-api/test/function.js +0 -137
  272. package/vendor/node-addon-api/test/function_reference.cc +0 -204
  273. package/vendor/node-addon-api/test/function_reference.js +0 -157
  274. package/vendor/node-addon-api/test/globalObject/global_object.cc +0 -61
  275. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +0 -31
  276. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +0 -58
  277. package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +0 -40
  278. package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +0 -56
  279. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +0 -28
  280. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +0 -46
  281. package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +0 -31
  282. package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +0 -56
  283. package/vendor/node-addon-api/test/handlescope.cc +0 -86
  284. package/vendor/node-addon-api/test/handlescope.js +0 -16
  285. package/vendor/node-addon-api/test/index.js +0 -160
  286. package/vendor/node-addon-api/test/maybe/check.cc +0 -69
  287. package/vendor/node-addon-api/test/maybe/index.js +0 -50
  288. package/vendor/node-addon-api/test/memory_management.cc +0 -18
  289. package/vendor/node-addon-api/test/memory_management.js +0 -9
  290. package/vendor/node-addon-api/test/movable_callbacks.cc +0 -23
  291. package/vendor/node-addon-api/test/movable_callbacks.js +0 -21
  292. package/vendor/node-addon-api/test/name.cc +0 -110
  293. package/vendor/node-addon-api/test/name.js +0 -59
  294. package/vendor/node-addon-api/test/napi_child.js +0 -14
  295. package/vendor/node-addon-api/test/object/delete_property.cc +0 -38
  296. package/vendor/node-addon-api/test/object/delete_property.js +0 -41
  297. package/vendor/node-addon-api/test/object/finalizer.cc +0 -30
  298. package/vendor/node-addon-api/test/object/finalizer.js +0 -28
  299. package/vendor/node-addon-api/test/object/get_property.cc +0 -34
  300. package/vendor/node-addon-api/test/object/get_property.js +0 -40
  301. package/vendor/node-addon-api/test/object/has_own_property.cc +0 -34
  302. package/vendor/node-addon-api/test/object/has_own_property.js +0 -34
  303. package/vendor/node-addon-api/test/object/has_property.cc +0 -38
  304. package/vendor/node-addon-api/test/object/has_property.js +0 -37
  305. package/vendor/node-addon-api/test/object/object.cc +0 -430
  306. package/vendor/node-addon-api/test/object/object.js +0 -218
  307. package/vendor/node-addon-api/test/object/object_deprecated.cc +0 -70
  308. package/vendor/node-addon-api/test/object/object_deprecated.js +0 -42
  309. package/vendor/node-addon-api/test/object/object_freeze_seal.cc +0 -25
  310. package/vendor/node-addon-api/test/object/object_freeze_seal.js +0 -61
  311. package/vendor/node-addon-api/test/object/set_property.cc +0 -45
  312. package/vendor/node-addon-api/test/object/set_property.js +0 -30
  313. package/vendor/node-addon-api/test/object/subscript_operator.cc +0 -58
  314. package/vendor/node-addon-api/test/object/subscript_operator.js +0 -17
  315. package/vendor/node-addon-api/test/object_reference.cc +0 -417
  316. package/vendor/node-addon-api/test/object_reference.js +0 -262
  317. package/vendor/node-addon-api/test/objectwrap.cc +0 -295
  318. package/vendor/node-addon-api/test/objectwrap.js +0 -309
  319. package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +0 -26
  320. package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +0 -18
  321. package/vendor/node-addon-api/test/objectwrap_function.cc +0 -43
  322. package/vendor/node-addon-api/test/objectwrap_function.js +0 -6
  323. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +0 -30
  324. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +0 -13
  325. package/vendor/node-addon-api/test/objectwrap_removewrap.cc +0 -45
  326. package/vendor/node-addon-api/test/objectwrap_removewrap.js +0 -32
  327. package/vendor/node-addon-api/test/objectwrap_worker_thread.js +0 -20
  328. package/vendor/node-addon-api/test/promise.cc +0 -111
  329. package/vendor/node-addon-api/test/promise.js +0 -43
  330. package/vendor/node-addon-api/test/reference.cc +0 -78
  331. package/vendor/node-addon-api/test/reference.js +0 -20
  332. package/vendor/node-addon-api/test/require_basic_finalizers/index.js +0 -38
  333. package/vendor/node-addon-api/test/require_basic_finalizers/tpl/addon.cc +0 -12
  334. package/vendor/node-addon-api/test/require_basic_finalizers/tpl/binding.gyp +0 -48
  335. package/vendor/node-addon-api/test/require_basic_finalizers/tpl/index.js +0 -3
  336. package/vendor/node-addon-api/test/require_basic_finalizers/tpl/package.json +0 -11
  337. package/vendor/node-addon-api/test/run_script.cc +0 -56
  338. package/vendor/node-addon-api/test/run_script.js +0 -45
  339. package/vendor/node-addon-api/test/symbol.cc +0 -79
  340. package/vendor/node-addon-api/test/symbol.js +0 -66
  341. package/vendor/node-addon-api/test/testUtil.js +0 -54
  342. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +0 -230
  343. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +0 -225
  344. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +0 -155
  345. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +0 -13
  346. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_exception.cc +0 -50
  347. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_exception.js +0 -20
  348. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +0 -125
  349. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +0 -14
  350. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +0 -27
  351. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +0 -7
  352. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +0 -240
  353. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +0 -59
  354. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +0 -55
  355. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +0 -98
  356. package/vendor/node-addon-api/test/thunking_manual.cc +0 -127
  357. package/vendor/node-addon-api/test/thunking_manual.js +0 -16
  358. package/vendor/node-addon-api/test/type_taggable.cc +0 -66
  359. package/vendor/node-addon-api/test/type_taggable.js +0 -59
  360. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +0 -215
  361. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +0 -188
  362. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +0 -120
  363. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +0 -14
  364. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_exception.cc +0 -39
  365. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_exception.js +0 -13
  366. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +0 -127
  367. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +0 -14
  368. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +0 -32
  369. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +0 -8
  370. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +0 -237
  371. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +0 -59
  372. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +0 -67
  373. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +0 -98
  374. package/vendor/node-addon-api/test/typedarray-bigint.js +0 -58
  375. package/vendor/node-addon-api/test/typedarray.cc +0 -413
  376. package/vendor/node-addon-api/test/typedarray.js +0 -103
  377. package/vendor/node-addon-api/test/value_type_cast.cc +0 -60
  378. package/vendor/node-addon-api/test/value_type_cast.js +0 -106
  379. package/vendor/node-addon-api/test/version_management.cc +0 -28
  380. package/vendor/node-addon-api/test/version_management.js +0 -29
  381. package/vendor/node-addon-api/tools/README.md +0 -73
  382. package/vendor/node-addon-api/tools/check-napi.js +0 -99
  383. package/vendor/node-addon-api/tools/clang-format.js +0 -71
  384. package/vendor/node-addon-api/tools/conversion.js +0 -301
  385. package/vendor/node-addon-api/unit-test/README.md +0 -28
  386. package/vendor/node-addon-api/unit-test/binding-file-template.js +0 -39
  387. package/vendor/node-addon-api/unit-test/binding.gyp +0 -72
  388. package/vendor/node-addon-api/unit-test/exceptions.js +0 -32
  389. package/vendor/node-addon-api/unit-test/generate-binding-cc.js +0 -61
  390. package/vendor/node-addon-api/unit-test/injectTestParams.js +0 -101
  391. package/vendor/node-addon-api/unit-test/listOfTestModules.js +0 -88
  392. package/vendor/node-addon-api/unit-test/matchModules.js +0 -65
  393. package/vendor/node-addon-api/unit-test/setup.js +0 -13
  394. package/vendor/node-addon-api/unit-test/spawnTask.js +0 -26
  395. package/vendor/node-addon-api/unit-test/test.js +0 -30
  396. package/vendor/node-api-headers/CHANGELOG.md +0 -130
  397. package/vendor/node-api-headers/CODE_OF_CONDUCT.md +0 -4
  398. package/vendor/node-api-headers/CONTRIBUTING.md +0 -32
  399. package/vendor/node-api-headers/CREATING_A_RELEASE.md +0 -68
  400. package/vendor/node-api-headers/index.js +0 -17
  401. package/vendor/node-api-headers/lib/clang-utils.js +0 -50
  402. package/vendor/node-api-headers/lib/parse-utils.js +0 -92
  403. package/vendor/node-api-headers/package.json +0 -59
  404. package/vendor/node-api-headers/release-please-config.json +0 -12
  405. package/vendor/node-api-headers/scripts/update-headers.js +0 -246
  406. package/vendor/node-api-headers/scripts/write-symbols.js +0 -154
  407. package/vendor/node-api-headers/scripts/write-win32-def.js +0 -52
  408. package/vendor/node-api-headers/symbols.js +0 -257
  409. package/vendor/node-api-headers/test/parse-utils.js +0 -21
  410. /package/doc/{pages/benchmarks.md → benchmarks.md} +0 -0
  411. /package/doc/{pages/callbacks.md → callbacks.md} +0 -0
  412. /package/doc/{pages/contribute.md → contribute.md} +0 -0
  413. /package/doc/{pages/functions.md → functions.md} +0 -0
  414. /package/doc/{pages/index.md → index.md} +0 -0
  415. /package/doc/{pages/input.md → input.md} +0 -0
  416. /package/doc/{pages/migration.md → migration.md} +0 -0
  417. /package/doc/{pages/misc.md → misc.md} +0 -0
  418. /package/doc/{pages/output.md → output.md} +0 -0
  419. /package/doc/{pages/packaging.md → packaging.md} +0 -0
  420. /package/doc/{pages/platforms.md → platforms.md} +0 -0
  421. /package/doc/{pages/pointers.md → pointers.md} +0 -0
  422. /package/doc/{pages/start.md → start.md} +0 -0
  423. /package/doc/{pages/unions.md → unions.md} +0 -0
  424. /package/doc/{pages/variables.md → variables.md} +0 -0
  425. /package/src/koffi/src/{abi/loong64.cc → abi_loong64.cc} +0 -0
@@ -1,72 +0,0 @@
1
- {
2
- 'target_defaults': {
3
- 'includes': ['../common.gypi'],
4
- 'include_dirs': ['../test/common', "./generated"],
5
- 'variables': {
6
- 'setup': ["<!@(node -p \"require('./setup')\")"],
7
- 'build_sources': [
8
- "<!@(node -p \"require('./injectTestParams').filesToCompile()\")",
9
- ]
10
- },
11
- },
12
- 'targets': [
13
- {
14
- "target_name": "generateBindingCC",
15
- "type": "none",
16
- "actions": [ {
17
- "action_name": "generateBindingCC",
18
- "message": "Generating binding cc file",
19
- "outputs": ["generated/binding.cc"],
20
- "conditions": [
21
- [ "'true'=='true'", {
22
- "inputs": [""],
23
- "action": [
24
- "node",
25
- "generate-binding-cc.js",
26
- "<!@(node -p \"require('./injectTestParams').filesForBinding()\" )"
27
- ]
28
- } ]
29
- ]
30
- } ]
31
- },
32
- {
33
- 'target_name': 'binding',
34
- 'includes': ['../except.gypi'],
35
- 'sources': ['>@(build_sources)'],
36
- 'dependencies': [ 'generateBindingCC' ]
37
- },
38
- {
39
- 'target_name': 'binding_noexcept',
40
- 'includes': ['../noexcept.gypi'],
41
- 'sources': ['>@(build_sources)'],
42
- 'dependencies': [ 'generateBindingCC' ]
43
- },
44
- {
45
- 'target_name': 'binding_noexcept_maybe',
46
- 'includes': ['../noexcept.gypi'],
47
- 'sources': ['>@(build_sources)'],
48
- 'defines': ['NODE_ADDON_API_ENABLE_MAYBE']
49
- },
50
- {
51
- 'target_name': 'binding_swallowexcept',
52
- 'includes': ['../except.gypi'],
53
- 'sources': ['>@(build_sources)'],
54
- 'defines': ['NODE_API_SWALLOW_UNTHROWABLE_EXCEPTIONS'],
55
- 'dependencies': [ 'generateBindingCC' ]
56
- },
57
- {
58
- 'target_name': 'binding_swallowexcept_noexcept',
59
- 'includes': ['../noexcept.gypi'],
60
- 'sources': ['>@(build_sources)'],
61
- 'defines': ['NODE_API_SWALLOW_UNTHROWABLE_EXCEPTIONS'],
62
- 'dependencies': [ 'generateBindingCC' ]
63
- },
64
- {
65
- 'target_name': 'binding_custom_namespace',
66
- 'includes': ['../noexcept.gypi'],
67
- 'sources': ['>@(build_sources)'],
68
- 'defines': ['NAPI_CPP_CUSTOM_NAMESPACE=cstm'],
69
- 'dependencies': [ 'generateBindingCC' ]
70
- },
71
- ],
72
- }
@@ -1,32 +0,0 @@
1
- /**
2
- * This file points out anomalies/exceptions in test files when generating the binding.cc file
3
- *
4
- * nouns: words in file names that are misspelled
5
- * *NOTE: a 'constructor' property is explicitly added to override javascript object constructor
6
- *
7
- * exportNames: anomalies in init function names
8
- *
9
- * propertyNames: anomalies in exported property name of init functions
10
- *
11
- * skipBinding: skip including this file in binding.cc
12
- */
13
- module.exports = {
14
- nouns: {
15
- constructor: 'constructor',
16
- threadsafe: 'threadSafe',
17
- objectwrap: 'objectWrap'
18
- },
19
- exportNames: {
20
- AsyncWorkerPersistent: 'PersistentAsyncWorker'
21
- },
22
- propertyNames: {
23
- async_worker_persistent: 'persistentasyncworker',
24
- objectwrap_constructor_exception: 'objectwrapConstructorException'
25
- },
26
- skipBinding: [
27
- 'global_object_delete_property',
28
- 'global_object_get_property',
29
- 'global_object_has_own_property',
30
- 'global_object_set_property'
31
- ]
32
- };
@@ -1,61 +0,0 @@
1
- const listOfTestModules = require('./listOfTestModules');
2
- const exceptions = require('./exceptions');
3
- const { generateFileContent, writeToBindingFile } = require('./binding-file-template');
4
-
5
- const buildDirs = listOfTestModules.dirs;
6
- const buildFiles = listOfTestModules.files;
7
-
8
- /**
9
- * @param none
10
- * @requires list of files to bind as command-line argument
11
- * @returns list of binding configurations
12
- */
13
- function generateBindingConfigurations () {
14
- const testFilesToBind = process.argv.slice(2);
15
- console.log('test modules to bind: ', testFilesToBind);
16
-
17
- const configs = [];
18
-
19
- testFilesToBind.forEach((file) => {
20
- const configName = file.split('.cc')[0];
21
-
22
- if (buildDirs[configName]) {
23
- for (const file of buildDirs[configName]) {
24
- if (exceptions.skipBinding.includes(file)) continue;
25
- configs.push(buildFiles[file]);
26
- }
27
- } else if (buildFiles[configName]) {
28
- configs.push(buildFiles[configName]);
29
- } else {
30
- console.log('not found', file, configName);
31
- }
32
- });
33
-
34
- return Promise.resolve(configs);
35
- }
36
-
37
- generateBindingConfigurations().then(generateFileContent).then(writeToBindingFile);
38
-
39
- /**
40
- * Test cases
41
- * @fires only when run directly from terminal with TEST=true
42
- * eg: TEST=true node generate-binding-cc
43
- */
44
- if (require.main === module && process.env.TEST === 'true') {
45
- const assert = require('assert');
46
-
47
- const setArgsAndCall = (fn, filterCondition) => { process.argv = [null, null, ...filterCondition.split(' ')]; return fn(); };
48
- const assertPromise = (promise, expectedVal) => promise.then((val) => assert.deepEqual(val, expectedVal)).catch(console.log);
49
-
50
- const expectedVal = [{
51
- dir: '',
52
- objectName: 'AsyncProgressWorker',
53
- propertyName: 'async_progress_worker'
54
- },
55
- {
56
- dir: '',
57
- objectName: 'PersistentAsyncWorker',
58
- propertyName: 'persistentasyncworker'
59
- }];
60
- assertPromise(setArgsAndCall(generateBindingConfigurations, 'async_progress_worker async_worker_persistent'), expectedVal);
61
- }
@@ -1,101 +0,0 @@
1
- const fs = require('fs');
2
- const path = require('path');
3
-
4
- const listOfTestModules = require('./listOfTestModules');
5
-
6
- const buildDirs = listOfTestModules.dirs;
7
- const buildFiles = listOfTestModules.files;
8
-
9
- if (!fs.existsSync('./generated')) {
10
- fs.mkdirSync('./generated');
11
- }
12
-
13
- /**
14
- * @returns : list of files to compile by node-gyp
15
- * @param : none
16
- * @requires : picks `filter` parameter from process.env
17
- * This function is used as an utility method to inject a list of files to compile into binding.gyp
18
- */
19
- module.exports.filesToCompile = function () {
20
- // match filter argument with available test modules
21
- const matchedModules = require('./matchModules').matchWildCards(process.env.npm_config_filter || '');
22
-
23
- // standard list of files to compile
24
- const addedFiles = './generated/binding.cc test_helper.h';
25
-
26
- const filterConditions = matchedModules.split(' ').length ? matchedModules.split(' ') : [matchedModules];
27
- const files = [];
28
-
29
- // generate a list of all files to compile
30
- for (const matchCondition of filterConditions) {
31
- if (buildDirs[matchCondition.toLowerCase()]) {
32
- for (const file of buildDirs[matchCondition.toLowerCase()]) {
33
- const config = buildFiles[file];
34
- const separator = config.dir.length ? '/' : '';
35
- files.push(config.dir + separator + file);
36
- }
37
- } else if (buildFiles[matchCondition.toLowerCase()]) {
38
- const config = buildFiles[matchCondition.toLowerCase()];
39
- const separator = config.dir.length ? '/' : '';
40
- files.push(config.dir + separator + matchCondition.toLowerCase());
41
- }
42
- }
43
-
44
- // generate a string of files to feed to the compiler
45
- let filesToCompile = '';
46
- files.forEach((file) => {
47
- filesToCompile = `${filesToCompile} ../test/${file}.cc`;
48
- });
49
-
50
- // log list of compiled files
51
- fs.writeFileSync(path.join(__dirname, '/generated/compilelist'), `${addedFiles} ${filesToCompile}`.split(' ').join('\r\n'));
52
-
53
- // return file list
54
- return `${addedFiles} ${filesToCompile}`;
55
- };
56
-
57
- /**
58
- * @returns list of test files to bind exported init functions
59
- * @param : none
60
- * @requires : picks `filter` parameter from process.env
61
- * This function is used as an utility method by the generateBindingCC step in binding.gyp
62
- */
63
- module.exports.filesForBinding = function () {
64
- const filterCondition = require('./matchModules').matchWildCards(process.env.npm_config_filter || '');
65
- fs.writeFileSync(path.join(__dirname, '/generated/bindingList'), filterCondition.split(' ').join('\r\n'));
66
- return filterCondition;
67
- };
68
-
69
- /**
70
- * Test cases
71
- * @fires only when run directly from terminal
72
- * eg: node injectTestParams
73
- */
74
- if (require.main === module) {
75
- const assert = require('assert');
76
-
77
- const setEnvAndCall = (fn, filterCondition) => { process.env.npm_config_filter = filterCondition; return fn(); };
78
-
79
- assert.strictEqual(setEnvAndCall(exports.filesToCompile, 'typed*ex*'), './generated/binding.cc test_helper.h ../test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc');
80
-
81
- const expectedFilesToMatch = [
82
- './generated/binding.cc test_helper.h ',
83
- '../test/threadsafe_function/threadsafe_function.cc',
84
- '../test/threadsafe_function/threadsafe_function_ctx.cc',
85
- '../test/threadsafe_function/threadsafe_function_existing_tsfn.cc',
86
- '../test/threadsafe_function/threadsafe_function_ptr.cc',
87
- '../test/threadsafe_function/threadsafe_function_sum.cc',
88
- '../test/threadsafe_function/threadsafe_function_unref.cc',
89
- '../test/typed_threadsafe_function/typed_threadsafe_function.cc',
90
- '../test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc',
91
- '../test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc',
92
- '../test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc',
93
- '../test/typed_threadsafe_function/typed_threadsafe_function_sum.cc',
94
- '../test/typed_threadsafe_function/typed_threadsafe_function_unref.cc'
95
- ];
96
- assert.strictEqual(setEnvAndCall(exports.filesToCompile, 'threadsafe_function typed_threadsafe_function'), expectedFilesToMatch.join(' '));
97
-
98
- assert.strictEqual(setEnvAndCall(exports.filesToCompile, 'objectwrap'), './generated/binding.cc test_helper.h ../test/objectwrap.cc');
99
-
100
- console.log('ALL tests passed');
101
- }
@@ -1,88 +0,0 @@
1
- const fs = require('fs');
2
- const path = require('path');
3
- const exceptions = require('./exceptions');
4
-
5
- const buildFiles = {};
6
- const buidDirs = {};
7
-
8
- /**
9
- * @param fileName - expect to be in snake case , eg: this_is_a_test_file.cc
10
- * @returns init function name in the file
11
- *
12
- * general format of init function name is camelCase version of the snake_case file name
13
- */
14
- function getExportObjectName (fileName) {
15
- fileName = fileName.split('_').map(token => exceptions.nouns[token] ? exceptions.nouns[token] : token).join('_');
16
- const str = fileName.replace(/(_\w)/g, (k) => k[1].toUpperCase());
17
- const exportObjectName = str.charAt(0).toUpperCase() + str.substring(1);
18
- if (exceptions.exportNames[exportObjectName]) {
19
- return exceptions.exportNames[exportObjectName];
20
- }
21
- return exportObjectName;
22
- }
23
-
24
- /**
25
- * @param fileName - expect to be in snake case , eg: this_is_a_test_file.cc
26
- * @returns property name of exported init function
27
- */
28
- function getExportPropertyName (fileName) {
29
- if (exceptions.propertyNames[fileName.toLowerCase()]) {
30
- return exceptions.propertyNames[fileName.toLowerCase()];
31
- }
32
- return fileName;
33
- }
34
-
35
- /**
36
- * creates a configuration list for all available test modules
37
- * The configuration object contains the expected init function names and corresponding export property names
38
- */
39
- function listOfTestModules (currentDirectory = path.join(__dirname, '/../test'), pre = '') {
40
- fs.readdirSync(currentDirectory).forEach((file) => {
41
- if (file === 'binding.cc' ||
42
- file === 'binding.gyp' ||
43
- file === 'build' ||
44
- file === 'common' ||
45
- file === 'thunking_manual.cc' ||
46
- file === 'addon_build' ||
47
- file[0] === '.') {
48
- return;
49
- }
50
- const absoluteFilepath = path.join(currentDirectory, file);
51
- const fileName = file.toLowerCase().replace('.cc', '');
52
- if (fs.statSync(absoluteFilepath).isDirectory()) {
53
- buidDirs[fileName] = [];
54
- listOfTestModules(absoluteFilepath, pre + file + '/');
55
- } else {
56
- if (!file.toLowerCase().endsWith('.cc')) return;
57
- if (currentDirectory.trim().split('/test/').length > 1) {
58
- buidDirs[currentDirectory.split('/test/')[1].toLowerCase()].push(fileName);
59
- }
60
- const relativePath = (currentDirectory.split(`${fileName}.cc`)[0]).split('/test/')[1] || '';
61
- buildFiles[fileName] = { dir: relativePath, propertyName: getExportPropertyName(fileName), objectName: getExportObjectName(fileName) };
62
- }
63
- });
64
- }
65
- listOfTestModules();
66
-
67
- module.exports = {
68
- dirs: buidDirs,
69
- files: buildFiles
70
- };
71
-
72
- /**
73
- * Test cases
74
- * @fires only when run directly from terminal
75
- * eg: node listOfTestModules
76
- */
77
- if (require.main === module) {
78
- const assert = require('assert');
79
- assert.strictEqual(getExportObjectName('objectwrap_constructor_exception'), 'ObjectWrapConstructorException');
80
- assert.strictEqual(getExportObjectName('typed_threadsafe_function'), 'TypedThreadSafeFunction');
81
- assert.strictEqual(getExportObjectName('objectwrap_removewrap'), 'ObjectWrapRemovewrap');
82
- assert.strictEqual(getExportObjectName('function_reference'), 'FunctionReference');
83
- assert.strictEqual(getExportObjectName('async_worker'), 'AsyncWorker');
84
- assert.strictEqual(getExportObjectName('async_progress_worker'), 'AsyncProgressWorker');
85
- assert.strictEqual(getExportObjectName('async_worker_persistent'), 'PersistentAsyncWorker');
86
-
87
- console.log('ALL tests passed');
88
- }
@@ -1,65 +0,0 @@
1
- const listOfTestModules = require('./listOfTestModules');
2
- const buildDirs = listOfTestModules.dirs;
3
- const buildFiles = listOfTestModules.files;
4
-
5
- function isWildcard (filter) {
6
- if (filter.includes('*')) return true;
7
- return false;
8
- }
9
-
10
- function filterBy (wildcard, item) {
11
- return new RegExp('^' + wildcard.replace(/\*/g, '.*') + '$').test(item);
12
- }
13
-
14
- /**
15
- * @param filterCondition
16
- * matches all given wildcards with available test modules to generate an elaborate filter condition
17
- */
18
- function matchWildCards (filterCondition) {
19
- const conditions = filterCondition.split(' ').length ? filterCondition.split(' ') : [filterCondition];
20
- const matches = [];
21
-
22
- for (const filter of conditions) {
23
- if (isWildcard(filter)) {
24
- const matchedDirs = Object.keys(buildDirs).filter(e => filterBy(filter, e));
25
- if (matchedDirs.length) {
26
- matches.push(matchedDirs.join(' '));
27
- }
28
- const matchedModules = Object.keys(buildFiles).filter(e => filterBy(filter, e));
29
- if (matchedModules.length) { matches.push(matchedModules.join(' ')); }
30
- } else {
31
- matches.push(filter);
32
- }
33
- }
34
-
35
- return matches.join(' ');
36
- }
37
-
38
- module.exports.matchWildCards = matchWildCards;
39
-
40
- /**
41
- * Test cases
42
- * @fires only when run directly from terminal
43
- * eg: node matchModules
44
- */
45
- if (require.main === module) {
46
- const assert = require('assert');
47
-
48
- assert.strictEqual(matchWildCards('typed*ex'), 'typed*ex');
49
- assert.strictEqual(matchWildCards('typed*ex*'), 'typed_threadsafe_function_existing_tsfn');
50
- assert.strictEqual(matchWildCards('async*'), 'async_context async_progress_queue_worker async_progress_worker async_worker async_worker_persistent');
51
- assert.strictEqual(matchWildCards('typed*func'), 'typed*func');
52
- assert.strictEqual(matchWildCards('typed*func*'), 'typed_threadsafe_function');
53
- assert.strictEqual(matchWildCards('typed*function'), 'typed_threadsafe_function');
54
- assert.strictEqual(matchWildCards('object*inh'), 'object*inh');
55
- assert.strictEqual(matchWildCards('object*inh*'), 'objectwrap_multiple_inheritance');
56
- assert.strictEqual(matchWildCards('*remove*'), 'objectwrap_removewrap');
57
- assert.strictEqual(matchWildCards('*function'), 'threadsafe_function typed_threadsafe_function');
58
- assert.strictEqual(matchWildCards('**function'), 'threadsafe_function typed_threadsafe_function');
59
- assert.strictEqual(matchWildCards('a*w*p*'), 'async_worker_persistent');
60
- assert.strictEqual(matchWildCards('fun*ref'), 'fun*ref');
61
- assert.strictEqual(matchWildCards('fun*ref*'), 'function_reference');
62
- assert.strictEqual(matchWildCards('*reference'), 'function_reference object_reference reference');
63
-
64
- console.log('ALL tests passed');
65
- }
@@ -1,13 +0,0 @@
1
- const fs = require('fs');
2
- const { generateFileContent, writeToBindingFile } = require('./binding-file-template');
3
-
4
- /**
5
- * @summary setup script to execute before node-gyp begins target actions
6
- */
7
- if (!fs.existsSync('./generated')) {
8
- // create generated folder
9
- fs.mkdirSync('./generated');
10
- // create empty binding.cc file
11
- generateFileContent([]).then(writeToBindingFile);
12
- // FIX: Its necessary to have an empty bindng.cc file, otherwise build fails first time
13
- }
@@ -1,26 +0,0 @@
1
- const { spawn } = require('child_process');
2
-
3
- /**
4
- * spawns a child process to run a given node.js script
5
- */
6
- module.exports.runChildProcess = function (scriptName, options) {
7
- const childProcess = spawn('node', [scriptName], options);
8
-
9
- childProcess.stdout.on('data', data => {
10
- console.log(`${data}`);
11
- });
12
- childProcess.stderr.on('data', data => {
13
- console.log(`error: ${data}`);
14
- });
15
-
16
- return new Promise((resolve, reject) => {
17
- childProcess.on('error', (error) => {
18
- console.log(`error: ${error.message}`);
19
- reject(error);
20
- });
21
- childProcess.on('close', code => {
22
- console.log(`child process exited with code ${code}`);
23
- resolve(code);
24
- });
25
- });
26
- };
@@ -1,30 +0,0 @@
1
- 'use strict';
2
- const path = require('path');
3
- const runChildProcess = require('./spawnTask').runChildProcess;
4
-
5
- /*
6
- * Execute tests with given filter conditions as a child process
7
- */
8
- const executeTests = async function () {
9
- try {
10
- const workingDir = path.join(__dirname, '../');
11
- const relativeBuildPath = path.join('../', 'unit-test');
12
- const buildPath = path.join(__dirname, './unit-test');
13
- const envVars = { ...process.env, REL_BUILD_PATH: relativeBuildPath, BUILD_PATH: buildPath };
14
-
15
- console.log('Starting to run tests in ', buildPath, new Date());
16
-
17
- const code = await runChildProcess('test', { cwd: workingDir, env: envVars });
18
-
19
- if (code !== '0') {
20
- process.exitCode = code;
21
- process.exit(process.exitCode);
22
- }
23
-
24
- console.log('Completed running tests', new Date());
25
- } catch (e) {
26
- console.log('Error occured running tests', new Date());
27
- }
28
- };
29
-
30
- executeTests();
@@ -1,130 +0,0 @@
1
- # node-api-headers Changelog
2
-
3
- ## [1.8.0](https://github.com/nodejs/node-api-headers/compare/v1.7.0...v1.8.0) (2026-01-23)
4
-
5
-
6
- ### Features
7
-
8
- * update headers from nodejs/node tag v25.4.0 ([#70](https://github.com/nodejs/node-api-headers/issues/70)) ([ebc02e1](https://github.com/nodejs/node-api-headers/commit/ebc02e18357a4d49f127f094c144371948b60c84))
9
-
10
- ## [1.7.0](https://github.com/nodejs/node-api-headers/compare/v1.6.0...v1.7.0) (2025-11-28)
11
-
12
-
13
- ### Features
14
-
15
- * update headers from nodejs/node tag v25.1.0 ([#65](https://github.com/nodejs/node-api-headers/issues/65)) ([f90f754](https://github.com/nodejs/node-api-headers/commit/f90f75459375cb4725914895aa418efefdde7af2))
16
- * update headers from nodejs/node tag v25.2.1 ([#68](https://github.com/nodejs/node-api-headers/issues/68)) ([769031b](https://github.com/nodejs/node-api-headers/commit/769031b208acd820bf3f2c3b2cf9f8b4b2e2bd83))
17
-
18
- ## [1.6.0](https://github.com/nodejs/node-api-headers/compare/v1.5.0...v1.6.0) (2025-09-26)
19
-
20
-
21
- ### Features
22
-
23
- * update headers from nodejs/node tag v24.9.0 ([#60](https://github.com/nodejs/node-api-headers/issues/60)) ([5963ef9](https://github.com/nodejs/node-api-headers/commit/5963ef9937c8f6bd8f33cb45c50f70bd9cbc0ffd))
24
-
25
- ## [1.5.0](https://github.com/nodejs/node-api-headers/compare/v1.4.0...v1.5.0) (2025-01-09)
26
-
27
-
28
- ### Features
29
-
30
- * update headers from nodejs/node tag v23.6.0 ([#57](https://github.com/nodejs/node-api-headers/issues/57)) ([64747b1](https://github.com/nodejs/node-api-headers/commit/64747b17a73e8356ed606d1b4dccb626804777f2))
31
-
32
- ## [1.4.0](https://github.com/nodejs/node-api-headers/compare/v1.3.0...v1.4.0) (2024-10-30)
33
-
34
-
35
- ### Features
36
-
37
- * **no-release:** add conditional support in `#if` ([#52](https://github.com/nodejs/node-api-headers/issues/52)) ([e1b8feb](https://github.com/nodejs/node-api-headers/commit/e1b8feb060cf85522538ec1b8a1d6eb782620022))
38
- * update headers from nodejs/node tag v23.1.0 ([#56](https://github.com/nodejs/node-api-headers/issues/56)) ([3336912](https://github.com/nodejs/node-api-headers/commit/33369124c7f8a670422a0c5a27ad149da83ed8d6))
39
-
40
- ## [1.3.0](https://github.com/nodejs/node-api-headers/compare/v1.2.0...v1.3.0) (2024-09-04)
41
-
42
-
43
- ### Features
44
-
45
- * update headers from nodejs/node tag v22.7.0 ([#48](https://github.com/nodejs/node-api-headers/issues/48)) ([6c73c34](https://github.com/nodejs/node-api-headers/commit/6c73c34b72e836531530f863eac315bd42e4569e))
46
-
47
- ## [1.2.0](https://github.com/nodejs/node-api-headers/compare/node-api-headers-v1.1.0...node-api-headers-v1.2.0) (2024-07-09)
48
-
49
-
50
- ### Features
51
-
52
- * update headers from nodejs/node tag v22.1.0 ([d5cfe19](https://github.com/nodejs/node-api-headers/commit/d5cfe19da8b974ca35764dd1c73b91d57cd3c4ce))
53
-
54
- ## 2023-08-05 Version 1.1.0, @NickNaso
55
-
56
- ### Notable changes
57
-
58
- - Update headers from nodejs/node tag v20.3.0.
59
-
60
- ### Commits
61
-
62
- - \[[`1f5a85dbb0`](https://github.com/nodejs/node-api-headers/commit/1f5a85dbb0)] - Update headers from nodejs/node tag v20.3.0 (#30) (github-actions\[bot])
63
-
64
- ## 2023-05-18 Version 1.0.1, @NickNaso
65
-
66
- ### Notable changes
67
-
68
- - Update headers from nodejs/node tag v20.2.0.
69
-
70
- ### Commits
71
-
72
- - \[[`d61451e6a3`](https://github.com/nodejs/node-api-headers/commit/d61451e6a3)] - Update headers from nodejs/node tag v20.2.0 (#27) (github-actions\[bot])
73
-
74
- ## 2023-04-20 Version 1.0.0, @NickNaso
75
-
76
- ### Notable changes
77
-
78
- - Explain package version rationale.
79
- - Update headers from nodejs/node tag v19.9.0.
80
-
81
- ### Commits
82
-
83
- - \[[`130338da33`](https://github.com/nodejs/node-api-headers/commit/130338da33)] - **doc**: explain package version rationale (#26) (Chengzhong Wu)
84
- - \[[`1a328031da`](https://github.com/nodejs/node-api-headers/commit/1a328031da)] - Update headers from nodejs/node tag v19.9.0 (#24) (github-actions\[bot])
85
-
86
- ## 2023-04-06 Version 0.0.5, @NickNaso
87
-
88
- ### Notable changes
89
-
90
- - Provide def file for windows import lib.
91
-
92
- ### Commits
93
-
94
- - \[[`15477c5898`](https://github.com/nodejs/node-api-headers/commit/15477c5898)] - Update headers from nodejs/node tag v19.8.1 (#22) (github-actions\[bot])
95
- - \[[`d7fa23b60e`](https://github.com/nodejs/node-api-headers/commit/d7fa23b60e)] - Use git status instead of git diff for change calculation (#21) (Kevin Eady)
96
- - \[[`ea0dc01425`](https://github.com/nodejs/node-api-headers/commit/ea0dc01425)] - **fix**: moved def files on a proper folder. (#19) (Nicola Del Gobbo)
97
- - \[[`069c3eb6f8`](https://github.com/nodejs/node-api-headers/commit/069c3eb6f8)] - **doc**: how to create a new release. (#18) (Nicola Del Gobbo)
98
- - \[[`d23c2879c8`](https://github.com/nodejs/node-api-headers/commit/d23c2879c8)] - Provide def file for windows import lib (#17) (Leonid Pospelov)
99
-
100
- ## 2023-03-17 Version 0.0.4, @NickNaso
101
-
102
- ### Notable changes
103
-
104
- - Update headers from nodejs/node tag v19.8.0.
105
-
106
- ### Commits
107
-
108
- - \[[`a1f0d41240`](https://github.com/nodejs/node-api-headers/commit/a1f0d41240)] - Merge pull request #14 from nodejs/update-headers/v19.8.0 (Nicola Del Gobbo)
109
- - \[[`7548267285`](https://github.com/nodejs/node-api-headers/commit/7548267285)] - Update headers from nodejs/node tag v19.8.0 (github-actions\[bot])
110
-
111
- ## 2023-03-08 Version 0.0.3, @NickNaso
112
-
113
- ### Notable changes
114
-
115
- - Add helper scripts for updating headers and symbols.js.
116
-
117
- ### Commits
118
-
119
- - \[[`4fdbdd1710`](https://github.com/nodejs/node-api-headers/commit/4fdbdd1710)] - Update headers from nodejs/node tag v19.6.0 (#9) (github-actions\[bot])
120
- - \[[`ecefbdd00f`](https://github.com/nodejs/node-api-headers/commit/ecefbdd00f)] - Add helper scripts for updating headers and symbols.js (#7) (Kevin Eady)
121
-
122
- ## 2022-12-29 Version 0.0.2, @NickNaso
123
-
124
- ### Notable changes
125
-
126
- - Fixed wrong symblos in v6.
127
-
128
- ### Commits
129
-
130
- - \[[`9c0b4ecaa5`](https://github.com/nodejs/node-api-headers/commit/9c0b4ecaa5)] - **fix**: wrong symblos in v6 (#6) (Nicola Del Gobbo)
@@ -1,4 +0,0 @@
1
- # Code of Conduct
2
-
3
- The Node.js Code of Conduct, which applies to this project, can be found at
4
- https://github.com/nodejs/admin/blob/master/CODE_OF_CONDUCT.md.
@@ -1,32 +0,0 @@
1
- # Developer's Certificate of Origin 1.1
2
-
3
- By making a contribution to this project, I certify that:
4
-
5
- * (a) The contribution was created in whole or in part by me and I
6
- have the right to submit it under the open source license
7
- indicated in the file; or
8
-
9
- * (b) The contribution is based upon previous work that, to the best
10
- of my knowledge, is covered under an appropriate open source
11
- license and I have the right under that license to submit that
12
- work with modifications, whether created in whole or in part
13
- by me, under the same open source license (unless I am
14
- permitted to submit under a different license), as indicated
15
- in the file; or
16
-
17
- * (c) The contribution was provided directly to me by some other
18
- person who certified (a), (b) or (c) and I have not modified
19
- it.
20
-
21
- * (d) I understand and agree that this project and the contribution
22
- are public and that a record of the contribution (including all
23
- personal information I submit with it, including my sign-off) is
24
- maintained indefinitely and may be redistributed consistent with
25
- this project or the open source license(s) involved.
26
-
27
- ## Moderation Policy
28
-
29
- The [Node.js Moderation Policy] applies to this project.
30
-
31
- [Node.js Moderation Policy]:
32
- https://github.com/nodejs/admin/blob/master/Moderation-Policy.md