koffi 1.0.4 → 1.1.0-beta.1

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 (268) hide show
  1. package/README.md +51 -22
  2. package/build/qemu/1.1.0-beta.1/koffi_darwin_x64.tar.gz +0 -0
  3. package/build/qemu/1.1.0-beta.1/koffi_freebsd_arm64.tar.gz +0 -0
  4. package/build/qemu/1.1.0-beta.1/koffi_freebsd_ia32.tar.gz +0 -0
  5. package/build/qemu/1.1.0-beta.1/koffi_freebsd_x64.tar.gz +0 -0
  6. package/build/qemu/1.1.0-beta.1/koffi_linux_arm.tar.gz +0 -0
  7. package/build/qemu/1.1.0-beta.1/koffi_linux_arm64.tar.gz +0 -0
  8. package/build/qemu/1.1.0-beta.1/koffi_linux_ia32.tar.gz +0 -0
  9. package/build/qemu/1.1.0-beta.1/koffi_linux_x64.tar.gz +0 -0
  10. package/build/qemu/1.1.0-beta.1/koffi_win32_ia32.tar.gz +0 -0
  11. package/build/qemu/1.1.0-beta.1/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 +13 -6
  16. package/src/abi_arm64.cc +13 -6
  17. package/src/abi_x64_sysv.cc +13 -6
  18. package/src/abi_x64_win.cc +13 -6
  19. package/src/abi_x86.cc +13 -6
  20. package/src/call.cc +25 -26
  21. package/src/call.hh +27 -41
  22. package/src/ffi.cc +152 -17
  23. package/src/ffi.hh +24 -10
  24. package/test/misc.c +2 -2
  25. package/build/qemu/1.0.4/koffi_darwin_x64.tar.gz +0 -0
  26. package/build/qemu/1.0.4/koffi_freebsd_arm64.tar.gz +0 -0
  27. package/build/qemu/1.0.4/koffi_freebsd_ia32.tar.gz +0 -0
  28. package/build/qemu/1.0.4/koffi_freebsd_x64.tar.gz +0 -0
  29. package/build/qemu/1.0.4/koffi_linux_arm.tar.gz +0 -0
  30. package/build/qemu/1.0.4/koffi_linux_arm64.tar.gz +0 -0
  31. package/build/qemu/1.0.4/koffi_linux_ia32.tar.gz +0 -0
  32. package/build/qemu/1.0.4/koffi_linux_x64.tar.gz +0 -0
  33. package/build/qemu/1.0.4/koffi_win32_ia32.tar.gz +0 -0
  34. package/build/qemu/1.0.4/koffi_win32_x64.tar.gz +0 -0
  35. package/test/misc.js +0 -227
  36. package/vendor/node-addon-api/CODE_OF_CONDUCT.md +0 -4
  37. package/vendor/node-addon-api/CONTRIBUTING.md +0 -93
  38. package/vendor/node-addon-api/appveyor.yml +0 -37
  39. package/vendor/node-addon-api/benchmark/README.md +0 -47
  40. package/vendor/node-addon-api/benchmark/binding.gyp +0 -25
  41. package/vendor/node-addon-api/benchmark/function_args.cc +0 -217
  42. package/vendor/node-addon-api/benchmark/function_args.js +0 -60
  43. package/vendor/node-addon-api/benchmark/index.js +0 -34
  44. package/vendor/node-addon-api/benchmark/property_descriptor.cc +0 -91
  45. package/vendor/node-addon-api/benchmark/property_descriptor.js +0 -37
  46. package/vendor/node-addon-api/doc/addon.md +0 -163
  47. package/vendor/node-addon-api/doc/array.md +0 -81
  48. package/vendor/node-addon-api/doc/array_buffer.md +0 -155
  49. package/vendor/node-addon-api/doc/async_context.md +0 -86
  50. package/vendor/node-addon-api/doc/async_operations.md +0 -31
  51. package/vendor/node-addon-api/doc/async_worker.md +0 -427
  52. package/vendor/node-addon-api/doc/async_worker_variants.md +0 -557
  53. package/vendor/node-addon-api/doc/bigint.md +0 -97
  54. package/vendor/node-addon-api/doc/boolean.md +0 -68
  55. package/vendor/node-addon-api/doc/buffer.md +0 -150
  56. package/vendor/node-addon-api/doc/callback_scope.md +0 -54
  57. package/vendor/node-addon-api/doc/callbackinfo.md +0 -97
  58. package/vendor/node-addon-api/doc/checker-tool.md +0 -32
  59. package/vendor/node-addon-api/doc/class_property_descriptor.md +0 -123
  60. package/vendor/node-addon-api/doc/cmake-js.md +0 -68
  61. package/vendor/node-addon-api/doc/conversion-tool.md +0 -28
  62. package/vendor/node-addon-api/doc/creating_a_release.md +0 -62
  63. package/vendor/node-addon-api/doc/dataview.md +0 -248
  64. package/vendor/node-addon-api/doc/date.md +0 -68
  65. package/vendor/node-addon-api/doc/env.md +0 -196
  66. package/vendor/node-addon-api/doc/error.md +0 -120
  67. package/vendor/node-addon-api/doc/error_handling.md +0 -254
  68. package/vendor/node-addon-api/doc/escapable_handle_scope.md +0 -80
  69. package/vendor/node-addon-api/doc/external.md +0 -63
  70. package/vendor/node-addon-api/doc/function.md +0 -402
  71. package/vendor/node-addon-api/doc/function_reference.md +0 -238
  72. package/vendor/node-addon-api/doc/generator.md +0 -13
  73. package/vendor/node-addon-api/doc/handle_scope.md +0 -63
  74. package/vendor/node-addon-api/doc/hierarchy.md +0 -91
  75. package/vendor/node-addon-api/doc/instance_wrap.md +0 -408
  76. package/vendor/node-addon-api/doc/maybe.md +0 -76
  77. package/vendor/node-addon-api/doc/memory_management.md +0 -27
  78. package/vendor/node-addon-api/doc/name.md +0 -29
  79. package/vendor/node-addon-api/doc/node-gyp.md +0 -82
  80. package/vendor/node-addon-api/doc/number.md +0 -163
  81. package/vendor/node-addon-api/doc/object.md +0 -411
  82. package/vendor/node-addon-api/doc/object_lifetime_management.md +0 -83
  83. package/vendor/node-addon-api/doc/object_reference.md +0 -117
  84. package/vendor/node-addon-api/doc/object_wrap.md +0 -588
  85. package/vendor/node-addon-api/doc/prebuild_tools.md +0 -16
  86. package/vendor/node-addon-api/doc/promises.md +0 -79
  87. package/vendor/node-addon-api/doc/property_descriptor.md +0 -286
  88. package/vendor/node-addon-api/doc/propertylvalue.md +0 -50
  89. package/vendor/node-addon-api/doc/range_error.md +0 -59
  90. package/vendor/node-addon-api/doc/reference.md +0 -113
  91. package/vendor/node-addon-api/doc/setup.md +0 -110
  92. package/vendor/node-addon-api/doc/string.md +0 -93
  93. package/vendor/node-addon-api/doc/symbol.md +0 -61
  94. package/vendor/node-addon-api/doc/threadsafe.md +0 -121
  95. package/vendor/node-addon-api/doc/threadsafe_function.md +0 -290
  96. package/vendor/node-addon-api/doc/type_error.md +0 -59
  97. package/vendor/node-addon-api/doc/typed_array.md +0 -78
  98. package/vendor/node-addon-api/doc/typed_array_of.md +0 -137
  99. package/vendor/node-addon-api/doc/typed_threadsafe_function.md +0 -306
  100. package/vendor/node-addon-api/doc/value.md +0 -340
  101. package/vendor/node-addon-api/doc/version_management.md +0 -43
  102. package/vendor/node-addon-api/package.json +0 -415
  103. package/vendor/node-addon-api/test/README.md +0 -91
  104. package/vendor/node-addon-api/test/addon.cc +0 -36
  105. package/vendor/node-addon-api/test/addon.js +0 -11
  106. package/vendor/node-addon-api/test/addon_build/index.js +0 -49
  107. package/vendor/node-addon-api/test/addon_build/tpl/addon.cc +0 -17
  108. package/vendor/node-addon-api/test/addon_build/tpl/binding.gyp +0 -62
  109. package/vendor/node-addon-api/test/addon_build/tpl/index.js +0 -9
  110. package/vendor/node-addon-api/test/addon_build/tpl/package.json +0 -11
  111. package/vendor/node-addon-api/test/addon_data.cc +0 -99
  112. package/vendor/node-addon-api/test/addon_data.js +0 -46
  113. package/vendor/node-addon-api/test/array_buffer.cc +0 -243
  114. package/vendor/node-addon-api/test/array_buffer.js +0 -69
  115. package/vendor/node-addon-api/test/async_context.cc +0 -36
  116. package/vendor/node-addon-api/test/async_context.js +0 -122
  117. package/vendor/node-addon-api/test/async_progress_queue_worker.cc +0 -83
  118. package/vendor/node-addon-api/test/async_progress_queue_worker.js +0 -46
  119. package/vendor/node-addon-api/test/async_progress_worker.cc +0 -134
  120. package/vendor/node-addon-api/test/async_progress_worker.js +0 -61
  121. package/vendor/node-addon-api/test/async_worker.cc +0 -106
  122. package/vendor/node-addon-api/test/async_worker.js +0 -179
  123. package/vendor/node-addon-api/test/async_worker_nocallback.js +0 -13
  124. package/vendor/node-addon-api/test/async_worker_persistent.cc +0 -63
  125. package/vendor/node-addon-api/test/async_worker_persistent.js +0 -24
  126. package/vendor/node-addon-api/test/basic_types/array.cc +0 -40
  127. package/vendor/node-addon-api/test/basic_types/array.js +0 -35
  128. package/vendor/node-addon-api/test/basic_types/boolean.cc +0 -38
  129. package/vendor/node-addon-api/test/basic_types/boolean.js +0 -35
  130. package/vendor/node-addon-api/test/basic_types/number.cc +0 -99
  131. package/vendor/node-addon-api/test/basic_types/number.js +0 -114
  132. package/vendor/node-addon-api/test/basic_types/value.cc +0 -120
  133. package/vendor/node-addon-api/test/basic_types/value.js +0 -133
  134. package/vendor/node-addon-api/test/bigint.cc +0 -91
  135. package/vendor/node-addon-api/test/bigint.js +0 -53
  136. package/vendor/node-addon-api/test/binding-swallowexcept.cc +0 -12
  137. package/vendor/node-addon-api/test/binding.cc +0 -173
  138. package/vendor/node-addon-api/test/binding.gyp +0 -124
  139. package/vendor/node-addon-api/test/buffer.cc +0 -183
  140. package/vendor/node-addon-api/test/buffer.js +0 -69
  141. package/vendor/node-addon-api/test/callbackscope.cc +0 -22
  142. package/vendor/node-addon-api/test/callbackscope.js +0 -49
  143. package/vendor/node-addon-api/test/common/index.js +0 -114
  144. package/vendor/node-addon-api/test/common/test_helper.h +0 -71
  145. package/vendor/node-addon-api/test/dataview/dataview.cc +0 -48
  146. package/vendor/node-addon-api/test/dataview/dataview.js +0 -35
  147. package/vendor/node-addon-api/test/dataview/dataview_read_write.cc +0 -115
  148. package/vendor/node-addon-api/test/dataview/dataview_read_write.js +0 -90
  149. package/vendor/node-addon-api/test/date.cc +0 -44
  150. package/vendor/node-addon-api/test/date.js +0 -18
  151. package/vendor/node-addon-api/test/env_cleanup.cc +0 -88
  152. package/vendor/node-addon-api/test/env_cleanup.js +0 -56
  153. package/vendor/node-addon-api/test/error.cc +0 -287
  154. package/vendor/node-addon-api/test/error.js +0 -81
  155. package/vendor/node-addon-api/test/error_handling_for_primitives.cc +0 -13
  156. package/vendor/node-addon-api/test/error_handling_for_primitives.js +0 -29
  157. package/vendor/node-addon-api/test/error_terminating_environment.js +0 -95
  158. package/vendor/node-addon-api/test/external.cc +0 -81
  159. package/vendor/node-addon-api/test/external.js +0 -88
  160. package/vendor/node-addon-api/test/function.cc +0 -324
  161. package/vendor/node-addon-api/test/function.js +0 -133
  162. package/vendor/node-addon-api/test/function_reference.cc +0 -202
  163. package/vendor/node-addon-api/test/function_reference.js +0 -157
  164. package/vendor/node-addon-api/test/globalObject/global_object.cc +0 -61
  165. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.cc +0 -31
  166. package/vendor/node-addon-api/test/globalObject/global_object_delete_property.js +0 -61
  167. package/vendor/node-addon-api/test/globalObject/global_object_get_property.cc +0 -40
  168. package/vendor/node-addon-api/test/globalObject/global_object_get_property.js +0 -57
  169. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.cc +0 -28
  170. package/vendor/node-addon-api/test/globalObject/global_object_has_own_property.js +0 -48
  171. package/vendor/node-addon-api/test/globalObject/global_object_set_property.cc +0 -31
  172. package/vendor/node-addon-api/test/globalObject/global_object_set_property.js +0 -58
  173. package/vendor/node-addon-api/test/handlescope.cc +0 -60
  174. package/vendor/node-addon-api/test/handlescope.js +0 -14
  175. package/vendor/node-addon-api/test/index.js +0 -159
  176. package/vendor/node-addon-api/test/maybe/check.cc +0 -23
  177. package/vendor/node-addon-api/test/maybe/index.js +0 -38
  178. package/vendor/node-addon-api/test/memory_management.cc +0 -17
  179. package/vendor/node-addon-api/test/memory_management.js +0 -9
  180. package/vendor/node-addon-api/test/movable_callbacks.cc +0 -23
  181. package/vendor/node-addon-api/test/movable_callbacks.js +0 -21
  182. package/vendor/node-addon-api/test/name.cc +0 -108
  183. package/vendor/node-addon-api/test/name.js +0 -59
  184. package/vendor/node-addon-api/test/napi_child.js +0 -14
  185. package/vendor/node-addon-api/test/object/delete_property.cc +0 -38
  186. package/vendor/node-addon-api/test/object/delete_property.js +0 -41
  187. package/vendor/node-addon-api/test/object/finalizer.cc +0 -29
  188. package/vendor/node-addon-api/test/object/finalizer.js +0 -28
  189. package/vendor/node-addon-api/test/object/get_property.cc +0 -34
  190. package/vendor/node-addon-api/test/object/get_property.js +0 -40
  191. package/vendor/node-addon-api/test/object/has_own_property.cc +0 -34
  192. package/vendor/node-addon-api/test/object/has_own_property.js +0 -34
  193. package/vendor/node-addon-api/test/object/has_property.cc +0 -38
  194. package/vendor/node-addon-api/test/object/has_property.js +0 -37
  195. package/vendor/node-addon-api/test/object/object.cc +0 -350
  196. package/vendor/node-addon-api/test/object/object.js +0 -217
  197. package/vendor/node-addon-api/test/object/object_deprecated.cc +0 -66
  198. package/vendor/node-addon-api/test/object/object_deprecated.js +0 -47
  199. package/vendor/node-addon-api/test/object/object_freeze_seal.cc +0 -25
  200. package/vendor/node-addon-api/test/object/object_freeze_seal.js +0 -61
  201. package/vendor/node-addon-api/test/object/set_property.cc +0 -45
  202. package/vendor/node-addon-api/test/object/set_property.js +0 -30
  203. package/vendor/node-addon-api/test/object/subscript_operator.cc +0 -58
  204. package/vendor/node-addon-api/test/object/subscript_operator.js +0 -17
  205. package/vendor/node-addon-api/test/object_reference.cc +0 -219
  206. package/vendor/node-addon-api/test/object_reference.js +0 -259
  207. package/vendor/node-addon-api/test/objectwrap.cc +0 -268
  208. package/vendor/node-addon-api/test/objectwrap.js +0 -284
  209. package/vendor/node-addon-api/test/objectwrap_constructor_exception.cc +0 -26
  210. package/vendor/node-addon-api/test/objectwrap_constructor_exception.js +0 -18
  211. package/vendor/node-addon-api/test/objectwrap_function.cc +0 -45
  212. package/vendor/node-addon-api/test/objectwrap_function.js +0 -22
  213. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.cc +0 -30
  214. package/vendor/node-addon-api/test/objectwrap_multiple_inheritance.js +0 -13
  215. package/vendor/node-addon-api/test/objectwrap_removewrap.cc +0 -45
  216. package/vendor/node-addon-api/test/objectwrap_removewrap.js +0 -40
  217. package/vendor/node-addon-api/test/objectwrap_worker_thread.js +0 -19
  218. package/vendor/node-addon-api/test/promise.cc +0 -29
  219. package/vendor/node-addon-api/test/promise.js +0 -18
  220. package/vendor/node-addon-api/test/reference.cc +0 -24
  221. package/vendor/node-addon-api/test/reference.js +0 -14
  222. package/vendor/node-addon-api/test/run_script.cc +0 -56
  223. package/vendor/node-addon-api/test/run_script.js +0 -45
  224. package/vendor/node-addon-api/test/symbol.cc +0 -79
  225. package/vendor/node-addon-api/test/symbol.js +0 -73
  226. package/vendor/node-addon-api/test/testUtil.js +0 -54
  227. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.cc +0 -195
  228. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function.js +0 -188
  229. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.cc +0 -63
  230. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ctx.js +0 -12
  231. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.cc +0 -115
  232. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_existing_tsfn.js +0 -14
  233. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.cc +0 -26
  234. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_ptr.js +0 -7
  235. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.cc +0 -225
  236. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_sum.js +0 -59
  237. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.cc +0 -42
  238. package/vendor/node-addon-api/test/threadsafe_function/threadsafe_function_unref.js +0 -53
  239. package/vendor/node-addon-api/test/thunking_manual.cc +0 -140
  240. package/vendor/node-addon-api/test/thunking_manual.js +0 -17
  241. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.cc +0 -215
  242. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function.js +0 -188
  243. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.cc +0 -68
  244. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ctx.js +0 -12
  245. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.cc +0 -127
  246. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_existing_tsfn.js +0 -14
  247. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.cc +0 -28
  248. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_ptr.js +0 -7
  249. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.cc +0 -237
  250. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_sum.js +0 -59
  251. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.cc +0 -53
  252. package/vendor/node-addon-api/test/typed_threadsafe_function/typed_threadsafe_function_unref.js +0 -53
  253. package/vendor/node-addon-api/test/typedarray-bigint.js +0 -58
  254. package/vendor/node-addon-api/test/typedarray.cc +0 -216
  255. package/vendor/node-addon-api/test/typedarray.js +0 -69
  256. package/vendor/node-addon-api/test/version_management.cc +0 -27
  257. package/vendor/node-addon-api/test/version_management.js +0 -31
  258. package/vendor/node-addon-api/unit-test/README.md +0 -28
  259. package/vendor/node-addon-api/unit-test/binding-file-template.js +0 -39
  260. package/vendor/node-addon-api/unit-test/binding.gyp +0 -72
  261. package/vendor/node-addon-api/unit-test/exceptions.js +0 -32
  262. package/vendor/node-addon-api/unit-test/generate-binding-cc.js +0 -61
  263. package/vendor/node-addon-api/unit-test/injectTestParams.js +0 -101
  264. package/vendor/node-addon-api/unit-test/listOfTestModules.js +0 -88
  265. package/vendor/node-addon-api/unit-test/matchModules.js +0 -65
  266. package/vendor/node-addon-api/unit-test/setup.js +0 -13
  267. package/vendor/node-addon-api/unit-test/spawnTask.js +0 -26
  268. package/vendor/node-addon-api/unit-test/test.js +0 -30
