koffi 0.9.4 → 0.9.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CMakeLists.txt +60 -60
- package/README.md +163 -153
- package/package.json +19 -18
- package/src/call.hh +27 -27
- package/src/call_arm64.cc +482 -482
- package/src/call_arm64_fwd.S +115 -115
- package/src/call_x64_sysv.cc +477 -477
- package/src/call_x64_sysv_fwd.S +131 -131
- package/src/call_x64_win.cc +243 -243
- package/src/call_x64_win_fwd.asm +105 -105
- package/src/call_x86.cc +259 -259
- package/src/call_x86_fwd.S +48 -48
- package/src/call_x86_fwd.asm +50 -50
- package/src/ffi.cc +504 -504
- package/src/ffi.hh +135 -135
- package/src/util.cc +296 -296
- package/src/util.hh +80 -80
- package/vendor/dragonbox/CMakeLists.txt +122 -122
- package/vendor/dragonbox/LICENSE-Apache2-LLVM +218 -218
- package/vendor/dragonbox/LICENSE-Boost +23 -23
- package/vendor/dragonbox/README.md +277 -277
- package/vendor/dragonbox/cmake/dragonboxConfig.cmake +1 -1
- package/vendor/dragonbox/include/dragonbox/dragonbox.h +2670 -2670
- package/vendor/dragonbox/include/dragonbox/dragonbox_to_chars.h +108 -108
- package/vendor/dragonbox/other_files/unknown_win64_vc2019.html +539 -539
- package/vendor/dragonbox/source/dragonbox_to_chars.cpp +303 -303
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/CMakeLists.txt +23 -23
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.cpp +238 -238
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.h +95 -95
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/grisu_exact.h +2666 -2666
- package/vendor/dragonbox/subproject/3rdparty/ryu/CMakeLists.txt +16 -16
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/common.h +114 -114
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s.c +509 -509
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_full_table.h +367 -367
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_intrinsics.h +357 -357
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/digit_table.h +35 -35
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s.c +345 -345
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_full_table.h +55 -55
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_intrinsics.h +128 -128
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/ryu.h +46 -46
- package/vendor/dragonbox/subproject/3rdparty/schubfach/CMakeLists.txt +21 -21
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.cc +699 -699
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.h +31 -31
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.cc +1354 -1354
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.h +31 -31
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/example_shaded_plots.m +68 -68
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/license.txt +25 -25
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution.m +92 -92
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution_prctile.m +121 -121
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_histogram_shaded.m +99 -99
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_shaded.m +93 -93
- package/vendor/dragonbox/subproject/benchmark/CMakeLists.txt +64 -64
- package/vendor/dragonbox/subproject/benchmark/include/benchmark.h +40 -40
- package/vendor/dragonbox/subproject/benchmark/matlab/plot_benchmarks.m +21 -21
- package/vendor/dragonbox/subproject/benchmark/matlab/plot_digit_benchmark.m +78 -78
- package/vendor/dragonbox/subproject/benchmark/matlab/plot_uniform_benchmark.m +95 -95
- package/vendor/dragonbox/subproject/benchmark/source/benchmark.cpp +237 -237
- package/vendor/dragonbox/subproject/benchmark/source/dragonbox.cpp +30 -30
- package/vendor/dragonbox/subproject/benchmark/source/grisu_exact.cpp +36 -36
- package/vendor/dragonbox/subproject/benchmark/source/ryu.cpp +27 -27
- package/vendor/dragonbox/subproject/benchmark/source/schubfach.cpp +31 -31
- package/vendor/dragonbox/subproject/common/CMakeLists.txt +41 -41
- package/vendor/dragonbox/subproject/common/include/best_rational_approx.h +96 -96
- package/vendor/dragonbox/subproject/common/include/big_uint.h +217 -217
- package/vendor/dragonbox/subproject/common/include/continued_fractions.h +173 -173
- package/vendor/dragonbox/subproject/common/include/good_rational_approx.h +266 -266
- package/vendor/dragonbox/subproject/common/include/random_float.h +182 -182
- package/vendor/dragonbox/subproject/common/include/rational_continued_fractions.h +56 -56
- package/vendor/dragonbox/subproject/common/source/big_uint.cpp +601 -601
- package/vendor/dragonbox/subproject/meta/CMakeLists.txt +40 -40
- package/vendor/dragonbox/subproject/meta/results/binary32_generated_cache.txt +81 -81
- package/vendor/dragonbox/subproject/meta/results/binary64_compressed_cache_error_table.txt +9 -9
- package/vendor/dragonbox/subproject/meta/results/binary64_generated_cache.txt +622 -622
- package/vendor/dragonbox/subproject/meta/source/generate_cache.cpp +126 -126
- package/vendor/dragonbox/subproject/meta/source/live_test.cpp +81 -81
- package/vendor/dragonbox/subproject/meta/source/perf_test.cpp +104 -104
- package/vendor/dragonbox/subproject/meta/source/sandbox.cpp +20 -20
- package/vendor/dragonbox/subproject/test/CMakeLists.txt +69 -69
- package/vendor/dragonbox/subproject/test/results/binary32.csv +255 -255
- package/vendor/dragonbox/subproject/test/results/binary64.csv +2047 -2047
- package/vendor/dragonbox/subproject/test/results/plot_required_bits.m +17 -17
- package/vendor/dragonbox/subproject/test/source/test_all_shorter_interval_cases.cpp +88 -88
- package/vendor/dragonbox/subproject/test/source/uniform_random_test.cpp +95 -95
- package/vendor/dragonbox/subproject/test/source/verify_cache_precision.cpp +337 -337
- package/vendor/dragonbox/subproject/test/source/verify_compressed_cache.cpp +154 -154
- package/vendor/dragonbox/subproject/test/source/verify_fast_multiplication.cpp +168 -168
- package/vendor/dragonbox/subproject/test/source/verify_log_computation.cpp +251 -251
- package/vendor/dragonbox/subproject/test/source/verify_magic_division.cpp +113 -113
- package/vendor/libcc/libcc.cc +7651 -7651
- package/vendor/libcc/libcc.hh +4312 -4312
- package/vendor/node-addon-api/CHANGELOG.md +859 -859
- package/vendor/node-addon-api/CODE_OF_CONDUCT.md +4 -4
- package/vendor/node-addon-api/CONTRIBUTING.md +93 -93
- package/vendor/node-addon-api/LICENSE.md +12 -12
- package/vendor/node-addon-api/README.md +293 -293
- package/vendor/node-addon-api/appveyor.yml +37 -37
- package/vendor/node-addon-api/benchmark/README.md +47 -47
- package/vendor/node-addon-api/benchmark/binding.gyp +25 -25
- package/vendor/node-addon-api/benchmark/function_args.cc +217 -217
- package/vendor/node-addon-api/benchmark/function_args.js +60 -60
- package/vendor/node-addon-api/benchmark/index.js +34 -34
- package/vendor/node-addon-api/benchmark/property_descriptor.cc +91 -91
- package/vendor/node-addon-api/benchmark/property_descriptor.js +37 -37
- package/vendor/node-addon-api/common.gypi +21 -21
- package/vendor/node-addon-api/doc/addon.md +163 -163
- package/vendor/node-addon-api/doc/array.md +81 -81
- package/vendor/node-addon-api/doc/array_buffer.md +155 -155
- package/vendor/node-addon-api/doc/async_context.md +86 -86
- package/vendor/node-addon-api/doc/async_operations.md +31 -31
- package/vendor/node-addon-api/doc/async_worker.md +427 -427
- package/vendor/node-addon-api/doc/async_worker_variants.md +557 -557
- package/vendor/node-addon-api/doc/bigint.md +97 -97
- package/vendor/node-addon-api/doc/boolean.md +68 -68
- package/vendor/node-addon-api/doc/buffer.md +150 -150
- package/vendor/node-addon-api/doc/callback_scope.md +54 -54
- package/vendor/node-addon-api/doc/callbackinfo.md +97 -97
- package/vendor/node-addon-api/doc/checker-tool.md +32 -32
- package/vendor/node-addon-api/doc/class_property_descriptor.md +115 -115
- package/vendor/node-addon-api/doc/cmake-js.md +68 -68
- package/vendor/node-addon-api/doc/conversion-tool.md +27 -27
- package/vendor/node-addon-api/doc/creating_a_release.md +62 -62
- package/vendor/node-addon-api/doc/dataview.md +248 -248
- package/vendor/node-addon-api/doc/date.md +68 -68
- package/vendor/node-addon-api/doc/env.md +196 -196
- package/vendor/node-addon-api/doc/error.md +120 -120
- package/vendor/node-addon-api/doc/error_handling.md +254 -254
- package/vendor/node-addon-api/doc/escapable_handle_scope.md +80 -80
- package/vendor/node-addon-api/doc/external.md +63 -63
- package/vendor/node-addon-api/doc/function.md +402 -402
- package/vendor/node-addon-api/doc/function_reference.md +238 -238
- package/vendor/node-addon-api/doc/generator.md +13 -13
- package/vendor/node-addon-api/doc/handle_scope.md +63 -63
- package/vendor/node-addon-api/doc/hierarchy.md +91 -91
- package/vendor/node-addon-api/doc/instance_wrap.md +408 -408
- package/vendor/node-addon-api/doc/maybe.md +76 -76
- package/vendor/node-addon-api/doc/memory_management.md +27 -27
- package/vendor/node-addon-api/doc/name.md +29 -29
- package/vendor/node-addon-api/doc/node-gyp.md +82 -82
- package/vendor/node-addon-api/doc/number.md +163 -163
- package/vendor/node-addon-api/doc/object.md +432 -432
- package/vendor/node-addon-api/doc/object_lifetime_management.md +83 -83
- package/vendor/node-addon-api/doc/object_reference.md +117 -117
- package/vendor/node-addon-api/doc/object_wrap.md +561 -561
- package/vendor/node-addon-api/doc/prebuild_tools.md +16 -16
- package/vendor/node-addon-api/doc/promises.md +79 -79
- package/vendor/node-addon-api/doc/property_descriptor.md +286 -286
- package/vendor/node-addon-api/doc/propertylvalue.md +50 -50
- package/vendor/node-addon-api/doc/range_error.md +59 -59
- package/vendor/node-addon-api/doc/reference.md +113 -113
- package/vendor/node-addon-api/doc/setup.md +110 -110
- package/vendor/node-addon-api/doc/string.md +93 -93
- package/vendor/node-addon-api/doc/symbol.md +60 -60
- package/vendor/node-addon-api/doc/threadsafe.md +121 -121
- package/vendor/node-addon-api/doc/threadsafe_function.md +290 -290
- package/vendor/node-addon-api/doc/type_error.md +59 -59
- package/vendor/node-addon-api/doc/typed_array.md +78 -78
- package/vendor/node-addon-api/doc/typed_array_of.md +137 -137
- package/vendor/node-addon-api/doc/typed_threadsafe_function.md +306 -306
- package/vendor/node-addon-api/doc/value.md +340 -340
- package/vendor/node-addon-api/doc/version_management.md +43 -43
- package/vendor/node-addon-api/except.gypi +25 -25
- package/vendor/node-addon-api/index.js +11 -11
- package/vendor/node-addon-api/napi-inl.deprecated.h +192 -192
- package/vendor/node-addon-api/napi-inl.h +6209 -6209
- package/vendor/node-addon-api/napi.h +2983 -2983
- package/vendor/node-addon-api/node_api.gyp +9 -9
- package/vendor/node-addon-api/noexcept.gypi +26 -26
- package/vendor/node-addon-api/package-support.json +21 -21
- package/vendor/node-addon-api/package.json +399 -399
- package/vendor/node-addon-api/test/README.md +91 -91
- package/vendor/node-addon-api/test/addon.cc +36 -36
- package/vendor/node-addon-api/test/addon.js +11 -11
- package/vendor/node-addon-api/test/addon_build/index.js +49 -49
- package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +17 -17
- package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +62 -62
- package/vendor/node-addon-api/test/addon_build/tpl/index.js +9 -9
- package/vendor/node-addon-api/test/addon_build/tpl/package.json +11 -11
- package/vendor/node-addon-api/test/addon_data.cc +99 -99
- package/vendor/node-addon-api/test/addon_data.js +46 -46
- package/vendor/node-addon-api/test/array_buffer.cc +243 -243
- package/vendor/node-addon-api/test/array_buffer.js +69 -69
- package/vendor/node-addon-api/test/async_context.cc +21 -21
- package/vendor/node-addon-api/test/async_context.js +86 -86
- package/vendor/node-addon-api/test/async_progress_queue_worker.cc +83 -83
- package/vendor/node-addon-api/test/async_progress_queue_worker.js +46 -46
- package/vendor/node-addon-api/test/async_progress_worker.cc +134 -134
- package/vendor/node-addon-api/test/async_progress_worker.js +61 -61
- package/vendor/node-addon-api/test/async_worker.cc +106 -106
- package/vendor/node-addon-api/test/async_worker.js +179 -179
- package/vendor/node-addon-api/test/async_worker_nocallback.js +13 -13
- package/vendor/node-addon-api/test/async_worker_persistent.cc +63 -63
- package/vendor/node-addon-api/test/async_worker_persistent.js +24 -24
- package/vendor/node-addon-api/test/basic_types/array.cc +40 -40
- package/vendor/node-addon-api/test/basic_types/array.js +35 -35
- package/vendor/node-addon-api/test/basic_types/boolean.cc +38 -38
- package/vendor/node-addon-api/test/basic_types/boolean.js +35 -35
- package/vendor/node-addon-api/test/basic_types/number.cc +99 -99
- package/vendor/node-addon-api/test/basic_types/number.js +114 -114
- package/vendor/node-addon-api/test/basic_types/value.cc +120 -120
- package/vendor/node-addon-api/test/basic_types/value.js +133 -133
- package/vendor/node-addon-api/test/bigint.cc +91 -91
- package/vendor/node-addon-api/test/bigint.js +53 -53
- package/vendor/node-addon-api/test/binding-swallowexcept.cc +12 -12
- package/vendor/node-addon-api/test/binding.cc +171 -171
- package/vendor/node-addon-api/test/binding.gyp +117 -117
- package/vendor/node-addon-api/test/buffer.cc +183 -183
- package/vendor/node-addon-api/test/buffer.js +69 -69
- package/vendor/node-addon-api/test/callbackscope.cc +22 -22
- package/vendor/node-addon-api/test/callbackscope.js +49 -49
- package/vendor/node-addon-api/test/common/index.js +113 -113
- package/vendor/node-addon-api/test/common/test_helper.h +61 -61
- package/vendor/node-addon-api/test/dataview/dataview.cc +48 -48
- package/vendor/node-addon-api/test/dataview/dataview.js +35 -35
- package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +115 -115
- package/vendor/node-addon-api/test/dataview/dataview_read_write.js +90 -90
- package/vendor/node-addon-api/test/date.cc +44 -44
- package/vendor/node-addon-api/test/date.js +18 -18
- package/vendor/node-addon-api/test/env_cleanup.cc +88 -88
- package/vendor/node-addon-api/test/env_cleanup.js +56 -56
- package/vendor/node-addon-api/test/error.cc +287 -287
- package/vendor/node-addon-api/test/error.js +81 -81
- package/vendor/node-addon-api/test/error_handling_for_primitives.cc +13 -13
- package/vendor/node-addon-api/test/error_handling_for_primitives.js +29 -29
- package/vendor/node-addon-api/test/error_terminating_environment.js +94 -94
- package/vendor/node-addon-api/test/external.cc +81 -81
- package/vendor/node-addon-api/test/external.js +88 -88
- package/vendor/node-addon-api/test/function.cc +295 -295
- package/vendor/node-addon-api/test/function.js +121 -121
- package/vendor/node-addon-api/test/function_reference.cc +202 -202
- package/vendor/node-addon-api/test/function_reference.js +157 -157
- package/vendor/node-addon-api/test/globalObject/global_object.cc +61 -61
- package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +31 -31
- package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +61 -61
- package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +40 -40
- package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +57 -57
- package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +28 -28
- package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +48 -48
- package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +30 -30
- package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +58 -58
- package/vendor/node-addon-api/test/handlescope.cc +60 -60
- package/vendor/node-addon-api/test/handlescope.js +14 -14
- package/vendor/node-addon-api/test/index.js +136 -136
- package/vendor/node-addon-api/test/maybe/check.cc +23 -23
- package/vendor/node-addon-api/test/maybe/index.js +38 -38
- package/vendor/node-addon-api/test/memory_management.cc +17 -17
- package/vendor/node-addon-api/test/memory_management.js +9 -9
- package/vendor/node-addon-api/test/movable_callbacks.cc +23 -23
- package/vendor/node-addon-api/test/movable_callbacks.js +21 -21
- package/vendor/node-addon-api/test/name.cc +108 -108
- package/vendor/node-addon-api/test/name.js +59 -59
- package/vendor/node-addon-api/test/napi_child.js +14 -14
- package/vendor/node-addon-api/test/object/delete_property.cc +38 -38
- package/vendor/node-addon-api/test/object/delete_property.js +41 -41
- package/vendor/node-addon-api/test/object/finalizer.cc +29 -29
- package/vendor/node-addon-api/test/object/finalizer.js +28 -28
- package/vendor/node-addon-api/test/object/get_property.cc +34 -34
- package/vendor/node-addon-api/test/object/get_property.js +40 -40
- package/vendor/node-addon-api/test/object/has_own_property.cc +34 -34
- package/vendor/node-addon-api/test/object/has_own_property.js +34 -34
- package/vendor/node-addon-api/test/object/has_property.cc +38 -38
- package/vendor/node-addon-api/test/object/has_property.js +37 -37
- package/vendor/node-addon-api/test/object/object.cc +348 -348
- package/vendor/node-addon-api/test/object/object.js +217 -217
- package/vendor/node-addon-api/test/object/object_deprecated.cc +66 -66
- package/vendor/node-addon-api/test/object/object_deprecated.js +47 -47
- package/vendor/node-addon-api/test/object/object_freeze_seal.cc +25 -25
- package/vendor/node-addon-api/test/object/object_freeze_seal.js +61 -61
- package/vendor/node-addon-api/test/object/set_property.cc +37 -37
- package/vendor/node-addon-api/test/object/set_property.js +29 -29
- package/vendor/node-addon-api/test/object/subscript_operator.cc +42 -42
- package/vendor/node-addon-api/test/object/subscript_operator.js +17 -17
- package/vendor/node-addon-api/test/object_reference.cc +219 -219
- package/vendor/node-addon-api/test/object_reference.js +259 -259
- package/vendor/node-addon-api/test/objectwrap.cc +268 -268
- package/vendor/node-addon-api/test/objectwrap.js +284 -284
- package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +26 -26
- package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +18 -18
- package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +30 -30
- package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +13 -13
- package/vendor/node-addon-api/test/objectwrap_removewrap.cc +45 -45
- package/vendor/node-addon-api/test/objectwrap_removewrap.js +40 -40
- package/vendor/node-addon-api/test/objectwrap_worker_thread.js +19 -19
- package/vendor/node-addon-api/test/promise.cc +29 -29
- package/vendor/node-addon-api/test/promise.js +18 -18
- package/vendor/node-addon-api/test/reference.cc +24 -24
- package/vendor/node-addon-api/test/reference.js +14 -14
- package/vendor/node-addon-api/test/run_script.cc +56 -56
- package/vendor/node-addon-api/test/run_script.js +45 -45
- package/vendor/node-addon-api/test/symbol.cc +79 -79
- package/vendor/node-addon-api/test/symbol.js +73 -73
- package/vendor/node-addon-api/test/testUtil.js +54 -54
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +195 -195
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +188 -188
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +63 -63
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +12 -12
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +115 -115
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +14 -14
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +26 -26
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +7 -7
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +225 -225
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +59 -59
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +42 -42
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +53 -53
- package/vendor/node-addon-api/test/thunking_manual.cc +140 -140
- package/vendor/node-addon-api/test/thunking_manual.js +17 -17
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +215 -215
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +188 -188
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +68 -68
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +12 -12
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +127 -127
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +14 -14
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +28 -28
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +7 -7
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +237 -237
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +59 -59
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +53 -53
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +53 -53
- package/vendor/node-addon-api/test/typedarray-bigint.js +58 -58
- package/vendor/node-addon-api/test/typedarray.cc +216 -216
- package/vendor/node-addon-api/test/typedarray.js +69 -69
- package/vendor/node-addon-api/test/version_management.cc +27 -27
- package/vendor/node-addon-api/test/version_management.js +31 -31
- package/vendor/node-addon-api/tools/README.md +73 -73
- package/vendor/node-addon-api/tools/check-napi.js +100 -100
- package/vendor/node-addon-api/tools/clang-format.js +68 -68
- package/vendor/node-addon-api/tools/conversion.js +309 -309
- package/vendor/node-addon-api/tools/eslint-format.js +71 -71
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
# CallbackScope
|
|
2
|
-
|
|
3
|
-
There are cases (for example, resolving promises) where it is necessary to have
|
|
4
|
-
the equivalent of the scope associated with a callback in place when making
|
|
5
|
-
certain Node-API calls.
|
|
6
|
-
|
|
7
|
-
## Methods
|
|
8
|
-
|
|
9
|
-
### Constructor
|
|
10
|
-
|
|
11
|
-
Creates a new callback scope on the stack.
|
|
12
|
-
|
|
13
|
-
```cpp
|
|
14
|
-
Napi::CallbackScope::CallbackScope(napi_env env, napi_callback_scope scope);
|
|
15
|
-
```
|
|
16
|
-
|
|
17
|
-
- `[in] env`: The environment in which to create the `Napi::CallbackScope`.
|
|
18
|
-
- `[in] scope`: The pre-existing `napi_callback_scope` or `Napi::CallbackScope`.
|
|
19
|
-
|
|
20
|
-
### Constructor
|
|
21
|
-
|
|
22
|
-
Creates a new callback scope on the stack.
|
|
23
|
-
|
|
24
|
-
```cpp
|
|
25
|
-
Napi::CallbackScope::CallbackScope(napi_env env, napi_async_context context);
|
|
26
|
-
```
|
|
27
|
-
|
|
28
|
-
- `[in] env`: The environment in which to create the `Napi::CallbackScope`.
|
|
29
|
-
- `[in] async_context`: The pre-existing `napi_async_context` or `Napi::AsyncContext`.
|
|
30
|
-
|
|
31
|
-
### Destructor
|
|
32
|
-
|
|
33
|
-
Deletes the instance of `Napi::CallbackScope` object.
|
|
34
|
-
|
|
35
|
-
```cpp
|
|
36
|
-
virtual Napi::CallbackScope::~CallbackScope();
|
|
37
|
-
```
|
|
38
|
-
|
|
39
|
-
### Env
|
|
40
|
-
|
|
41
|
-
```cpp
|
|
42
|
-
Napi::Env Napi::CallbackScope::Env() const;
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
Returns the `Napi::Env` associated with the `Napi::CallbackScope`.
|
|
46
|
-
|
|
47
|
-
## Operator
|
|
48
|
-
|
|
49
|
-
```cpp
|
|
50
|
-
Napi::CallbackScope::operator napi_callback_scope() const;
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
Returns the Node-API `napi_callback_scope` wrapped by the `Napi::CallbackScope`
|
|
54
|
-
object. This can be used to mix usage of the C Node-API and node-addon-api.
|
|
1
|
+
# CallbackScope
|
|
2
|
+
|
|
3
|
+
There are cases (for example, resolving promises) where it is necessary to have
|
|
4
|
+
the equivalent of the scope associated with a callback in place when making
|
|
5
|
+
certain Node-API calls.
|
|
6
|
+
|
|
7
|
+
## Methods
|
|
8
|
+
|
|
9
|
+
### Constructor
|
|
10
|
+
|
|
11
|
+
Creates a new callback scope on the stack.
|
|
12
|
+
|
|
13
|
+
```cpp
|
|
14
|
+
Napi::CallbackScope::CallbackScope(napi_env env, napi_callback_scope scope);
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
- `[in] env`: The environment in which to create the `Napi::CallbackScope`.
|
|
18
|
+
- `[in] scope`: The pre-existing `napi_callback_scope` or `Napi::CallbackScope`.
|
|
19
|
+
|
|
20
|
+
### Constructor
|
|
21
|
+
|
|
22
|
+
Creates a new callback scope on the stack.
|
|
23
|
+
|
|
24
|
+
```cpp
|
|
25
|
+
Napi::CallbackScope::CallbackScope(napi_env env, napi_async_context context);
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
- `[in] env`: The environment in which to create the `Napi::CallbackScope`.
|
|
29
|
+
- `[in] async_context`: The pre-existing `napi_async_context` or `Napi::AsyncContext`.
|
|
30
|
+
|
|
31
|
+
### Destructor
|
|
32
|
+
|
|
33
|
+
Deletes the instance of `Napi::CallbackScope` object.
|
|
34
|
+
|
|
35
|
+
```cpp
|
|
36
|
+
virtual Napi::CallbackScope::~CallbackScope();
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### Env
|
|
40
|
+
|
|
41
|
+
```cpp
|
|
42
|
+
Napi::Env Napi::CallbackScope::Env() const;
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
Returns the `Napi::Env` associated with the `Napi::CallbackScope`.
|
|
46
|
+
|
|
47
|
+
## Operator
|
|
48
|
+
|
|
49
|
+
```cpp
|
|
50
|
+
Napi::CallbackScope::operator napi_callback_scope() const;
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
Returns the Node-API `napi_callback_scope` wrapped by the `Napi::CallbackScope`
|
|
54
|
+
object. This can be used to mix usage of the C Node-API and node-addon-api.
|
|
@@ -1,97 +1,97 @@
|
|
|
1
|
-
# CallbackInfo
|
|
2
|
-
|
|
3
|
-
The object representing the components of the JavaScript request being made.
|
|
4
|
-
|
|
5
|
-
The `Napi::CallbackInfo` object is usually created and passed by the Node.js runtime or node-addon-api infrastructure.
|
|
6
|
-
|
|
7
|
-
The `Napi::CallbackInfo` object contains the arguments passed by the caller. The number of arguments is returned by the `Length` method. Each individual argument can be accessed using the `operator[]` method.
|
|
8
|
-
|
|
9
|
-
The `SetData` and `Data` methods are used to set and retrieve the data pointer contained in the `Napi::CallbackInfo` object.
|
|
10
|
-
|
|
11
|
-
## Methods
|
|
12
|
-
|
|
13
|
-
### Constructor
|
|
14
|
-
|
|
15
|
-
```cpp
|
|
16
|
-
Napi::CallbackInfo::CallbackInfo(napi_env env, napi_callback_info info);
|
|
17
|
-
```
|
|
18
|
-
|
|
19
|
-
- `[in] env`: The `napi_env` environment in which to construct the `Napi::CallbackInfo` object.
|
|
20
|
-
- `[in] info`: The `napi_callback_info` data structure from which to construct the `Napi::CallbackInfo` object.
|
|
21
|
-
|
|
22
|
-
### Env
|
|
23
|
-
|
|
24
|
-
```cpp
|
|
25
|
-
Napi::Env Napi::CallbackInfo::Env() const;
|
|
26
|
-
```
|
|
27
|
-
|
|
28
|
-
Returns the `Env` object in which the request is being made.
|
|
29
|
-
|
|
30
|
-
### NewTarget
|
|
31
|
-
|
|
32
|
-
```cpp
|
|
33
|
-
Napi::Value Napi::CallbackInfo::NewTarget() const;
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
Returns the `new.target` value of the constructor call. If the function that was invoked (and for which the `Napi::NCallbackInfo` was passed) is not a constructor call, a call to `IsEmpty()` on the returned value returns true.
|
|
37
|
-
|
|
38
|
-
### IsConstructCall
|
|
39
|
-
|
|
40
|
-
```cpp
|
|
41
|
-
bool Napi::CallbackInfo::IsConstructCall() const;
|
|
42
|
-
```
|
|
43
|
-
|
|
44
|
-
Returns a `bool` indicating if the function that was invoked (and for which the `Napi::CallbackInfo` was passed) is a constructor call.
|
|
45
|
-
|
|
46
|
-
### Length
|
|
47
|
-
|
|
48
|
-
```cpp
|
|
49
|
-
size_t Napi::CallbackInfo::Length() const;
|
|
50
|
-
```
|
|
51
|
-
|
|
52
|
-
Returns the number of arguments passed in the `Napi::CallbackInfo` object.
|
|
53
|
-
|
|
54
|
-
### operator []
|
|
55
|
-
|
|
56
|
-
```cpp
|
|
57
|
-
const Napi::Value operator [](size_t index) const;
|
|
58
|
-
```
|
|
59
|
-
|
|
60
|
-
- `[in] index`: The zero-based index of the requested argument.
|
|
61
|
-
|
|
62
|
-
Returns a `Napi::Value` object containing the requested argument.
|
|
63
|
-
|
|
64
|
-
### This
|
|
65
|
-
|
|
66
|
-
```cpp
|
|
67
|
-
Napi::Value Napi::CallbackInfo::This() const;
|
|
68
|
-
```
|
|
69
|
-
|
|
70
|
-
Returns the JavaScript `this` value for the call
|
|
71
|
-
|
|
72
|
-
### Data
|
|
73
|
-
|
|
74
|
-
```cpp
|
|
75
|
-
void* Napi::CallbackInfo::Data() const;
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
Returns the data pointer for the callback.
|
|
79
|
-
|
|
80
|
-
### SetData
|
|
81
|
-
|
|
82
|
-
```cpp
|
|
83
|
-
void Napi::CallbackInfo::SetData(void* data);
|
|
84
|
-
```
|
|
85
|
-
|
|
86
|
-
- `[in] data`: The new data pointer to associate with this `Napi::CallbackInfo` object.
|
|
87
|
-
|
|
88
|
-
Returns `void`.
|
|
89
|
-
|
|
90
|
-
### Not documented here
|
|
91
|
-
|
|
92
|
-
```cpp
|
|
93
|
-
Napi::CallbackInfo::~CallbackInfo();
|
|
94
|
-
// Disallow copying to prevent multiple free of _dynamicArgs
|
|
95
|
-
Napi::CallbackInfo::CallbackInfo(CallbackInfo const &) = delete;
|
|
96
|
-
void Napi::CallbackInfo::operator=(CallbackInfo const &) = delete;
|
|
97
|
-
```
|
|
1
|
+
# CallbackInfo
|
|
2
|
+
|
|
3
|
+
The object representing the components of the JavaScript request being made.
|
|
4
|
+
|
|
5
|
+
The `Napi::CallbackInfo` object is usually created and passed by the Node.js runtime or node-addon-api infrastructure.
|
|
6
|
+
|
|
7
|
+
The `Napi::CallbackInfo` object contains the arguments passed by the caller. The number of arguments is returned by the `Length` method. Each individual argument can be accessed using the `operator[]` method.
|
|
8
|
+
|
|
9
|
+
The `SetData` and `Data` methods are used to set and retrieve the data pointer contained in the `Napi::CallbackInfo` object.
|
|
10
|
+
|
|
11
|
+
## Methods
|
|
12
|
+
|
|
13
|
+
### Constructor
|
|
14
|
+
|
|
15
|
+
```cpp
|
|
16
|
+
Napi::CallbackInfo::CallbackInfo(napi_env env, napi_callback_info info);
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
- `[in] env`: The `napi_env` environment in which to construct the `Napi::CallbackInfo` object.
|
|
20
|
+
- `[in] info`: The `napi_callback_info` data structure from which to construct the `Napi::CallbackInfo` object.
|
|
21
|
+
|
|
22
|
+
### Env
|
|
23
|
+
|
|
24
|
+
```cpp
|
|
25
|
+
Napi::Env Napi::CallbackInfo::Env() const;
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
Returns the `Env` object in which the request is being made.
|
|
29
|
+
|
|
30
|
+
### NewTarget
|
|
31
|
+
|
|
32
|
+
```cpp
|
|
33
|
+
Napi::Value Napi::CallbackInfo::NewTarget() const;
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
Returns the `new.target` value of the constructor call. If the function that was invoked (and for which the `Napi::NCallbackInfo` was passed) is not a constructor call, a call to `IsEmpty()` on the returned value returns true.
|
|
37
|
+
|
|
38
|
+
### IsConstructCall
|
|
39
|
+
|
|
40
|
+
```cpp
|
|
41
|
+
bool Napi::CallbackInfo::IsConstructCall() const;
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Returns a `bool` indicating if the function that was invoked (and for which the `Napi::CallbackInfo` was passed) is a constructor call.
|
|
45
|
+
|
|
46
|
+
### Length
|
|
47
|
+
|
|
48
|
+
```cpp
|
|
49
|
+
size_t Napi::CallbackInfo::Length() const;
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
Returns the number of arguments passed in the `Napi::CallbackInfo` object.
|
|
53
|
+
|
|
54
|
+
### operator []
|
|
55
|
+
|
|
56
|
+
```cpp
|
|
57
|
+
const Napi::Value operator [](size_t index) const;
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
- `[in] index`: The zero-based index of the requested argument.
|
|
61
|
+
|
|
62
|
+
Returns a `Napi::Value` object containing the requested argument.
|
|
63
|
+
|
|
64
|
+
### This
|
|
65
|
+
|
|
66
|
+
```cpp
|
|
67
|
+
Napi::Value Napi::CallbackInfo::This() const;
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
Returns the JavaScript `this` value for the call
|
|
71
|
+
|
|
72
|
+
### Data
|
|
73
|
+
|
|
74
|
+
```cpp
|
|
75
|
+
void* Napi::CallbackInfo::Data() const;
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
Returns the data pointer for the callback.
|
|
79
|
+
|
|
80
|
+
### SetData
|
|
81
|
+
|
|
82
|
+
```cpp
|
|
83
|
+
void Napi::CallbackInfo::SetData(void* data);
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
- `[in] data`: The new data pointer to associate with this `Napi::CallbackInfo` object.
|
|
87
|
+
|
|
88
|
+
Returns `void`.
|
|
89
|
+
|
|
90
|
+
### Not documented here
|
|
91
|
+
|
|
92
|
+
```cpp
|
|
93
|
+
Napi::CallbackInfo::~CallbackInfo();
|
|
94
|
+
// Disallow copying to prevent multiple free of _dynamicArgs
|
|
95
|
+
Napi::CallbackInfo::CallbackInfo(CallbackInfo const &) = delete;
|
|
96
|
+
void Napi::CallbackInfo::operator=(CallbackInfo const &) = delete;
|
|
97
|
+
```
|
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
# Checker Tool
|
|
2
|
-
|
|
3
|
-
**node-addon-api** provides a [checker tool][] that will inspect a given
|
|
4
|
-
directory tree, identifying all Node.js native addons therein, and further
|
|
5
|
-
indicating for each addon whether it is an Node-API addon.
|
|
6
|
-
|
|
7
|
-
## To use the checker tool:
|
|
8
|
-
|
|
9
|
-
1. Install the application with `npm install`.
|
|
10
|
-
|
|
11
|
-
2. If the application does not depend on **node-addon-api**, copy the
|
|
12
|
-
checker tool into the application's directory.
|
|
13
|
-
|
|
14
|
-
3. If the application does not depend on **node-addon-api**, run the checker
|
|
15
|
-
tool from the application's directory:
|
|
16
|
-
|
|
17
|
-
```sh
|
|
18
|
-
node ./check-napi.js
|
|
19
|
-
```
|
|
20
|
-
|
|
21
|
-
Otherwise, the checker tool can be run from the application's
|
|
22
|
-
`node_modules/` subdirectory:
|
|
23
|
-
|
|
24
|
-
```sh
|
|
25
|
-
node ./node_modules/node-addon-api/tools/check-napi.js
|
|
26
|
-
```
|
|
27
|
-
|
|
28
|
-
The tool accepts the root directory from which to start checking for Node.js
|
|
29
|
-
native addons as a single optional command line parameter. If omitted it will
|
|
30
|
-
start checking from the current directory (`.`).
|
|
31
|
-
|
|
32
|
-
[checker tool]: ../tools/check-napi.js
|
|
1
|
+
# Checker Tool
|
|
2
|
+
|
|
3
|
+
**node-addon-api** provides a [checker tool][] that will inspect a given
|
|
4
|
+
directory tree, identifying all Node.js native addons therein, and further
|
|
5
|
+
indicating for each addon whether it is an Node-API addon.
|
|
6
|
+
|
|
7
|
+
## To use the checker tool:
|
|
8
|
+
|
|
9
|
+
1. Install the application with `npm install`.
|
|
10
|
+
|
|
11
|
+
2. If the application does not depend on **node-addon-api**, copy the
|
|
12
|
+
checker tool into the application's directory.
|
|
13
|
+
|
|
14
|
+
3. If the application does not depend on **node-addon-api**, run the checker
|
|
15
|
+
tool from the application's directory:
|
|
16
|
+
|
|
17
|
+
```sh
|
|
18
|
+
node ./check-napi.js
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
Otherwise, the checker tool can be run from the application's
|
|
22
|
+
`node_modules/` subdirectory:
|
|
23
|
+
|
|
24
|
+
```sh
|
|
25
|
+
node ./node_modules/node-addon-api/tools/check-napi.js
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
The tool accepts the root directory from which to start checking for Node.js
|
|
29
|
+
native addons as a single optional command line parameter. If omitted it will
|
|
30
|
+
start checking from the current directory (`.`).
|
|
31
|
+
|
|
32
|
+
[checker tool]: ../tools/check-napi.js
|
|
@@ -1,115 +1,115 @@
|
|
|
1
|
-
# Class property and descriptor
|
|
2
|
-
|
|
3
|
-
Property descriptor for use with `Napi::ObjectWrap::DefineClass()`.
|
|
4
|
-
This is different from the standalone `Napi::PropertyDescriptor` because it is
|
|
5
|
-
specific to each `Napi::ObjectWrap<T>` subclass.
|
|
6
|
-
This prevents using descriptors from a different class when defining a new class
|
|
7
|
-
(preventing the callbacks from having incorrect `this` pointers).
|
|
8
|
-
|
|
9
|
-
## Example
|
|
10
|
-
|
|
11
|
-
```cpp
|
|
12
|
-
#include <napi.h>
|
|
13
|
-
|
|
14
|
-
class Example : public Napi::ObjectWrap<Example> {
|
|
15
|
-
public:
|
|
16
|
-
static Napi::Object Init(Napi::Env env, Napi::Object exports);
|
|
17
|
-
Example(const Napi::CallbackInfo &info);
|
|
18
|
-
|
|
19
|
-
private:
|
|
20
|
-
double _value;
|
|
21
|
-
Napi::Value GetValue(const Napi::CallbackInfo &info);
|
|
22
|
-
void SetValue(const Napi::CallbackInfo &info, const Napi::Value &value);
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
Napi::Object Example::Init(Napi::Env env, Napi::Object exports) {
|
|
26
|
-
Napi::Function func = DefineClass(env, "Example", {
|
|
27
|
-
// Register a class instance accessor with getter and setter functions.
|
|
28
|
-
InstanceAccessor<&Example::GetValue, &Example::SetValue>("value"),
|
|
29
|
-
// We can also register a readonly accessor by omitting the setter.
|
|
30
|
-
InstanceAccessor<&Example::GetValue>("readOnlyProp")
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
Napi::FunctionReference *constructor = new Napi::FunctionReference();
|
|
34
|
-
*constructor = Napi::Persistent(func);
|
|
35
|
-
env.SetInstanceData(constructor);
|
|
36
|
-
exports.Set("Example", func);
|
|
37
|
-
|
|
38
|
-
return exports;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
Example::Example(const Napi::CallbackInfo &info) : Napi::ObjectWrap<Example>(info) {
|
|
42
|
-
Napi::Env env = info.Env();
|
|
43
|
-
// ...
|
|
44
|
-
Napi::Number value = info[0].As<Napi::Number>();
|
|
45
|
-
this->_value = value.DoubleValue();
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
Napi::Value Example::GetValue(const Napi::CallbackInfo &info) {
|
|
49
|
-
Napi::Env env = info.Env();
|
|
50
|
-
return Napi::Number::New(env, this->_value);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
void Example::SetValue(const Napi::CallbackInfo &info, const Napi::Value &value) {
|
|
54
|
-
Napi::Env env = info.Env();
|
|
55
|
-
// ...
|
|
56
|
-
Napi::Number arg = value.As<Napi::Number>();
|
|
57
|
-
this->_value = arg.DoubleValue();
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
// Initialize native add-on
|
|
61
|
-
Napi::Object Init (Napi::Env env, Napi::Object exports) {
|
|
62
|
-
Example::Init(env, exports);
|
|
63
|
-
return exports;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Register and initialize native add-on
|
|
67
|
-
NODE_API_MODULE(NODE_GYP_MODULE_NAME, Init)
|
|
68
|
-
```
|
|
69
|
-
|
|
70
|
-
The above code can be used from JavaScript as follows:
|
|
71
|
-
|
|
72
|
-
```js
|
|
73
|
-
'use strict';
|
|
74
|
-
|
|
75
|
-
const { Example } = require('bindings')('addon');
|
|
76
|
-
|
|
77
|
-
const example = new Example(11);
|
|
78
|
-
console.log(example.value);
|
|
79
|
-
// It prints 11
|
|
80
|
-
example.value = 19;
|
|
81
|
-
console.log(example.value);
|
|
82
|
-
// It prints 19
|
|
83
|
-
example.readOnlyProp = 500;
|
|
84
|
-
console.log(example.readOnlyProp);
|
|
85
|
-
// Unchanged. It prints 19
|
|
86
|
-
```
|
|
87
|
-
|
|
88
|
-
## Methods
|
|
89
|
-
|
|
90
|
-
### Constructor
|
|
91
|
-
|
|
92
|
-
Creates new instance of `Napi::ClassPropertyDescriptor` descriptor object.
|
|
93
|
-
|
|
94
|
-
```cpp
|
|
95
|
-
Napi::ClassPropertyDescriptor(napi_property_descriptor desc) : _desc(desc) {}
|
|
96
|
-
```
|
|
97
|
-
|
|
98
|
-
- `[in] desc`: The `napi_property_descriptor`
|
|
99
|
-
|
|
100
|
-
Returns new instance of `Napi::ClassPropertyDescriptor` that is used as property descriptor
|
|
101
|
-
inside the `Napi::ObjectWrap<T>` class.
|
|
102
|
-
|
|
103
|
-
### Operator
|
|
104
|
-
|
|
105
|
-
```cpp
|
|
106
|
-
operator napi_property_descriptor&() { return _desc; }
|
|
107
|
-
```
|
|
108
|
-
|
|
109
|
-
Returns the original Node-API `napi_property_descriptor` wrapped inside the `Napi::ClassPropertyDescriptor`
|
|
110
|
-
|
|
111
|
-
```cpp
|
|
112
|
-
operator const napi_property_descriptor&() const { return _desc; }
|
|
113
|
-
```
|
|
114
|
-
|
|
115
|
-
Returns the original Node-API `napi_property_descriptor` wrapped inside the `Napi::ClassPropertyDescriptor`
|
|
1
|
+
# Class property and descriptor
|
|
2
|
+
|
|
3
|
+
Property descriptor for use with `Napi::ObjectWrap::DefineClass()`.
|
|
4
|
+
This is different from the standalone `Napi::PropertyDescriptor` because it is
|
|
5
|
+
specific to each `Napi::ObjectWrap<T>` subclass.
|
|
6
|
+
This prevents using descriptors from a different class when defining a new class
|
|
7
|
+
(preventing the callbacks from having incorrect `this` pointers).
|
|
8
|
+
|
|
9
|
+
## Example
|
|
10
|
+
|
|
11
|
+
```cpp
|
|
12
|
+
#include <napi.h>
|
|
13
|
+
|
|
14
|
+
class Example : public Napi::ObjectWrap<Example> {
|
|
15
|
+
public:
|
|
16
|
+
static Napi::Object Init(Napi::Env env, Napi::Object exports);
|
|
17
|
+
Example(const Napi::CallbackInfo &info);
|
|
18
|
+
|
|
19
|
+
private:
|
|
20
|
+
double _value;
|
|
21
|
+
Napi::Value GetValue(const Napi::CallbackInfo &info);
|
|
22
|
+
void SetValue(const Napi::CallbackInfo &info, const Napi::Value &value);
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
Napi::Object Example::Init(Napi::Env env, Napi::Object exports) {
|
|
26
|
+
Napi::Function func = DefineClass(env, "Example", {
|
|
27
|
+
// Register a class instance accessor with getter and setter functions.
|
|
28
|
+
InstanceAccessor<&Example::GetValue, &Example::SetValue>("value"),
|
|
29
|
+
// We can also register a readonly accessor by omitting the setter.
|
|
30
|
+
InstanceAccessor<&Example::GetValue>("readOnlyProp")
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
Napi::FunctionReference *constructor = new Napi::FunctionReference();
|
|
34
|
+
*constructor = Napi::Persistent(func);
|
|
35
|
+
env.SetInstanceData(constructor);
|
|
36
|
+
exports.Set("Example", func);
|
|
37
|
+
|
|
38
|
+
return exports;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
Example::Example(const Napi::CallbackInfo &info) : Napi::ObjectWrap<Example>(info) {
|
|
42
|
+
Napi::Env env = info.Env();
|
|
43
|
+
// ...
|
|
44
|
+
Napi::Number value = info[0].As<Napi::Number>();
|
|
45
|
+
this->_value = value.DoubleValue();
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
Napi::Value Example::GetValue(const Napi::CallbackInfo &info) {
|
|
49
|
+
Napi::Env env = info.Env();
|
|
50
|
+
return Napi::Number::New(env, this->_value);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
void Example::SetValue(const Napi::CallbackInfo &info, const Napi::Value &value) {
|
|
54
|
+
Napi::Env env = info.Env();
|
|
55
|
+
// ...
|
|
56
|
+
Napi::Number arg = value.As<Napi::Number>();
|
|
57
|
+
this->_value = arg.DoubleValue();
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// Initialize native add-on
|
|
61
|
+
Napi::Object Init (Napi::Env env, Napi::Object exports) {
|
|
62
|
+
Example::Init(env, exports);
|
|
63
|
+
return exports;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// Register and initialize native add-on
|
|
67
|
+
NODE_API_MODULE(NODE_GYP_MODULE_NAME, Init)
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
The above code can be used from JavaScript as follows:
|
|
71
|
+
|
|
72
|
+
```js
|
|
73
|
+
'use strict';
|
|
74
|
+
|
|
75
|
+
const { Example } = require('bindings')('addon');
|
|
76
|
+
|
|
77
|
+
const example = new Example(11);
|
|
78
|
+
console.log(example.value);
|
|
79
|
+
// It prints 11
|
|
80
|
+
example.value = 19;
|
|
81
|
+
console.log(example.value);
|
|
82
|
+
// It prints 19
|
|
83
|
+
example.readOnlyProp = 500;
|
|
84
|
+
console.log(example.readOnlyProp);
|
|
85
|
+
// Unchanged. It prints 19
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
## Methods
|
|
89
|
+
|
|
90
|
+
### Constructor
|
|
91
|
+
|
|
92
|
+
Creates new instance of `Napi::ClassPropertyDescriptor` descriptor object.
|
|
93
|
+
|
|
94
|
+
```cpp
|
|
95
|
+
Napi::ClassPropertyDescriptor(napi_property_descriptor desc) : _desc(desc) {}
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
- `[in] desc`: The `napi_property_descriptor`
|
|
99
|
+
|
|
100
|
+
Returns new instance of `Napi::ClassPropertyDescriptor` that is used as property descriptor
|
|
101
|
+
inside the `Napi::ObjectWrap<T>` class.
|
|
102
|
+
|
|
103
|
+
### Operator
|
|
104
|
+
|
|
105
|
+
```cpp
|
|
106
|
+
operator napi_property_descriptor&() { return _desc; }
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
Returns the original Node-API `napi_property_descriptor` wrapped inside the `Napi::ClassPropertyDescriptor`
|
|
110
|
+
|
|
111
|
+
```cpp
|
|
112
|
+
operator const napi_property_descriptor&() const { return _desc; }
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
Returns the original Node-API `napi_property_descriptor` wrapped inside the `Napi::ClassPropertyDescriptor`
|