koffi 1.0.3 → 1.1.0-beta.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/README.md +48 -22
- package/build/qemu/1.1.0-beta.0/koffi_darwin_x64.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_freebsd_arm64.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_freebsd_ia32.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_freebsd_x64.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_linux_arm.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_linux_arm64.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_linux_ia32.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_linux_x64.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_win32_ia32.tar.gz +0 -0
- package/build/qemu/1.1.0-beta.0/koffi_win32_x64.tar.gz +0 -0
- package/package.json +1 -1
- package/qemu/qemu.js +11 -5
- package/qemu/registry/machines.json +20 -10
- package/src/abi_arm32.cc +130 -215
- package/src/abi_arm64.cc +103 -117
- package/src/abi_x64_sysv.cc +117 -135
- package/src/abi_x64_win.cc +89 -98
- package/src/abi_x86.cc +91 -99
- package/src/call.cc +164 -40
- package/src/call.hh +53 -31
- package/src/ffi.cc +163 -19
- package/src/ffi.hh +30 -22
- package/src/util.cc +0 -127
- package/src/util.hh +0 -16
- package/test/misc.c +68 -2
- package/vendor/libcc/libcc.hh +1 -1
- package/build/qemu/1.0.3/koffi_darwin_x64.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_freebsd_arm64.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_freebsd_ia32.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_freebsd_x64.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_linux_arm.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_linux_arm64.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_linux_ia32.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_linux_x64.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_win32_ia32.tar.gz +0 -0
- package/build/qemu/1.0.3/koffi_win32_x64.tar.gz +0 -0
- package/test/misc.js +0 -180
- package/vendor/node-addon-api/CODE_OF_CONDUCT.md +0 -4
- package/vendor/node-addon-api/CONTRIBUTING.md +0 -93
- 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 -217
- 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 -91
- package/vendor/node-addon-api/benchmark/property_descriptor.js +0 -37
- 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 -155
- 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 -427
- package/vendor/node-addon-api/doc/async_worker_variants.md +0 -557
- 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 -150
- 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 -68
- package/vendor/node-addon-api/doc/conversion-tool.md +0 -28
- package/vendor/node-addon-api/doc/creating_a_release.md +0 -62
- 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 -196
- package/vendor/node-addon-api/doc/error.md +0 -120
- package/vendor/node-addon-api/doc/error_handling.md +0 -254
- package/vendor/node-addon-api/doc/escapable_handle_scope.md +0 -80
- package/vendor/node-addon-api/doc/external.md +0 -63
- 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 -63
- package/vendor/node-addon-api/doc/hierarchy.md +0 -91
- 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 -588
- package/vendor/node-addon-api/doc/prebuild_tools.md +0 -16
- package/vendor/node-addon-api/doc/promises.md +0 -79
- 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 -110
- 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/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/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 -340
- package/vendor/node-addon-api/doc/version_management.md +0 -43
- package/vendor/node-addon-api/package.json +0 -415
- package/vendor/node-addon-api/test/README.md +0 -91
- package/vendor/node-addon-api/test/addon.cc +0 -36
- package/vendor/node-addon-api/test/addon.js +0 -11
- package/vendor/node-addon-api/test/addon_build/index.js +0 -49
- package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +0 -17
- package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +0 -62
- 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 -99
- package/vendor/node-addon-api/test/addon_data.js +0 -46
- package/vendor/node-addon-api/test/array_buffer.cc +0 -243
- package/vendor/node-addon-api/test/array_buffer.js +0 -69
- 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 -83
- package/vendor/node-addon-api/test/async_progress_queue_worker.js +0 -46
- package/vendor/node-addon-api/test/async_progress_worker.cc +0 -134
- package/vendor/node-addon-api/test/async_progress_worker.js +0 -61
- package/vendor/node-addon-api/test/async_worker.cc +0 -106
- package/vendor/node-addon-api/test/async_worker.js +0 -179
- package/vendor/node-addon-api/test/async_worker_nocallback.js +0 -13
- 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 -35
- package/vendor/node-addon-api/test/basic_types/boolean.cc +0 -38
- package/vendor/node-addon-api/test/basic_types/boolean.js +0 -35
- package/vendor/node-addon-api/test/basic_types/number.cc +0 -99
- package/vendor/node-addon-api/test/basic_types/number.js +0 -114
- package/vendor/node-addon-api/test/basic_types/value.cc +0 -120
- package/vendor/node-addon-api/test/basic_types/value.js +0 -133
- 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 -173
- package/vendor/node-addon-api/test/binding.gyp +0 -124
- package/vendor/node-addon-api/test/buffer.cc +0 -183
- package/vendor/node-addon-api/test/buffer.js +0 -69
- package/vendor/node-addon-api/test/callbackscope.cc +0 -22
- package/vendor/node-addon-api/test/callbackscope.js +0 -49
- package/vendor/node-addon-api/test/common/index.js +0 -114
- 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 -90
- package/vendor/node-addon-api/test/date.cc +0 -44
- package/vendor/node-addon-api/test/date.js +0 -18
- package/vendor/node-addon-api/test/env_cleanup.cc +0 -88
- package/vendor/node-addon-api/test/env_cleanup.js +0 -56
- package/vendor/node-addon-api/test/error.cc +0 -287
- package/vendor/node-addon-api/test/error.js +0 -81
- 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 -95
- package/vendor/node-addon-api/test/external.cc +0 -81
- package/vendor/node-addon-api/test/external.js +0 -88
- package/vendor/node-addon-api/test/function.cc +0 -324
- package/vendor/node-addon-api/test/function.js +0 -133
- package/vendor/node-addon-api/test/function_reference.cc +0 -202
- 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 -61
- 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 -57
- 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 -48
- 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 -58
- package/vendor/node-addon-api/test/handlescope.cc +0 -60
- package/vendor/node-addon-api/test/handlescope.js +0 -14
- package/vendor/node-addon-api/test/index.js +0 -159
- package/vendor/node-addon-api/test/maybe/check.cc +0 -23
- package/vendor/node-addon-api/test/maybe/index.js +0 -38
- package/vendor/node-addon-api/test/memory_management.cc +0 -17
- 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 -108
- 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 -29
- 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 -350
- package/vendor/node-addon-api/test/object/object.js +0 -217
- package/vendor/node-addon-api/test/object/object_deprecated.cc +0 -66
- package/vendor/node-addon-api/test/object/object_deprecated.js +0 -47
- 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 -219
- package/vendor/node-addon-api/test/object_reference.js +0 -259
- package/vendor/node-addon-api/test/objectwrap.cc +0 -268
- package/vendor/node-addon-api/test/objectwrap.js +0 -284
- 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 -45
- package/vendor/node-addon-api/test/objectwrap_function.js +0 -22
- 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 -40
- package/vendor/node-addon-api/test/objectwrap_worker_thread.js +0 -19
- package/vendor/node-addon-api/test/promise.cc +0 -29
- package/vendor/node-addon-api/test/promise.js +0 -18
- package/vendor/node-addon-api/test/reference.cc +0 -24
- package/vendor/node-addon-api/test/reference.js +0 -14
- 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 -73
- package/vendor/node-addon-api/test/testUtil.js +0 -54
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +0 -195
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +0 -188
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +0 -63
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +0 -12
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +0 -115
- 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 -26
- 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 -225
- 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 -42
- package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +0 -53
- package/vendor/node-addon-api/test/thunking_manual.cc +0 -140
- package/vendor/node-addon-api/test/thunking_manual.js +0 -17
- 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 -68
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +0 -12
- 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 -28
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +0 -7
- 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 -53
- package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +0 -53
- package/vendor/node-addon-api/test/typedarray-bigint.js +0 -58
- package/vendor/node-addon-api/test/typedarray.cc +0 -216
- package/vendor/node-addon-api/test/typedarray.js +0 -69
- package/vendor/node-addon-api/test/version_management.cc +0 -27
- package/vendor/node-addon-api/test/version_management.js +0 -31
- 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
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
environment:
|
|
2
|
-
# https://github.com/jasongin/nvs/blob/HEAD/doc/CI.md
|
|
3
|
-
NVS_VERSION: 1.4.2
|
|
4
|
-
matrix:
|
|
5
|
-
- NODEJS_VERSION: node/10
|
|
6
|
-
- NODEJS_VERSION: node/12
|
|
7
|
-
- NODEJS_VERSION: node/14
|
|
8
|
-
- NODEJS_VERSION: nightly
|
|
9
|
-
|
|
10
|
-
os: Visual Studio 2017
|
|
11
|
-
platform:
|
|
12
|
-
- x86
|
|
13
|
-
- x64
|
|
14
|
-
|
|
15
|
-
install:
|
|
16
|
-
# nvs
|
|
17
|
-
- git clone --branch v%NVS_VERSION% --depth 1 https://github.com/jasongin/nvs %LOCALAPPDATA%\nvs
|
|
18
|
-
- set PATH=%LOCALAPPDATA%\nvs;%PATH%
|
|
19
|
-
- nvs --version
|
|
20
|
-
# node.js
|
|
21
|
-
- nvs add %NODEJS_VERSION%/%PLATFORM%
|
|
22
|
-
- nvs use %NODEJS_VERSION%/%PLATFORM%
|
|
23
|
-
- node --version
|
|
24
|
-
- node -p process.arch
|
|
25
|
-
- npm --version
|
|
26
|
-
# app
|
|
27
|
-
- npm install
|
|
28
|
-
|
|
29
|
-
test_script:
|
|
30
|
-
- npm test
|
|
31
|
-
|
|
32
|
-
build: off
|
|
33
|
-
|
|
34
|
-
version: "{build}"
|
|
35
|
-
|
|
36
|
-
cache:
|
|
37
|
-
- node_modules
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
# Benchmarks
|
|
2
|
-
|
|
3
|
-
## Running the benchmarks
|
|
4
|
-
|
|
5
|
-
From the parent directory, run
|
|
6
|
-
|
|
7
|
-
```bash
|
|
8
|
-
npm run-script benchmark
|
|
9
|
-
```
|
|
10
|
-
|
|
11
|
-
The above script supports the following arguments:
|
|
12
|
-
|
|
13
|
-
* `--benchmarks=...`: A semicolon-separated list of benchmark names. These names
|
|
14
|
-
will be mapped to file names in this directory by appending `.js`.
|
|
15
|
-
|
|
16
|
-
## Adding benchmarks
|
|
17
|
-
|
|
18
|
-
The steps below should be followed when adding new benchmarks.
|
|
19
|
-
|
|
20
|
-
0. Decide on a name for the benchmark. This name will be used in several places.
|
|
21
|
-
This example will use the name `new_benchmark`.
|
|
22
|
-
|
|
23
|
-
0. Create files `new_benchmark.cc` and `new_benchmark.js` in this directory.
|
|
24
|
-
|
|
25
|
-
0. Copy an existing benchmark in `binding.gyp` and change the target name prefix
|
|
26
|
-
and the source file name to `new_benchmark`. This should result in two new
|
|
27
|
-
targets which look like this:
|
|
28
|
-
|
|
29
|
-
```gyp
|
|
30
|
-
{
|
|
31
|
-
'target_name': 'new_benchmark',
|
|
32
|
-
'sources': [ 'new_benchmark.cc' ],
|
|
33
|
-
'includes': [ '../except.gypi' ],
|
|
34
|
-
},
|
|
35
|
-
{
|
|
36
|
-
'target_name': 'new_benchmark_noexcept',
|
|
37
|
-
'sources': [ 'new_benchmark.cc' ],
|
|
38
|
-
'includes': [ '../noexcept.gypi' ],
|
|
39
|
-
},
|
|
40
|
-
```
|
|
41
|
-
|
|
42
|
-
There should always be a pair of targets: one bearing the name of the
|
|
43
|
-
benchmark and configured with C++ exceptions enabled, and one bearing the
|
|
44
|
-
same name followed by the suffix `_noexcept` and configured with C++
|
|
45
|
-
exceptions disabled. This will ensure that the benchmark can be written to
|
|
46
|
-
cover both the case where C++ exceptions are enabled and the case where they
|
|
47
|
-
are disabled.
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
'target_defaults': { 'includes': ['../common.gypi'] },
|
|
3
|
-
'targets': [
|
|
4
|
-
{
|
|
5
|
-
'target_name': 'function_args',
|
|
6
|
-
'sources': [ 'function_args.cc' ],
|
|
7
|
-
'includes': [ '../except.gypi' ],
|
|
8
|
-
},
|
|
9
|
-
{
|
|
10
|
-
'target_name': 'function_args_noexcept',
|
|
11
|
-
'sources': [ 'function_args.cc' ],
|
|
12
|
-
'includes': [ '../noexcept.gypi' ],
|
|
13
|
-
},
|
|
14
|
-
{
|
|
15
|
-
'target_name': 'property_descriptor',
|
|
16
|
-
'sources': [ 'property_descriptor.cc' ],
|
|
17
|
-
'includes': [ '../except.gypi' ],
|
|
18
|
-
},
|
|
19
|
-
{
|
|
20
|
-
'target_name': 'property_descriptor_noexcept',
|
|
21
|
-
'sources': [ 'property_descriptor.cc' ],
|
|
22
|
-
'includes': [ '../noexcept.gypi' ],
|
|
23
|
-
},
|
|
24
|
-
]
|
|
25
|
-
}
|
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
#include "napi.h"
|
|
2
|
-
|
|
3
|
-
static napi_value NoArgFunction_Core(napi_env env, napi_callback_info info) {
|
|
4
|
-
(void) env;
|
|
5
|
-
(void) info;
|
|
6
|
-
return nullptr;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
static napi_value OneArgFunction_Core(napi_env env, napi_callback_info info) {
|
|
10
|
-
size_t argc = 1;
|
|
11
|
-
napi_value argv;
|
|
12
|
-
if (napi_get_cb_info(env, info, &argc, &argv, nullptr, nullptr) != napi_ok) {
|
|
13
|
-
return nullptr;
|
|
14
|
-
}
|
|
15
|
-
(void) argv;
|
|
16
|
-
return nullptr;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
static napi_value TwoArgFunction_Core(napi_env env, napi_callback_info info) {
|
|
20
|
-
size_t argc = 2;
|
|
21
|
-
napi_value argv[2];
|
|
22
|
-
if (napi_get_cb_info(env, info, &argc, argv, nullptr, nullptr) != napi_ok) {
|
|
23
|
-
return nullptr;
|
|
24
|
-
}
|
|
25
|
-
(void) argv[0];
|
|
26
|
-
(void) argv[1];
|
|
27
|
-
return nullptr;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
static napi_value ThreeArgFunction_Core(napi_env env, napi_callback_info info) {
|
|
31
|
-
size_t argc = 3;
|
|
32
|
-
napi_value argv[3];
|
|
33
|
-
if (napi_get_cb_info(env, info, &argc, argv, nullptr, nullptr) != napi_ok) {
|
|
34
|
-
return nullptr;
|
|
35
|
-
}
|
|
36
|
-
(void) argv[0];
|
|
37
|
-
(void) argv[1];
|
|
38
|
-
(void) argv[2];
|
|
39
|
-
return nullptr;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
static napi_value FourArgFunction_Core(napi_env env, napi_callback_info info) {
|
|
43
|
-
size_t argc = 4;
|
|
44
|
-
napi_value argv[4];
|
|
45
|
-
if (napi_get_cb_info(env, info, &argc, argv, nullptr, nullptr) != napi_ok) {
|
|
46
|
-
return nullptr;
|
|
47
|
-
}
|
|
48
|
-
(void) argv[0];
|
|
49
|
-
(void) argv[1];
|
|
50
|
-
(void) argv[2];
|
|
51
|
-
(void) argv[3];
|
|
52
|
-
return nullptr;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
static void NoArgFunction(const Napi::CallbackInfo& info) {
|
|
56
|
-
(void) info;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
static void OneArgFunction(const Napi::CallbackInfo& info) {
|
|
60
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
static void TwoArgFunction(const Napi::CallbackInfo& info) {
|
|
64
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
65
|
-
Napi::Value argv1 = info[1]; (void) argv1;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
static void ThreeArgFunction(const Napi::CallbackInfo& info) {
|
|
69
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
70
|
-
Napi::Value argv1 = info[1]; (void) argv1;
|
|
71
|
-
Napi::Value argv2 = info[2]; (void) argv2;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
static void FourArgFunction(const Napi::CallbackInfo& info) {
|
|
75
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
76
|
-
Napi::Value argv1 = info[1]; (void) argv1;
|
|
77
|
-
Napi::Value argv2 = info[2]; (void) argv2;
|
|
78
|
-
Napi::Value argv3 = info[3]; (void) argv3;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
#if NAPI_VERSION > 5
|
|
82
|
-
class FunctionArgsBenchmark : public Napi::Addon<FunctionArgsBenchmark> {
|
|
83
|
-
public:
|
|
84
|
-
FunctionArgsBenchmark(Napi::Env env, Napi::Object exports) {
|
|
85
|
-
DefineAddon(exports, {
|
|
86
|
-
InstanceValue("addon", DefineProperties(Napi::Object::New(env), {
|
|
87
|
-
InstanceMethod("noArgFunction", &FunctionArgsBenchmark::NoArgFunction),
|
|
88
|
-
InstanceMethod("oneArgFunction",
|
|
89
|
-
&FunctionArgsBenchmark::OneArgFunction),
|
|
90
|
-
InstanceMethod("twoArgFunction",
|
|
91
|
-
&FunctionArgsBenchmark::TwoArgFunction),
|
|
92
|
-
InstanceMethod("threeArgFunction",
|
|
93
|
-
&FunctionArgsBenchmark::ThreeArgFunction),
|
|
94
|
-
InstanceMethod("fourArgFunction",
|
|
95
|
-
&FunctionArgsBenchmark::FourArgFunction),
|
|
96
|
-
}), napi_enumerable),
|
|
97
|
-
InstanceValue("addon_templated",
|
|
98
|
-
DefineProperties(Napi::Object::New(env), {
|
|
99
|
-
InstanceMethod<&FunctionArgsBenchmark::NoArgFunction>(
|
|
100
|
-
"noArgFunction"),
|
|
101
|
-
InstanceMethod<&FunctionArgsBenchmark::OneArgFunction>(
|
|
102
|
-
"oneArgFunction"),
|
|
103
|
-
InstanceMethod<&FunctionArgsBenchmark::TwoArgFunction>(
|
|
104
|
-
"twoArgFunction"),
|
|
105
|
-
InstanceMethod<&FunctionArgsBenchmark::ThreeArgFunction>(
|
|
106
|
-
"threeArgFunction"),
|
|
107
|
-
InstanceMethod<&FunctionArgsBenchmark::FourArgFunction>(
|
|
108
|
-
"fourArgFunction"),
|
|
109
|
-
}), napi_enumerable),
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
private:
|
|
113
|
-
void NoArgFunction(const Napi::CallbackInfo& info) {
|
|
114
|
-
(void) info;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
void OneArgFunction(const Napi::CallbackInfo& info) {
|
|
118
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
void TwoArgFunction(const Napi::CallbackInfo& info) {
|
|
122
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
123
|
-
Napi::Value argv1 = info[1]; (void) argv1;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
void ThreeArgFunction(const Napi::CallbackInfo& info) {
|
|
127
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
128
|
-
Napi::Value argv1 = info[1]; (void) argv1;
|
|
129
|
-
Napi::Value argv2 = info[2]; (void) argv2;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
void FourArgFunction(const Napi::CallbackInfo& info) {
|
|
133
|
-
Napi::Value argv0 = info[0]; (void) argv0;
|
|
134
|
-
Napi::Value argv1 = info[1]; (void) argv1;
|
|
135
|
-
Napi::Value argv2 = info[2]; (void) argv2;
|
|
136
|
-
Napi::Value argv3 = info[3]; (void) argv3;
|
|
137
|
-
}
|
|
138
|
-
};
|
|
139
|
-
#endif // NAPI_VERSION > 5
|
|
140
|
-
|
|
141
|
-
static Napi::Object Init(Napi::Env env, Napi::Object exports) {
|
|
142
|
-
napi_value no_arg_function, one_arg_function, two_arg_function,
|
|
143
|
-
three_arg_function, four_arg_function;
|
|
144
|
-
napi_status status;
|
|
145
|
-
|
|
146
|
-
status = napi_create_function(env,
|
|
147
|
-
"noArgFunction",
|
|
148
|
-
NAPI_AUTO_LENGTH,
|
|
149
|
-
NoArgFunction_Core,
|
|
150
|
-
nullptr,
|
|
151
|
-
&no_arg_function);
|
|
152
|
-
NAPI_THROW_IF_FAILED(env, status, Napi::Object());
|
|
153
|
-
|
|
154
|
-
status = napi_create_function(env,
|
|
155
|
-
"oneArgFunction",
|
|
156
|
-
NAPI_AUTO_LENGTH,
|
|
157
|
-
OneArgFunction_Core,
|
|
158
|
-
nullptr,
|
|
159
|
-
&one_arg_function);
|
|
160
|
-
NAPI_THROW_IF_FAILED(env, status, Napi::Object());
|
|
161
|
-
|
|
162
|
-
status = napi_create_function(env,
|
|
163
|
-
"twoArgFunction",
|
|
164
|
-
NAPI_AUTO_LENGTH,
|
|
165
|
-
TwoArgFunction_Core,
|
|
166
|
-
nullptr,
|
|
167
|
-
&two_arg_function);
|
|
168
|
-
NAPI_THROW_IF_FAILED(env, status, Napi::Object());
|
|
169
|
-
|
|
170
|
-
status = napi_create_function(env,
|
|
171
|
-
"threeArgFunction",
|
|
172
|
-
NAPI_AUTO_LENGTH,
|
|
173
|
-
ThreeArgFunction_Core,
|
|
174
|
-
nullptr,
|
|
175
|
-
&three_arg_function);
|
|
176
|
-
NAPI_THROW_IF_FAILED(env, status, Napi::Object());
|
|
177
|
-
|
|
178
|
-
status = napi_create_function(env,
|
|
179
|
-
"fourArgFunction",
|
|
180
|
-
NAPI_AUTO_LENGTH,
|
|
181
|
-
FourArgFunction_Core,
|
|
182
|
-
nullptr,
|
|
183
|
-
&four_arg_function);
|
|
184
|
-
NAPI_THROW_IF_FAILED(env, status, Napi::Object());
|
|
185
|
-
|
|
186
|
-
Napi::Object core = Napi::Object::New(env);
|
|
187
|
-
core["noArgFunction"] = Napi::Value(env, no_arg_function);
|
|
188
|
-
core["oneArgFunction"] = Napi::Value(env, one_arg_function);
|
|
189
|
-
core["twoArgFunction"] = Napi::Value(env, two_arg_function);
|
|
190
|
-
core["threeArgFunction"] = Napi::Value(env, three_arg_function);
|
|
191
|
-
core["fourArgFunction"] = Napi::Value(env, four_arg_function);
|
|
192
|
-
exports["core"] = core;
|
|
193
|
-
|
|
194
|
-
Napi::Object cplusplus = Napi::Object::New(env);
|
|
195
|
-
cplusplus["noArgFunction"] = Napi::Function::New(env, NoArgFunction);
|
|
196
|
-
cplusplus["oneArgFunction"] = Napi::Function::New(env, OneArgFunction);
|
|
197
|
-
cplusplus["twoArgFunction"] = Napi::Function::New(env, TwoArgFunction);
|
|
198
|
-
cplusplus["threeArgFunction"] = Napi::Function::New(env, ThreeArgFunction);
|
|
199
|
-
cplusplus["fourArgFunction"] = Napi::Function::New(env, FourArgFunction);
|
|
200
|
-
exports["cplusplus"] = cplusplus;
|
|
201
|
-
|
|
202
|
-
Napi::Object templated = Napi::Object::New(env);
|
|
203
|
-
templated["noArgFunction"] = Napi::Function::New<NoArgFunction>(env);
|
|
204
|
-
templated["oneArgFunction"] = Napi::Function::New<OneArgFunction>(env);
|
|
205
|
-
templated["twoArgFunction"] = Napi::Function::New<TwoArgFunction>(env);
|
|
206
|
-
templated["threeArgFunction"] = Napi::Function::New<ThreeArgFunction>(env);
|
|
207
|
-
templated["fourArgFunction"] = Napi::Function::New<FourArgFunction>(env);
|
|
208
|
-
exports["templated"] = templated;
|
|
209
|
-
|
|
210
|
-
#if NAPI_VERSION > 5
|
|
211
|
-
FunctionArgsBenchmark::Init(env, exports);
|
|
212
|
-
#endif // NAPI_VERSION > 5
|
|
213
|
-
|
|
214
|
-
return exports;
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
NODE_API_MODULE(NODE_GYP_MODULE_NAME, Init)
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
const path = require('path');
|
|
2
|
-
const Benchmark = require('benchmark');
|
|
3
|
-
const addonName = path.basename(__filename, '.js');
|
|
4
|
-
|
|
5
|
-
[ addonName, addonName + '_noexcept' ]
|
|
6
|
-
.forEach((addonName) => {
|
|
7
|
-
const rootAddon = require('bindings')({
|
|
8
|
-
bindings: addonName,
|
|
9
|
-
module_root: __dirname
|
|
10
|
-
});
|
|
11
|
-
delete rootAddon.path;
|
|
12
|
-
const implems = Object.keys(rootAddon);
|
|
13
|
-
const maxNameLength =
|
|
14
|
-
implems.reduce((soFar, value) => Math.max(soFar, value.length), 0);
|
|
15
|
-
const anObject = {};
|
|
16
|
-
|
|
17
|
-
console.log(`\n${addonName}: `);
|
|
18
|
-
|
|
19
|
-
console.log('no arguments:');
|
|
20
|
-
implems.reduce((suite, implem) => {
|
|
21
|
-
const fn = rootAddon[implem].noArgFunction;
|
|
22
|
-
return suite.add(implem.padStart(maxNameLength, ' '), () => fn());
|
|
23
|
-
}, new Benchmark.Suite)
|
|
24
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
25
|
-
.run();
|
|
26
|
-
|
|
27
|
-
console.log('one argument:');
|
|
28
|
-
implems.reduce((suite, implem) => {
|
|
29
|
-
const fn = rootAddon[implem].oneArgFunction;
|
|
30
|
-
return suite.add(implem.padStart(maxNameLength, ' '), () => fn('x'));
|
|
31
|
-
}, new Benchmark.Suite)
|
|
32
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
33
|
-
.run();
|
|
34
|
-
|
|
35
|
-
console.log('two arguments:');
|
|
36
|
-
implems.reduce((suite, implem) => {
|
|
37
|
-
const fn = rootAddon[implem].twoArgFunction;
|
|
38
|
-
return suite.add(implem.padStart(maxNameLength, ' '), () => fn('x', 12));
|
|
39
|
-
}, new Benchmark.Suite)
|
|
40
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
41
|
-
.run();
|
|
42
|
-
|
|
43
|
-
console.log('three arguments:');
|
|
44
|
-
implems.reduce((suite, implem) => {
|
|
45
|
-
const fn = rootAddon[implem].threeArgFunction;
|
|
46
|
-
return suite.add(implem.padStart(maxNameLength, ' '),
|
|
47
|
-
() => fn('x', 12, true));
|
|
48
|
-
}, new Benchmark.Suite)
|
|
49
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
50
|
-
.run();
|
|
51
|
-
|
|
52
|
-
console.log('four arguments:');
|
|
53
|
-
implems.reduce((suite, implem) => {
|
|
54
|
-
const fn = rootAddon[implem].fourArgFunction;
|
|
55
|
-
return suite.add(implem.padStart(maxNameLength, ' '),
|
|
56
|
-
() => fn('x', 12, true, anObject));
|
|
57
|
-
}, new Benchmark.Suite)
|
|
58
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
59
|
-
.run();
|
|
60
|
-
});
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const { readdirSync } = require('fs');
|
|
4
|
-
const { spawnSync } = require('child_process');
|
|
5
|
-
const path = require('path');
|
|
6
|
-
|
|
7
|
-
let benchmarks = [];
|
|
8
|
-
|
|
9
|
-
if (!!process.env.npm_config_benchmarks) {
|
|
10
|
-
benchmarks = process.env.npm_config_benchmarks
|
|
11
|
-
.split(';')
|
|
12
|
-
.map((item) => (item + '.js'));
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
// Run each file in this directory or the list given on the command line except
|
|
16
|
-
// index.js as a Node.js process.
|
|
17
|
-
(benchmarks.length > 0 ? benchmarks : readdirSync(__dirname))
|
|
18
|
-
.filter((item) => (item !== 'index.js' && item.match(/\.js$/)))
|
|
19
|
-
.map((item) => path.join(__dirname, item))
|
|
20
|
-
.forEach((item) => {
|
|
21
|
-
const child = spawnSync(process.execPath, [
|
|
22
|
-
'--expose-gc',
|
|
23
|
-
item
|
|
24
|
-
], { stdio: 'inherit' });
|
|
25
|
-
if (child.signal) {
|
|
26
|
-
console.error(`Tests aborted with ${child.signal}`);
|
|
27
|
-
process.exitCode = 1;
|
|
28
|
-
} else {
|
|
29
|
-
process.exitCode = child.status;
|
|
30
|
-
}
|
|
31
|
-
if (child.status !== 0) {
|
|
32
|
-
process.exit(process.exitCode);
|
|
33
|
-
}
|
|
34
|
-
});
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
#include "napi.h"
|
|
2
|
-
|
|
3
|
-
static napi_value Getter_Core(napi_env env, napi_callback_info info) {
|
|
4
|
-
(void) info;
|
|
5
|
-
napi_value result;
|
|
6
|
-
napi_status status = napi_create_uint32(env, 42, &result);
|
|
7
|
-
NAPI_THROW_IF_FAILED(env, status, nullptr);
|
|
8
|
-
return result;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
static napi_value Setter_Core(napi_env env, napi_callback_info info) {
|
|
12
|
-
size_t argc = 1;
|
|
13
|
-
napi_value argv;
|
|
14
|
-
napi_status status =
|
|
15
|
-
napi_get_cb_info(env, info, &argc, &argv, nullptr, nullptr);
|
|
16
|
-
NAPI_THROW_IF_FAILED(env, status, nullptr);
|
|
17
|
-
(void) argv;
|
|
18
|
-
return nullptr;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
static Napi::Value Getter(const Napi::CallbackInfo& info) {
|
|
22
|
-
return Napi::Number::New(info.Env(), 42);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
static void Setter(const Napi::CallbackInfo& info) {
|
|
26
|
-
(void) info[0];
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
#if NAPI_VERSION > 5
|
|
30
|
-
class PropDescBenchmark : public Napi::Addon<PropDescBenchmark> {
|
|
31
|
-
public:
|
|
32
|
-
PropDescBenchmark(Napi::Env, Napi::Object exports) {
|
|
33
|
-
DefineAddon(exports, {
|
|
34
|
-
InstanceAccessor("addon",
|
|
35
|
-
&PropDescBenchmark::Getter,
|
|
36
|
-
&PropDescBenchmark::Setter,
|
|
37
|
-
napi_enumerable),
|
|
38
|
-
InstanceAccessor<&PropDescBenchmark::Getter,
|
|
39
|
-
&PropDescBenchmark::Setter>("addon_templated",
|
|
40
|
-
napi_enumerable),
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
private:
|
|
45
|
-
Napi::Value Getter(const Napi::CallbackInfo& info) {
|
|
46
|
-
return Napi::Number::New(info.Env(), 42);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
void Setter(const Napi::CallbackInfo& info, const Napi::Value& val) {
|
|
50
|
-
(void) info[0];
|
|
51
|
-
(void) val;
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
#endif // NAPI_VERSION > 5
|
|
55
|
-
|
|
56
|
-
static Napi::Object Init(Napi::Env env, Napi::Object exports) {
|
|
57
|
-
napi_status status;
|
|
58
|
-
napi_property_descriptor core_prop = {
|
|
59
|
-
"core",
|
|
60
|
-
nullptr,
|
|
61
|
-
nullptr,
|
|
62
|
-
Getter_Core,
|
|
63
|
-
Setter_Core,
|
|
64
|
-
nullptr,
|
|
65
|
-
napi_enumerable,
|
|
66
|
-
nullptr
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
status = napi_define_properties(env, exports, 1, &core_prop);
|
|
70
|
-
NAPI_THROW_IF_FAILED(env, status, Napi::Object());
|
|
71
|
-
|
|
72
|
-
exports.DefineProperty(
|
|
73
|
-
Napi::PropertyDescriptor::Accessor(env,
|
|
74
|
-
exports,
|
|
75
|
-
"cplusplus",
|
|
76
|
-
Getter,
|
|
77
|
-
Setter,
|
|
78
|
-
napi_enumerable));
|
|
79
|
-
|
|
80
|
-
exports.DefineProperty(
|
|
81
|
-
Napi::PropertyDescriptor::Accessor<Getter, Setter>("templated",
|
|
82
|
-
napi_enumerable));
|
|
83
|
-
|
|
84
|
-
#if NAPI_VERSION > 5
|
|
85
|
-
PropDescBenchmark::Init(env, exports);
|
|
86
|
-
#endif // NAPI_VERSION > 5
|
|
87
|
-
|
|
88
|
-
return exports;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
NODE_API_MODULE(NODE_GYP_MODULE_NAME, Init)
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
const path = require('path');
|
|
2
|
-
const Benchmark = require('benchmark');
|
|
3
|
-
const addonName = path.basename(__filename, '.js');
|
|
4
|
-
|
|
5
|
-
[ addonName, addonName + '_noexcept' ]
|
|
6
|
-
.forEach((addonName) => {
|
|
7
|
-
const rootAddon = require('bindings')({
|
|
8
|
-
bindings: addonName,
|
|
9
|
-
module_root: __dirname
|
|
10
|
-
});
|
|
11
|
-
delete rootAddon.path;
|
|
12
|
-
const getters = new Benchmark.Suite;
|
|
13
|
-
const setters = new Benchmark.Suite;
|
|
14
|
-
const maxNameLength = Object.keys(rootAddon)
|
|
15
|
-
.reduce((soFar, value) => Math.max(soFar, value.length), 0);
|
|
16
|
-
|
|
17
|
-
console.log(`\n${addonName}: `);
|
|
18
|
-
|
|
19
|
-
Object.keys(rootAddon).forEach((key) => {
|
|
20
|
-
getters.add(`${key} getter`.padStart(maxNameLength + 7), () => {
|
|
21
|
-
const x = rootAddon[key];
|
|
22
|
-
});
|
|
23
|
-
setters.add(`${key} setter`.padStart(maxNameLength + 7), () => {
|
|
24
|
-
rootAddon[key] = 5;
|
|
25
|
-
})
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
getters
|
|
29
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
30
|
-
.run();
|
|
31
|
-
|
|
32
|
-
console.log('');
|
|
33
|
-
|
|
34
|
-
setters
|
|
35
|
-
.on('cycle', (event) => console.log(String(event.target)))
|
|
36
|
-
.run();
|
|
37
|
-
});
|