@@ -1,286 +0,0 @@
1
- # Property Descriptor
2
-
3
- A [`Napi::Object`](object.md) can be assigned properties via its [`DefineProperty`](object.md#defineproperty) and [`DefineProperties`](object.md#defineproperties) functions, which take PropertyDescriptor(s) as their parameters. The `Napi::PropertyDescriptor` can contain either values or functions, which are then assigned to the `Napi::Object`. Note that a single instance of a `Napi::PropertyDescriptor` class can only contain either one value, or at most two functions. PropertyDescriptors can only be created through the class methods [`Accessor`](#accessor), [`Function`](#function), or [`Value`](#value), each of which return a new static instance of a `Napi::PropertyDescriptor`.
4
-
5
- ## Example
6
-
7
- ```cpp
8
- #include <napi.h>
9
-
10
- using namespace Napi;
11
-
12
- Value TestGetter(const CallbackInfo& info) {
13
- return Boolean::New(info.Env(), testValue);
14
- }
15
-
16
- void TestSetter(const CallbackInfo& info) {
17
- testValue = info[0].As<Boolean>();
18
- }
19
-
20
- Value TestFunction(const CallbackInfo& info) {
21
- return Boolean::New(info.Env(), true);
22
- }
23
-
24
- Void Init(Env env) {
25
- // Create an object.
26
- Object obj = Object::New(env);
27
-
28
- // Accessor
29
- PropertyDescriptor pd1 = PropertyDescriptor::Accessor<TestGetter>("pd1");
30
- PropertyDescriptor pd2 =
31
- PropertyDescriptor::Accessor<TestGetter, TestSetter>("pd2");
32
- // Function
33
- PropertyDescriptor pd3 = PropertyDescriptor::Function(env,
34
- "function",
35
- TestFunction);
36
- // Value
37
- Boolean true_bool = Boolean::New(env, true);
38
- PropertyDescriptor pd4 =
39
- PropertyDescriptor::Value("boolean value",
40
- Napi::Boolean::New(env, true),
41
- napi_writable);
42
-
43
- // Assign properties to the object.
44
- obj.DefineProperties({pd1, pd2, pd3, pd4});
45
- }
46
- ```
47
-
48
- ## Types
49
-
50
- ### PropertyDescriptor::GetterCallback
51
-
52
- ```cpp
53
- using GetterCallback = Napi::Value (*)(const Napi::CallbackInfo& info);
54
- ```
55
-
56
- This is the signature of a getter function to be passed as a template parameter
57
- to `PropertyDescriptor::Accessor`.
58
-
59
- ### PropertyDescriptor::SetterCallback
60
-
61
- ```cpp
62
- using SetterCallback = void (*)(const Napi::CallbackInfo& info);
63
- ```
64
-
65
- This is the signature of a setter function to be passed as a template parameter
66
- to `PropertyDescriptor::Accessor`.
67
-
68
- ## Methods
69
-
70
- ### Constructor
71
-
72
- ```cpp
73
- Napi::PropertyDescriptor::PropertyDescriptor (napi_property_descriptor desc);
74
- ```
75
-
76
- * `[in] desc`: A PropertyDescriptor that is needed in order to create another PropertyDescriptor.
77
-
78
- ### Accessor
79
-
80
- ```cpp
81
- template <Napi::PropertyDescriptor::GetterCallback Getter>
82
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name,
83
- napi_property_attributes attributes = napi_default,
84
- void* data = nullptr);
85
- ```
86
-
87
- * `[template] Getter`: A getter function.
88
- * `[in] attributes`: Potential attributes for the getter function.
89
- * `[in] data`: A pointer to data of any type, default is a null pointer.
90
-
91
- Returns a PropertyDescriptor that contains a read-only property.
92
-
93
- The name of the property can be any of the following types:
94
- - `const char*`
95
- - `const std::string &`
96
- - `napi_value value`
97
- - `Napi::Name`
98
-
99
- ```cpp
100
- template <
101
- Napi::PropertyDescriptor::GetterCallback Getter,
102
- Napi::PropertyDescriptor::SetterCallback Setter>
103
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name,
104
- napi_property_attributes attributes = napi_default,
105
- void* data = nullptr);
106
- ```
107
-
108
- * `[template] Getter`: A getter function.
109
- * `[template] Setter`: A setter function.
110
- * `[in] attributes`: Potential attributes for the getter function.
111
- * `[in] data`: A pointer to data of any type, default is a null pointer.
112
-
113
- Returns a PropertyDescriptor that contains a read-write property.
114
-
115
- The name of the property can be any of the following types:
116
- - `const char*`
117
- - `const std::string &`
118
- - `napi_value value`
119
- - `Napi::Name`
120
-
121
- ```cpp
122
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name,
123
- Getter getter,
124
- napi_property_attributes attributes = napi_default,
125
- void *data = nullptr);
126
- ```
127
-
128
- * `[in] name`: The name used for the getter function.
129
- * `[in] getter`: A getter function.
130
- * `[in] attributes`: Potential attributes for the getter function.
131
- * `[in] data`: A pointer to data of any type, default is a null pointer.
132
-
133
- Returns a PropertyDescriptor that contains a function.
134
-
135
- The name of the property can be any of the following types:
136
- - `const char*`
137
- - `const std::string &`
138
- - `napi_value value`
139
- - `Napi::Name`
140
-
141
- **The above signature is deprecated. It will result in a memory leak if used.**
142
-
143
- ```cpp
144
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (
145
- Napi::Env env,
146
- Napi::Object object,
147
- ___ name,
148
- Getter getter,
149
- napi_property_attributes attributes = napi_default,
150
- void *data = nullptr);
151
- ```
152
-
153
- * `[in] env`: The environment in which to create this accessor.
154
- * `[in] object`: The object on which the accessor will be defined.
155
- * `[in] name`: The name used for the getter function.
156
- * `[in] getter`: A getter function.
157
- * `[in] attributes`: Potential attributes for the getter function.
158
- * `[in] data`: A pointer to data of any type, default is a null pointer.
159
-
160
- Returns a `Napi::PropertyDescriptor` that contains a `Getter` accessor.
161
-
162
- The name of the property can be any of the following types:
163
- - `const char*`
164
- - `const std::string &`
165
- - `Napi::Name`
166
-
167
- ```cpp
168
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name,
169
- Getter getter,
170
- Setter setter,
171
- napi_property_attributes attributes = napi_default,
172
- void *data = nullptr);
173
- ```
174
-
175
- * `[in] name`: The name of the getter and setter function.
176
- * `[in] getter`: The getter function.
177
- * `[in] setter`: The setter function.
178
- * `[in] attributes`: Potential attributes for the getter function.
179
- * `[in] data`: A pointer to data of any type, default is a null pointer.
180
-
181
- Returns a `Napi::PropertyDescriptor` that contains a `Getter` and `Setter` function.
182
-
183
- The name of the property can be any of the following types:
184
- - `const char*`
185
- - `const std::string &`
186
- - `napi_value value`
187
- - `Napi::Name`
188
-
189
- **The above signature is deprecated. It will result in a memory leak if used.**
190
-
191
- ```cpp
192
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (
193
- Napi::Env env,
194
- Napi::Object object,
195
- ___ name,
196
- Getter getter,
197
- Setter setter,
198
- napi_property_attributes attributes = napi_default,
199
- void *data = nullptr);
200
- ```
201
-
202
- * `[in] env`: The environment in which to create this accessor.
203
- * `[in] object`: The object on which the accessor will be defined.
204
- * `[in] name`: The name of the getter and setter function.
205
- * `[in] getter`: The getter function.
206
- * `[in] setter`: The setter function.
207
- * `[in] attributes`: Potential attributes for the getter function.
208
- * `[in] data`: A pointer to data of any type, default is a null pointer.
209
-
210
- Returns a `Napi::PropertyDescriptor` that contains a `Getter` and `Setter` function.
211
-
212
- The name of the property can be any of the following types:
213
- - `const char*`
214
- - `const std::string &`
215
- - `Napi::Name`
216
-
217
- ### Function
218
-
219
- ```cpp
220
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Function (___ name,
221
- Callable cb,
222
- napi_property_attributes attributes = napi_default,
223
- void *data = nullptr);
224
- ```
225
-
226
- * `[in] name`: The name of the Callable function.
227
- * `[in] cb`: The function
228
- * `[in] attributes`: Potential attributes for the getter function.
229
- * `[in] data`: A pointer to data of any type, default is a null pointer.
230
-
231
- Returns a `Napi::PropertyDescriptor` that contains a callable `Napi::Function`.
232
-
233
- The name of the property can be any of the following types:
234
- - `const char*`
235
- - `const std::string &`
236
- - `napi_value value`
237
- - `Napi::Name`
238
-
239
- **The above signature is deprecated. It will result in a memory leak if used.**
240
-
241
- ```cpp
242
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Function (
243
- Napi::Env env,
244
- ___ name,
245
- Callable cb,
246
- napi_property_attributes attributes = napi_default,
247
- void *data = nullptr);
248
- ```
249
-
250
- * `[in] env`: The environment in which to create this accessor.
251
- * `[in] name`: The name of the Callable function.
252
- * `[in] cb`: The function
253
- * `[in] attributes`: Potential attributes for the getter function.
254
- * `[in] data`: A pointer to data of any type, default is a null pointer.
255
-
256
- Returns a `Napi::PropertyDescriptor` that contains a callable `Napi::Function`.
257
-
258
- The name of the property can be any of the following types:
259
- - `const char*`
260
- - `const std::string &`
261
- - `Napi::Name`
262
-
263
- ### Value
264
-
265
- ```cpp
266
- static Napi::PropertyDescriptor Napi::PropertyDescriptor::Value (___ name,
267
- napi_value value,
268
- napi_property_attributes attributes = napi_default);
269
- ```
270
-
271
- The name of the property can be any of the following types:
272
- - `const char*`
273
- - `const std::string &`
274
- - `napi_value value`
275
- - `Napi::Name`
276
-
277
- ## Related Information
278
-
279
- ### napi\_property\_attributes
280
- `napi_property_attributes` are flags used to indicate to JavaScript certain permissions that the property is meant to have. The following are the flag options:
281
- - napi\_default,
282
- - napi\_writable,
283
- - napi\_enumerable,
284
- - napi\_configurable
285
- For more information on the flags and on napi\_property\_attributes, please read the documentation [here](https://github.com/nodejs/node/blob/HEAD/doc/api/n-api.md#napi_property_attributes).
286
-
@@ -1,50 +0,0 @@
1
- # PropertyLValue
2
-
3
- The `Napi::Object::PropertyLValue` class is a helper class provided by
4
- `Napi::Object` to allow more intuitive assignment of properties.
5
-
6
- ## Example
7
- ```cpp
8
- #include <napi.h>
9
-
10
- using namespace Napi;
11
-
12
- Void Init(Env env) {
13
- // Create a new instance
14
- Object obj = Object::New(env);
15
-
16
- // Assign a value to a property.
17
- obj["hello"] = "world";
18
- }
19
- ```
20
-
21
- In the above example, `obj["hello"]` returns a `Napi::Object::PropertyLValue`
22
- whose `operator=()` method accepts a string which will become the value of the
23
- "hello" property of the newly created object.
24
-
25
- In general, `obj[key] = value` is the equivalent of `obj.Set(key, value)`, where
26
- the types of `key` and `value` are all those supported by
27
- [`Napi::Object::Set()`](object.md#set).
28
-
29
- ## Methods
30
-
31
- ### operator Value()
32
-
33
- ```cpp
34
- operator Value() const;
35
- ```
36
-
37
- Implicitly casts this `Napi::Object::PropertyLValue` to a `Napi::Value`.
38
-
39
- ### operator =()
40
-
41
- ```cpp
42
- template <typename ValueType>
43
- PropertyLValue& operator =(ValueType value);
44
- ```
45
-
46
- * `[in] value` a value to assign to the property referred to by the
47
- `Napi::Object::PropertyLValue`. The type of the value is one of the types
48
- supported by the second parameter of [`Napi::Object::Set()`](object.md#set).
49
-
50
- Returns a self-reference.
@@ -1,59 +0,0 @@
1
- # RangeError
2
-
3
- The `Napi::RangeError` class is a representation of the JavaScript `RangeError` that is
4
- thrown when trying to pass a value as an argument to a function that does not allow
5
- a range that includes the value.
6
-
7
- The `Napi::RangeError` class inherits its behaviors from the `Napi::Error` class (for
8
- more info see: [`Napi::Error`](error.md)).
9
-
10
- For more details about error handling refer to the section titled [Error handling](error_handling.md).
11
-
12
- ## Methods
13
-
14
- ### New
15
-
16
- Creates a new instance of a `Napi::RangeError` object.
17
-
18
- ```cpp
19
- Napi::RangeError::New(Napi::Env env, const char* message);
20
- ```
21
-
22
- - `[in] Env`: The environment in which to construct the `Napi::RangeError` object.
23
- - `[in] message`: Null-terminated string to be used as the message for the `Napi::RangeError`.
24
-
25
- Returns an instance of a `Napi::RangeError` object.
26
-
27
- ### New
28
-
29
- Creates a new instance of a `Napi::RangeError` object.
30
-
31
- ```cpp
32
- Napi::RangeError::New(Napi::Env env, const std::string& message);
33
- ```
34
-
35
- - `[in] Env`: The environment in which to construct the `Napi::RangeError` object.
36
- - `[in] message`: Reference string to be used as the message for the `Napi::RangeError`.
37
-
38
- Returns an instance of a `Napi::RangeError` object.
39
-
40
- ### Constructor
41
-
42
- Creates a new empty instance of a `Napi::RangeError`.
43
-
44
- ```cpp
45
- Napi::RangeError::RangeError();
46
- ```
47
-
48
- ### Constructor
49
-
50
- Initializes a `Napi::RangeError` instance from an existing Javascript error object.
51
-
52
- ```cpp
53
- Napi::RangeError::RangeError(napi_env env, napi_value value);
54
- ```
55
-
56
- - `[in] Env`: The environment in which to construct the `Napi::RangeError` object.
57
- - `[in] value`: The `Napi::Error` reference to wrap.
58
-
59
- Returns an instance of a `Napi::RangeError` object.
@@ -1,113 +0,0 @@
1
- # Reference (template)
2
-
3
- Holds a counted reference to a [`Napi::Value`](value.md) object; initially a weak reference unless otherwise specified, may be changed to/from a strong reference by adjusting the refcount.
4
-
5
- The referenced `Napi::Value` is not immediately destroyed when the reference count is zero; it is merely then eligible for garbage-collection if there are no other references to the `Napi::Value`.
6
-
7
- `Napi::Reference` objects allocated in static space, such as a global static instance, must call the `SuppressDestruct` method to prevent its destructor, running at program shutdown time, from attempting to reset the reference when the environment is no longer valid. Avoid using this if at all possible.
8
-
9
- The following classes inherit, either directly or indirectly, from `Napi::Reference`:
10
-
11
- * [`Napi::ObjectWrap`](object_wrap.md)
12
- * [`Napi::ObjectReference`](object_reference.md)
13
- * [`Napi::FunctionReference`](function_reference.md)
14
-
15
- ## Methods
16
-
17
- ### Factory Method
18
-
19
- ```cpp
20
- static Napi::Reference<T> Napi::Reference::New(const T& value, uint32_t initialRefcount = 0);
21
- ```
22
-
23
- * `[in] value`: The value which is to be referenced.
24
-
25
- * `[in] initialRefcount`: The initial reference count.
26
-
27
- ### Empty Constructor
28
-
29
- ```cpp
30
- Napi::Reference::Reference();
31
- ```
32
-
33
- Creates a new _empty_ `Napi::Reference` instance.
34
-
35
- ### Constructor
36
-
37
- ```cpp
38
- Napi::Reference::Reference(napi_env env, napi_value value);
39
- ```
40
-
41
- * `[in] env`: The `napi_env` environment in which to construct the `Napi::Reference` object.
42
-
43
- * `[in] value`: The Node-API primitive value to be held by the `Napi::Reference`.
44
-
45
- ### Env
46
-
47
- ```cpp
48
- Napi::Env Napi::Reference::Env() const;
49
- ```
50
-
51
- Returns the `Napi::Env` value in which the `Napi::Reference` was instantiated.
52
-
53
- ### IsEmpty
54
-
55
- ```cpp
56
- bool Napi::Reference::IsEmpty() const;
57
- ```
58
-
59
- Determines whether the value held by the `Napi::Reference` is empty.
60
-
61
- ### Value
62
-
63
- ```cpp
64
- T Napi::Reference::Value() const;
65
- ```
66
-
67
- Returns the value held by the `Napi::Reference`.
68
-
69
- ### Ref
70
-
71
- ```cpp
72
- uint32_t Napi::Reference::Ref() const;
73
- ```
74
-
75
- Increments the reference count for the `Napi::Reference` and returns the resulting reference count. Throws an error if the increment fails.
76
-
77
- ### Unref
78
-
79
- ```cpp
80
- uint32_t Napi::Reference::Unref() const;
81
- ```
82
-
83
- Decrements the reference count for the `Napi::Reference` and returns the resulting reference count. Throws an error if the decrement fails.
84
-
85
- ### Reset (Empty)
86
-
87
- ```cpp
88
- void Napi::Reference::Reset();
89
- ```
90
-
91
- Sets the value held by the `Napi::Reference` to be empty.
92
-
93
- ### Reset
94
-
95
- ```cpp
96
- void Napi::Reference::Reset(const T& value, uint32_t refcount = 0);
97
- ```
98
-
99
- * `[in] value`: The value which is to be referenced.
100
-
101
- * `[in] initialRefcount`: The initial reference count.
102
-
103
- Sets the value held by the `Napi::Reference`.
104
-
105
- ### SuppressDestruct
106
-
107
- ```cpp
108
- void Napi::Reference::SuppressDestruct();
109
- ```
110
-
111
- Call this method on a `Napi::Reference` that is declared as static data to prevent its destructor, running at program shutdown time, from attempting to reset the reference when the environment is no longer valid.
112
-
113
- Avoid using this if at all possible. If you do need to use static data, **MAKE SURE** to warn your users that your addon is **NOT** threadsafe.
@@ -1,110 +0,0 @@
1
- # Setup
2
-
3
- ## Prerequisites
4
-
5
- Before starting to use **Node-API** you need to assure you have the following
6
- prerequisites:
7
-
8
- * **Node.JS** see: [Installing Node.js](https://nodejs.org/)
9
-
10
- * **Node.js native addon build tool**
11
-
12
- - **[node-gyp](node-gyp.md)**
13
-
14
- ## Installation and usage
15
-
16
- To use **Node-API** in a native module:
17
-
18
- 1. Add a dependency on this package to `package.json`:
19
-
20
- ```json
21
- "dependencies": {
22
- "node-addon-api": "*",
23
- }
24
- ```
25
-
26
- 2. Reference this package's include directory and gyp file in `binding.gyp`:
27
-
28
- ```gyp
29
- 'include_dirs': ["<!(node -p \"require('node-addon-api').include_dir\")"],
30
- ```
31
-
32
- 3. Decide whether the package will enable C++ exceptions in the Node-API wrapper.
33
- The base ABI-stable C APIs do not throw or handle C++ exceptions, but the
34
- Node-API C++ wrapper classes may _optionally_
35
- [integrate C++ and JavaScript exception-handling
36
- ](https://github.com/nodejs/node-addon-api/blob/HEAD/doc/error_handling.md).
37
- To enable that capability, C++ exceptions must be enabled in `binding.gyp`:
38
-
39
- ```gyp
40
- 'cflags!': [ '-fno-exceptions' ],
41
- 'cflags_cc!': [ '-fno-exceptions' ],
42
- 'conditions': [
43
- ["OS=='win'", {
44
- "defines": [
45
- "_HAS_EXCEPTIONS=1"
46
- ],
47
- "msvs_settings": {
48
- "VCCLCompilerTool": {
49
- "ExceptionHandling": 1
50
- },
51
- },
52
- }],
53
- ["OS=='mac'", {
54
- 'xcode_settings': {
55
- 'GCC_ENABLE_CPP_EXCEPTIONS': 'YES',
56
- 'CLANG_CXX_LIBRARY': 'libc++',
57
- 'MACOSX_DEPLOYMENT_TARGET': '10.7',
58
- },
59
- }],
60
- ],
61
- ```
62
-
63
- Alternatively, disable use of C++ exceptions in Node-API:
64
-
65
- ```gyp
66
- 'defines': [ 'NAPI_DISABLE_CPP_EXCEPTIONS' ],
67
- ```
68
-
69
- If you decide to use node-addon-api without C++ exceptions enabled, please
70
- consider enabling node-addon-api safe API type guards to ensure the proper
71
- exception handling pattern:
72
-
73
- ```gyp
74
- 'defines': [ 'NODE_ADDON_API_ENABLE_MAYBE' ],
75
- ```
76
-
77
- 4. If you would like your native addon to support OSX, please also add the
78
- following settings in the `binding.gyp` file:
79
-
80
- ```gyp
81
- 'conditions': [
82
- ['OS=="mac"', {
83
- 'cflags+': ['-fvisibility=hidden'],
84
- 'xcode_settings': {
85
- 'GCC_SYMBOLS_PRIVATE_EXTERN': 'YES', # -fvisibility=hidden
86
- }
87
- }]
88
- ]
89
- ```
90
-
91
- 5. Include `napi.h` in the native module code.
92
- To ensure only ABI-stable APIs are used, DO NOT include
93
- `node.h`, `nan.h`, or `v8.h`.
94
-
95
- ```C++
96
- #include "napi.h"
97
- ```
98
-
99
- At build time, the Node-API back-compat library code will be used only when the
100
- targeted node version *does not* have Node-API built-in.
101
-
102
- The preprocessor directive `NODE_ADDON_API_DISABLE_DEPRECATED` can be defined at
103
- compile time before including `napi.h` to skip the definition of deprecated APIs.
104
-
105
- By default, throwing an exception on a terminating environment (eg. worker
106
- threads) will cause a fatal exception, terminating the Node process. This is to
107
- provide feedback to the user of the runtime error, as it is impossible to pass
108
- the error to JavaScript when the environment is terminating. In order to bypass
109
- this behavior such that the Node process will not terminate, define the
110
- preprocessor directive `NODE_API_SWALLOW_UNTHROWABLE_EXCEPTIONS`.