koffi 0.9.3 → 0.9.6
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 +63 -60
- package/README.md +162 -153
- package/package.json +19 -18
- package/src/call.hh +27 -27
- package/src/call_arm32.cc +514 -0
- package/src/call_arm32_fwd.S +108 -0
- package/src/call_arm64.cc +497 -482
- package/src/call_arm64_fwd.S +110 -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 +136 -135
- package/src/util.cc +297 -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 +2674 -2670
- package/vendor/dragonbox/include/dragonbox/dragonbox_to_chars.h +108 -108
- package/vendor/dragonbox/other_files/Dragonbox.pdf +0 -0
- 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
package/src/util.cc
CHANGED
|
@@ -1,296 +1,297 @@
|
|
|
1
|
-
// This program is free software: you can redistribute it and/or modify
|
|
2
|
-
// it under the terms of the GNU Affero General Public License as published by
|
|
3
|
-
// the Free Software Foundation, either version 3 of the License, or
|
|
4
|
-
// (at your option) any later version.
|
|
5
|
-
//
|
|
6
|
-
// This program is distributed in the hope that it will be useful,
|
|
7
|
-
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
8
|
-
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
9
|
-
// GNU Affero General Public License for more details.
|
|
10
|
-
//
|
|
11
|
-
// You should have received a copy of the GNU Affero General Public License
|
|
12
|
-
// along with this program. If not, see https://www.gnu.org/licenses/.
|
|
13
|
-
|
|
14
|
-
#include "vendor/libcc/libcc.hh"
|
|
15
|
-
#include "ffi.hh"
|
|
16
|
-
#include "util.hh"
|
|
17
|
-
|
|
18
|
-
#include <napi.h>
|
|
19
|
-
|
|
20
|
-
namespace RG {
|
|
21
|
-
|
|
22
|
-
const char *GetValueType(const InstanceData *instance, Napi::Value value)
|
|
23
|
-
{
|
|
24
|
-
for (const TypeInfo &type: instance->types) {
|
|
25
|
-
if (CheckValueTag(instance, value, &type))
|
|
26
|
-
return type.name;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
switch (value.Type()) {
|
|
30
|
-
case napi_undefined: return "undefined";
|
|
31
|
-
case napi_null: return "null";
|
|
32
|
-
case napi_boolean: return "boolean";
|
|
33
|
-
case napi_number: return "number";
|
|
34
|
-
case napi_string: return "string";
|
|
35
|
-
case napi_symbol: return "symbol";
|
|
36
|
-
case napi_object: return "object";
|
|
37
|
-
case napi_function: return "fucntion";
|
|
38
|
-
case napi_external: return "external";
|
|
39
|
-
case napi_bigint: return "bigint";
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
return "unknown";
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
void SetValueTag(const InstanceData *instance, Napi::Value value, const void *marker)
|
|
46
|
-
{
|
|
47
|
-
napi_type_tag tag = { instance->tag_lower, (uint64_t)marker };
|
|
48
|
-
napi_status status = napi_type_tag_object(value.Env(), value, &tag);
|
|
49
|
-
RG_ASSERT(status == napi_ok);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
bool CheckValueTag(const InstanceData *instance, Napi::Value value, const void *marker)
|
|
53
|
-
{
|
|
54
|
-
bool match = false;
|
|
55
|
-
|
|
56
|
-
napi_type_tag tag = { instance->tag_lower, (uint64_t)marker };
|
|
57
|
-
napi_check_object_type_tag(value.Env(), value, &tag, &match);
|
|
58
|
-
|
|
59
|
-
return match;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
const char *CopyNodeString(const Napi::Value &value, Allocator *alloc)
|
|
63
|
-
{
|
|
64
|
-
RG_ASSERT(value.IsString());
|
|
65
|
-
|
|
66
|
-
Napi::Env env = value.Env();
|
|
67
|
-
napi_status status;
|
|
68
|
-
|
|
69
|
-
size_t len = 0;
|
|
70
|
-
status = napi_get_value_string_utf8(env, value, nullptr, 0, &len);
|
|
71
|
-
RG_ASSERT(status == napi_ok);
|
|
72
|
-
|
|
73
|
-
Span<char> buf;
|
|
74
|
-
buf.len = (Size)len + 1;
|
|
75
|
-
buf.ptr = (char *)Allocator::Allocate(alloc, buf.len);
|
|
76
|
-
|
|
77
|
-
status = napi_get_value_string_utf8(env, value, buf.ptr, (size_t)buf.len, &len);
|
|
78
|
-
RG_ASSERT(status == napi_ok);
|
|
79
|
-
|
|
80
|
-
return buf.ptr;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
bool PushObject(const Napi::Object &obj, const TypeInfo *type, Allocator *alloc, uint8_t *dest)
|
|
84
|
-
{
|
|
85
|
-
Napi::Env env = obj.Env();
|
|
86
|
-
InstanceData *instance = env.GetInstanceData<InstanceData>();
|
|
87
|
-
|
|
88
|
-
RG_ASSERT(obj.IsObject());
|
|
89
|
-
RG_ASSERT(type->primitive == PrimitiveKind::Record);
|
|
90
|
-
|
|
91
|
-
dest = AlignUp(dest, type->align);
|
|
92
|
-
|
|
93
|
-
for (const RecordMember &member: type->members) {
|
|
94
|
-
Napi::Value value = obj.Get(member.name);
|
|
95
|
-
|
|
96
|
-
if (RG_UNLIKELY(value.IsUndefined())) {
|
|
97
|
-
ThrowError<Napi::TypeError>(env, "Missing expected object property '%1'", member.name);
|
|
98
|
-
return false;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
dest = AlignUp(dest, member.type->align);
|
|
102
|
-
|
|
103
|
-
switch (member.type->primitive) {
|
|
104
|
-
case PrimitiveKind::Void: { RG_UNREACHABLE(); } break;
|
|
105
|
-
|
|
106
|
-
case PrimitiveKind::Bool: {
|
|
107
|
-
if (RG_UNLIKELY(!value.IsBoolean())) {
|
|
108
|
-
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected boolean", GetValueType(instance, value), member.name);
|
|
109
|
-
return false;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
bool b = value.As<Napi::Boolean>();
|
|
113
|
-
*(bool *)dest = b;
|
|
114
|
-
} break;
|
|
115
|
-
|
|
116
|
-
case PrimitiveKind::Int8:
|
|
117
|
-
case PrimitiveKind::UInt8:
|
|
118
|
-
case PrimitiveKind::Int16:
|
|
119
|
-
case PrimitiveKind::UInt16:
|
|
120
|
-
case PrimitiveKind::Int32:
|
|
121
|
-
case PrimitiveKind::UInt32:
|
|
122
|
-
case PrimitiveKind::Int64:
|
|
123
|
-
case PrimitiveKind::UInt64: {
|
|
124
|
-
if (RG_UNLIKELY(!value.IsNumber() && !value.IsBigInt())) {
|
|
125
|
-
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected number", GetValueType(instance, value), member.name);
|
|
126
|
-
return false;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
int64_t v = CopyNodeNumber<int64_t>(value);
|
|
130
|
-
memcpy(dest, &v, member.type->size); // Little Endian
|
|
131
|
-
} break;
|
|
132
|
-
case PrimitiveKind::Float32: {
|
|
133
|
-
if (RG_UNLIKELY(!value.IsNumber() && !value.IsBigInt())) {
|
|
134
|
-
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected number", GetValueType(instance, value), member.name);
|
|
135
|
-
return false;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
float f = CopyNodeNumber<float>(value);
|
|
139
|
-
memcpy(dest, &f, 4);
|
|
140
|
-
} break;
|
|
141
|
-
case PrimitiveKind::Float64: {
|
|
142
|
-
if (RG_UNLIKELY(!value.IsNumber() && !value.IsBigInt())) {
|
|
143
|
-
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected number", GetValueType(instance, value), member.name);
|
|
144
|
-
return false;
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
double d = CopyNodeNumber<double>(value);
|
|
148
|
-
memcpy(dest, &d, 8);
|
|
149
|
-
} break;
|
|
150
|
-
case PrimitiveKind::String: {
|
|
151
|
-
if (RG_UNLIKELY(!value.IsString())) {
|
|
152
|
-
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected string", GetValueType(instance, value), member.name);
|
|
153
|
-
return false;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
const char *str = CopyNodeString(value, alloc);
|
|
157
|
-
*(const char **)dest = str;
|
|
158
|
-
} break;
|
|
159
|
-
case PrimitiveKind::Pointer: {
|
|
160
|
-
if (RG_UNLIKELY(!CheckValueTag(instance, value, member.type))) {
|
|
161
|
-
ThrowError<Napi::TypeError>(env, "Unexpected %1 value for member '%2', expected %3", GetValueType(instance, value), member.name, member.type->name);
|
|
162
|
-
return false;
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
Napi::External external = value.As<Napi::External<void>>();
|
|
166
|
-
void *ptr = external.Data();
|
|
167
|
-
*(void **)dest = ptr;
|
|
168
|
-
} break;
|
|
169
|
-
|
|
170
|
-
case PrimitiveKind::Record: {
|
|
171
|
-
if (RG_UNLIKELY(!value.IsObject())) {
|
|
172
|
-
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected object", GetValueType(instance, value), member.name);
|
|
173
|
-
return false;
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
Napi::Object obj = value.As<Napi::Object>();
|
|
177
|
-
if (!PushObject(obj, member.type, alloc, dest))
|
|
178
|
-
return false;
|
|
179
|
-
} break;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
dest += member.type->size;
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
return true;
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
Napi::Object PopObject(Napi::Env env, const uint8_t *ptr, const TypeInfo *type)
|
|
189
|
-
{
|
|
190
|
-
InstanceData *instance = env.GetInstanceData<InstanceData>();
|
|
191
|
-
|
|
192
|
-
RG_ASSERT(type->primitive == PrimitiveKind::Record);
|
|
193
|
-
|
|
194
|
-
Napi::Object obj = Napi::Object::New(env);
|
|
195
|
-
|
|
196
|
-
ptr = AlignUp(ptr, type->align);
|
|
197
|
-
|
|
198
|
-
for (const RecordMember &member: type->members) {
|
|
199
|
-
ptr = AlignUp(ptr, member.type->align);
|
|
200
|
-
|
|
201
|
-
switch (member.type->primitive) {
|
|
202
|
-
case PrimitiveKind::Void: { RG_UNREACHABLE(); } break;
|
|
203
|
-
|
|
204
|
-
case PrimitiveKind::Bool: {
|
|
205
|
-
bool b = *(bool *)ptr;
|
|
206
|
-
obj.Set(member.name, Napi::Boolean::New(env, b));
|
|
207
|
-
} break;
|
|
208
|
-
case PrimitiveKind::Int8: {
|
|
209
|
-
double d = (double)*(int8_t *)ptr;
|
|
210
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
211
|
-
} break;
|
|
212
|
-
case PrimitiveKind::UInt8: {
|
|
213
|
-
double d = (double)*(uint8_t *)ptr;
|
|
214
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
215
|
-
} break;
|
|
216
|
-
case PrimitiveKind::Int16: {
|
|
217
|
-
double d = (double)*(int16_t *)ptr;
|
|
218
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
219
|
-
} break;
|
|
220
|
-
case PrimitiveKind::UInt16: {
|
|
221
|
-
double d = (double)*(uint16_t *)ptr;
|
|
222
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
223
|
-
} break;
|
|
224
|
-
case PrimitiveKind::Int32: {
|
|
225
|
-
double d = (double)*(int32_t *)ptr;
|
|
226
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
227
|
-
} break;
|
|
228
|
-
case PrimitiveKind::UInt32: {
|
|
229
|
-
double d = (double)*(uint32_t *)ptr;
|
|
230
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
231
|
-
} break;
|
|
232
|
-
case PrimitiveKind::Int64: {
|
|
233
|
-
int64_t v = *(int64_t *)ptr;
|
|
234
|
-
obj.Set(member.name, Napi::BigInt::New(env, v));
|
|
235
|
-
} break;
|
|
236
|
-
case PrimitiveKind::UInt64: {
|
|
237
|
-
uint64_t v = *(uint64_t *)ptr;
|
|
238
|
-
obj.Set(member.name, Napi::BigInt::New(env, v));
|
|
239
|
-
} break;
|
|
240
|
-
case PrimitiveKind::Float32: {
|
|
241
|
-
float f;
|
|
242
|
-
memcpy(&f, ptr, 4);
|
|
243
|
-
obj.Set(member.name, Napi::Number::New(env, (double)f));
|
|
244
|
-
} break;
|
|
245
|
-
case PrimitiveKind::Float64: {
|
|
246
|
-
double d;
|
|
247
|
-
memcpy(&d, ptr, 8);
|
|
248
|
-
obj.Set(member.name, Napi::Number::New(env, d));
|
|
249
|
-
} break;
|
|
250
|
-
case PrimitiveKind::String: {
|
|
251
|
-
const char *str = *(const char **)ptr;
|
|
252
|
-
obj.Set(member.name, Napi::String::New(env, str));
|
|
253
|
-
} break;
|
|
254
|
-
case PrimitiveKind::Pointer: {
|
|
255
|
-
void *ptr2 = *(void **)ptr;
|
|
256
|
-
|
|
257
|
-
Napi::External<void> external = Napi::External<void>::New(env, ptr2);
|
|
258
|
-
SetValueTag(instance, external, member.type);
|
|
259
|
-
|
|
260
|
-
obj.Set(member.name, external);
|
|
261
|
-
} break;
|
|
262
|
-
|
|
263
|
-
case PrimitiveKind::Record: {
|
|
264
|
-
Napi::Object obj2 = PopObject(env, ptr, member.type);
|
|
265
|
-
obj.Set(member.name, obj2);
|
|
266
|
-
} break;
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
ptr += member.type->size;
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
return obj;
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
void DumpStack(const FunctionInfo *func, Span<const uint8_t> sp)
|
|
276
|
-
{
|
|
277
|
-
PrintLn(stderr, "%!..+---- %1 ----%!0", func->name);
|
|
278
|
-
|
|
279
|
-
PrintLn(stderr, "Parameters:");
|
|
280
|
-
for (Size i = 0; i < func->parameters.len; i++) {
|
|
281
|
-
const ParameterInfo ¶m = func->parameters[i];
|
|
282
|
-
PrintLn(stderr, " %1 = %2", i, param.type->name);
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
PrintLn(stderr, "Stack (%1 bytes) at 0x%2:", sp.len, sp.ptr);
|
|
286
|
-
for (const uint8_t *ptr = sp.begin(); ptr < sp.end();) {
|
|
287
|
-
Print(stderr, " [0x%1 %2 %3] ", FmtArg(ptr).Pad0(-16),
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
|
|
1
|
+
// This program is free software: you can redistribute it and/or modify
|
|
2
|
+
// it under the terms of the GNU Affero General Public License as published by
|
|
3
|
+
// the Free Software Foundation, either version 3 of the License, or
|
|
4
|
+
// (at your option) any later version.
|
|
5
|
+
//
|
|
6
|
+
// This program is distributed in the hope that it will be useful,
|
|
7
|
+
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
8
|
+
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
9
|
+
// GNU Affero General Public License for more details.
|
|
10
|
+
//
|
|
11
|
+
// You should have received a copy of the GNU Affero General Public License
|
|
12
|
+
// along with this program. If not, see https://www.gnu.org/licenses/.
|
|
13
|
+
|
|
14
|
+
#include "vendor/libcc/libcc.hh"
|
|
15
|
+
#include "ffi.hh"
|
|
16
|
+
#include "util.hh"
|
|
17
|
+
|
|
18
|
+
#include <napi.h>
|
|
19
|
+
|
|
20
|
+
namespace RG {
|
|
21
|
+
|
|
22
|
+
const char *GetValueType(const InstanceData *instance, Napi::Value value)
|
|
23
|
+
{
|
|
24
|
+
for (const TypeInfo &type: instance->types) {
|
|
25
|
+
if (CheckValueTag(instance, value, &type))
|
|
26
|
+
return type.name;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
switch (value.Type()) {
|
|
30
|
+
case napi_undefined: return "undefined";
|
|
31
|
+
case napi_null: return "null";
|
|
32
|
+
case napi_boolean: return "boolean";
|
|
33
|
+
case napi_number: return "number";
|
|
34
|
+
case napi_string: return "string";
|
|
35
|
+
case napi_symbol: return "symbol";
|
|
36
|
+
case napi_object: return "object";
|
|
37
|
+
case napi_function: return "fucntion";
|
|
38
|
+
case napi_external: return "external";
|
|
39
|
+
case napi_bigint: return "bigint";
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
return "unknown";
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
void SetValueTag(const InstanceData *instance, Napi::Value value, const void *marker)
|
|
46
|
+
{
|
|
47
|
+
napi_type_tag tag = { instance->tag_lower, (uint64_t)marker };
|
|
48
|
+
napi_status status = napi_type_tag_object(value.Env(), value, &tag);
|
|
49
|
+
RG_ASSERT(status == napi_ok);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
bool CheckValueTag(const InstanceData *instance, Napi::Value value, const void *marker)
|
|
53
|
+
{
|
|
54
|
+
bool match = false;
|
|
55
|
+
|
|
56
|
+
napi_type_tag tag = { instance->tag_lower, (uint64_t)marker };
|
|
57
|
+
napi_check_object_type_tag(value.Env(), value, &tag, &match);
|
|
58
|
+
|
|
59
|
+
return match;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
const char *CopyNodeString(const Napi::Value &value, Allocator *alloc)
|
|
63
|
+
{
|
|
64
|
+
RG_ASSERT(value.IsString());
|
|
65
|
+
|
|
66
|
+
Napi::Env env = value.Env();
|
|
67
|
+
napi_status status;
|
|
68
|
+
|
|
69
|
+
size_t len = 0;
|
|
70
|
+
status = napi_get_value_string_utf8(env, value, nullptr, 0, &len);
|
|
71
|
+
RG_ASSERT(status == napi_ok);
|
|
72
|
+
|
|
73
|
+
Span<char> buf;
|
|
74
|
+
buf.len = (Size)len + 1;
|
|
75
|
+
buf.ptr = (char *)Allocator::Allocate(alloc, buf.len);
|
|
76
|
+
|
|
77
|
+
status = napi_get_value_string_utf8(env, value, buf.ptr, (size_t)buf.len, &len);
|
|
78
|
+
RG_ASSERT(status == napi_ok);
|
|
79
|
+
|
|
80
|
+
return buf.ptr;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
bool PushObject(const Napi::Object &obj, const TypeInfo *type, Allocator *alloc, uint8_t *dest)
|
|
84
|
+
{
|
|
85
|
+
Napi::Env env = obj.Env();
|
|
86
|
+
InstanceData *instance = env.GetInstanceData<InstanceData>();
|
|
87
|
+
|
|
88
|
+
RG_ASSERT(obj.IsObject());
|
|
89
|
+
RG_ASSERT(type->primitive == PrimitiveKind::Record);
|
|
90
|
+
|
|
91
|
+
dest = AlignUp(dest, type->align);
|
|
92
|
+
|
|
93
|
+
for (const RecordMember &member: type->members) {
|
|
94
|
+
Napi::Value value = obj.Get(member.name);
|
|
95
|
+
|
|
96
|
+
if (RG_UNLIKELY(value.IsUndefined())) {
|
|
97
|
+
ThrowError<Napi::TypeError>(env, "Missing expected object property '%1'", member.name);
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
dest = AlignUp(dest, member.type->align);
|
|
102
|
+
|
|
103
|
+
switch (member.type->primitive) {
|
|
104
|
+
case PrimitiveKind::Void: { RG_UNREACHABLE(); } break;
|
|
105
|
+
|
|
106
|
+
case PrimitiveKind::Bool: {
|
|
107
|
+
if (RG_UNLIKELY(!value.IsBoolean())) {
|
|
108
|
+
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected boolean", GetValueType(instance, value), member.name);
|
|
109
|
+
return false;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
bool b = value.As<Napi::Boolean>();
|
|
113
|
+
*(bool *)dest = b;
|
|
114
|
+
} break;
|
|
115
|
+
|
|
116
|
+
case PrimitiveKind::Int8:
|
|
117
|
+
case PrimitiveKind::UInt8:
|
|
118
|
+
case PrimitiveKind::Int16:
|
|
119
|
+
case PrimitiveKind::UInt16:
|
|
120
|
+
case PrimitiveKind::Int32:
|
|
121
|
+
case PrimitiveKind::UInt32:
|
|
122
|
+
case PrimitiveKind::Int64:
|
|
123
|
+
case PrimitiveKind::UInt64: {
|
|
124
|
+
if (RG_UNLIKELY(!value.IsNumber() && !value.IsBigInt())) {
|
|
125
|
+
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected number", GetValueType(instance, value), member.name);
|
|
126
|
+
return false;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
int64_t v = CopyNodeNumber<int64_t>(value);
|
|
130
|
+
memcpy(dest, &v, member.type->size); // Little Endian
|
|
131
|
+
} break;
|
|
132
|
+
case PrimitiveKind::Float32: {
|
|
133
|
+
if (RG_UNLIKELY(!value.IsNumber() && !value.IsBigInt())) {
|
|
134
|
+
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected number", GetValueType(instance, value), member.name);
|
|
135
|
+
return false;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
float f = CopyNodeNumber<float>(value);
|
|
139
|
+
memcpy(dest, &f, 4);
|
|
140
|
+
} break;
|
|
141
|
+
case PrimitiveKind::Float64: {
|
|
142
|
+
if (RG_UNLIKELY(!value.IsNumber() && !value.IsBigInt())) {
|
|
143
|
+
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected number", GetValueType(instance, value), member.name);
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
double d = CopyNodeNumber<double>(value);
|
|
148
|
+
memcpy(dest, &d, 8);
|
|
149
|
+
} break;
|
|
150
|
+
case PrimitiveKind::String: {
|
|
151
|
+
if (RG_UNLIKELY(!value.IsString())) {
|
|
152
|
+
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected string", GetValueType(instance, value), member.name);
|
|
153
|
+
return false;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
const char *str = CopyNodeString(value, alloc);
|
|
157
|
+
*(const char **)dest = str;
|
|
158
|
+
} break;
|
|
159
|
+
case PrimitiveKind::Pointer: {
|
|
160
|
+
if (RG_UNLIKELY(!CheckValueTag(instance, value, member.type))) {
|
|
161
|
+
ThrowError<Napi::TypeError>(env, "Unexpected %1 value for member '%2', expected %3", GetValueType(instance, value), member.name, member.type->name);
|
|
162
|
+
return false;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
Napi::External external = value.As<Napi::External<void>>();
|
|
166
|
+
void *ptr = external.Data();
|
|
167
|
+
*(void **)dest = ptr;
|
|
168
|
+
} break;
|
|
169
|
+
|
|
170
|
+
case PrimitiveKind::Record: {
|
|
171
|
+
if (RG_UNLIKELY(!value.IsObject())) {
|
|
172
|
+
ThrowError<Napi::TypeError>(env, "Unexpected value %1 for member '%2', expected object", GetValueType(instance, value), member.name);
|
|
173
|
+
return false;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
Napi::Object obj = value.As<Napi::Object>();
|
|
177
|
+
if (!PushObject(obj, member.type, alloc, dest))
|
|
178
|
+
return false;
|
|
179
|
+
} break;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
dest += member.type->size;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
return true;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
Napi::Object PopObject(Napi::Env env, const uint8_t *ptr, const TypeInfo *type)
|
|
189
|
+
{
|
|
190
|
+
InstanceData *instance = env.GetInstanceData<InstanceData>();
|
|
191
|
+
|
|
192
|
+
RG_ASSERT(type->primitive == PrimitiveKind::Record);
|
|
193
|
+
|
|
194
|
+
Napi::Object obj = Napi::Object::New(env);
|
|
195
|
+
|
|
196
|
+
ptr = AlignUp(ptr, type->align);
|
|
197
|
+
|
|
198
|
+
for (const RecordMember &member: type->members) {
|
|
199
|
+
ptr = AlignUp(ptr, member.type->align);
|
|
200
|
+
|
|
201
|
+
switch (member.type->primitive) {
|
|
202
|
+
case PrimitiveKind::Void: { RG_UNREACHABLE(); } break;
|
|
203
|
+
|
|
204
|
+
case PrimitiveKind::Bool: {
|
|
205
|
+
bool b = *(bool *)ptr;
|
|
206
|
+
obj.Set(member.name, Napi::Boolean::New(env, b));
|
|
207
|
+
} break;
|
|
208
|
+
case PrimitiveKind::Int8: {
|
|
209
|
+
double d = (double)*(int8_t *)ptr;
|
|
210
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
211
|
+
} break;
|
|
212
|
+
case PrimitiveKind::UInt8: {
|
|
213
|
+
double d = (double)*(uint8_t *)ptr;
|
|
214
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
215
|
+
} break;
|
|
216
|
+
case PrimitiveKind::Int16: {
|
|
217
|
+
double d = (double)*(int16_t *)ptr;
|
|
218
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
219
|
+
} break;
|
|
220
|
+
case PrimitiveKind::UInt16: {
|
|
221
|
+
double d = (double)*(uint16_t *)ptr;
|
|
222
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
223
|
+
} break;
|
|
224
|
+
case PrimitiveKind::Int32: {
|
|
225
|
+
double d = (double)*(int32_t *)ptr;
|
|
226
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
227
|
+
} break;
|
|
228
|
+
case PrimitiveKind::UInt32: {
|
|
229
|
+
double d = (double)*(uint32_t *)ptr;
|
|
230
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
231
|
+
} break;
|
|
232
|
+
case PrimitiveKind::Int64: {
|
|
233
|
+
int64_t v = *(int64_t *)ptr;
|
|
234
|
+
obj.Set(member.name, Napi::BigInt::New(env, v));
|
|
235
|
+
} break;
|
|
236
|
+
case PrimitiveKind::UInt64: {
|
|
237
|
+
uint64_t v = *(uint64_t *)ptr;
|
|
238
|
+
obj.Set(member.name, Napi::BigInt::New(env, v));
|
|
239
|
+
} break;
|
|
240
|
+
case PrimitiveKind::Float32: {
|
|
241
|
+
float f;
|
|
242
|
+
memcpy(&f, ptr, 4);
|
|
243
|
+
obj.Set(member.name, Napi::Number::New(env, (double)f));
|
|
244
|
+
} break;
|
|
245
|
+
case PrimitiveKind::Float64: {
|
|
246
|
+
double d;
|
|
247
|
+
memcpy(&d, ptr, 8);
|
|
248
|
+
obj.Set(member.name, Napi::Number::New(env, d));
|
|
249
|
+
} break;
|
|
250
|
+
case PrimitiveKind::String: {
|
|
251
|
+
const char *str = *(const char **)ptr;
|
|
252
|
+
obj.Set(member.name, Napi::String::New(env, str));
|
|
253
|
+
} break;
|
|
254
|
+
case PrimitiveKind::Pointer: {
|
|
255
|
+
void *ptr2 = *(void **)ptr;
|
|
256
|
+
|
|
257
|
+
Napi::External<void> external = Napi::External<void>::New(env, ptr2);
|
|
258
|
+
SetValueTag(instance, external, member.type);
|
|
259
|
+
|
|
260
|
+
obj.Set(member.name, external);
|
|
261
|
+
} break;
|
|
262
|
+
|
|
263
|
+
case PrimitiveKind::Record: {
|
|
264
|
+
Napi::Object obj2 = PopObject(env, ptr, member.type);
|
|
265
|
+
obj.Set(member.name, obj2);
|
|
266
|
+
} break;
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
ptr += member.type->size;
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
return obj;
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
void DumpStack(const FunctionInfo *func, Span<const uint8_t> sp)
|
|
276
|
+
{
|
|
277
|
+
PrintLn(stderr, "%!..+---- %1 ----%!0", func->name);
|
|
278
|
+
|
|
279
|
+
PrintLn(stderr, "Parameters:");
|
|
280
|
+
for (Size i = 0; i < func->parameters.len; i++) {
|
|
281
|
+
const ParameterInfo ¶m = func->parameters[i];
|
|
282
|
+
PrintLn(stderr, " %1 = %2", i, param.type->name);
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
PrintLn(stderr, "Stack (%1 bytes) at 0x%2:", sp.len, sp.ptr);
|
|
286
|
+
for (const uint8_t *ptr = sp.begin(); ptr < sp.end();) {
|
|
287
|
+
Print(stderr, " [0x%1 %2 %3] ", FmtArg(ptr).Pad0(-16),
|
|
288
|
+
FmtArg((ptr - sp.begin()) / sizeof(void *)).Pad(-4),
|
|
289
|
+
FmtArg(ptr - sp.begin()).Pad(-4));
|
|
290
|
+
for (int i = 0; ptr < sp.end() && i < sizeof(void *); i++, ptr++) {
|
|
291
|
+
Print(stderr, " %1", FmtHex(*ptr).Pad0(-2));
|
|
292
|
+
}
|
|
293
|
+
PrintLn(stderr);
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
}
|