• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef SRC_JS_NATIVE_API_H_
2 #define SRC_JS_NATIVE_API_H_
3 
4 // This file needs to be compatible with C compilers.
5 #include <stddef.h>   // NOLINT(modernize-deprecated-headers)
6 #include <stdbool.h>  // NOLINT(modernize-deprecated-headers)
7 
8 // Use INT_MAX, this should only be consumed by the pre-processor anyway.
9 #define NAPI_VERSION_EXPERIMENTAL 2147483647
10 #ifndef NAPI_VERSION
11 #ifdef NAPI_EXPERIMENTAL
12 #define NAPI_VERSION NAPI_VERSION_EXPERIMENTAL
13 #else
14 // The baseline version for N-API.
15 // The NAPI_VERSION controls which version will be used by default when
16 // compilling a native addon. If the addon developer specifically wants to use
17 // functions available in a new version of N-API that is not yet ported in all
18 // LTS versions, they can set NAPI_VERSION knowing that they have specifically
19 // depended on that version.
20 #define NAPI_VERSION 7
21 #endif
22 #endif
23 
24 #include "js_native_api_types.h"
25 
26 // If you need __declspec(dllimport), either include <node_api.h> instead, or
27 // define NAPI_EXTERN as __declspec(dllimport) on the compiler's command line.
28 #ifndef NAPI_EXTERN
29   #ifdef _WIN32
30     #define NAPI_EXTERN __declspec(dllexport)
31   #elif defined(__wasm32__)
32     #define NAPI_EXTERN __attribute__((visibility("default")))                \
33                         __attribute__((__import_module__("napi")))
34   #else
35     #define NAPI_EXTERN __attribute__((visibility("default")))
36   #endif
37 #endif
38 
39 #define NAPI_AUTO_LENGTH SIZE_MAX
40 
41 #ifdef __cplusplus
42 #define EXTERN_C_START extern "C" {
43 #define EXTERN_C_END }
44 #else
45 #define EXTERN_C_START
46 #define EXTERN_C_END
47 #endif
48 
49 EXTERN_C_START
50 
51 NAPI_EXTERN napi_status
52 napi_get_last_error_info(napi_env env,
53                          const napi_extended_error_info** result);
54 
55 // Getters for defined singletons
56 NAPI_EXTERN napi_status napi_get_undefined(napi_env env, napi_value* result);
57 NAPI_EXTERN napi_status napi_get_null(napi_env env, napi_value* result);
58 NAPI_EXTERN napi_status napi_get_global(napi_env env, napi_value* result);
59 NAPI_EXTERN napi_status napi_get_boolean(napi_env env,
60                                          bool value,
61                                          napi_value* result);
62 
63 // Methods to create Primitive types/Objects
64 NAPI_EXTERN napi_status napi_create_object(napi_env env, napi_value* result);
65 NAPI_EXTERN napi_status napi_create_array(napi_env env, napi_value* result);
66 NAPI_EXTERN napi_status napi_create_array_with_length(napi_env env,
67                                                       size_t length,
68                                                       napi_value* result);
69 NAPI_EXTERN napi_status napi_create_double(napi_env env,
70                                            double value,
71                                            napi_value* result);
72 NAPI_EXTERN napi_status napi_create_int32(napi_env env,
73                                           int32_t value,
74                                           napi_value* result);
75 NAPI_EXTERN napi_status napi_create_uint32(napi_env env,
76                                            uint32_t value,
77                                            napi_value* result);
78 NAPI_EXTERN napi_status napi_create_int64(napi_env env,
79                                           int64_t value,
80                                           napi_value* result);
81 NAPI_EXTERN napi_status napi_create_string_latin1(napi_env env,
82                                                   const char* str,
83                                                   size_t length,
84                                                   napi_value* result);
85 NAPI_EXTERN napi_status napi_create_string_utf8(napi_env env,
86                                                 const char* str,
87                                                 size_t length,
88                                                 napi_value* result);
89 NAPI_EXTERN napi_status napi_create_string_utf16(napi_env env,
90                                                  const char16_t* str,
91                                                  size_t length,
92                                                  napi_value* result);
93 NAPI_EXTERN napi_status napi_create_symbol(napi_env env,
94                                            napi_value description,
95                                            napi_value* result);
96 NAPI_EXTERN napi_status napi_create_function(napi_env env,
97                                              const char* utf8name,
98                                              size_t length,
99                                              napi_callback cb,
100                                              void* data,
101                                              napi_value* result);
102 NAPI_EXTERN napi_status napi_create_error(napi_env env,
103                                           napi_value code,
104                                           napi_value msg,
105                                           napi_value* result);
106 NAPI_EXTERN napi_status napi_create_type_error(napi_env env,
107                                                napi_value code,
108                                                napi_value msg,
109                                                napi_value* result);
110 NAPI_EXTERN napi_status napi_create_range_error(napi_env env,
111                                                 napi_value code,
112                                                 napi_value msg,
113                                                 napi_value* result);
114 
115 // Methods to get the native napi_value from Primitive type
116 NAPI_EXTERN napi_status napi_typeof(napi_env env,
117                                     napi_value value,
118                                     napi_valuetype* result);
119 NAPI_EXTERN napi_status napi_get_value_double(napi_env env,
120                                               napi_value value,
121                                               double* result);
122 NAPI_EXTERN napi_status napi_get_value_int32(napi_env env,
123                                              napi_value value,
124                                              int32_t* result);
125 NAPI_EXTERN napi_status napi_get_value_uint32(napi_env env,
126                                               napi_value value,
127                                               uint32_t* result);
128 NAPI_EXTERN napi_status napi_get_value_int64(napi_env env,
129                                              napi_value value,
130                                              int64_t* result);
131 NAPI_EXTERN napi_status napi_get_value_bool(napi_env env,
132                                             napi_value value,
133                                             bool* result);
134 
135 // Copies LATIN-1 encoded bytes from a string into a buffer.
136 NAPI_EXTERN napi_status napi_get_value_string_latin1(napi_env env,
137                                                      napi_value value,
138                                                      char* buf,
139                                                      size_t bufsize,
140                                                      size_t* result);
141 
142 // Copies UTF-8 encoded bytes from a string into a buffer.
143 NAPI_EXTERN napi_status napi_get_value_string_utf8(napi_env env,
144                                                    napi_value value,
145                                                    char* buf,
146                                                    size_t bufsize,
147                                                    size_t* result);
148 
149 // Copies UTF-16 encoded bytes from a string into a buffer.
150 NAPI_EXTERN napi_status napi_get_value_string_utf16(napi_env env,
151                                                     napi_value value,
152                                                     char16_t* buf,
153                                                     size_t bufsize,
154                                                     size_t* result);
155 
156 // Methods to coerce values
157 // These APIs may execute user scripts
158 NAPI_EXTERN napi_status napi_coerce_to_bool(napi_env env,
159                                             napi_value value,
160                                             napi_value* result);
161 NAPI_EXTERN napi_status napi_coerce_to_number(napi_env env,
162                                               napi_value value,
163                                               napi_value* result);
164 NAPI_EXTERN napi_status napi_coerce_to_object(napi_env env,
165                                               napi_value value,
166                                               napi_value* result);
167 NAPI_EXTERN napi_status napi_coerce_to_string(napi_env env,
168                                               napi_value value,
169                                               napi_value* result);
170 
171 // Methods to work with Objects
172 NAPI_EXTERN napi_status napi_get_prototype(napi_env env,
173                                            napi_value object,
174                                            napi_value* result);
175 NAPI_EXTERN napi_status napi_get_property_names(napi_env env,
176                                                 napi_value object,
177                                                 napi_value* result);
178 NAPI_EXTERN napi_status napi_set_property(napi_env env,
179                                           napi_value object,
180                                           napi_value key,
181                                           napi_value value);
182 NAPI_EXTERN napi_status napi_has_property(napi_env env,
183                                           napi_value object,
184                                           napi_value key,
185                                           bool* result);
186 NAPI_EXTERN napi_status napi_get_property(napi_env env,
187                                           napi_value object,
188                                           napi_value key,
189                                           napi_value* result);
190 NAPI_EXTERN napi_status napi_delete_property(napi_env env,
191                                              napi_value object,
192                                              napi_value key,
193                                              bool* result);
194 NAPI_EXTERN napi_status napi_has_own_property(napi_env env,
195                                               napi_value object,
196                                               napi_value key,
197                                               bool* result);
198 NAPI_EXTERN napi_status napi_set_named_property(napi_env env,
199                                           napi_value object,
200                                           const char* utf8name,
201                                           napi_value value);
202 NAPI_EXTERN napi_status napi_has_named_property(napi_env env,
203                                           napi_value object,
204                                           const char* utf8name,
205                                           bool* result);
206 NAPI_EXTERN napi_status napi_get_named_property(napi_env env,
207                                           napi_value object,
208                                           const char* utf8name,
209                                           napi_value* result);
210 NAPI_EXTERN napi_status napi_set_element(napi_env env,
211                                          napi_value object,
212                                          uint32_t index,
213                                          napi_value value);
214 NAPI_EXTERN napi_status napi_has_element(napi_env env,
215                                          napi_value object,
216                                          uint32_t index,
217                                          bool* result);
218 NAPI_EXTERN napi_status napi_get_element(napi_env env,
219                                          napi_value object,
220                                          uint32_t index,
221                                          napi_value* result);
222 NAPI_EXTERN napi_status napi_delete_element(napi_env env,
223                                             napi_value object,
224                                             uint32_t index,
225                                             bool* result);
226 NAPI_EXTERN napi_status
227 napi_define_properties(napi_env env,
228                        napi_value object,
229                        size_t property_count,
230                        const napi_property_descriptor* properties);
231 
232 // Methods to work with Arrays
233 NAPI_EXTERN napi_status napi_is_array(napi_env env,
234                                       napi_value value,
235                                       bool* result);
236 NAPI_EXTERN napi_status napi_get_array_length(napi_env env,
237                                               napi_value value,
238                                               uint32_t* result);
239 
240 // Methods to compare values
241 NAPI_EXTERN napi_status napi_strict_equals(napi_env env,
242                                            napi_value lhs,
243                                            napi_value rhs,
244                                            bool* result);
245 
246 // Methods to work with Functions
247 NAPI_EXTERN napi_status napi_call_function(napi_env env,
248                                            napi_value recv,
249                                            napi_value func,
250                                            size_t argc,
251                                            const napi_value* argv,
252                                            napi_value* result);
253 NAPI_EXTERN napi_status napi_new_instance(napi_env env,
254                                           napi_value constructor,
255                                           size_t argc,
256                                           const napi_value* argv,
257                                           napi_value* result);
258 NAPI_EXTERN napi_status napi_instanceof(napi_env env,
259                                         napi_value object,
260                                         napi_value constructor,
261                                         bool* result);
262 
263 // Methods to work with napi_callbacks
264 
265 // Gets all callback info in a single call. (Ugly, but faster.)
266 NAPI_EXTERN napi_status napi_get_cb_info(
267     napi_env env,               // [in] NAPI environment handle
268     napi_callback_info cbinfo,  // [in] Opaque callback-info handle
269     size_t* argc,      // [in-out] Specifies the size of the provided argv array
270                        // and receives the actual count of args.
271     napi_value* argv,  // [out] Array of values
272     napi_value* this_arg,  // [out] Receives the JS 'this' arg for the call
273     void** data);          // [out] Receives the data pointer for the callback.
274 
275 NAPI_EXTERN napi_status napi_get_new_target(napi_env env,
276                                             napi_callback_info cbinfo,
277                                             napi_value* result);
278 NAPI_EXTERN napi_status
279 napi_define_class(napi_env env,
280                   const char* utf8name,
281                   size_t length,
282                   napi_callback constructor,
283                   void* data,
284                   size_t property_count,
285                   const napi_property_descriptor* properties,
286                   napi_value* result);
287 
288 // Methods to work with external data objects
289 NAPI_EXTERN napi_status napi_wrap(napi_env env,
290                                   napi_value js_object,
291                                   void* native_object,
292                                   napi_finalize finalize_cb,
293                                   void* finalize_hint,
294                                   napi_ref* result);
295 NAPI_EXTERN napi_status napi_unwrap(napi_env env,
296                                     napi_value js_object,
297                                     void** result);
298 NAPI_EXTERN napi_status napi_remove_wrap(napi_env env,
299                                          napi_value js_object,
300                                          void** result);
301 NAPI_EXTERN napi_status napi_create_external(napi_env env,
302                                              void* data,
303                                              napi_finalize finalize_cb,
304                                              void* finalize_hint,
305                                              napi_value* result);
306 NAPI_EXTERN napi_status napi_get_value_external(napi_env env,
307                                                 napi_value value,
308                                                 void** result);
309 
310 // Methods to control object lifespan
311 
312 // Set initial_refcount to 0 for a weak reference, >0 for a strong reference.
313 NAPI_EXTERN napi_status napi_create_reference(napi_env env,
314                                               napi_value value,
315                                               uint32_t initial_refcount,
316                                               napi_ref* result);
317 
318 // Deletes a reference. The referenced value is released, and may
319 // be GC'd unless there are other references to it.
320 NAPI_EXTERN napi_status napi_delete_reference(napi_env env, napi_ref ref);
321 
322 // Increments the reference count, optionally returning the resulting count.
323 // After this call the  reference will be a strong reference because its
324 // refcount is >0, and the referenced object is effectively "pinned".
325 // Calling this when the refcount is 0 and the object is unavailable
326 // results in an error.
327 NAPI_EXTERN napi_status napi_reference_ref(napi_env env,
328                                            napi_ref ref,
329                                            uint32_t* result);
330 
331 // Decrements the reference count, optionally returning the resulting count.
332 // If the result is 0 the reference is now weak and the object may be GC'd
333 // at any time if there are no other references. Calling this when the
334 // refcount is already 0 results in an error.
335 NAPI_EXTERN napi_status napi_reference_unref(napi_env env,
336                                              napi_ref ref,
337                                              uint32_t* result);
338 
339 // Attempts to get a referenced value. If the reference is weak,
340 // the value might no longer be available, in that case the call
341 // is still successful but the result is NULL.
342 NAPI_EXTERN napi_status napi_get_reference_value(napi_env env,
343                                                  napi_ref ref,
344                                                  napi_value* result);
345 
346 NAPI_EXTERN napi_status napi_open_handle_scope(napi_env env,
347                                                napi_handle_scope* result);
348 NAPI_EXTERN napi_status napi_close_handle_scope(napi_env env,
349                                                 napi_handle_scope scope);
350 NAPI_EXTERN napi_status
351 napi_open_escapable_handle_scope(napi_env env,
352                                  napi_escapable_handle_scope* result);
353 NAPI_EXTERN napi_status
354 napi_close_escapable_handle_scope(napi_env env,
355                                   napi_escapable_handle_scope scope);
356 
357 NAPI_EXTERN napi_status napi_escape_handle(napi_env env,
358                                            napi_escapable_handle_scope scope,
359                                            napi_value escapee,
360                                            napi_value* result);
361 
362 // Methods to support error handling
363 NAPI_EXTERN napi_status napi_throw(napi_env env, napi_value error);
364 NAPI_EXTERN napi_status napi_throw_error(napi_env env,
365                                          const char* code,
366                                          const char* msg);
367 NAPI_EXTERN napi_status napi_throw_type_error(napi_env env,
368                                          const char* code,
369                                          const char* msg);
370 NAPI_EXTERN napi_status napi_throw_range_error(napi_env env,
371                                          const char* code,
372                                          const char* msg);
373 NAPI_EXTERN napi_status napi_is_error(napi_env env,
374                                       napi_value value,
375                                       bool* result);
376 
377 // Methods to support catching exceptions
378 NAPI_EXTERN napi_status napi_is_exception_pending(napi_env env, bool* result);
379 NAPI_EXTERN napi_status napi_get_and_clear_last_exception(napi_env env,
380                                                           napi_value* result);
381 
382 // Methods to work with array buffers and typed arrays
383 NAPI_EXTERN napi_status napi_is_arraybuffer(napi_env env,
384                                             napi_value value,
385                                             bool* result);
386 NAPI_EXTERN napi_status napi_create_arraybuffer(napi_env env,
387                                                 size_t byte_length,
388                                                 void** data,
389                                                 napi_value* result);
390 NAPI_EXTERN napi_status
391 napi_create_external_arraybuffer(napi_env env,
392                                  void* external_data,
393                                  size_t byte_length,
394                                  napi_finalize finalize_cb,
395                                  void* finalize_hint,
396                                  napi_value* result);
397 NAPI_EXTERN napi_status napi_get_arraybuffer_info(napi_env env,
398                                                   napi_value arraybuffer,
399                                                   void** data,
400                                                   size_t* byte_length);
401 NAPI_EXTERN napi_status napi_is_typedarray(napi_env env,
402                                            napi_value value,
403                                            bool* result);
404 NAPI_EXTERN napi_status napi_create_typedarray(napi_env env,
405                                                napi_typedarray_type type,
406                                                size_t length,
407                                                napi_value arraybuffer,
408                                                size_t byte_offset,
409                                                napi_value* result);
410 NAPI_EXTERN napi_status napi_get_typedarray_info(napi_env env,
411                                                  napi_value typedarray,
412                                                  napi_typedarray_type* type,
413                                                  size_t* length,
414                                                  void** data,
415                                                  napi_value* arraybuffer,
416                                                  size_t* byte_offset);
417 
418 NAPI_EXTERN napi_status napi_create_dataview(napi_env env,
419                                              size_t length,
420                                              napi_value arraybuffer,
421                                              size_t byte_offset,
422                                              napi_value* result);
423 NAPI_EXTERN napi_status napi_is_dataview(napi_env env,
424                                          napi_value value,
425                                          bool* result);
426 NAPI_EXTERN napi_status napi_get_dataview_info(napi_env env,
427                                                napi_value dataview,
428                                                size_t* bytelength,
429                                                void** data,
430                                                napi_value* arraybuffer,
431                                                size_t* byte_offset);
432 
433 // version management
434 NAPI_EXTERN napi_status napi_get_version(napi_env env, uint32_t* result);
435 
436 // Promises
437 NAPI_EXTERN napi_status napi_create_promise(napi_env env,
438                                             napi_deferred* deferred,
439                                             napi_value* promise);
440 NAPI_EXTERN napi_status napi_resolve_deferred(napi_env env,
441                                               napi_deferred deferred,
442                                               napi_value resolution);
443 NAPI_EXTERN napi_status napi_reject_deferred(napi_env env,
444                                              napi_deferred deferred,
445                                              napi_value rejection);
446 NAPI_EXTERN napi_status napi_is_promise(napi_env env,
447                                         napi_value value,
448                                         bool* is_promise);
449 
450 // Running a script
451 NAPI_EXTERN napi_status napi_run_script(napi_env env,
452                                         napi_value script,
453                                         napi_value* result);
454 
455 // Memory management
456 NAPI_EXTERN napi_status napi_adjust_external_memory(napi_env env,
457                                                     int64_t change_in_bytes,
458                                                     int64_t* adjusted_value);
459 
460 #if NAPI_VERSION >= 5
461 
462 // Dates
463 NAPI_EXTERN napi_status napi_create_date(napi_env env,
464                                          double time,
465                                          napi_value* result);
466 
467 NAPI_EXTERN napi_status napi_is_date(napi_env env,
468                                      napi_value value,
469                                      bool* is_date);
470 
471 NAPI_EXTERN napi_status napi_get_date_value(napi_env env,
472                                             napi_value value,
473                                             double* result);
474 
475 // Add finalizer for pointer
476 NAPI_EXTERN napi_status napi_add_finalizer(napi_env env,
477                                            napi_value js_object,
478                                            void* native_object,
479                                            napi_finalize finalize_cb,
480                                            void* finalize_hint,
481                                            napi_ref* result);
482 
483 #endif  // NAPI_VERSION >= 5
484 
485 #if NAPI_VERSION >= 6
486 
487 // BigInt
488 NAPI_EXTERN napi_status napi_create_bigint_int64(napi_env env,
489                                                  int64_t value,
490                                                  napi_value* result);
491 NAPI_EXTERN napi_status napi_create_bigint_uint64(napi_env env,
492                                                   uint64_t value,
493                                                   napi_value* result);
494 NAPI_EXTERN napi_status napi_create_bigint_words(napi_env env,
495                                                  int sign_bit,
496                                                  size_t word_count,
497                                                  const uint64_t* words,
498                                                  napi_value* result);
499 NAPI_EXTERN napi_status napi_get_value_bigint_int64(napi_env env,
500                                                     napi_value value,
501                                                     int64_t* result,
502                                                     bool* lossless);
503 NAPI_EXTERN napi_status napi_get_value_bigint_uint64(napi_env env,
504                                                      napi_value value,
505                                                      uint64_t* result,
506                                                      bool* lossless);
507 NAPI_EXTERN napi_status napi_get_value_bigint_words(napi_env env,
508                                                     napi_value value,
509                                                     int* sign_bit,
510                                                     size_t* word_count,
511                                                     uint64_t* words);
512 
513 // Object
514 NAPI_EXTERN napi_status
515 napi_get_all_property_names(napi_env env,
516                             napi_value object,
517                             napi_key_collection_mode key_mode,
518                             napi_key_filter key_filter,
519                             napi_key_conversion key_conversion,
520                             napi_value* result);
521 
522 // Instance data
523 NAPI_EXTERN napi_status napi_set_instance_data(napi_env env,
524                                                void* data,
525                                                napi_finalize finalize_cb,
526                                                void* finalize_hint);
527 
528 NAPI_EXTERN napi_status napi_get_instance_data(napi_env env,
529                                                void** data);
530 #endif  // NAPI_VERSION >= 6
531 
532 #if NAPI_VERSION >= 7
533 // ArrayBuffer detaching
534 NAPI_EXTERN napi_status napi_detach_arraybuffer(napi_env env,
535                                                 napi_value arraybuffer);
536 
537 NAPI_EXTERN napi_status napi_is_detached_arraybuffer(napi_env env,
538                                                      napi_value value,
539                                                      bool* result);
540 #endif  // NAPI_VERSION >= 7
541 
542 #ifdef NAPI_EXPERIMENTAL
543 // Type tagging
544 NAPI_EXTERN napi_status napi_type_tag_object(napi_env env,
545                                              napi_value value,
546                                              const napi_type_tag* type_tag);
547 
548 NAPI_EXTERN napi_status
549 napi_check_object_type_tag(napi_env env,
550                            napi_value value,
551                            const napi_type_tag* type_tag,
552                            bool* result);
553 #endif  // NAPI_EXPERIMENTAL
554 
555 EXTERN_C_END
556 
557 #endif  // SRC_JS_NATIVE_API_H_
558