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.
Files changed (271) hide show
  1. package/README.md +48 -22
  2. package/build/qemu/1.1.0-beta.0/koffi_darwin_x64.tar.gz +0 -0
  3. package/build/qemu/1.1.0-beta.0/koffi_freebsd_arm64.tar.gz +0 -0
  4. package/build/qemu/1.1.0-beta.0/koffi_freebsd_ia32.tar.gz +0 -0
  5. package/build/qemu/1.1.0-beta.0/koffi_freebsd_x64.tar.gz +0 -0
  6. package/build/qemu/1.1.0-beta.0/koffi_linux_arm.tar.gz +0 -0
  7. package/build/qemu/1.1.0-beta.0/koffi_linux_arm64.tar.gz +0 -0
  8. package/build/qemu/1.1.0-beta.0/koffi_linux_ia32.tar.gz +0 -0
  9. package/build/qemu/1.1.0-beta.0/koffi_linux_x64.tar.gz +0 -0
  10. package/build/qemu/1.1.0-beta.0/koffi_win32_ia32.tar.gz +0 -0
  11. package/build/qemu/1.1.0-beta.0/koffi_win32_x64.tar.gz +0 -0
  12. package/package.json +1 -1
  13. package/qemu/qemu.js +11 -5
  14. package/qemu/registry/machines.json +20 -10
  15. package/src/abi_arm32.cc +130 -215
  16. package/src/abi_arm64.cc +103 -117
  17. package/src/abi_x64_sysv.cc +117 -135
  18. package/src/abi_x64_win.cc +89 -98
  19. package/src/abi_x86.cc +91 -99
  20. package/src/call.cc +164 -40
  21. package/src/call.hh +53 -31
  22. package/src/ffi.cc +163 -19
  23. package/src/ffi.hh +30 -22
  24. package/src/util.cc +0 -127
  25. package/src/util.hh +0 -16
  26. package/test/misc.c +68 -2
  27. package/vendor/libcc/libcc.hh +1 -1
  28. package/build/qemu/1.0.3/koffi_darwin_x64.tar.gz +0 -0
  29. package/build/qemu/1.0.3/koffi_freebsd_arm64.tar.gz +0 -0
  30. package/build/qemu/1.0.3/koffi_freebsd_ia32.tar.gz +0 -0
  31. package/build/qemu/1.0.3/koffi_freebsd_x64.tar.gz +0 -0
  32. package/build/qemu/1.0.3/koffi_linux_arm.tar.gz +0 -0
  33. package/build/qemu/1.0.3/koffi_linux_arm64.tar.gz +0 -0
  34. package/build/qemu/1.0.3/koffi_linux_ia32.tar.gz +0 -0
  35. package/build/qemu/1.0.3/koffi_linux_x64.tar.gz +0 -0
  36. package/build/qemu/1.0.3/koffi_win32_ia32.tar.gz +0 -0
  37. package/build/qemu/1.0.3/koffi_win32_x64.tar.gz +0 -0
  38. package/test/misc.js +0 -180
  39. package/vendor/node-addon-api/CODE_OF_CONDUCT.md +0 -4
  40. package/vendor/node-addon-api/CONTRIBUTING.md +0 -93
  41. package/vendor/node-addon-api/appveyor.yml +0 -37
  42. package/vendor/node-addon-api/benchmark/README.md +0 -47
  43. package/vendor/node-addon-api/benchmark/binding.gyp +0 -25
  44. package/vendor/node-addon-api/benchmark/function_args.cc +0 -217
  45. package/vendor/node-addon-api/benchmark/function_args.js +0 -60
  46. package/vendor/node-addon-api/benchmark/index.js +0 -34
  47. package/vendor/node-addon-api/benchmark/property_descriptor.cc +0 -91
  48. package/vendor/node-addon-api/benchmark/property_descriptor.js +0 -37
  49. package/vendor/node-addon-api/doc/addon.md +0 -163
  50. package/vendor/node-addon-api/doc/array.md +0 -81
  51. package/vendor/node-addon-api/doc/array_buffer.md +0 -155
  52. package/vendor/node-addon-api/doc/async_context.md +0 -86
  53. package/vendor/node-addon-api/doc/async_operations.md +0 -31
  54. package/vendor/node-addon-api/doc/async_worker.md +0 -427
  55. package/vendor/node-addon-api/doc/async_worker_variants.md +0 -557
  56. package/vendor/node-addon-api/doc/bigint.md +0 -97
  57. package/vendor/node-addon-api/doc/boolean.md +0 -68
  58. package/vendor/node-addon-api/doc/buffer.md +0 -150
  59. package/vendor/node-addon-api/doc/callback_scope.md +0 -54
  60. package/vendor/node-addon-api/doc/callbackinfo.md +0 -97
  61. package/vendor/node-addon-api/doc/checker-tool.md +0 -32
  62. package/vendor/node-addon-api/doc/class_property_descriptor.md +0 -123
  63. package/vendor/node-addon-api/doc/cmake-js.md +0 -68
  64. package/vendor/node-addon-api/doc/conversion-tool.md +0 -28
  65. package/vendor/node-addon-api/doc/creating_a_release.md +0 -62
  66. package/vendor/node-addon-api/doc/dataview.md +0 -248
  67. package/vendor/node-addon-api/doc/date.md +0 -68
  68. package/vendor/node-addon-api/doc/env.md +0 -196
  69. package/vendor/node-addon-api/doc/error.md +0 -120
  70. package/vendor/node-addon-api/doc/error_handling.md +0 -254
  71. package/vendor/node-addon-api/doc/escapable_handle_scope.md +0 -80
  72. package/vendor/node-addon-api/doc/external.md +0 -63
  73. package/vendor/node-addon-api/doc/function.md +0 -402
  74. package/vendor/node-addon-api/doc/function_reference.md +0 -238
  75. package/vendor/node-addon-api/doc/generator.md +0 -13
  76. package/vendor/node-addon-api/doc/handle_scope.md +0 -63
  77. package/vendor/node-addon-api/doc/hierarchy.md +0 -91
  78. package/vendor/node-addon-api/doc/instance_wrap.md +0 -408
  79. package/vendor/node-addon-api/doc/maybe.md +0 -76
  80. package/vendor/node-addon-api/doc/memory_management.md +0 -27
  81. package/vendor/node-addon-api/doc/name.md +0 -29
  82. package/vendor/node-addon-api/doc/node-gyp.md +0 -82
  83. package/vendor/node-addon-api/doc/number.md +0 -163
  84. package/vendor/node-addon-api/doc/object.md +0 -411
  85. package/vendor/node-addon-api/doc/object_lifetime_management.md +0 -83
  86. package/vendor/node-addon-api/doc/object_reference.md +0 -117
  87. package/vendor/node-addon-api/doc/object_wrap.md +0 -588
  88. package/vendor/node-addon-api/doc/prebuild_tools.md +0 -16
  89. package/vendor/node-addon-api/doc/promises.md +0 -79
  90. package/vendor/node-addon-api/doc/property_descriptor.md +0 -286
  91. package/vendor/node-addon-api/doc/propertylvalue.md +0 -50
  92. package/vendor/node-addon-api/doc/range_error.md +0 -59
  93. package/vendor/node-addon-api/doc/reference.md +0 -113
  94. package/vendor/node-addon-api/doc/setup.md +0 -110
  95. package/vendor/node-addon-api/doc/string.md +0 -93
  96. package/vendor/node-addon-api/doc/symbol.md +0 -61
  97. package/vendor/node-addon-api/doc/threadsafe.md +0 -121
  98. package/vendor/node-addon-api/doc/threadsafe_function.md +0 -290
  99. package/vendor/node-addon-api/doc/type_error.md +0 -59
  100. package/vendor/node-addon-api/doc/typed_array.md +0 -78
  101. package/vendor/node-addon-api/doc/typed_array_of.md +0 -137
  102. package/vendor/node-addon-api/doc/typed_threadsafe_function.md +0 -306
  103. package/vendor/node-addon-api/doc/value.md +0 -340
  104. package/vendor/node-addon-api/doc/version_management.md +0 -43
  105. package/vendor/node-addon-api/package.json +0 -415
  106. package/vendor/node-addon-api/test/README.md +0 -91
  107. package/vendor/node-addon-api/test/addon.cc +0 -36
  108. package/vendor/node-addon-api/test/addon.js +0 -11
  109. package/vendor/node-addon-api/test/addon_build/index.js +0 -49
  110. package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +0 -17
  111. package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +0 -62
  112. package/vendor/node-addon-api/test/addon_build/tpl/index.js +0 -9
  113. package/vendor/node-addon-api/test/addon_build/tpl/package.json +0 -11
  114. package/vendor/node-addon-api/test/addon_data.cc +0 -99
  115. package/vendor/node-addon-api/test/addon_data.js +0 -46
  116. package/vendor/node-addon-api/test/array_buffer.cc +0 -243
  117. package/vendor/node-addon-api/test/array_buffer.js +0 -69
  118. package/vendor/node-addon-api/test/async_context.cc +0 -36
  119. package/vendor/node-addon-api/test/async_context.js +0 -122
  120. package/vendor/node-addon-api/test/async_progress_queue_worker.cc +0 -83
  121. package/vendor/node-addon-api/test/async_progress_queue_worker.js +0 -46
  122. package/vendor/node-addon-api/test/async_progress_worker.cc +0 -134
  123. package/vendor/node-addon-api/test/async_progress_worker.js +0 -61
  124. package/vendor/node-addon-api/test/async_worker.cc +0 -106
  125. package/vendor/node-addon-api/test/async_worker.js +0 -179
  126. package/vendor/node-addon-api/test/async_worker_nocallback.js +0 -13
  127. package/vendor/node-addon-api/test/async_worker_persistent.cc +0 -63
  128. package/vendor/node-addon-api/test/async_worker_persistent.js +0 -24
  129. package/vendor/node-addon-api/test/basic_types/array.cc +0 -40
  130. package/vendor/node-addon-api/test/basic_types/array.js +0 -35
  131. package/vendor/node-addon-api/test/basic_types/boolean.cc +0 -38
  132. package/vendor/node-addon-api/test/basic_types/boolean.js +0 -35
  133. package/vendor/node-addon-api/test/basic_types/number.cc +0 -99
  134. package/vendor/node-addon-api/test/basic_types/number.js +0 -114
  135. package/vendor/node-addon-api/test/basic_types/value.cc +0 -120
  136. package/vendor/node-addon-api/test/basic_types/value.js +0 -133
  137. package/vendor/node-addon-api/test/bigint.cc +0 -91
  138. package/vendor/node-addon-api/test/bigint.js +0 -53
  139. package/vendor/node-addon-api/test/binding-swallowexcept.cc +0 -12
  140. package/vendor/node-addon-api/test/binding.cc +0 -173
  141. package/vendor/node-addon-api/test/binding.gyp +0 -124
  142. package/vendor/node-addon-api/test/buffer.cc +0 -183
  143. package/vendor/node-addon-api/test/buffer.js +0 -69
  144. package/vendor/node-addon-api/test/callbackscope.cc +0 -22
  145. package/vendor/node-addon-api/test/callbackscope.js +0 -49
  146. package/vendor/node-addon-api/test/common/index.js +0 -114
  147. package/vendor/node-addon-api/test/common/test_helper.h +0 -71
  148. package/vendor/node-addon-api/test/dataview/dataview.cc +0 -48
  149. package/vendor/node-addon-api/test/dataview/dataview.js +0 -35
  150. package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +0 -115
  151. package/vendor/node-addon-api/test/dataview/dataview_read_write.js +0 -90
  152. package/vendor/node-addon-api/test/date.cc +0 -44
  153. package/vendor/node-addon-api/test/date.js +0 -18
  154. package/vendor/node-addon-api/test/env_cleanup.cc +0 -88
  155. package/vendor/node-addon-api/test/env_cleanup.js +0 -56
  156. package/vendor/node-addon-api/test/error.cc +0 -287
  157. package/vendor/node-addon-api/test/error.js +0 -81
  158. package/vendor/node-addon-api/test/error_handling_for_primitives.cc +0 -13
  159. package/vendor/node-addon-api/test/error_handling_for_primitives.js +0 -29
  160. package/vendor/node-addon-api/test/error_terminating_environment.js +0 -95
  161. package/vendor/node-addon-api/test/external.cc +0 -81
  162. package/vendor/node-addon-api/test/external.js +0 -88
  163. package/vendor/node-addon-api/test/function.cc +0 -324
  164. package/vendor/node-addon-api/test/function.js +0 -133
  165. package/vendor/node-addon-api/test/function_reference.cc +0 -202
  166. package/vendor/node-addon-api/test/function_reference.js +0 -157
  167. package/vendor/node-addon-api/test/globalObject/global_object.cc +0 -61
  168. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +0 -31
  169. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +0 -61
  170. package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +0 -40
  171. package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +0 -57
  172. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +0 -28
  173. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +0 -48
  174. package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +0 -31
  175. package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +0 -58
  176. package/vendor/node-addon-api/test/handlescope.cc +0 -60
  177. package/vendor/node-addon-api/test/handlescope.js +0 -14
  178. package/vendor/node-addon-api/test/index.js +0 -159
  179. package/vendor/node-addon-api/test/maybe/check.cc +0 -23
  180. package/vendor/node-addon-api/test/maybe/index.js +0 -38
  181. package/vendor/node-addon-api/test/memory_management.cc +0 -17
  182. package/vendor/node-addon-api/test/memory_management.js +0 -9
  183. package/vendor/node-addon-api/test/movable_callbacks.cc +0 -23
  184. package/vendor/node-addon-api/test/movable_callbacks.js +0 -21
  185. package/vendor/node-addon-api/test/name.cc +0 -108
  186. package/vendor/node-addon-api/test/name.js +0 -59
  187. package/vendor/node-addon-api/test/napi_child.js +0 -14
  188. package/vendor/node-addon-api/test/object/delete_property.cc +0 -38
  189. package/vendor/node-addon-api/test/object/delete_property.js +0 -41
  190. package/vendor/node-addon-api/test/object/finalizer.cc +0 -29
  191. package/vendor/node-addon-api/test/object/finalizer.js +0 -28
  192. package/vendor/node-addon-api/test/object/get_property.cc +0 -34
  193. package/vendor/node-addon-api/test/object/get_property.js +0 -40
  194. package/vendor/node-addon-api/test/object/has_own_property.cc +0 -34
  195. package/vendor/node-addon-api/test/object/has_own_property.js +0 -34
  196. package/vendor/node-addon-api/test/object/has_property.cc +0 -38
  197. package/vendor/node-addon-api/test/object/has_property.js +0 -37
  198. package/vendor/node-addon-api/test/object/object.cc +0 -350
  199. package/vendor/node-addon-api/test/object/object.js +0 -217
  200. package/vendor/node-addon-api/test/object/object_deprecated.cc +0 -66
  201. package/vendor/node-addon-api/test/object/object_deprecated.js +0 -47
  202. package/vendor/node-addon-api/test/object/object_freeze_seal.cc +0 -25
  203. package/vendor/node-addon-api/test/object/object_freeze_seal.js +0 -61
  204. package/vendor/node-addon-api/test/object/set_property.cc +0 -45
  205. package/vendor/node-addon-api/test/object/set_property.js +0 -30
  206. package/vendor/node-addon-api/test/object/subscript_operator.cc +0 -58
  207. package/vendor/node-addon-api/test/object/subscript_operator.js +0 -17
  208. package/vendor/node-addon-api/test/object_reference.cc +0 -219
  209. package/vendor/node-addon-api/test/object_reference.js +0 -259
  210. package/vendor/node-addon-api/test/objectwrap.cc +0 -268
  211. package/vendor/node-addon-api/test/objectwrap.js +0 -284
  212. package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +0 -26
  213. package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +0 -18
  214. package/vendor/node-addon-api/test/objectwrap_function.cc +0 -45
  215. package/vendor/node-addon-api/test/objectwrap_function.js +0 -22
  216. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +0 -30
  217. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +0 -13
  218. package/vendor/node-addon-api/test/objectwrap_removewrap.cc +0 -45
  219. package/vendor/node-addon-api/test/objectwrap_removewrap.js +0 -40
  220. package/vendor/node-addon-api/test/objectwrap_worker_thread.js +0 -19
  221. package/vendor/node-addon-api/test/promise.cc +0 -29
  222. package/vendor/node-addon-api/test/promise.js +0 -18
  223. package/vendor/node-addon-api/test/reference.cc +0 -24
  224. package/vendor/node-addon-api/test/reference.js +0 -14
  225. package/vendor/node-addon-api/test/run_script.cc +0 -56
  226. package/vendor/node-addon-api/test/run_script.js +0 -45
  227. package/vendor/node-addon-api/test/symbol.cc +0 -79
  228. package/vendor/node-addon-api/test/symbol.js +0 -73
  229. package/vendor/node-addon-api/test/testUtil.js +0 -54
  230. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +0 -195
  231. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +0 -188
  232. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +0 -63
  233. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +0 -12
  234. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +0 -115
  235. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +0 -14
  236. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +0 -26
  237. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +0 -7
  238. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +0 -225
  239. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +0 -59
  240. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +0 -42
  241. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +0 -53
  242. package/vendor/node-addon-api/test/thunking_manual.cc +0 -140
  243. package/vendor/node-addon-api/test/thunking_manual.js +0 -17
  244. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +0 -215
  245. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +0 -188
  246. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +0 -68
  247. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +0 -12
  248. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +0 -127
  249. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +0 -14
  250. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +0 -28
  251. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +0 -7
  252. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +0 -237
  253. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +0 -59
  254. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +0 -53
  255. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +0 -53
  256. package/vendor/node-addon-api/test/typedarray-bigint.js +0 -58
  257. package/vendor/node-addon-api/test/typedarray.cc +0 -216
  258. package/vendor/node-addon-api/test/typedarray.js +0 -69
  259. package/vendor/node-addon-api/test/version_management.cc +0 -27
  260. package/vendor/node-addon-api/test/version_management.js +0 -31
  261. package/vendor/node-addon-api/unit-test/README.md +0 -28
  262. package/vendor/node-addon-api/unit-test/binding-file-template.js +0 -39
  263. package/vendor/node-addon-api/unit-test/binding.gyp +0 -72
  264. package/vendor/node-addon-api/unit-test/exceptions.js +0 -32
  265. package/vendor/node-addon-api/unit-test/generate-binding-cc.js +0 -61
  266. package/vendor/node-addon-api/unit-test/injectTestParams.js +0 -101
  267. package/vendor/node-addon-api/unit-test/listOfTestModules.js +0 -88
  268. package/vendor/node-addon-api/unit-test/matchModules.js +0 -65
  269. package/vendor/node-addon-api/unit-test/setup.js +0 -13
  270. package/vendor/node-addon-api/unit-test/spawnTask.js +0 -26
  271. 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
- });