koffi 1.0.5 → 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 (268) hide show
  1. package/README.md +46 -21
  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 +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.5/koffi_darwin_x64.tar.gz +0 -0
  26. package/build/qemu/1.0.5/koffi_freebsd_arm64.tar.gz +0 -0
  27. package/build/qemu/1.0.5/koffi_freebsd_ia32.tar.gz +0 -0
  28. package/build/qemu/1.0.5/koffi_freebsd_x64.tar.gz +0 -0
  29. package/build/qemu/1.0.5/koffi_linux_arm.tar.gz +0 -0
  30. package/build/qemu/1.0.5/koffi_linux_arm64.tar.gz +0 -0
  31. package/build/qemu/1.0.5/koffi_linux_ia32.tar.gz +0 -0
  32. package/build/qemu/1.0.5/koffi_linux_x64.tar.gz +0 -0
  33. package/build/qemu/1.0.5/koffi_win32_ia32.tar.gz +0 -0
  34. package/build/qemu/1.0.5/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,340 +0,0 @@
1
- # Value
2
-
3
- `Napi::Value` is the C++ manifestation of a JavaScript value. It is the base
4
- class upon which other JavaScript values such as `Napi::Number`,
5
- `Napi::Boolean`, `Napi::String`, and `Napi::Object` are based. It represents a
6
- JavaScript value of an unknown type. It is a thin wrapper around the Node-API
7
- datatype `napi_value`. Methods on this class can be used to check the JavaScript
8
- type of the underlying Node-API `napi_value` and also to convert to C++ types.
9
-
10
- ## Constructors
11
-
12
- ### Empty Constructor
13
-
14
- ```cpp
15
- Napi::Value::Value();
16
- ```
17
-
18
- Creates a new *empty* `Napi::Value` instance.
19
-
20
- ### Constructor
21
-
22
- ```cpp
23
- Napi::Value::Value(napi_env env, napi_value value);
24
- ```
25
-
26
- - `[in] env`: The `napi_env` environment in which to construct the `Napi::Value`
27
- object.
28
- - `[in] value`: The C++ primitive from which to instantiate the `Napi::Value`.
29
- value` may be any of:
30
- - `bool`
31
- - Any integer type
32
- - Any floating point type
33
- - `const char*` (encoded using UTF-8, null-terminated)
34
- - `const char16_t*` (encoded using UTF-16-LE, null-terminated)
35
- - `std::string` (encoded using UTF-8)
36
- - `std::u16string`
37
- - `Napi::Value`
38
- - `napi_value`
39
-
40
- ## Operators
41
-
42
- ### operator napi_value
43
-
44
- ```cpp
45
- Napi::Value::operator napi_value() const;
46
- ```
47
-
48
- Returns the underlying Node-API `napi_value`. If the instance is _empty_, this
49
- returns `nullptr`.
50
-
51
- ### operator ==
52
-
53
- ```cpp
54
- bool Napi::Value::operator ==(const Napi::Value& other) const;
55
- ```
56
-
57
- Returns `true` if this value strictly equals another value, or `false`
58
- otherwise.
59
-
60
- ### operator !=
61
-
62
- ```cpp
63
- bool Napi::Value::operator !=(const Napi::Value& other) const;
64
- ```
65
-
66
- Returns `false` if this value strictly equals another value, or `true`
67
- otherwise.
68
-
69
- ## Methods
70
-
71
- ### As
72
-
73
- ```cpp
74
- template <typename T> T Napi::Value::As() const;
75
- ```
76
-
77
- Casts to another type of `Napi::Value`, when the actual type is known or
78
- assumed.
79
-
80
- This conversion does not coerce the type. Calling any methods inappropriate for
81
- the actual value type will throw `Napi::Error`.
82
-
83
- ### Env
84
-
85
- ```cpp
86
- Napi::Env Napi::Value::Env() const;
87
- ```
88
-
89
- Returns the `Napi::Env` environment this value is associated with. See
90
- [`Napi::Env`](env.md) for more details about environments.
91
-
92
- ### From
93
-
94
- ```cpp
95
- template <typename T>
96
- static Napi::Value Napi::Value::From(napi_env env, const T& value);
97
- ```
98
-
99
- - `[in] env`: The `napi_env` environment in which to create the `Napi::Value`
100
- object.
101
- - `[in] value`: The Node-API primitive value from which to create the `Napi::Value`
102
- object.
103
-
104
- Returns a `Napi::Value` object from an Node-API primitive value.
105
-
106
- This method is used to convert from a C++ type to a JavaScript value.
107
- Here, `value` may be any of:
108
- - `bool` - returns a `Napi::Boolean`.
109
- - Any integer type - returns a `Napi::Number`.
110
- - Any floating point type - returns a `Napi::Number`.
111
- - `const char*` (encoded using UTF-8, null-terminated) - returns a
112
- `Napi::String`.
113
- - `const char16_t*` (encoded using UTF-16-LE, null-terminated) - returns a
114
- `Napi::String`.
115
- - `std::string` (encoded using UTF-8) - returns a `Napi::String`.
116
- - `std::u16string` - returns a `Napi::String`.
117
- - `Napi::Value` - returns a `Napi::Value`.
118
- - `Napi_value` - returns a `Napi::Value`.
119
-
120
- ### IsArray
121
-
122
- ```cpp
123
- bool Napi::Value::IsArray() const;
124
- ```
125
-
126
- Returns `true` if the underlying value is a JavaScript `Napi::Array` or `false`
127
- otherwise.
128
-
129
- ### IsArrayBuffer
130
-
131
- ```cpp
132
- bool Napi::Value::IsArrayBuffer() const;
133
- ```
134
-
135
- Returns `true` if the underlying value is a JavaScript `Napi::ArrayBuffer` or
136
- `false` otherwise.
137
-
138
- ### IsBoolean
139
-
140
- ```cpp
141
- bool Napi::Value::IsBoolean() const;
142
- ```
143
-
144
- Returns `true` if the underlying value is a JavaScript `true` or JavaScript
145
- `false`, or `false` if the value is not a `Napi::Boolean` value in JavaScript.
146
-
147
- ### IsBuffer
148
-
149
- ```cpp
150
- bool Napi::Value::IsBuffer() const;
151
- ```
152
-
153
- Returns `true` if the underlying value is a Node.js `Napi::Buffer` or `false`
154
- otherwise.
155
-
156
- ### IsDataView
157
- ```cpp
158
- bool Napi::Value::IsDataView() const;
159
- ```
160
-
161
- Returns `true` if the underlying value is a JavaScript `Napi::DataView` or
162
- `false` otherwise.
163
-
164
- ### IsDate
165
-
166
- ```cpp
167
- bool Napi::Value::IsDate() const;
168
- ```
169
-
170
- Returns `true` if the underlying value is a JavaScript `Date` or `false`
171
- otherwise.
172
-
173
- ### IsEmpty
174
-
175
- ```cpp
176
- bool Napi::Value::IsEmpty() const;
177
- ```
178
-
179
- Returns `true` if the value is uninitialized.
180
-
181
- An empty `Napi::Value` is invalid, and most attempts to perform an operation on
182
- an empty `Napi::Value` will result in an exception. An empty `Napi::Value` is
183
- distinct from JavaScript `null` or `undefined`, which are valid values.
184
-
185
- When C++ exceptions are disabled at compile time, a method with a `Napi::Value`
186
- return type may return an empty `Napi::Value` to indicate a pending exception.
187
- Thus, when C++ exceptions are not being used, callers should check the result of
188
- `Env::IsExceptionPending` before attempting to use the value.
189
-
190
- ### IsExternal
191
- ```cpp
192
- bool Napi::Value::IsExternal() const;
193
- ```
194
-
195
- Returns `true` if the underlying value is a Node-API external object or `false`
196
- otherwise.
197
-
198
- ### IsFunction
199
-
200
- ```cpp
201
- bool Napi::Value::IsFunction() const;
202
- ```
203
-
204
- Returns `true` if the underlying value is a JavaScript `Napi::Function` or
205
- `false` otherwise.
206
-
207
- ### IsNull
208
-
209
- ```cpp
210
- bool Napi::Value::IsNull() const;
211
- ```
212
-
213
- Returns `true` if the underlying value is a JavaScript `null` or `false`
214
- otherwise.
215
-
216
- ### IsNumber
217
-
218
- ```cpp
219
- bool Napi::Value::IsNumber() const;
220
- ```
221
-
222
- Returns `true` if the underlying value is a JavaScript `Napi::Number` or `false`
223
- otherwise.
224
-
225
- ### IsObject
226
-
227
- ```cpp
228
- bool Napi::Value::IsObject() const;
229
- ```
230
-
231
- Returns `true` if the underlying value is a JavaScript `Napi::Object` or `false`
232
- otherwise.
233
-
234
- ### IsPromise
235
-
236
- ```cpp
237
- bool Napi::Value::IsPromise() const;
238
- ```
239
-
240
- Returns `true` if the underlying value is a JavaScript `Napi::Promise` or
241
- `false` otherwise.
242
-
243
- ### IsString
244
-
245
- ```cpp
246
- bool Napi::Value::IsString() const;
247
- ```
248
-
249
- Returns `true` if the underlying value is a JavaScript `Napi::String` or `false`
250
- otherwise.
251
-
252
- ### IsSymbol
253
-
254
- ```cpp
255
- bool Napi::Value::IsSymbol() const;
256
- ```
257
-
258
- Returns `true` if the underlying value is a JavaScript `Napi::Symbol` or `false`
259
- otherwise.
260
-
261
- ### IsTypedArray
262
-
263
- ```cpp
264
- bool Napi::Value::IsTypedArray() const;
265
- ```
266
-
267
- Returns `true` if the underlying value is a JavaScript `Napi::TypedArray` or
268
- `false` otherwise.
269
-
270
- ### IsUndefined
271
-
272
- ```cpp
273
- bool Napi::Value::IsUndefined() const;
274
- ```
275
-
276
- Returns `true` if the underlying value is a JavaScript `undefined` or `false`
277
- otherwise.
278
-
279
- ### StrictEquals
280
-
281
- ```cpp
282
- bool Napi::Value::StrictEquals(const Napi::Value& other) const;
283
- ```
284
- - `[in] other`: The `Napi::Value` object to be compared.
285
-
286
- Returns a `bool` indicating if this `Napi::Value` strictly equals another
287
- `Napi::Value`.
288
-
289
- ### ToBoolean
290
-
291
- ```cpp
292
- Napi::Boolean Napi::Value::ToBoolean() const;
293
- ```
294
-
295
- Returns a `Napi::Boolean` representing the `Napi::Value`.
296
-
297
- This is a wrapper around `napi_coerce_to_boolean`. This will throw a JavaScript
298
- exception if the coercion fails. If C++ exceptions are not being used, callers
299
- should check the result of `Env::IsExceptionPending` before attempting to use
300
- the returned value.
301
-
302
- ### ToNumber
303
-
304
- ```cpp
305
- Napi::Number Napi::Value::ToNumber() const;
306
- ```
307
-
308
- Returns the `Napi::Value` coerced to a JavaScript number.
309
-
310
- ### ToObject
311
-
312
- ```cpp
313
- Napi::Object Napi::Value::ToObject() const;
314
- ```
315
-
316
- Returns the `Napi::Value` coerced to a JavaScript object.
317
-
318
- ### ToString
319
-
320
- ```cpp
321
- Napi::String Napi::Value::ToString() const;
322
- ```
323
-
324
- Returns the `Napi::Value` coerced to a JavaScript string.
325
-
326
- ### Type
327
-
328
- ```cpp
329
- napi_valuetype Napi::Value::Type() const;
330
- ```
331
-
332
- Returns the `napi_valuetype` type of the `Napi::Value`.
333
-
334
- [`Napi::Boolean`]: ./boolean.md
335
- [`Napi::BigInt`]: ./bigint.md
336
- [`Napi::Date`]: ./date.md
337
- [`Napi::External`]: ./external.md
338
- [`Napi::Name`]: ./name.md
339
- [`Napi::Number`]: ./number.md
340
- [`Napi::Object`]: ./object.md
@@ -1,43 +0,0 @@
1
- # VersionManagement
2
-
3
- The `Napi::VersionManagement` class contains methods that allow information
4
- to be retrieved about the version of Node-API and Node.js. In some cases it is
5
- important to make decisions based on different versions of the system.
6
-
7
- ## Methods
8
-
9
- ### GetNapiVersion
10
-
11
- Retrieves the highest Node-API version supported by Node.js runtime.
12
-
13
- ```cpp
14
- static uint32_t Napi::VersionManagement::GetNapiVersion(Env env);
15
- ```
16
-
17
- - `[in] env`: The environment in which the API is invoked under.
18
-
19
- Returns the highest Node-API version supported by Node.js runtime.
20
-
21
- ### GetNodeVersion
22
-
23
- Retrieves information about Node.js version present on the system. All the
24
- information is stored in the `napi_node_version` structure that is defined as
25
- shown below:
26
-
27
- ```cpp
28
- typedef struct {
29
- uint32_t major;
30
- uint32_t minor;
31
- uint32_t patch;
32
- const char* release;
33
- } napi_node_version;
34
- ````
35
-
36
- ```cpp
37
- static const napi_node_version* Napi::VersionManagement::GetNodeVersion(Env env);
38
- ```
39
-
40
- - `[in] env`: The environment in which the API is invoked under.
41
-
42
- Returns the structure a pointer to the structure `napi_node_version` populated by
43
- the version information of Node.js runtime.