koffi 1.1.0-beta.0 → 1.1.0-beta.3

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 (270) hide show
  1. package/CMakeLists.txt +4 -0
  2. package/README.md +16 -11
  3. package/build/qemu/1.1.0-beta.3/koffi_darwin_x64.tar.gz +0 -0
  4. package/build/qemu/1.1.0-beta.3/koffi_freebsd_arm64.tar.gz +0 -0
  5. package/build/qemu/1.1.0-beta.3/koffi_freebsd_ia32.tar.gz +0 -0
  6. package/build/qemu/1.1.0-beta.3/koffi_freebsd_x64.tar.gz +0 -0
  7. package/build/qemu/1.1.0-beta.3/koffi_linux_arm.tar.gz +0 -0
  8. package/build/qemu/1.1.0-beta.3/koffi_linux_arm64.tar.gz +0 -0
  9. package/build/qemu/1.1.0-beta.3/koffi_linux_ia32.tar.gz +0 -0
  10. package/build/qemu/1.1.0-beta.3/koffi_linux_x64.tar.gz +0 -0
  11. package/build/qemu/1.1.0-beta.3/koffi_win32_ia32.tar.gz +0 -0
  12. package/build/qemu/1.1.0-beta.3/koffi_win32_x64.tar.gz +0 -0
  13. package/package.json +1 -1
  14. package/qemu/qemu.js +1 -0
  15. package/src/abi_arm32.cc +27 -45
  16. package/src/abi_arm64.cc +58 -132
  17. package/src/abi_x64_sysv.cc +24 -7
  18. package/src/abi_x64_win.cc +3 -0
  19. package/src/abi_x86.cc +3 -0
  20. package/src/call.cc +540 -33
  21. package/src/call.hh +5 -3
  22. package/src/ffi.cc +69 -4
  23. package/src/ffi.hh +3 -1
  24. package/src/parser.cc +7 -2
  25. package/src/util.cc +72 -0
  26. package/src/util.hh +2 -0
  27. package/test/misc.c +14 -8
  28. package/vendor/node-addon-api/CODE_OF_CONDUCT.md +4 -0
  29. package/vendor/node-addon-api/CONTRIBUTING.md +93 -0
  30. package/vendor/node-addon-api/appveyor.yml +37 -0
  31. package/vendor/node-addon-api/benchmark/README.md +47 -0
  32. package/vendor/node-addon-api/benchmark/binding.gyp +25 -0
  33. package/vendor/node-addon-api/benchmark/function_args.cc +217 -0
  34. package/vendor/node-addon-api/benchmark/function_args.js +60 -0
  35. package/vendor/node-addon-api/benchmark/index.js +34 -0
  36. package/vendor/node-addon-api/benchmark/property_descriptor.cc +91 -0
  37. package/vendor/node-addon-api/benchmark/property_descriptor.js +37 -0
  38. package/vendor/node-addon-api/doc/addon.md +163 -0
  39. package/vendor/node-addon-api/doc/array.md +81 -0
  40. package/vendor/node-addon-api/doc/array_buffer.md +155 -0
  41. package/vendor/node-addon-api/doc/async_context.md +86 -0
  42. package/vendor/node-addon-api/doc/async_operations.md +31 -0
  43. package/vendor/node-addon-api/doc/async_worker.md +427 -0
  44. package/vendor/node-addon-api/doc/async_worker_variants.md +557 -0
  45. package/vendor/node-addon-api/doc/bigint.md +97 -0
  46. package/vendor/node-addon-api/doc/boolean.md +68 -0
  47. package/vendor/node-addon-api/doc/buffer.md +150 -0
  48. package/vendor/node-addon-api/doc/callback_scope.md +54 -0
  49. package/vendor/node-addon-api/doc/callbackinfo.md +97 -0
  50. package/vendor/node-addon-api/doc/checker-tool.md +32 -0
  51. package/vendor/node-addon-api/doc/class_property_descriptor.md +123 -0
  52. package/vendor/node-addon-api/doc/cmake-js.md +68 -0
  53. package/vendor/node-addon-api/doc/conversion-tool.md +28 -0
  54. package/vendor/node-addon-api/doc/creating_a_release.md +62 -0
  55. package/vendor/node-addon-api/doc/dataview.md +248 -0
  56. package/vendor/node-addon-api/doc/date.md +68 -0
  57. package/vendor/node-addon-api/doc/env.md +196 -0
  58. package/vendor/node-addon-api/doc/error.md +120 -0
  59. package/vendor/node-addon-api/doc/error_handling.md +254 -0
  60. package/vendor/node-addon-api/doc/escapable_handle_scope.md +80 -0
  61. package/vendor/node-addon-api/doc/external.md +63 -0
  62. package/vendor/node-addon-api/doc/function.md +402 -0
  63. package/vendor/node-addon-api/doc/function_reference.md +238 -0
  64. package/vendor/node-addon-api/doc/generator.md +13 -0
  65. package/vendor/node-addon-api/doc/handle_scope.md +63 -0
  66. package/vendor/node-addon-api/doc/hierarchy.md +91 -0
  67. package/vendor/node-addon-api/doc/instance_wrap.md +408 -0
  68. package/vendor/node-addon-api/doc/maybe.md +76 -0
  69. package/vendor/node-addon-api/doc/memory_management.md +27 -0
  70. package/vendor/node-addon-api/doc/name.md +29 -0
  71. package/vendor/node-addon-api/doc/node-gyp.md +82 -0
  72. package/vendor/node-addon-api/doc/number.md +163 -0
  73. package/vendor/node-addon-api/doc/object.md +411 -0
  74. package/vendor/node-addon-api/doc/object_lifetime_management.md +83 -0
  75. package/vendor/node-addon-api/doc/object_reference.md +117 -0
  76. package/vendor/node-addon-api/doc/object_wrap.md +588 -0
  77. package/vendor/node-addon-api/doc/prebuild_tools.md +16 -0
  78. package/vendor/node-addon-api/doc/promises.md +79 -0
  79. package/vendor/node-addon-api/doc/property_descriptor.md +286 -0
  80. package/vendor/node-addon-api/doc/propertylvalue.md +50 -0
  81. package/vendor/node-addon-api/doc/range_error.md +59 -0
  82. package/vendor/node-addon-api/doc/reference.md +113 -0
  83. package/vendor/node-addon-api/doc/setup.md +110 -0
  84. package/vendor/node-addon-api/doc/string.md +93 -0
  85. package/vendor/node-addon-api/doc/symbol.md +61 -0
  86. package/vendor/node-addon-api/doc/threadsafe.md +121 -0
  87. package/vendor/node-addon-api/doc/threadsafe_function.md +290 -0
  88. package/vendor/node-addon-api/doc/type_error.md +59 -0
  89. package/vendor/node-addon-api/doc/typed_array.md +78 -0
  90. package/vendor/node-addon-api/doc/typed_array_of.md +137 -0
  91. package/vendor/node-addon-api/doc/typed_threadsafe_function.md +306 -0
  92. package/vendor/node-addon-api/doc/value.md +340 -0
  93. package/vendor/node-addon-api/doc/version_management.md +43 -0
  94. package/vendor/node-addon-api/package.json +415 -0
  95. package/vendor/node-addon-api/test/README.md +91 -0
  96. package/vendor/node-addon-api/test/addon.cc +36 -0
  97. package/vendor/node-addon-api/test/addon.js +11 -0
  98. package/vendor/node-addon-api/test/addon_build/index.js +49 -0
  99. package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +17 -0
  100. package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +62 -0
  101. package/vendor/node-addon-api/test/addon_build/tpl/index.js +9 -0
  102. package/vendor/node-addon-api/test/addon_build/tpl/package.json +11 -0
  103. package/vendor/node-addon-api/test/addon_data.cc +99 -0
  104. package/vendor/node-addon-api/test/addon_data.js +46 -0
  105. package/vendor/node-addon-api/test/array_buffer.cc +243 -0
  106. package/vendor/node-addon-api/test/array_buffer.js +69 -0
  107. package/vendor/node-addon-api/test/async_context.cc +36 -0
  108. package/vendor/node-addon-api/test/async_context.js +122 -0
  109. package/vendor/node-addon-api/test/async_progress_queue_worker.cc +83 -0
  110. package/vendor/node-addon-api/test/async_progress_queue_worker.js +46 -0
  111. package/vendor/node-addon-api/test/async_progress_worker.cc +134 -0
  112. package/vendor/node-addon-api/test/async_progress_worker.js +61 -0
  113. package/vendor/node-addon-api/test/async_worker.cc +106 -0
  114. package/vendor/node-addon-api/test/async_worker.js +179 -0
  115. package/vendor/node-addon-api/test/async_worker_nocallback.js +13 -0
  116. package/vendor/node-addon-api/test/async_worker_persistent.cc +63 -0
  117. package/vendor/node-addon-api/test/async_worker_persistent.js +24 -0
  118. package/vendor/node-addon-api/test/basic_types/array.cc +40 -0
  119. package/vendor/node-addon-api/test/basic_types/array.js +35 -0
  120. package/vendor/node-addon-api/test/basic_types/boolean.cc +38 -0
  121. package/vendor/node-addon-api/test/basic_types/boolean.js +35 -0
  122. package/vendor/node-addon-api/test/basic_types/number.cc +99 -0
  123. package/vendor/node-addon-api/test/basic_types/number.js +114 -0
  124. package/vendor/node-addon-api/test/basic_types/value.cc +120 -0
  125. package/vendor/node-addon-api/test/basic_types/value.js +133 -0
  126. package/vendor/node-addon-api/test/bigint.cc +91 -0
  127. package/vendor/node-addon-api/test/bigint.js +53 -0
  128. package/vendor/node-addon-api/test/binding-swallowexcept.cc +12 -0
  129. package/vendor/node-addon-api/test/binding.cc +173 -0
  130. package/vendor/node-addon-api/test/binding.gyp +124 -0
  131. package/vendor/node-addon-api/test/buffer.cc +183 -0
  132. package/vendor/node-addon-api/test/buffer.js +69 -0
  133. package/vendor/node-addon-api/test/callbackscope.cc +22 -0
  134. package/vendor/node-addon-api/test/callbackscope.js +49 -0
  135. package/vendor/node-addon-api/test/common/index.js +114 -0
  136. package/vendor/node-addon-api/test/common/test_helper.h +71 -0
  137. package/vendor/node-addon-api/test/dataview/dataview.cc +48 -0
  138. package/vendor/node-addon-api/test/dataview/dataview.js +35 -0
  139. package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +115 -0
  140. package/vendor/node-addon-api/test/dataview/dataview_read_write.js +90 -0
  141. package/vendor/node-addon-api/test/date.cc +44 -0
  142. package/vendor/node-addon-api/test/date.js +18 -0
  143. package/vendor/node-addon-api/test/env_cleanup.cc +88 -0
  144. package/vendor/node-addon-api/test/env_cleanup.js +56 -0
  145. package/vendor/node-addon-api/test/error.cc +287 -0
  146. package/vendor/node-addon-api/test/error.js +81 -0
  147. package/vendor/node-addon-api/test/error_handling_for_primitives.cc +13 -0
  148. package/vendor/node-addon-api/test/error_handling_for_primitives.js +29 -0
  149. package/vendor/node-addon-api/test/error_terminating_environment.js +95 -0
  150. package/vendor/node-addon-api/test/external.cc +81 -0
  151. package/vendor/node-addon-api/test/external.js +88 -0
  152. package/vendor/node-addon-api/test/function.cc +324 -0
  153. package/vendor/node-addon-api/test/function.js +133 -0
  154. package/vendor/node-addon-api/test/function_reference.cc +202 -0
  155. package/vendor/node-addon-api/test/function_reference.js +157 -0
  156. package/vendor/node-addon-api/test/globalObject/global_object.cc +61 -0
  157. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +31 -0
  158. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +61 -0
  159. package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +40 -0
  160. package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +57 -0
  161. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +28 -0
  162. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +48 -0
  163. package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +31 -0
  164. package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +58 -0
  165. package/vendor/node-addon-api/test/handlescope.cc +60 -0
  166. package/vendor/node-addon-api/test/handlescope.js +14 -0
  167. package/vendor/node-addon-api/test/index.js +159 -0
  168. package/vendor/node-addon-api/test/maybe/check.cc +23 -0
  169. package/vendor/node-addon-api/test/maybe/index.js +38 -0
  170. package/vendor/node-addon-api/test/memory_management.cc +17 -0
  171. package/vendor/node-addon-api/test/memory_management.js +9 -0
  172. package/vendor/node-addon-api/test/movable_callbacks.cc +23 -0
  173. package/vendor/node-addon-api/test/movable_callbacks.js +21 -0
  174. package/vendor/node-addon-api/test/name.cc +108 -0
  175. package/vendor/node-addon-api/test/name.js +59 -0
  176. package/vendor/node-addon-api/test/napi_child.js +14 -0
  177. package/vendor/node-addon-api/test/object/delete_property.cc +38 -0
  178. package/vendor/node-addon-api/test/object/delete_property.js +41 -0
  179. package/vendor/node-addon-api/test/object/finalizer.cc +29 -0
  180. package/vendor/node-addon-api/test/object/finalizer.js +28 -0
  181. package/vendor/node-addon-api/test/object/get_property.cc +34 -0
  182. package/vendor/node-addon-api/test/object/get_property.js +40 -0
  183. package/vendor/node-addon-api/test/object/has_own_property.cc +34 -0
  184. package/vendor/node-addon-api/test/object/has_own_property.js +34 -0
  185. package/vendor/node-addon-api/test/object/has_property.cc +38 -0
  186. package/vendor/node-addon-api/test/object/has_property.js +37 -0
  187. package/vendor/node-addon-api/test/object/object.cc +350 -0
  188. package/vendor/node-addon-api/test/object/object.js +217 -0
  189. package/vendor/node-addon-api/test/object/object_deprecated.cc +66 -0
  190. package/vendor/node-addon-api/test/object/object_deprecated.js +47 -0
  191. package/vendor/node-addon-api/test/object/object_freeze_seal.cc +25 -0
  192. package/vendor/node-addon-api/test/object/object_freeze_seal.js +61 -0
  193. package/vendor/node-addon-api/test/object/set_property.cc +45 -0
  194. package/vendor/node-addon-api/test/object/set_property.js +30 -0
  195. package/vendor/node-addon-api/test/object/subscript_operator.cc +58 -0
  196. package/vendor/node-addon-api/test/object/subscript_operator.js +17 -0
  197. package/vendor/node-addon-api/test/object_reference.cc +219 -0
  198. package/vendor/node-addon-api/test/object_reference.js +259 -0
  199. package/vendor/node-addon-api/test/objectwrap.cc +268 -0
  200. package/vendor/node-addon-api/test/objectwrap.js +284 -0
  201. package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +26 -0
  202. package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +18 -0
  203. package/vendor/node-addon-api/test/objectwrap_function.cc +45 -0
  204. package/vendor/node-addon-api/test/objectwrap_function.js +22 -0
  205. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +30 -0
  206. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +13 -0
  207. package/vendor/node-addon-api/test/objectwrap_removewrap.cc +45 -0
  208. package/vendor/node-addon-api/test/objectwrap_removewrap.js +40 -0
  209. package/vendor/node-addon-api/test/objectwrap_worker_thread.js +19 -0
  210. package/vendor/node-addon-api/test/promise.cc +29 -0
  211. package/vendor/node-addon-api/test/promise.js +18 -0
  212. package/vendor/node-addon-api/test/reference.cc +24 -0
  213. package/vendor/node-addon-api/test/reference.js +14 -0
  214. package/vendor/node-addon-api/test/run_script.cc +56 -0
  215. package/vendor/node-addon-api/test/run_script.js +45 -0
  216. package/vendor/node-addon-api/test/symbol.cc +79 -0
  217. package/vendor/node-addon-api/test/symbol.js +73 -0
  218. package/vendor/node-addon-api/test/testUtil.js +54 -0
  219. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +195 -0
  220. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +188 -0
  221. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +63 -0
  222. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +12 -0
  223. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +115 -0
  224. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +14 -0
  225. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +26 -0
  226. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +7 -0
  227. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +225 -0
  228. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +59 -0
  229. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +42 -0
  230. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +53 -0
  231. package/vendor/node-addon-api/test/thunking_manual.cc +140 -0
  232. package/vendor/node-addon-api/test/thunking_manual.js +17 -0
  233. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +215 -0
  234. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +188 -0
  235. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +68 -0
  236. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +12 -0
  237. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +127 -0
  238. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +14 -0
  239. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +28 -0
  240. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +7 -0
  241. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +237 -0
  242. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +59 -0
  243. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +53 -0
  244. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +53 -0
  245. package/vendor/node-addon-api/test/typedarray-bigint.js +58 -0
  246. package/vendor/node-addon-api/test/typedarray.cc +216 -0
  247. package/vendor/node-addon-api/test/typedarray.js +69 -0
  248. package/vendor/node-addon-api/test/version_management.cc +27 -0
  249. package/vendor/node-addon-api/test/version_management.js +31 -0
  250. package/vendor/node-addon-api/unit-test/README.md +28 -0
  251. package/vendor/node-addon-api/unit-test/binding-file-template.js +39 -0
  252. package/vendor/node-addon-api/unit-test/binding.gyp +72 -0
  253. package/vendor/node-addon-api/unit-test/exceptions.js +32 -0
  254. package/vendor/node-addon-api/unit-test/generate-binding-cc.js +61 -0
  255. package/vendor/node-addon-api/unit-test/injectTestParams.js +101 -0
  256. package/vendor/node-addon-api/unit-test/listOfTestModules.js +88 -0
  257. package/vendor/node-addon-api/unit-test/matchModules.js +65 -0
  258. package/vendor/node-addon-api/unit-test/setup.js +13 -0
  259. package/vendor/node-addon-api/unit-test/spawnTask.js +26 -0
  260. package/vendor/node-addon-api/unit-test/test.js +30 -0
  261. package/build/qemu/1.1.0-beta.0/koffi_darwin_x64.tar.gz +0 -0
  262. package/build/qemu/1.1.0-beta.0/koffi_freebsd_arm64.tar.gz +0 -0
  263. package/build/qemu/1.1.0-beta.0/koffi_freebsd_ia32.tar.gz +0 -0
  264. package/build/qemu/1.1.0-beta.0/koffi_freebsd_x64.tar.gz +0 -0
  265. package/build/qemu/1.1.0-beta.0/koffi_linux_arm.tar.gz +0 -0
  266. package/build/qemu/1.1.0-beta.0/koffi_linux_arm64.tar.gz +0 -0
  267. package/build/qemu/1.1.0-beta.0/koffi_linux_ia32.tar.gz +0 -0
  268. package/build/qemu/1.1.0-beta.0/koffi_linux_x64.tar.gz +0 -0
  269. package/build/qemu/1.1.0-beta.0/koffi_win32_ia32.tar.gz +0 -0
  270. package/build/qemu/1.1.0-beta.0/koffi_win32_x64.tar.gz +0 -0
