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.
- package/CHANGELOG.md +59 -0
- package/build/koffi/darwin_arm64/koffi.node +0 -0
- package/build/koffi/darwin_x64/koffi.node +0 -0
- package/build/koffi/freebsd_arm64/koffi.node +0 -0
- package/build/koffi/freebsd_ia32/koffi.node +0 -0
- package/build/koffi/freebsd_x64/koffi.node +0 -0
- package/build/koffi/linux_arm64/koffi.node +0 -0
- package/build/koffi/linux_armhf/koffi.node +0 -0
- package/build/koffi/linux_ia32/koffi.node +0 -0
- package/build/koffi/linux_loong64/koffi.node +0 -0
- package/build/koffi/linux_riscv64d/koffi.node +0 -0
- package/build/koffi/linux_x64/koffi.node +0 -0
- package/build/koffi/musl_arm64/koffi.node +0 -0
- package/build/koffi/musl_x64/koffi.node +0 -0
- package/build/koffi/openbsd_ia32/koffi.node +0 -0
- package/build/koffi/openbsd_x64/koffi.node +0 -0
- package/build/koffi/win32_arm64/koffi.exp +0 -0
- package/build/koffi/win32_arm64/koffi.lib +0 -0
- package/build/koffi/win32_arm64/koffi.node +0 -0
- package/build/koffi/win32_ia32/koffi.exp +0 -0
- package/build/koffi/win32_ia32/koffi.lib +0 -0
- package/build/koffi/win32_ia32/koffi.node +0 -0
- package/build/koffi/win32_x64/koffi.exp +0 -0
- package/build/koffi/win32_x64/koffi.lib +0 -0
- package/build/koffi/win32_x64/koffi.node +0 -0
- package/index.d.ts +9 -11
- package/index.js +6 -9
- package/indirect.js +6 -9
- package/lib/native/base/base.cc +1 -6
- package/package.json +3 -3
- package/src/cnoke/assets/FindCNoke.cmake +27 -16
- package/src/cnoke/assets/toolchains.json +126 -0
- package/src/cnoke/cnoke.js +27 -33
- package/src/cnoke/src/builder.js +124 -63
- package/src/cnoke/src/tools.js +1 -5
- package/src/koffi/CMakeLists.txt +32 -21
- package/src/koffi/src/{abi/arm32.cc → abi_arm32.cc} +235 -238
- package/src/koffi/src/{abi/arm32_asm.S → abi_arm32_asm.S} +19 -15
- package/src/koffi/src/{abi/arm64.cc → abi_arm64.cc} +253 -274
- package/src/koffi/src/{abi/arm64_asm.S → abi_arm64_asm.S} +16 -10
- package/src/koffi/src/{abi/arm64_asm.asm → abi_arm64_asm.asm} +17 -10
- package/src/koffi/src/{abi/loong64_asm.S → abi_loong64_asm.S} +16 -10
- package/src/koffi/src/{abi/riscv64.cc → abi_riscv64.cc} +233 -236
- package/src/koffi/src/{abi/riscv64_asm.S → abi_riscv64_asm.S} +16 -10
- package/src/koffi/src/{abi/x64_sysv.cc → abi_x64_sysv.cc} +208 -212
- package/src/koffi/src/{abi/x64_sysv_asm.S → abi_x64_sysv_asm.S} +17 -10
- package/src/koffi/src/{abi/x64_win.cc → abi_x64_win.cc} +175 -206
- package/src/koffi/src/{abi/x64_win_asm.S → abi_x64_win_asm.S} +49 -27
- package/src/koffi/src/{abi/x64_win_asm.asm → abi_x64_win_asm.asm} +54 -27
- package/src/koffi/src/{abi/x86.cc → abi_x86.cc} +187 -226
- package/src/koffi/src/{abi/x86_asm.S → abi_x86_asm.S} +36 -21
- package/src/koffi/src/{abi/x86_asm.asm → abi_x86_asm.asm} +31 -16
- package/src/koffi/src/call.cc +473 -287
- package/src/koffi/src/call.hh +15 -18
- package/src/koffi/src/ffi.cc +167 -183
- package/src/koffi/src/ffi.hh +59 -13
- package/src/koffi/src/init.js +1 -0
- package/src/koffi/src/util.cc +113 -159
- package/src/koffi/src/util.hh +23 -74
- package/src/koffi/src/win32.cc +13 -0
- package/src/koffi/src/win32.hh +7 -0
- package/src/koffi/tools/write_trampolines.js +77 -0
- package/doc/README.md +0 -27
- package/doc/assets.ini +0 -24
- package/doc/build.sh +0 -9
- package/doc/develop.sh +0 -15
- package/doc/pages/404.md +0 -17
- package/doc/pages.ini +0 -86
- package/doc/static/highlight.js +0 -8
- package/doc/static/koffi.css +0 -11
- package/doc/static/koffi.png +0 -0
- package/doc/static/logo.webp +0 -0
- package/doc/static/perf_linux.png +0 -0
- package/doc/static/perf_windows.png +0 -0
- package/doc/static/print.css +0 -10
- package/doc/templates/code.html +0 -48
- package/doc/templates/page.html +0 -47
- package/src/koffi/cmake/raylib.cmake +0 -85
- package/src/koffi/cmake/sqlite3.cmake +0 -9
- package/src/koffi/examples/electron-builder/README.md +0 -11
- package/src/koffi/examples/electron-builder/package.json +0 -21
- package/src/koffi/examples/electron-builder/src/app.js +0 -20
- package/src/koffi/examples/electron-builder/src/index.html +0 -143
- package/src/koffi/examples/electron-builder/src/preload.js +0 -5
- package/src/koffi/examples/electron-forge/README.md +0 -25
- package/src/koffi/examples/electron-forge/forge.config.js +0 -63
- package/src/koffi/examples/electron-forge/package.json +0 -39
- package/src/koffi/examples/electron-forge/src/index.css +0 -7
- package/src/koffi/examples/electron-forge/src/index.html +0 -143
- package/src/koffi/examples/electron-forge/src/main.js +0 -52
- package/src/koffi/examples/electron-forge/src/preload.js +0 -5
- package/src/koffi/examples/electron-forge/src/renderer.js +0 -31
- package/src/koffi/examples/electron-forge/webpack.main.config.js +0 -11
- package/src/koffi/examples/electron-forge/webpack.renderer.config.js +0 -13
- package/src/koffi/examples/electron-forge/webpack.rules.js +0 -35
- package/src/koffi/examples/node-esbuild/README.md +0 -19
- package/src/koffi/examples/node-esbuild/index.js +0 -2
- package/src/koffi/examples/node-esbuild/package.json +0 -16
- package/src/koffi/examples/nwjs/README.md +0 -20
- package/src/koffi/examples/nwjs/package.json +0 -11
- package/src/koffi/examples/nwjs/src/index.html +0 -145
- package/src/koffi/examples/nwjs/src/package.json +0 -10
- package/src/koffi/examples/yao-pkg/README.md +0 -17
- package/src/koffi/examples/yao-pkg/index.js +0 -2
- package/src/koffi/examples/yao-pkg/package.json +0 -22
- package/src/koffi/src/primitives.inc +0 -39
- package/src/koffi/src/trampolines/armasm.inc +0 -32771
- package/src/koffi/src/trampolines/gnu.inc +0 -24577
- package/src/koffi/src/trampolines/masm32.inc +0 -32769
- package/src/koffi/src/trampolines/masm64.inc +0 -32769
- package/src/koffi/src/trampolines/prototypes.inc +0 -16388
- package/vendor/node-addon-api/CHANGELOG.md +0 -1272
- package/vendor/node-addon-api/CODE_OF_CONDUCT.md +0 -4
- package/vendor/node-addon-api/CONTRIBUTING.md +0 -203
- package/vendor/node-addon-api/appveyor.yml +0 -37
- package/vendor/node-addon-api/benchmark/README.md +0 -47
- package/vendor/node-addon-api/benchmark/binding.gyp +0 -25
- package/vendor/node-addon-api/benchmark/function_args.cc +0 -250
- package/vendor/node-addon-api/benchmark/function_args.js +0 -60
- package/vendor/node-addon-api/benchmark/index.js +0 -34
- package/vendor/node-addon-api/benchmark/property_descriptor.cc +0 -84
- package/vendor/node-addon-api/benchmark/property_descriptor.js +0 -38
- package/vendor/node-addon-api/common.gypi +0 -21
- package/vendor/node-addon-api/doc/README.md +0 -145
- package/vendor/node-addon-api/doc/addon.md +0 -163
- package/vendor/node-addon-api/doc/array.md +0 -81
- package/vendor/node-addon-api/doc/array_buffer.md +0 -165
- package/vendor/node-addon-api/doc/async_context.md +0 -86
- package/vendor/node-addon-api/doc/async_operations.md +0 -31
- package/vendor/node-addon-api/doc/async_worker.md +0 -428
- package/vendor/node-addon-api/doc/async_worker_variants.md +0 -578
- package/vendor/node-addon-api/doc/basic_env.md +0 -200
- package/vendor/node-addon-api/doc/bigint.md +0 -97
- package/vendor/node-addon-api/doc/boolean.md +0 -68
- package/vendor/node-addon-api/doc/buffer.md +0 -245
- package/vendor/node-addon-api/doc/callback_scope.md +0 -54
- package/vendor/node-addon-api/doc/callbackinfo.md +0 -97
- package/vendor/node-addon-api/doc/checker-tool.md +0 -32
- package/vendor/node-addon-api/doc/class_property_descriptor.md +0 -123
- package/vendor/node-addon-api/doc/cmake-js.md +0 -87
- package/vendor/node-addon-api/doc/contributing/creating_a_release.md +0 -95
- package/vendor/node-addon-api/doc/conversion-tool.md +0 -28
- package/vendor/node-addon-api/doc/dataview.md +0 -248
- package/vendor/node-addon-api/doc/date.md +0 -68
- package/vendor/node-addon-api/doc/env.md +0 -87
- package/vendor/node-addon-api/doc/error.md +0 -120
- package/vendor/node-addon-api/doc/error_handling.md +0 -266
- package/vendor/node-addon-api/doc/escapable_handle_scope.md +0 -80
- package/vendor/node-addon-api/doc/external.md +0 -79
- package/vendor/node-addon-api/doc/external_buffer.md +0 -18
- package/vendor/node-addon-api/doc/finalization.md +0 -153
- package/vendor/node-addon-api/doc/function.md +0 -402
- package/vendor/node-addon-api/doc/function_reference.md +0 -238
- package/vendor/node-addon-api/doc/generator.md +0 -13
- package/vendor/node-addon-api/doc/handle_scope.md +0 -77
- package/vendor/node-addon-api/doc/hierarchy.md +0 -95
- package/vendor/node-addon-api/doc/instance_wrap.md +0 -408
- package/vendor/node-addon-api/doc/maybe.md +0 -76
- package/vendor/node-addon-api/doc/memory_management.md +0 -27
- package/vendor/node-addon-api/doc/name.md +0 -29
- package/vendor/node-addon-api/doc/node-gyp.md +0 -82
- package/vendor/node-addon-api/doc/number.md +0 -163
- package/vendor/node-addon-api/doc/object.md +0 -411
- package/vendor/node-addon-api/doc/object_lifetime_management.md +0 -83
- package/vendor/node-addon-api/doc/object_reference.md +0 -117
- package/vendor/node-addon-api/doc/object_wrap.md +0 -604
- package/vendor/node-addon-api/doc/prebuild_tools.md +0 -16
- package/vendor/node-addon-api/doc/promises.md +0 -130
- package/vendor/node-addon-api/doc/property_descriptor.md +0 -286
- package/vendor/node-addon-api/doc/propertylvalue.md +0 -50
- package/vendor/node-addon-api/doc/range_error.md +0 -59
- package/vendor/node-addon-api/doc/reference.md +0 -113
- package/vendor/node-addon-api/doc/setup.md +0 -115
- package/vendor/node-addon-api/doc/string.md +0 -93
- package/vendor/node-addon-api/doc/symbol.md +0 -61
- package/vendor/node-addon-api/doc/syntax_error.md +0 -66
- package/vendor/node-addon-api/doc/threadsafe.md +0 -121
- package/vendor/node-addon-api/doc/threadsafe_function.md +0 -290
- package/vendor/node-addon-api/doc/type_error.md +0 -59
- package/vendor/node-addon-api/doc/type_taggable.md +0 -40
- package/vendor/node-addon-api/doc/typed_array.md +0 -78
- package/vendor/node-addon-api/doc/typed_array_of.md +0 -137
- package/vendor/node-addon-api/doc/typed_threadsafe_function.md +0 -306
- package/vendor/node-addon-api/doc/value.md +0 -368
- package/vendor/node-addon-api/doc/version_management.md +0 -43
- package/vendor/node-addon-api/eslint.config.js +0 -5
- package/vendor/node-addon-api/except.gypi +0 -25
- package/vendor/node-addon-api/index.js +0 -14
- package/vendor/node-addon-api/node_addon_api.gyp +0 -42
- package/vendor/node-addon-api/node_api.gyp +0 -9
- package/vendor/node-addon-api/noexcept.gypi +0 -26
- package/vendor/node-addon-api/nothing.c +0 -0
- package/vendor/node-addon-api/package-support.json +0 -21
- package/vendor/node-addon-api/package.json +0 -480
- package/vendor/node-addon-api/release-please-config.json +0 -15
- package/vendor/node-addon-api/test/README.md +0 -91
- package/vendor/node-addon-api/test/addon.cc +0 -44
- package/vendor/node-addon-api/test/addon.js +0 -7
- package/vendor/node-addon-api/test/addon_build/index.js +0 -49
- package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +0 -18
- package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +0 -63
- package/vendor/node-addon-api/test/addon_build/tpl/index.js +0 -9
- package/vendor/node-addon-api/test/addon_build/tpl/package.json +0 -11
- package/vendor/node-addon-api/test/addon_data.cc +0 -98
- package/vendor/node-addon-api/test/addon_data.js +0 -24
- package/vendor/node-addon-api/test/array_buffer.cc +0 -243
- package/vendor/node-addon-api/test/array_buffer.js +0 -70
- package/vendor/node-addon-api/test/async_context.cc +0 -36
- package/vendor/node-addon-api/test/async_context.js +0 -122
- package/vendor/node-addon-api/test/async_progress_queue_worker.cc +0 -248
- package/vendor/node-addon-api/test/async_progress_queue_worker.js +0 -180
- package/vendor/node-addon-api/test/async_progress_worker.cc +0 -357
- package/vendor/node-addon-api/test/async_progress_worker.js +0 -200
- package/vendor/node-addon-api/test/async_worker.cc +0 -341
- package/vendor/node-addon-api/test/async_worker.js +0 -264
- package/vendor/node-addon-api/test/async_worker_nocallback.js +0 -19
- package/vendor/node-addon-api/test/async_worker_persistent.cc +0 -63
- package/vendor/node-addon-api/test/async_worker_persistent.js +0 -24
- package/vendor/node-addon-api/test/basic_types/array.cc +0 -40
- package/vendor/node-addon-api/test/basic_types/array.js +0 -34
- package/vendor/node-addon-api/test/basic_types/boolean.cc +0 -40
- package/vendor/node-addon-api/test/basic_types/boolean.js +0 -34
- package/vendor/node-addon-api/test/basic_types/number.cc +0 -105
- package/vendor/node-addon-api/test/basic_types/number.js +0 -115
- package/vendor/node-addon-api/test/basic_types/value.cc +0 -177
- package/vendor/node-addon-api/test/basic_types/value.js +0 -173
- package/vendor/node-addon-api/test/bigint.cc +0 -91
- package/vendor/node-addon-api/test/bigint.js +0 -53
- package/vendor/node-addon-api/test/binding-swallowexcept.cc +0 -12
- package/vendor/node-addon-api/test/binding.cc +0 -200
- package/vendor/node-addon-api/test/binding.gyp +0 -160
- package/vendor/node-addon-api/test/buffer.cc +0 -185
- package/vendor/node-addon-api/test/buffer.h +0 -26
- package/vendor/node-addon-api/test/buffer.js +0 -150
- package/vendor/node-addon-api/test/buffer_new_or_copy-inl.h +0 -68
- package/vendor/node-addon-api/test/buffer_no_external.cc +0 -24
- package/vendor/node-addon-api/test/callbackInfo.cc +0 -27
- package/vendor/node-addon-api/test/callbackInfo.js +0 -9
- package/vendor/node-addon-api/test/callbackscope.cc +0 -39
- package/vendor/node-addon-api/test/callbackscope.js +0 -49
- package/vendor/node-addon-api/test/child_processes/addon.js +0 -11
- package/vendor/node-addon-api/test/child_processes/addon_data.js +0 -24
- package/vendor/node-addon-api/test/child_processes/objectwrap_function.js +0 -22
- package/vendor/node-addon-api/test/child_processes/threadsafe_function_exception.js +0 -33
- package/vendor/node-addon-api/test/child_processes/typed_threadsafe_function_exception.js +0 -19
- package/vendor/node-addon-api/test/common/index.js +0 -246
- package/vendor/node-addon-api/test/common/test_helper.h +0 -71
- package/vendor/node-addon-api/test/dataview/dataview.cc +0 -48
- package/vendor/node-addon-api/test/dataview/dataview.js +0 -35
- package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +0 -115
- package/vendor/node-addon-api/test/dataview/dataview_read_write.js +0 -92
- package/vendor/node-addon-api/test/date.cc +0 -45
- package/vendor/node-addon-api/test/date.js +0 -18
- package/vendor/node-addon-api/test/env_cleanup.cc +0 -100
- package/vendor/node-addon-api/test/env_cleanup.js +0 -55
- package/vendor/node-addon-api/test/env_misc.cc +0 -25
- package/vendor/node-addon-api/test/env_misc.js +0 -12
- package/vendor/node-addon-api/test/error.cc +0 -436
- package/vendor/node-addon-api/test/error.js +0 -111
- package/vendor/node-addon-api/test/error_handling_for_primitives.cc +0 -13
- package/vendor/node-addon-api/test/error_handling_for_primitives.js +0 -29
- package/vendor/node-addon-api/test/error_terminating_environment.js +0 -99
- package/vendor/node-addon-api/test/except_all.cc +0 -22
- package/vendor/node-addon-api/test/except_all.js +0 -14
- package/vendor/node-addon-api/test/exports.js +0 -19
- package/vendor/node-addon-api/test/external.cc +0 -85
- package/vendor/node-addon-api/test/external.js +0 -85
- package/vendor/node-addon-api/test/finalizer_order.cc +0 -152
- package/vendor/node-addon-api/test/finalizer_order.js +0 -98
- package/vendor/node-addon-api/test/function.cc +0 -338
- package/vendor/node-addon-api/test/function.js +0 -137
- package/vendor/node-addon-api/test/function_reference.cc +0 -204
- package/vendor/node-addon-api/test/function_reference.js +0 -157
- package/vendor/node-addon-api/test/globalObject/global_object.cc +0 -61
- package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +0 -31
- package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +0 -58
- package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +0 -40
- package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +0 -56
- package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +0 -28
- package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +0 -46
- package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +0 -31
- package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +0 -56
- package/vendor/node-addon-api/test/handlescope.cc +0 -86
- package/vendor/node-addon-api/test/handlescope.js +0 -16
- package/vendor/node-addon-api/test/index.js +0 -160
- package/vendor/node-addon-api/test/maybe/check.cc +0 -69
- package/vendor/node-addon-api/test/maybe/index.js +0 -50
- package/vendor/node-addon-api/test/memory_management.cc +0 -18
- package/vendor/node-addon-api/test/memory_management.js +0 -9
- package/vendor/node-addon-api/test/movable_callbacks.cc +0 -23
- package/vendor/node-addon-api/test/movable_callbacks.js +0 -21
- package/vendor/node-addon-api/test/name.cc +0 -110
- package/vendor/node-addon-api/test/name.js +0 -59
- package/vendor/node-addon-api/test/napi_child.js +0 -14
- package/vendor/node-addon-api/test/object/delete_property.cc +0 -38
- package/vendor/node-addon-api/test/object/delete_property.js +0 -41
- package/vendor/node-addon-api/test/object/finalizer.cc +0 -30
- package/vendor/node-addon-api/test/object/finalizer.js +0 -28
- package/vendor/node-addon-api/test/object/get_property.cc +0 -34
- package/vendor/node-addon-api/test/object/get_property.js +0 -40
- package/vendor/node-addon-api/test/object/has_own_property.cc +0 -34
- package/vendor/node-addon-api/test/object/has_own_property.js +0 -34
- package/vendor/node-addon-api/test/object/has_property.cc +0 -38
- package/vendor/node-addon-api/test/object/has_property.js +0 -37
- package/vendor/node-addon-api/test/object/object.cc +0 -430
- package/vendor/node-addon-api/test/object/object.js +0 -218
- package/vendor/node-addon-api/test/object/object_deprecated.cc +0 -70
- package/vendor/node-addon-api/test/object/object_deprecated.js +0 -42
- package/vendor/node-addon-api/test/object/object_freeze_seal.cc +0 -25
- package/vendor/node-addon-api/test/object/object_freeze_seal.js +0 -61
- package/vendor/node-addon-api/test/object/set_property.cc +0 -45
- package/vendor/node-addon-api/test/object/set_property.js +0 -30
- package/vendor/node-addon-api/test/object/subscript_operator.cc +0 -58
- package/vendor/node-addon-api/test/object/subscript_operator.js +0 -17
- package/vendor/node-addon-api/test/object_reference.cc +0 -417
- package/vendor/node-addon-api/test/object_reference.js +0 -262
- package/vendor/node-addon-api/test/objectwrap.cc +0 -295
- package/vendor/node-addon-api/test/objectwrap.js +0 -309
- package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +0 -26
- package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +0 -18
- package/vendor/node-addon-api/test/objectwrap_function.cc +0 -43
- package/vendor/node-addon-api/test/objectwrap_function.js +0 -6
- package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +0 -30
- package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +0 -13
- package/vendor/node-addon-api/test/objectwrap_removewrap.cc +0 -45
- package/vendor/node-addon-api/test/objectwrap_removewrap.js +0 -32
- package/vendor/node-addon-api/test/objectwrap_worker_thread.js +0 -20
- package/vendor/node-addon-api/test/promise.cc +0 -111
- package/vendor/node-addon-api/test/promise.js +0 -43
- package/vendor/node-addon-api/test/reference.cc +0 -78
- package/vendor/node-addon-api/test/reference.js +0 -20
- package/vendor/node-addon-api/test/require_basic_finalizers/index.js +0 -38
- package/vendor/node-addon-api/test/require_basic_finalizers/tpl/addon.cc +0 -12
- package/vendor/node-addon-api/test/require_basic_finalizers/tpl/binding.gyp +0 -48
- package/vendor/node-addon-api/test/require_basic_finalizers/tpl/index.js +0 -3
- package/vendor/node-addon-api/test/require_basic_finalizers/tpl/package.json +0 -11
- package/vendor/node-addon-api/test/run_script.cc +0 -56
- package/vendor/node-addon-api/test/run_script.js +0 -45
- package/vendor/node-addon-api/test/symbol.cc +0 -79
- package/vendor/node-addon-api/test/symbol.js +0 -66
- package/vendor/node-addon-api/test/testUtil.js +0 -54
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +0 -230
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +0 -225
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +0 -155
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +0 -13
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_exception.cc +0 -50
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_exception.js +0 -20
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +0 -125
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +0 -14
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +0 -27
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +0 -7
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +0 -240
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +0 -59
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +0 -55
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +0 -98
- package/vendor/node-addon-api/test/thunking_manual.cc +0 -127
- package/vendor/node-addon-api/test/thunking_manual.js +0 -16
- package/vendor/node-addon-api/test/type_taggable.cc +0 -66
- package/vendor/node-addon-api/test/type_taggable.js +0 -59
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +0 -215
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +0 -188
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +0 -120
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +0 -14
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_exception.cc +0 -39
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_exception.js +0 -13
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +0 -127
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +0 -14
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +0 -32
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +0 -8
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +0 -237
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +0 -59
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +0 -67
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +0 -98
- package/vendor/node-addon-api/test/typedarray-bigint.js +0 -58
- package/vendor/node-addon-api/test/typedarray.cc +0 -413
- package/vendor/node-addon-api/test/typedarray.js +0 -103
- package/vendor/node-addon-api/test/value_type_cast.cc +0 -60
- package/vendor/node-addon-api/test/value_type_cast.js +0 -106
- package/vendor/node-addon-api/test/version_management.cc +0 -28
- package/vendor/node-addon-api/test/version_management.js +0 -29
- package/vendor/node-addon-api/tools/README.md +0 -73
- package/vendor/node-addon-api/tools/check-napi.js +0 -99
- package/vendor/node-addon-api/tools/clang-format.js +0 -71
- package/vendor/node-addon-api/tools/conversion.js +0 -301
- package/vendor/node-addon-api/unit-test/README.md +0 -28
- package/vendor/node-addon-api/unit-test/binding-file-template.js +0 -39
- package/vendor/node-addon-api/unit-test/binding.gyp +0 -72
- package/vendor/node-addon-api/unit-test/exceptions.js +0 -32
- package/vendor/node-addon-api/unit-test/generate-binding-cc.js +0 -61
- package/vendor/node-addon-api/unit-test/injectTestParams.js +0 -101
- package/vendor/node-addon-api/unit-test/listOfTestModules.js +0 -88
- package/vendor/node-addon-api/unit-test/matchModules.js +0 -65
- package/vendor/node-addon-api/unit-test/setup.js +0 -13
- package/vendor/node-addon-api/unit-test/spawnTask.js +0 -26
- package/vendor/node-addon-api/unit-test/test.js +0 -30
- package/vendor/node-api-headers/CHANGELOG.md +0 -130
- package/vendor/node-api-headers/CODE_OF_CONDUCT.md +0 -4
- package/vendor/node-api-headers/CONTRIBUTING.md +0 -32
- package/vendor/node-api-headers/CREATING_A_RELEASE.md +0 -68
- package/vendor/node-api-headers/index.js +0 -17
- package/vendor/node-api-headers/lib/clang-utils.js +0 -50
- package/vendor/node-api-headers/lib/parse-utils.js +0 -92
- package/vendor/node-api-headers/package.json +0 -59
- package/vendor/node-api-headers/release-please-config.json +0 -12
- package/vendor/node-api-headers/scripts/update-headers.js +0 -246
- package/vendor/node-api-headers/scripts/write-symbols.js +0 -154
- package/vendor/node-api-headers/scripts/write-win32-def.js +0 -52
- package/vendor/node-api-headers/symbols.js +0 -257
- package/vendor/node-api-headers/test/parse-utils.js +0 -21
- /package/doc/{pages/benchmarks.md → benchmarks.md} +0 -0
- /package/doc/{pages/callbacks.md → callbacks.md} +0 -0
- /package/doc/{pages/contribute.md → contribute.md} +0 -0
- /package/doc/{pages/functions.md → functions.md} +0 -0
- /package/doc/{pages/index.md → index.md} +0 -0
- /package/doc/{pages/input.md → input.md} +0 -0
- /package/doc/{pages/migration.md → migration.md} +0 -0
- /package/doc/{pages/misc.md → misc.md} +0 -0
- /package/doc/{pages/output.md → output.md} +0 -0
- /package/doc/{pages/packaging.md → packaging.md} +0 -0
- /package/doc/{pages/platforms.md → platforms.md} +0 -0
- /package/doc/{pages/pointers.md → pointers.md} +0 -0
- /package/doc/{pages/start.md → start.md} +0 -0
- /package/doc/{pages/unions.md → unions.md} +0 -0
- /package/doc/{pages/variables.md → variables.md} +0 -0
- /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,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
|