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,115 +0,0 @@
1
- # Setup
2
-
3
- ## Prerequisites
4
-
5
- Before starting to use **Node-API** you need to assure you have the following
6
- prerequisites:
7
-
8
- * **Node.JS** see: [Installing Node.js](https://nodejs.org/)
9
-
10
- * **Node.js native addon build tool**
11
-
12
- - **[node-gyp](node-gyp.md)**
13
-
14
- ## Installation and usage
15
-
16
- To use **Node-API** in a native module:
17
-
18
- 1. Add a dependency on this package to `package.json`:
19
-
20
- ```json
21
- "dependencies": {
22
- "node-addon-api": "*",
23
- }
24
- ```
25
-
26
- 2. Decide whether the package will enable C++ exceptions in the Node-API
27
- wrapper, and reference this package as a dependency in `binding.gyp`.
28
- The base ABI-stable C APIs do not throw or handle C++ exceptions, but the
29
- Node-API C++ wrapper classes may _optionally_
30
- [integrate C++ and JavaScript exception-handling
31
- ](https://github.com/nodejs/node-addon-api/blob/HEAD/doc/error_handling.md).
32
-
33
- To use without C++ exceptions, add the following to `binding.gyp`:
34
-
35
- ```gyp
36
- 'dependencies': [
37
- "<!(node -p \"require('node-addon-api').targets\"):node_addon_api",
38
- ],
39
- ```
40
-
41
- To enable that capability, add an alternative dependency in `binding.gyp`
42
- depending on if you want to integrate C++ exception handling for exceptions
43
- derived from `Napi::Error` or all C++ exceptions. To catch only
44
- `Napi::Error` exceptions, use:
45
-
46
- ```gyp
47
- 'dependencies': [
48
- "<!(node -p \"require('node-addon-api').targets\"):node_addon_api_except",
49
- ],
50
- ```
51
-
52
- Or, to allow catching all native C++ exceptions, use the
53
- `node_addon_api_except_all` dependency:
54
-
55
- ```gyp
56
- 'dependencies': [
57
- "<!(node -p \"require('node-addon-api').targets\"):node_addon_api_except_all",
58
- ],
59
- ```
60
-
61
- If you decide to use node-addon-api without C++ exceptions enabled, please
62
- consider enabling node-addon-api safe API type guards to ensure the proper
63
- exception handling pattern:
64
-
65
- ```gyp
66
- 'dependencies': [
67
- "<!(node -p \"require('node-addon-api').targets\"):node_addon_api_maybe",
68
- ],
69
- ```
70
-
71
- 3. If you would like your native addon to support OSX, please also add the
72
- following settings in the `binding.gyp` file:
73
-
74
- ```gyp
75
- 'conditions': [
76
- ['OS=="mac"', {
77
- 'cflags+': ['-fvisibility=hidden'],
78
- 'xcode_settings': {
79
- 'GCC_SYMBOLS_PRIVATE_EXTERN': 'YES', # -fvisibility=hidden
80
- }
81
- }]
82
- ]
83
- ```
84
-
85
- 4. Include `napi.h` in the native module code.
86
- To ensure only ABI-stable APIs are used, DO NOT include
87
- `node.h`, `nan.h`, or `v8.h`.
88
-
89
- ```C++
90
- #include "napi.h"
91
- ```
92
-
93
- At build time, the Node-API back-compat library code will be used only when the
94
- targeted node version *does not* have Node-API built-in.
95
-
96
- The `NODE_ADDON_API_DISABLE_DEPRECATED` preprocessor directive can be defined at
97
- compile time before including `napi.h` to skip the definition of deprecated
98
- APIs.
99
-
100
- By default, throwing an exception on a terminating environment (eg. worker
101
- threads) will cause a fatal exception, terminating the Node process. This is to
102
- provide feedback to the user of the runtime error, as it is impossible to pass
103
- the error to JavaScript when the environment is terminating. The
104
- `NODE_API_SWALLOW_UNTHROWABLE_EXCEPTIONS` preprocessor directive can be defined
105
- to bypass this behavior, such that the Node process will not terminate.
106
-
107
- Various Node-API constructs provide a mechanism to run a callback in response to
108
- a garbage collection event of that object. These callbacks are called
109
- [_finalizers_]. Some finalizers have restrictions on the type of Node-APIs
110
- available within the callback. node-addon-api provides convenience helpers that
111
- bypass this limitation, but may cause the add-on to run less efficiently. The
112
- `NODE_ADDON_API_REQUIRE_BASIC_FINALIZERS` preprocessor directive can be defined
113
- to disable the convenience helpers.
114
-
115
- [_finalizers_]: ./finalization.md
@@ -1,93 +0,0 @@
1
- # String
2
-
3
- Class `Napi::String` inherits from class [`Napi::Name`][].
4
-
5
- ## Constructor
6
-
7
- ```cpp
8
- Napi::String::String();
9
- ```
10
-
11
- Returns a new **empty** `Napi::String` instance.
12
-
13
- If an error occurs, a `Napi::Error` will get thrown. If C++ exceptions are not
14
- being used, callers should check the result of `Env::IsExceptionPending` before
15
- attempting to use the returned value.
16
-
17
- ```cpp
18
- Napi::String::String(napi_env env, napi_value value); ///< Wraps a Node-API value primitive.
19
- ```
20
- - `[in] env` - The environment in which to create the string.
21
- - `[in] value` - The primitive to wrap.
22
-
23
- Returns a `Napi::String` wrapping a `napi_value`.
24
-
25
- If an error occurs, a `Napi::Error` will get thrown. If C++ exceptions are not
26
- being used, callers should check the result of `Env::IsExceptionPending` before
27
- attempting to use the returned value.
28
-
29
- ## Operators
30
-
31
- ### operator std::string
32
-
33
- ```cpp
34
- Napi::String::operator std::string() const;
35
- ```
36
-
37
- Returns a UTF-8 encoded C++ string.
38
-
39
- ### operator std::u16string
40
- ```cpp
41
- Napi::String::operator std::u16string() const;
42
- ```
43
-
44
- Returns a UTF-16 encoded C++ string.
45
-
46
- ## Methods
47
-
48
- ### New
49
- ```cpp
50
- Napi::String::New();
51
- ```
52
-
53
- Returns a new empty `Napi::String`.
54
-
55
- ### New
56
- ```cpp
57
- Napi::String::New(napi_env env, const std::string& value);
58
- Napi::String::New(napi_env env, const std::u16::string& value);
59
- Napi::String::New(napi_env env, const char* value);
60
- Napi::String::New(napi_env env, const char16_t* value);
61
- Napi::String::New(napi_env env, const char* value, size_t length);
62
- Napi::String::New(napi_env env, const char16_t* value, size_t length);
63
- ```
64
-
65
- - `[in] env`: The `napi_env` environment in which to construct the `Napi::Value` object.
66
- - `[in] value`: The C++ primitive from which to instantiate the `Napi::Value`. `value` may be any of:
67
- - `std::string&` - represents a UTF8 string.
68
- - `std::u16string&` - represents a UTF16-LE string.
69
- - `const char*` - represents a UTF8 string.
70
- - `const char16_t*` - represents a UTF16-LE string.
71
- - `[in] length`: The length of the string (not necessarily null-terminated) in code units.
72
-
73
- Returns a new `Napi::String` that represents the passed in C++ string.
74
-
75
- If an error occurs, a `Napi::Error` will get thrown. If C++ exceptions are not
76
- being used, callers should check the result of `Env::IsExceptionPending` before
77
- attempting to use the returned value.
78
-
79
- ### Utf8Value
80
- ```cpp
81
- std::string Napi::String::Utf8Value() const;
82
- ```
83
-
84
- Returns a UTF-8 encoded C++ string.
85
-
86
- ### Utf16Value
87
- ```cpp
88
- std::u16string Napi::String::Utf16Value() const;
89
- ```
90
-
91
- Returns a UTF-16 encoded C++ string.
92
-
93
- [`Napi::Name`]: ./name.md
@@ -1,61 +0,0 @@
1
- # Symbol
2
-
3
- Class `Napi::Symbol` inherits from class [`Napi::Name`][].
4
-
5
- ## Methods
6
-
7
- ### Constructor
8
-
9
- Instantiates a new `Napi::Symbol` value.
10
-
11
- ```cpp
12
- Napi::Symbol::Symbol();
13
- ```
14
-
15
- Returns a new empty `Napi::Symbol`.
16
-
17
- ### New
18
- ```cpp
19
- Napi::Symbol::New(napi_env env, const std::string& description);
20
- Napi::Symbol::New(napi_env env, const char* description);
21
- Napi::Symbol::New(napi_env env, Napi::String description);
22
- Napi::Symbol::New(napi_env env, napi_value description);
23
- ```
24
-
25
- - `[in] env`: The `napi_env` environment in which to construct the `Napi::Symbol` object.
26
- - `[in] value`: The C++ primitive which represents the description hint for the `Napi::Symbol`.
27
- `description` may be any of:
28
- - `std::string&` - UTF8 string description.
29
- - `const char*` - represents a UTF8 string description.
30
- - `String` - Node addon API String description.
31
- - `napi_value` - Node-API `napi_value` description.
32
-
33
- If an error occurs, a `Napi::Error` will get thrown. If C++ exceptions are not
34
- being used, callers should check the result of `Napi::Env::IsExceptionPending` before
35
- attempting to use the returned value.
36
-
37
- ### WellKnown
38
- ```cpp
39
- static Napi::Symbol Napi::Symbol::WellKnown(napi_env env, const std::string& name);
40
- ```
41
-
42
- - `[in] env`: The `napi_env` environment in which to construct the `Napi::Symbol` object.
43
- - `[in] name`: The C++ string representing the `Napi::Symbol` to retrieve.
44
-
45
- Returns a `Napi::Symbol` representing a well-known `Symbol` from the
46
- `Symbol` registry.
47
-
48
- ### For
49
- ```cpp
50
- static Napi::Symbol Napi::Symbol::For(napi_env env, const std::string& description);
51
- static Napi::Symbol Napi::Symbol::For(napi_env env, const char* description);
52
- static Napi::Symbol Napi::Symbol::For(napi_env env, String description);
53
- static Napi::Symbol Napi::Symbol::For(napi_env env, napi_value description);
54
- ```
55
-
56
- - `[in] env`: The `napi_env` environment in which to construct the `Napi::Symbol` object.
57
- - `[in] description`: The C++ string representing the `Napi::Symbol` in the global registry to retrieve.
58
-
59
- Searches in the global registry for existing symbol with the given name. If the symbol already exist it will be returned, otherwise a new symbol will be created in the registry. It's equivalent to Symbol.for() called from JavaScript.
60
-
61
- [`Napi::Name`]: ./name.md
@@ -1,66 +0,0 @@
1
- # SyntaxError
2
-
3
- The `Napi::SyntaxError` class is a representation of the JavaScript
4
- `SyntaxError` that is thrown when the engine encounters tokens or token order
5
- that does not conform to the syntax of the language when parsing code.
6
-
7
- The `Napi::SyntaxError` class inherits its behaviors from the `Napi::Error`
8
- class (for more info see: [`Napi::Error`](error.md)).
9
-
10
- For more details about error handling refer to the section titled [Error
11
- handling](error_handling.md).
12
-
13
- ## Methods
14
-
15
- ### New
16
-
17
- Creates a new instance of a `Napi::SyntaxError` object.
18
-
19
- ```cpp
20
- Napi::SyntaxError::New(Napi::Env env, const char* message);
21
- ```
22
-
23
- - `[in] Env`: The environment in which to construct the `Napi::SyntaxError`
24
- object.
25
- - `[in] message`: Null-terminated string to be used as the message for the
26
- `Napi::SyntaxError`.
27
-
28
- Returns an instance of a `Napi::SyntaxError` object.
29
-
30
- ### New
31
-
32
- Creates a new instance of a `Napi::SyntaxError` object.
33
-
34
- ```cpp
35
- Napi::SyntaxError::New(Napi::Env env, const std::string& message);
36
- ```
37
-
38
- - `[in] Env`: The environment in which to construct the `Napi::SyntaxError`
39
- object.
40
- - `[in] message`: Reference string to be used as the message for the
41
- `Napi::SyntaxError`.
42
-
43
- Returns an instance of a `Napi::SyntaxError` object.
44
-
45
- ### Constructor
46
-
47
- Creates a new empty instance of a `Napi::SyntaxError`.
48
-
49
- ```cpp
50
- Napi::SyntaxError::SyntaxError();
51
- ```
52
-
53
- ### Constructor
54
-
55
- Initializes a `Napi::SyntaxError` instance from an existing Javascript error
56
- object.
57
-
58
- ```cpp
59
- Napi::SyntaxError::SyntaxError(napi_env env, napi_value value);
60
- ```
61
-
62
- - `[in] Env`: The environment in which to construct the `Napi::SyntaxError`
63
- object.
64
- - `[in] value`: The `Napi::Error` reference to wrap.
65
-
66
- Returns an instance of a `Napi::SyntaxError` object.
@@ -1,121 +0,0 @@
1
- # Thread-safe Functions
2
-
3
- JavaScript functions can normally only be called from a native addon's main
4
- thread. If an addon creates additional threads, then node-addon-api functions
5
- that require a `Napi::Env`, `Napi::Value`, or `Napi::Reference` must not be
6
- called from those threads.
7
-
8
- When an addon has additional threads and JavaScript functions need to be invoked
9
- based on the processing completed by those threads, those threads must
10
- communicate with the addon's main thread so that the main thread can invoke the
11
- JavaScript function on their behalf. The thread-safe function APIs provide an
12
- easy way to do this. These APIs provide two types --
13
- [`Napi::ThreadSafeFunction`](threadsafe_function.md) and
14
- [`Napi::TypedThreadSafeFunction`](typed_threadsafe_function.md) -- as well as
15
- APIs to create, destroy, and call objects of this type. The differences between
16
- the two are subtle and are [highlighted below](#implementation-differences).
17
- Regardless of which type you choose, the APIs between the two are similar.
18
-
19
- `Napi::[Typed]ThreadSafeFunction::New()` creates a persistent reference that
20
- holds a JavaScript function which can be called from multiple threads. The calls
21
- happen asynchronously. This means that values with which the JavaScript callback
22
- is to be called will be placed in a queue, and, for each value in the queue, a
23
- call will eventually be made to the JavaScript function.
24
-
25
- `Napi::[Typed]ThreadSafeFunction` objects are destroyed when every thread which
26
- uses the object has called `Release()` or has received a return status of
27
- `napi_closing` in response to a call to `BlockingCall()` or `NonBlockingCall()`.
28
- The queue is emptied before the `Napi::[Typed]ThreadSafeFunction` is destroyed.
29
- It is important that `Release()` be the last API call made in conjunction with a
30
- given `Napi::[Typed]ThreadSafeFunction`, because after the call completes, there
31
- is no guarantee that the `Napi::[Typed]ThreadSafeFunction` is still allocated.
32
- For the same reason it is also important that no more use be made of a
33
- thread-safe function after receiving a return value of `napi_closing` in
34
- response to a call to `BlockingCall()` or `NonBlockingCall()`. Data associated
35
- with the `Napi::[Typed]ThreadSafeFunction` can be freed in its `Finalizer`
36
- callback which was passed to `[Typed]ThreadSafeFunction::New()`.
37
-
38
- Once the number of threads making use of a `Napi::[Typed]ThreadSafeFunction`
39
- reaches zero, no further threads can start making use of it by calling
40
- `Acquire()`. In fact, all subsequent API calls associated with it, except
41
- `Release()`, will return an error value of `napi_closing`.
42
-
43
- ## Implementation Differences
44
-
45
- The choice between `Napi::ThreadSafeFunction` and
46
- `Napi::TypedThreadSafeFunction` depends largely on how you plan to execute your
47
- native C++ code (the "callback") on the Node.js thread.
48
-
49
- ### [`Napi::ThreadSafeFunction`](threadsafe_function.md)
50
-
51
- This API is designed without Node-API 5 native support for [the optional JavaScript
52
- function callback feature](https://github.com/nodejs/node/commit/53297e66cb).
53
-
54
- This API has some dynamic functionality, in that:
55
- - The `[Non]BlockingCall()` methods provide a `Napi::Function` parameter as the
56
- callback to run when processing the data item on the main thread -- the
57
- `CallJs` callback. Since the callback is a parameter, it can be changed for
58
- every call.
59
- - Different C++ data types may be passed with each call of `[Non]BlockingCall()`
60
- to match the specific data type as specified in the `CallJs` callback.
61
-
62
- Note that this functionality comes with some **additional overhead** and
63
- situational **memory leaks**:
64
- - The API acts as a "broker" between the underlying `napi_threadsafe_function`,
65
- and dynamically constructs a wrapper for your callback on the heap for every
66
- call to `[Non]BlockingCall()`.
67
- - In acting in this "broker" fashion, the API will call the underlying "make
68
- call" Node-API method on this packaged item. If the API has determined the
69
- thread-safe function is no longer accessible (eg. all threads have released
70
- yet there are still items on the queue), **the callback passed to
71
- [Non]BlockingCall will not execute**. This means it is impossible to perform
72
- clean-up for calls that never execute their `CallJs` callback. **This may lead
73
- to memory leaks** if you are dynamically allocating memory.
74
- - The `CallJs` does not receive the thread-safe function's context as a
75
- parameter. In order for the callback to access the context, it must have a
76
- reference to either (1) the context directly, or (2) the thread-safe function
77
- to call `GetContext()`. Furthermore, the `GetContext()` method is not
78
- _type-safe_, as the method returns an object that can be "any-casted", instead
79
- of having a static type.
80
-
81
- ### [`Napi::TypedThreadSafeFunction`](typed_threadsafe_function.md)
82
-
83
- The `TypedThreadSafeFunction` class is a new implementation to address the
84
- drawbacks listed above. The API is designed with Node-API 5's support of an
85
- optional function callback. The API will correctly allow developers to pass
86
- `std::nullptr` instead of a `const Function&` for the callback function
87
- specified in `::New`. It also provides helper APIs to _target_ Node-API 4 and
88
- construct a no-op `Function` **or** to target Node-API 5 and "construct" a
89
- `std::nullptr` callback. This allows a single codebase to use the same APIs,
90
- with just a switch of the `NAPI_VERSION` compile-time constant.
91
-
92
- The removal of the dynamic call functionality has the following implications:
93
- - The API does _not_ act as a "broker" compared to the
94
- `Napi::ThreadSafeFunction`. Once Node.js finalizes the thread-safe function,
95
- the `CallJs` callback will execute with an empty `Napi::Env` for any remaining
96
- items on the queue. This provides the ability to handle any necessary cleanup
97
- of the item's data.
98
- - The callback _does_ receive the context as a parameter, so a call to
99
- `GetContext()` is _not_ necessary. This context type is specified as the
100
- **first template argument** specified to `::New`, ensuring type safety.
101
- - The `New()` constructor accepts the `CallJs` callback as the **second type
102
- argument**. The callback must be statically defined for the API to access it.
103
- This affords the ability to statically pass the context as the correct type
104
- across all methods.
105
- - Only one C++ data type may be specified to every call to `[Non]BlockingCall()`
106
- -- the **third template argument** specified to `::New`. Any "dynamic call
107
- data" must be implemented by the user.
108
-
109
-
110
- ### Usage Suggestions
111
-
112
- In summary, it may be best to use `Napi::TypedThreadSafeFunction` if:
113
-
114
- - static, compile-time support for targeting Node-API 4 or 5+ with an optional
115
- JavaScript callback feature is desired;
116
- - the callback can have `static` storage class and will not change across calls
117
- to `[Non]BlockingCall()`;
118
- - cleanup of items' data is required (eg. deleting dynamically-allocated data
119
- that is created at the caller level).
120
-
121
- Otherwise, `Napi::ThreadSafeFunction` may be a better choice.