@@ -0,0 +1,69 @@
1
+ 'use strict';
2
+
3
+ const assert = require('assert');
4
+
5
+ module.exports = require('./common').runTest(test);
6
+
7
+ function test(binding) {
8
+ const testData = [
9
+ [ 'int8', Int8Array ],
10
+ [ 'uint8', Uint8Array ],
11
+ [ 'uint8_clamped', Uint8ClampedArray ],
12
+ [ 'int16', Int16Array ],
13
+ [ 'uint16', Uint16Array ],
14
+ [ 'int32', Int32Array ],
15
+ [ 'uint32', Uint32Array ],
16
+ [ 'float32', Float32Array ],
17
+ [ 'float64', Float64Array ],
18
+ ];
19
+
20
+ testData.forEach(data => {
21
+ try {
22
+ const length = 4;
23
+ const t = binding.typedarray.createTypedArray(data[0], length);
24
+ assert.ok(t instanceof data[1]);
25
+ assert.strictEqual(binding.typedarray.getTypedArrayType(t), data[0]);
26
+ assert.strictEqual(binding.typedarray.getTypedArrayLength(t), length);
27
+
28
+ t[3] = 11;
29
+ assert.strictEqual(binding.typedarray.getTypedArrayElement(t, 3), 11);
30
+ binding.typedarray.setTypedArrayElement(t, 3, 22);
31
+ assert.strictEqual(binding.typedarray.getTypedArrayElement(t, 3), 22);
32
+ assert.strictEqual(t[3], 22);
33
+
34
+ const b = binding.typedarray.getTypedArrayBuffer(t);
35
+ assert.ok(b instanceof ArrayBuffer);
36
+ } catch (e) {
37
+ console.log(data);
38
+ throw e;
39
+ }
40
+ });
41
+
42
+ testData.forEach(data => {
43
+ try {
44
+ const length = 4;
45
+ const offset = 8;
46
+ const b = new ArrayBuffer(offset + 64 * 4);
47
+
48
+ const t = binding.typedarray.createTypedArray(data[0], length, b, offset);
49
+ assert.ok(t instanceof data[1]);
50
+ assert.strictEqual(binding.typedarray.getTypedArrayType(t), data[0]);
51
+ assert.strictEqual(binding.typedarray.getTypedArrayLength(t), length);
52
+
53
+ t[3] = 11;
54
+ assert.strictEqual(binding.typedarray.getTypedArrayElement(t, 3), 11);
55
+ binding.typedarray.setTypedArrayElement(t, 3, 22);
56
+ assert.strictEqual(binding.typedarray.getTypedArrayElement(t, 3), 22);
57
+ assert.strictEqual(t[3], 22);
58
+
59
+ assert.strictEqual(binding.typedarray.getTypedArrayBuffer(t), b);
60
+ } catch (e) {
61
+ console.log(data);
62
+ throw e;
63
+ }
64
+ });
65
+
66
+ assert.throws(() => {
67
+ binding.typedarray.createInvalidTypedArray();
68
+ }, /Invalid (pointer passed as )?argument/);
69
+ }
@@ -0,0 +1,27 @@
1
+ #include "napi.h"
2
+
3
+ using namespace Napi;
4
+
5
+ Value getNapiVersion(const CallbackInfo& info) {
6
+ Napi::Env env = info.Env();
7
+ uint32_t napi_version = VersionManagement::GetNapiVersion(env);
8
+ return Number::New(env, napi_version);
9
+ }
10
+
11
+ Value getNodeVersion(const CallbackInfo& info) {
12
+ Napi::Env env = info.Env();
13
+ const napi_node_version* node_version = VersionManagement::GetNodeVersion(env);
14
+ Object version = Object::New(env);
15
+ version.Set("major", Number::New(env, node_version->major));
16
+ version.Set("minor", Number::New(env, node_version->minor));
17
+ version.Set("patch", Number::New(env, node_version->patch));
18
+ version.Set("release", String::New(env, node_version->release));
19
+ return version;
20
+ }
21
+
22
+ Object InitVersionManagement(Env env) {
23
+ Object exports = Object::New(env);
24
+ exports["getNapiVersion"] = Function::New(env, getNapiVersion);
25
+ exports["getNodeVersion"] = Function::New(env, getNodeVersion);
26
+ return exports;
27
+ }
@@ -0,0 +1,31 @@
1
+ 'use strict';
2
+
3
+ const assert = require('assert');
4
+
5
+ module.exports = require('./common').runTest(test);
6
+
7
+ function parseVersion() {
8
+ const expected = {};
9
+ expected.napi = parseInt(process.versions.napi);
10
+ expected.release = process.release.name;
11
+ const nodeVersion = process.versions.node.split('.');
12
+ expected.major = parseInt(nodeVersion[0]);
13
+ expected.minor = parseInt(nodeVersion[1]);
14
+ expected.patch = parseInt(nodeVersion[2]);
15
+ return expected;
16
+ }
17
+
18
+ function test(binding) {
19
+
20
+ const expected = parseVersion();
21
+
22
+ const napiVersion = binding.version_management.getNapiVersion();
23
+ assert.strictEqual(napiVersion, expected.napi);
24
+
25
+ const nodeVersion = binding.version_management.getNodeVersion();
26
+ assert.strictEqual(nodeVersion.major, expected.major);
27
+ assert.strictEqual(nodeVersion.minor, expected.minor);
28
+ assert.strictEqual(nodeVersion.patch, expected.patch);
29
+ assert.strictEqual(nodeVersion.release, expected.release);
30
+
31
+ }
@@ -0,0 +1,28 @@
1
+
2
+ # Enable running tests with specific filter conditions:
3
+
4
+ ### Example:
5
+
6
+ - compile ad run only tests on objectwrap.cc and objectwrap.js
7
+ ```
8
+ npm run unit --filter=objectwrap
9
+ ```
10
+
11
+
12
+ # Wildcards are also possible:
13
+
14
+ ### Example:
15
+
16
+ - compile and run all tests files ending with reference -> function_reference.cc object_reference.cc reference.cc
17
+ ```
18
+ npm run unit --filter=*reference
19
+ ```
20
+
21
+ # Multiple filter conditions are also allowed
22
+
23
+ ### Example:
24
+
25
+ - compile and run all tests under folders threadsafe_function and typed_threadsafe_function and also the objectwrap.cc file
26
+ ```
27
+ npm run unit --filter='*function objectwrap'
28
+ ```
@@ -0,0 +1,39 @@
1
+ const path = require('path');
2
+ const fs = require('fs');
3
+
4
+ /**
5
+ * @param bindingConfigurations
6
+ * This method acts as a template to generate the content of binding.cc file
7
+ */
8
+ module.exports.generateFileContent = function (bindingConfigurations) {
9
+ const content = [];
10
+ const inits = [];
11
+ const exports = [];
12
+
13
+ for (const config of bindingConfigurations) {
14
+ inits.push(`Object Init${config.objectName}(Env env);`);
15
+ exports.push(`exports.Set("${config.propertyName}", Init${config.objectName}(env));`);
16
+ }
17
+
18
+ content.push('#include "napi.h"');
19
+ content.push('using namespace Napi;');
20
+
21
+ inits.forEach(init => content.push(init));
22
+
23
+ content.push('Object Init(Env env, Object exports) {');
24
+
25
+ exports.forEach(exp => content.push(exp));
26
+
27
+ content.push('return exports;');
28
+ content.push('}');
29
+ content.push('NODE_API_MODULE(addon, Init);');
30
+
31
+ return Promise.resolve(content.join('\r\n'));
32
+ };
33
+
34
+ module.exports.writeToBindingFile = function writeToBindingFile (content) {
35
+ const generatedFilePath = path.join(__dirname, 'generated', 'binding.cc');
36
+ fs.writeFileSync(generatedFilePath, '');
37
+ fs.writeFileSync(generatedFilePath, content, { flag: 'a' });
38
+ console.log('generated binding file ', generatedFilePath, new Date());
39
+ };
@@ -0,0 +1,72 @@
1
+ {
2
+ 'target_defaults': {
3
+ 'includes': ['../common.gypi'],
4
+ 'include_dirs': ['../test/common', "./generated"],
5
+ 'variables': {
6
+ 'setup': ["<!@(node -p \"require('./setup')\")"],
7
+ 'build_sources': [
8
+ "<!@(node -p \"require('./injectTestParams').filesToCompile()\")",
9
+ ]
10
+ },
11
+ },
12
+ 'targets': [
13
+ {
14
+ "target_name": "generateBindingCC",
15
+ "type": "none",
16
+ "actions": [ {
17
+ "action_name": "generateBindingCC",
18
+ "message": "Generating binding cc file",
19
+ "outputs": ["generated/binding.cc"],
20
+ "conditions": [
21
+ [ "'true'=='true'", {
22
+ "inputs": [""],
23
+ "action": [
24
+ "node",
25
+ "generate-binding-cc.js",
26
+ "<!@(node -p \"require('./injectTestParams').filesForBinding()\" )"
27
+ ]
28
+ } ]
29
+ ]
30
+ } ]
31
+ },
32
+ {
33
+ 'target_name': 'binding',
34
+ 'includes': ['../except.gypi'],
35
+ 'sources': ['>@(build_sources)'],
36
+ 'dependencies': [ 'generateBindingCC' ]
37
+ },
38
+ {
39
+ 'target_name': 'binding_noexcept',
40
+ 'includes': ['../noexcept.gypi'],
41
+ 'sources': ['>@(build_sources)'],
42
+ 'dependencies': [ 'generateBindingCC' ]
43
+ },
44
+ {
45
+ 'target_name': 'binding_noexcept_maybe',
46
+ 'includes': ['../noexcept.gypi'],
47
+ 'sources': ['>@(build_sources)'],
48
+ 'defines': ['NODE_ADDON_API_ENABLE_MAYBE']
49
+ },
50
+ {
51
+ 'target_name': 'binding_swallowexcept',
52
+ 'includes': ['../except.gypi'],
53
+ 'sources': ['>@(build_sources)'],
54
+ 'defines': ['NODE_API_SWALLOW_UNTHROWABLE_EXCEPTIONS'],
55
+ 'dependencies': [ 'generateBindingCC' ]
56
+ },
57
+ {
58
+ 'target_name': 'binding_swallowexcept_noexcept',
59
+ 'includes': ['../noexcept.gypi'],
60
+ 'sources': ['>@(build_sources)'],
61
+ 'defines': ['NODE_API_SWALLOW_UNTHROWABLE_EXCEPTIONS'],
62
+ 'dependencies': [ 'generateBindingCC' ]
63
+ },
64
+ {
65
+ 'target_name': 'binding_custom_namespace',
66
+ 'includes': ['../noexcept.gypi'],
67
+ 'sources': ['>@(build_sources)'],
68
+ 'defines': ['NAPI_CPP_CUSTOM_NAMESPACE=cstm'],
69
+ 'dependencies': [ 'generateBindingCC' ]
70
+ },
71
+ ],
72
+ }
@@ -0,0 +1,32 @@
1
+ /**
2
+ * This file points out anomalies/exceptions in test files when generating the binding.cc file
3
+ *
4
+ * nouns: words in file names that are misspelled
5
+ * *NOTE: a 'constructor' property is explicitly added to override javascript object constructor
6
+ *
7
+ * exportNames: anomalies in init function names
8
+ *
9
+ * propertyNames: anomalies in exported property name of init functions
10
+ *
11
+ * skipBinding: skip including this file in binding.cc
12
+ */
13
+ module.exports = {
14
+ nouns: {
15
+ constructor: 'constructor',
16
+ threadsafe: 'threadSafe',
17
+ objectwrap: 'objectWrap'
18
+ },
19
+ exportNames: {
20
+ AsyncWorkerPersistent: 'PersistentAsyncWorker'
21
+ },
22
+ propertyNames: {
23
+ async_worker_persistent: 'persistentasyncworker',
24
+ objectwrap_constructor_exception: 'objectwrapConstructorException'
25
+ },
26
+ skipBinding: [
27
+ 'global_object_delete_property',
28
+ 'global_object_get_property',
29
+ 'global_object_has_own_property',
30
+ 'global_object_set_property'
31
+ ]
32
+ };
@@ -0,0 +1,61 @@
1
+ const listOfTestModules = require('./listOfTestModules');
2
+ const exceptions = require('./exceptions');
3
+ const { generateFileContent, writeToBindingFile } = require('./binding-file-template');
4
+
5
+ const buildDirs = listOfTestModules.dirs;
6
+ const buildFiles = listOfTestModules.files;
7
+
8
+ /**
9
+ * @param none
10
+ * @requires list of files to bind as command-line argument
11
+ * @returns list of binding configurations
12
+ */
13
+ function generateBindingConfigurations () {
14
+ const testFilesToBind = process.argv.slice(2);
15
+ console.log('test modules to bind: ', testFilesToBind);
16
+
17
+ const configs = [];
18
+
19
+ testFilesToBind.forEach((file) => {
20
+ const configName = file.split('.cc')[0];
21
+
22
+ if (buildDirs[configName]) {
23
+ for (const file of buildDirs[configName]) {
24
+ if (exceptions.skipBinding.includes(file)) continue;
25
+ configs.push(buildFiles[file]);
26
+ }
27
+ } else if (buildFiles[configName]) {
28
+ configs.push(buildFiles[configName]);
29
+ } else {
30
+ console.log('not found', file, configName);
31
+ }
32
+ });
33
+
34
+ return Promise.resolve(configs);
35
+ }
36
+
37
+ generateBindingConfigurations().then(generateFileContent).then(writeToBindingFile);
38
+
39
+ /**
40
+ * Test cases
41
+ * @fires only when run directly from terminal with TEST=true
42
+ * eg: TEST=true node generate-binding-cc
43
+ */
44
+ if (require.main === module && process.env.TEST === 'true') {
45
+ const assert = require('assert');
46
+
47
+ const setArgsAndCall = (fn, filterCondition) => { process.argv = [null, null, ...filterCondition.split(' ')]; return fn(); };
48
+ const assertPromise = (promise, expectedVal) => promise.then((val) => assert.deepEqual(val, expectedVal)).catch(console.log);
49
+
50
+ const expectedVal = [{
51
+ dir: '',
52
+ objectName: 'AsyncProgressWorker',
53
+ propertyName: 'async_progress_worker'
54
+ },
55
+ {
56
+ dir: '',
57
+ objectName: 'PersistentAsyncWorker',
58
+ propertyName: 'persistentasyncworker'
59
+ }];
60
+ assertPromise(setArgsAndCall(generateBindingConfigurations, 'async_progress_worker async_worker_persistent'), expectedVal);
61
+ }
@@ -0,0 +1,101 @@
1
+ const fs = require('fs');
2
+ const path = require('path');
3
+
4
+ const listOfTestModules = require('./listOfTestModules');
5
+
6
+ const buildDirs = listOfTestModules.dirs;
7
+ const buildFiles = listOfTestModules.files;
8
+
9
+ if (!fs.existsSync('./generated')) {
10
+ fs.mkdirSync('./generated');
11
+ }
12
+
13
+ /**
14
+ * @returns : list of files to compile by node-gyp
15
+ * @param : none
16
+ * @requires : picks `filter` parameter from process.env
17
+ * This function is used as an utility method to inject a list of files to compile into binding.gyp
18
+ */
19
+ module.exports.filesToCompile = function () {
20
+ // match filter argument with available test modules
21
+ const matchedModules = require('./matchModules').matchWildCards(process.env.npm_config_filter || '');
22
+
23
+ // standard list of files to compile
24
+ const addedFiles = './generated/binding.cc test_helper.h';
25
+
26
+ const filterConditions = matchedModules.split(' ').length ? matchedModules.split(' ') : [matchedModules];
27
+ const files = [];
28
+
29
+ // generate a list of all files to compile
30
+ for (const matchCondition of filterConditions) {
31
+ if (buildDirs[matchCondition.toLowerCase()]) {
32
+ for (const file of buildDirs[matchCondition.toLowerCase()]) {
33
+ const config = buildFiles[file];
34
+ const separator = config.dir.length ? '/' : '';
35
+ files.push(config.dir + separator + file);
36
+ }
37
+ } else if (buildFiles[matchCondition.toLowerCase()]) {
38
+ const config = buildFiles[matchCondition.toLowerCase()];
39
+ const separator = config.dir.length ? '/' : '';
40
+ files.push(config.dir + separator + matchCondition.toLowerCase());
41
+ }
42
+ }
43
+
44
+ // generate a string of files to feed to the compiler
45
+ let filesToCompile = '';
46
+ files.forEach((file) => {
47
+ filesToCompile = `${filesToCompile} ../test/${file}.cc`;
48
+ });
49
+
50
+ // log list of compiled files
51
+ fs.writeFileSync(path.join(__dirname, '/generated/compilelist'), `${addedFiles} ${filesToCompile}`.split(' ').join('\r\n'));
52
+
53
+ // return file list
54
+ return `${addedFiles} ${filesToCompile}`;
55
+ };
56
+
57
+ /**
58
+ * @returns list of test files to bind exported init functions
59
+ * @param : none
60
+ * @requires : picks `filter` parameter from process.env
61
+ * This function is used as an utility method by the generateBindingCC step in binding.gyp
62
+ */
63
+ module.exports.filesForBinding = function () {
64
+ const filterCondition = require('./matchModules').matchWildCards(process.env.npm_config_filter || '');
65
+ fs.writeFileSync(path.join(__dirname, '/generated/bindingList'), filterCondition.split(' ').join('\r\n'));
66
+ return filterCondition;
67
+ };
68
+
69
+ /**
70
+ * Test cases
71
+ * @fires only when run directly from terminal
72
+ * eg: node injectTestParams
73
+ */
74
+ if (require.main === module) {
75
+ const assert = require('assert');
76
+
77
+ const setEnvAndCall = (fn, filterCondition) => { process.env.npm_config_filter = filterCondition; return fn(); };
78
+
79
+ assert.strictEqual(setEnvAndCall(exports.filesToCompile, 'typed*ex*'), './generated/binding.cc test_helper.h ../test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc');
80
+
81
+ const expectedFilesToMatch = [
82
+ './generated/binding.cc test_helper.h ',
83
+ '../test/threadsafe_function/threadsafe_function.cc',
84
+ '../test/threadsafe_function/threadsafe_function_ctx.cc',
85
+ '../test/threadsafe_function/threadsafe_function_existing_tsfn.cc',
86
+ '../test/threadsafe_function/threadsafe_function_ptr.cc',
87
+ '../test/threadsafe_function/threadsafe_function_sum.cc',
88
+ '../test/threadsafe_function/threadsafe_function_unref.cc',
89
+ '../test/typed_threadsafe_function/typed_threadsafe_function.cc',
90
+ '../test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc',
91
+ '../test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc',
92
+ '../test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc',
93
+ '../test/typed_threadsafe_function/typed_threadsafe_function_sum.cc',
94
+ '../test/typed_threadsafe_function/typed_threadsafe_function_unref.cc'
95
+ ];
96
+ assert.strictEqual(setEnvAndCall(exports.filesToCompile, 'threadsafe_function typed_threadsafe_function'), expectedFilesToMatch.join(' '));
97
+
98
+ assert.strictEqual(setEnvAndCall(exports.filesToCompile, 'objectwrap'), './generated/binding.cc test_helper.h ../test/objectwrap.cc');
99
+
100
+ console.log('ALL tests passed');
101
+ }
@@ -0,0 +1,88 @@
1
+ const fs = require('fs');
2
+ const path = require('path');
3
+ const exceptions = require('./exceptions');
4
+
5
+ const buildFiles = {};
6
+ const buidDirs = {};
7
+
8
+ /**
9
+ * @param fileName - expect to be in snake case , eg: this_is_a_test_file.cc
10
+ * @returns init function name in the file
11
+ *
12
+ * general format of init function name is camelCase version of the snake_case file name
13
+ */
14
+ function getExportObjectName (fileName) {
15
+ fileName = fileName.split('_').map(token => exceptions.nouns[token] ? exceptions.nouns[token] : token).join('_');
16
+ const str = fileName.replace(/(_\w)/g, (k) => k[1].toUpperCase());
17
+ const exportObjectName = str.charAt(0).toUpperCase() + str.substring(1);
18
+ if (exceptions.exportNames[exportObjectName]) {
19
+ return exceptions.exportNames[exportObjectName];
20
+ }
21
+ return exportObjectName;
22
+ }
23
+
24
+ /**
25
+ * @param fileName - expect to be in snake case , eg: this_is_a_test_file.cc
26
+ * @returns property name of exported init function
27
+ */
28
+ function getExportPropertyName (fileName) {
29
+ if (exceptions.propertyNames[fileName.toLowerCase()]) {
30
+ return exceptions.propertyNames[fileName.toLowerCase()];
31
+ }
32
+ return fileName;
33
+ }
34
+
35
+ /**
36
+ * creates a configuration list for all available test modules
37
+ * The configuration object contains the expected init function names and corresponding export property names
38
+ */
39
+ function listOfTestModules (currentDirectory = path.join(__dirname, '/../test'), pre = '') {
40
+ fs.readdirSync(currentDirectory).forEach((file) => {
41
+ if (file === 'binding.cc' ||
42
+ file === 'binding.gyp' ||
43
+ file === 'build' ||
44
+ file === 'common' ||
45
+ file === 'thunking_manual.cc' ||
46
+ file === 'addon_build' ||
47
+ file[0] === '.') {
48
+ return;
49
+ }
50
+ const absoluteFilepath = path.join(currentDirectory, file);
51
+ const fileName = file.toLowerCase().replace('.cc', '');
52
+ if (fs.statSync(absoluteFilepath).isDirectory()) {
53
+ buidDirs[fileName] = [];
54
+ listOfTestModules(absoluteFilepath, pre + file + '/');
55
+ } else {
56
+ if (!file.toLowerCase().endsWith('.cc')) return;
57
+ if (currentDirectory.trim().split('/test/').length > 1) {
58
+ buidDirs[currentDirectory.split('/test/')[1].toLowerCase()].push(fileName);
59
+ }
60
+ const relativePath = (currentDirectory.split(`${fileName}.cc`)[0]).split('/test/')[1] || '';
61
+ buildFiles[fileName] = { dir: relativePath, propertyName: getExportPropertyName(fileName), objectName: getExportObjectName(fileName) };
62
+ }
63
+ });
64
+ }
65
+ listOfTestModules();
66
+
67
+ module.exports = {
68
+ dirs: buidDirs,
69
+ files: buildFiles
70
+ };
71
+
72
+ /**
73
+ * Test cases
74
+ * @fires only when run directly from terminal
75
+ * eg: node listOfTestModules
76
+ */
77
+ if (require.main === module) {
78
+ const assert = require('assert');
79
+ assert.strictEqual(getExportObjectName('objectwrap_constructor_exception'), 'ObjectWrapConstructorException');
80
+ assert.strictEqual(getExportObjectName('typed_threadsafe_function'), 'TypedThreadSafeFunction');
81
+ assert.strictEqual(getExportObjectName('objectwrap_removewrap'), 'ObjectWrapRemovewrap');
82
+ assert.strictEqual(getExportObjectName('function_reference'), 'FunctionReference');
83
+ assert.strictEqual(getExportObjectName('async_worker'), 'AsyncWorker');
84
+ assert.strictEqual(getExportObjectName('async_progress_worker'), 'AsyncProgressWorker');
85
+ assert.strictEqual(getExportObjectName('async_worker_persistent'), 'PersistentAsyncWorker');
86
+
87
+ console.log('ALL tests passed');
88
+ }
@@ -0,0 +1,65 @@
1
+ const listOfTestModules = require('./listOfTestModules');
2
+ const buildDirs = listOfTestModules.dirs;
3
+ const buildFiles = listOfTestModules.files;
4
+
5
+ function isWildcard (filter) {
6
+ if (filter.includes('*')) return true;
7
+ return false;
8
+ }
9
+
10
+ function filterBy (wildcard, item) {
11
+ return new RegExp('^' + wildcard.replace(/\*/g, '.*') + '$').test(item);
12
+ }
13
+
14
+ /**
15
+ * @param filterCondition
16
+ * matches all given wildcards with available test modules to generate an elaborate filter condition
17
+ */
18
+ function matchWildCards (filterCondition) {
19
+ const conditions = filterCondition.split(' ').length ? filterCondition.split(' ') : [filterCondition];
20
+ const matches = [];
21
+
22
+ for (const filter of conditions) {
23
+ if (isWildcard(filter)) {
24
+ const matchedDirs = Object.keys(buildDirs).filter(e => filterBy(filter, e));
25
+ if (matchedDirs.length) {
26
+ matches.push(matchedDirs.join(' '));
27
+ }
28
+ const matchedModules = Object.keys(buildFiles).filter(e => filterBy(filter, e));
29
+ if (matchedModules.length) { matches.push(matchedModules.join(' ')); }
30
+ } else {
31
+ matches.push(filter);
32
+ }
33
+ }
34
+
35
+ return matches.join(' ');
36
+ }
37
+
38
+ module.exports.matchWildCards = matchWildCards;
39
+
40
+ /**
41
+ * Test cases
42
+ * @fires only when run directly from terminal
43
+ * eg: node matchModules
44
+ */
45
+ if (require.main === module) {
46
+ const assert = require('assert');
47
+
48
+ assert.strictEqual(matchWildCards('typed*ex'), 'typed*ex');
49
+ assert.strictEqual(matchWildCards('typed*ex*'), 'typed_threadsafe_function_existing_tsfn');
50
+ assert.strictEqual(matchWildCards('async*'), 'async_context async_progress_queue_worker async_progress_worker async_worker async_worker_persistent');
51
+ assert.strictEqual(matchWildCards('typed*func'), 'typed*func');
52
+ assert.strictEqual(matchWildCards('typed*func*'), 'typed_threadsafe_function');
53
+ assert.strictEqual(matchWildCards('typed*function'), 'typed_threadsafe_function');
54
+ assert.strictEqual(matchWildCards('object*inh'), 'object*inh');
55
+ assert.strictEqual(matchWildCards('object*inh*'), 'objectwrap_multiple_inheritance');
56
+ assert.strictEqual(matchWildCards('*remove*'), 'objectwrap_removewrap');
57
+ assert.strictEqual(matchWildCards('*function'), 'threadsafe_function typed_threadsafe_function');
58
+ assert.strictEqual(matchWildCards('**function'), 'threadsafe_function typed_threadsafe_function');
59
+ assert.strictEqual(matchWildCards('a*w*p*'), 'async_worker_persistent');
60
+ assert.strictEqual(matchWildCards('fun*ref'), 'fun*ref');
61
+ assert.strictEqual(matchWildCards('fun*ref*'), 'function_reference');
62
+ assert.strictEqual(matchWildCards('*reference'), 'function_reference object_reference reference');
63
+
64
+ console.log('ALL tests passed');
65
+ }
@@ -0,0 +1,13 @@
1
+ const fs = require('fs');
2
+ const { generateFileContent, writeToBindingFile } = require('./binding-file-template');
3
+
4
+ /**
5
+ * @summary setup script to execute before node-gyp begins target actions
6
+ */
7
+ if (!fs.existsSync('./generated')) {
8
+ // create generated folder
9
+ fs.mkdirSync('./generated');
10
+ // create empty binding.cc file
11
+ generateFileContent([]).then(writeToBindingFile);
12
+ // FIX: Its necessary to have an empty bindng.cc file, otherwise build fails first time
13
+ }
@@ -0,0 +1,26 @@
1
+ const { spawn } = require('child_process');
2
+
3
+ /**
4
+ * spawns a child process to run a given node.js script
5
+ */
6
+ module.exports.runChildProcess = function (scriptName, options) {
7
+ const childProcess = spawn('node', [scriptName], options);
8
+
9
+ childProcess.stdout.on('data', data => {
10
+ console.log(`${data}`);
11
+ });
12
+ childProcess.stderr.on('data', data => {
13
+ console.log(`error: ${data}`);
14
+ });
15
+
16
+ return new Promise((resolve, reject) => {
17
+ childProcess.on('error', (error) => {
18
+ console.log(`error: ${error.message}`);
19
+ reject(error);
20
+ });
21
+ childProcess.on('close', code => {
22
+ console.log(`child process exited with code ${code}`);
23
+ resolve(code);
24
+ });
25
+ });
26
+ };