aboutsummaryrefslogtreecommitdiff
path: root/src/napi/js_native_api.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/napi/js_native_api.h')
-rw-r--r--src/napi/js_native_api.h458
1 files changed, 458 insertions, 0 deletions
diff --git a/src/napi/js_native_api.h b/src/napi/js_native_api.h
new file mode 100644
index 000000000..40db9dec2
--- /dev/null
+++ b/src/napi/js_native_api.h
@@ -0,0 +1,458 @@
+#ifndef SRC_JS_NATIVE_API_H_
+#define SRC_JS_NATIVE_API_H_
+
+// This file needs to be compatible with C compilers.
+#include <stdbool.h> // NOLINT(modernize-deprecated-headers)
+#include <stddef.h> // NOLINT(modernize-deprecated-headers)
+
+// Use INT_MAX, this should only be consumed by the pre-processor anyway.
+#define NAPI_VERSION_EXPERIMENTAL 2147483647
+#ifndef NAPI_VERSION
+#ifdef NAPI_EXPERIMENTAL
+#define NAPI_VERSION NAPI_VERSION_EXPERIMENTAL
+#else
+// The baseline version for N-API.
+// The NAPI_VERSION controls which version will be used by default when
+// compilling a native addon. If the addon developer specifically wants to use
+// functions available in a new version of N-API that is not yet ported in all
+// LTS versions, they can set NAPI_VERSION knowing that they have specifically
+// depended on that version.
+#define NAPI_VERSION 8
+#endif
+#endif
+
+#include "js_native_api_types.h"
+
+// If you need __declspec(dllimport), either include <node_api.h> instead, or
+// define NAPI_EXTERN as __declspec(dllimport) on the compiler's command line.
+#ifndef NAPI_EXTERN
+#ifdef _WIN32
+#define NAPI_EXTERN __declspec(dllexport)
+#elif defined(__wasm32__)
+#define NAPI_EXTERN \
+ __attribute__((visibility("default"))) \
+ __attribute__((__import_module__("napi")))
+#else
+#define NAPI_EXTERN __attribute__((visibility("default")))
+#endif
+#endif
+
+#define NAPI_AUTO_LENGTH SIZE_MAX
+
+#ifdef __cplusplus
+#define EXTERN_C_START extern "C" {
+#define EXTERN_C_END }
+#else
+#define EXTERN_C_START
+#define EXTERN_C_END
+#endif
+
+EXTERN_C_START
+
+NAPI_EXTERN napi_status
+napi_get_last_error_info(napi_env env, const napi_extended_error_info **result);
+
+// Getters for defined singletons
+NAPI_EXTERN napi_status napi_get_undefined(napi_env env, napi_value *result);
+NAPI_EXTERN napi_status napi_get_null(napi_env env, napi_value *result);
+NAPI_EXTERN napi_status napi_get_global(napi_env env, napi_value *result);
+NAPI_EXTERN napi_status napi_get_boolean(napi_env env, bool value,
+ napi_value *result);
+
+// Methods to create Primitive types/Objects
+NAPI_EXTERN napi_status napi_create_object(napi_env env, napi_value *result);
+NAPI_EXTERN napi_status napi_create_array(napi_env env, napi_value *result);
+NAPI_EXTERN napi_status napi_create_array_with_length(napi_env env,
+ size_t length,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_double(napi_env env, double value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_int32(napi_env env, int32_t value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_uint32(napi_env env, uint32_t value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_int64(napi_env env, int64_t value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_string_latin1(napi_env env, const char *str,
+ size_t length,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_string_utf8(napi_env env, const char *str,
+ size_t length,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_string_utf16(napi_env env,
+ const char16_t *str,
+ size_t length,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_symbol(napi_env env, napi_value description,
+ napi_value *result);
+#ifdef NAPI_EXPERIMENTAL
+NAPI_EXTERN napi_status node_api_symbol_for(napi_env env,
+ const char *utf8description,
+ size_t length, napi_value *result);
+#endif // NAPI_EXPERIMENTAL
+NAPI_EXTERN napi_status napi_create_function(napi_env env, const char *utf8name,
+ size_t length, napi_callback cb,
+ void *data, napi_value *result);
+NAPI_EXTERN napi_status napi_create_error(napi_env env, napi_value code,
+ napi_value msg, napi_value *result);
+NAPI_EXTERN napi_status napi_create_type_error(napi_env env, napi_value code,
+ napi_value msg,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_range_error(napi_env env, napi_value code,
+ napi_value msg,
+ napi_value *result);
+#ifdef NAPI_EXPERIMENTAL
+NAPI_EXTERN napi_status node_api_create_syntax_error(napi_env env,
+ napi_value code,
+ napi_value msg,
+ napi_value *result);
+#endif // NAPI_EXPERIMENTAL
+
+// Methods to get the native napi_value from Primitive type
+NAPI_EXTERN napi_status napi_typeof(napi_env env, napi_value value,
+ napi_valuetype *result);
+NAPI_EXTERN napi_status napi_get_value_double(napi_env env, napi_value value,
+ double *result);
+NAPI_EXTERN napi_status napi_get_value_int32(napi_env env, napi_value value,
+ int32_t *result);
+NAPI_EXTERN napi_status napi_get_value_uint32(napi_env env, napi_value value,
+ uint32_t *result);
+NAPI_EXTERN napi_status napi_get_value_int64(napi_env env, napi_value value,
+ int64_t *result);
+NAPI_EXTERN napi_status napi_get_value_bool(napi_env env, napi_value value,
+ bool *result);
+
+// Copies LATIN-1 encoded bytes from a string into a buffer.
+NAPI_EXTERN napi_status napi_get_value_string_latin1(napi_env env,
+ napi_value value,
+ char *buf, size_t bufsize,
+ size_t *result);
+
+// Copies UTF-8 encoded bytes from a string into a buffer.
+NAPI_EXTERN napi_status napi_get_value_string_utf8(napi_env env,
+ napi_value value, char *buf,
+ size_t bufsize,
+ size_t *result);
+
+// Copies UTF-16 encoded bytes from a string into a buffer.
+NAPI_EXTERN napi_status napi_get_value_string_utf16(napi_env env,
+ napi_value value,
+ char16_t *buf,
+ size_t bufsize,
+ size_t *result);
+
+// Methods to coerce values
+// These APIs may execute user scripts
+NAPI_EXTERN napi_status napi_coerce_to_bool(napi_env env, napi_value value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_coerce_to_number(napi_env env, napi_value value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_coerce_to_object(napi_env env, napi_value value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_coerce_to_string(napi_env env, napi_value value,
+ napi_value *result);
+
+// Methods to work with Objects
+NAPI_EXTERN napi_status napi_get_prototype(napi_env env, napi_value object,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_get_property_names(napi_env env, napi_value object,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_set_property(napi_env env, napi_value object,
+ napi_value key, napi_value value);
+NAPI_EXTERN napi_status napi_has_property(napi_env env, napi_value object,
+ napi_value key, bool *result);
+NAPI_EXTERN napi_status napi_get_property(napi_env env, napi_value object,
+ napi_value key, napi_value *result);
+NAPI_EXTERN napi_status napi_delete_property(napi_env env, napi_value object,
+ napi_value key, bool *result);
+NAPI_EXTERN napi_status napi_has_own_property(napi_env env, napi_value object,
+ napi_value key, bool *result);
+NAPI_EXTERN napi_status napi_set_named_property(napi_env env, napi_value object,
+ const char *utf8name,
+ napi_value value);
+NAPI_EXTERN napi_status napi_has_named_property(napi_env env, napi_value object,
+ const char *utf8name,
+ bool *result);
+NAPI_EXTERN napi_status napi_get_named_property(napi_env env, napi_value object,
+ const char *utf8name,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_set_element(napi_env env, napi_value object,
+ uint32_t index, napi_value value);
+NAPI_EXTERN napi_status napi_has_element(napi_env env, napi_value object,
+ uint32_t index, bool *result);
+NAPI_EXTERN napi_status napi_get_element(napi_env env, napi_value object,
+ uint32_t index, napi_value *result);
+NAPI_EXTERN napi_status napi_delete_element(napi_env env, napi_value object,
+ uint32_t index, bool *result);
+NAPI_EXTERN napi_status
+napi_define_properties(napi_env env, napi_value object, size_t property_count,
+ const napi_property_descriptor *properties);
+
+// Methods to work with Arrays
+NAPI_EXTERN napi_status napi_is_array(napi_env env, napi_value value,
+ bool *result);
+NAPI_EXTERN napi_status napi_get_array_length(napi_env env, napi_value value,
+ uint32_t *result);
+
+// Methods to compare values
+NAPI_EXTERN napi_status napi_strict_equals(napi_env env, napi_value lhs,
+ napi_value rhs, bool *result);
+
+// Methods to work with Functions
+NAPI_EXTERN napi_status napi_call_function(napi_env env, napi_value recv,
+ napi_value func, size_t argc,
+ const napi_value *argv,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_new_instance(napi_env env, napi_value constructor,
+ size_t argc, const napi_value *argv,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_instanceof(napi_env env, napi_value object,
+ napi_value constructor, bool *result);
+
+// Methods to work with napi_callbacks
+
+// Gets all callback info in a single call. (Ugly, but faster.)
+NAPI_EXTERN napi_status napi_get_cb_info(
+ napi_env env, // [in] NAPI environment handle
+ napi_callback_info cbinfo, // [in] Opaque callback-info handle
+ size_t *argc, // [in-out] Specifies the size of the provided argv array
+ // and receives the actual count of args.
+ napi_value *argv, // [out] Array of values
+ napi_value *this_arg, // [out] Receives the JS 'this' arg for the call
+ void **data); // [out] Receives the data pointer for the callback.
+
+NAPI_EXTERN napi_status napi_get_new_target(napi_env env,
+ napi_callback_info cbinfo,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_define_class(
+ napi_env env, const char *utf8name, size_t length,
+ napi_callback constructor, void *data, size_t property_count,
+ const napi_property_descriptor *properties, napi_value *result);
+
+// Methods to work with external data objects
+NAPI_EXTERN napi_status napi_wrap(napi_env env, napi_value js_object,
+ void *native_object,
+ napi_finalize finalize_cb,
+ void *finalize_hint, napi_ref *result);
+NAPI_EXTERN napi_status napi_unwrap(napi_env env, napi_value js_object,
+ void **result);
+NAPI_EXTERN napi_status napi_remove_wrap(napi_env env, napi_value js_object,
+ void **result);
+NAPI_EXTERN napi_status napi_create_external(napi_env env, void *data,
+ napi_finalize finalize_cb,
+ void *finalize_hint,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_get_value_external(napi_env env, napi_value value,
+ void **result);
+
+// Methods to control object lifespan
+
+// Set initial_refcount to 0 for a weak reference, >0 for a strong reference.
+NAPI_EXTERN napi_status napi_create_reference(napi_env env, napi_value value,
+ uint32_t initial_refcount,
+ napi_ref *result);
+
+// Deletes a reference. The referenced value is released, and may
+// be GC'd unless there are other references to it.
+NAPI_EXTERN napi_status napi_delete_reference(napi_env env, napi_ref ref);
+
+// Increments the reference count, optionally returning the resulting count.
+// After this call the reference will be a strong reference because its
+// refcount is >0, and the referenced object is effectively "pinned".
+// Calling this when the refcount is 0 and the object is unavailable
+// results in an error.
+NAPI_EXTERN napi_status napi_reference_ref(napi_env env, napi_ref ref,
+ uint32_t *result);
+
+// Decrements the reference count, optionally returning the resulting count.
+// If the result is 0 the reference is now weak and the object may be GC'd
+// at any time if there are no other references. Calling this when the
+// refcount is already 0 results in an error.
+NAPI_EXTERN napi_status napi_reference_unref(napi_env env, napi_ref ref,
+ uint32_t *result);
+
+// Attempts to get a referenced value. If the reference is weak,
+// the value might no longer be available, in that case the call
+// is still successful but the result is NULL.
+NAPI_EXTERN napi_status napi_get_reference_value(napi_env env, napi_ref ref,
+ napi_value *result);
+
+NAPI_EXTERN napi_status napi_open_handle_scope(napi_env env,
+ napi_handle_scope *result);
+NAPI_EXTERN napi_status napi_close_handle_scope(napi_env env,
+ napi_handle_scope scope);
+NAPI_EXTERN napi_status napi_open_escapable_handle_scope(
+ napi_env env, napi_escapable_handle_scope *result);
+NAPI_EXTERN napi_status napi_close_escapable_handle_scope(
+ napi_env env, napi_escapable_handle_scope scope);
+
+NAPI_EXTERN napi_status napi_escape_handle(napi_env env,
+ napi_escapable_handle_scope scope,
+ napi_value escapee,
+ napi_value *result);
+
+// Methods to support error handling
+NAPI_EXTERN napi_status napi_throw(napi_env env, napi_value error);
+NAPI_EXTERN napi_status napi_throw_error(napi_env env, const char *code,
+ const char *msg);
+NAPI_EXTERN napi_status napi_throw_type_error(napi_env env, const char *code,
+ const char *msg);
+NAPI_EXTERN napi_status napi_throw_range_error(napi_env env, const char *code,
+ const char *msg);
+#ifdef NAPI_EXPERIMENTAL
+NAPI_EXTERN napi_status node_api_throw_syntax_error(napi_env env,
+ const char *code,
+ const char *msg);
+#endif // NAPI_EXPERIMENTAL
+NAPI_EXTERN napi_status napi_is_error(napi_env env, napi_value value,
+ bool *result);
+
+// Methods to support catching exceptions
+NAPI_EXTERN napi_status napi_is_exception_pending(napi_env env, bool *result);
+NAPI_EXTERN napi_status napi_get_and_clear_last_exception(napi_env env,
+ napi_value *result);
+
+// Methods to work with array buffers and typed arrays
+NAPI_EXTERN napi_status napi_is_arraybuffer(napi_env env, napi_value value,
+ bool *result);
+NAPI_EXTERN napi_status napi_create_arraybuffer(napi_env env,
+ size_t byte_length, void **data,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_external_arraybuffer(
+ napi_env env, void *external_data, size_t byte_length,
+ napi_finalize finalize_cb, void *finalize_hint, napi_value *result);
+NAPI_EXTERN napi_status napi_get_arraybuffer_info(napi_env env,
+ napi_value arraybuffer,
+ void **data,
+ size_t *byte_length);
+NAPI_EXTERN napi_status napi_is_typedarray(napi_env env, napi_value value,
+ bool *result);
+NAPI_EXTERN napi_status napi_create_typedarray(
+ napi_env env, napi_typedarray_type type, size_t length,
+ napi_value arraybuffer, size_t byte_offset, napi_value *result);
+NAPI_EXTERN napi_status napi_get_typedarray_info(
+ napi_env env, napi_value typedarray, napi_typedarray_type *type,
+ size_t *length, void **data, napi_value *arraybuffer, size_t *byte_offset);
+
+NAPI_EXTERN napi_status napi_create_dataview(napi_env env, size_t length,
+ napi_value arraybuffer,
+ size_t byte_offset,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_is_dataview(napi_env env, napi_value value,
+ bool *result);
+NAPI_EXTERN napi_status napi_get_dataview_info(napi_env env,
+ napi_value dataview,
+ size_t *bytelength, void **data,
+ napi_value *arraybuffer,
+ size_t *byte_offset);
+
+// version management
+NAPI_EXTERN napi_status napi_get_version(napi_env env, uint32_t *result);
+
+// Promises
+NAPI_EXTERN napi_status napi_create_promise(napi_env env,
+ napi_deferred *deferred,
+ napi_value *promise);
+NAPI_EXTERN napi_status napi_resolve_deferred(napi_env env,
+ napi_deferred deferred,
+ napi_value resolution);
+NAPI_EXTERN napi_status napi_reject_deferred(napi_env env,
+ napi_deferred deferred,
+ napi_value rejection);
+NAPI_EXTERN napi_status napi_is_promise(napi_env env, napi_value value,
+ bool *is_promise);
+
+// Running a script
+NAPI_EXTERN napi_status napi_run_script(napi_env env, napi_value script,
+ napi_value *result);
+
+// Memory management
+NAPI_EXTERN napi_status napi_adjust_external_memory(napi_env env,
+ int64_t change_in_bytes,
+ int64_t *adjusted_value);
+
+#if NAPI_VERSION >= 5
+
+// Dates
+NAPI_EXTERN napi_status napi_create_date(napi_env env, double time,
+ napi_value *result);
+
+NAPI_EXTERN napi_status napi_is_date(napi_env env, napi_value value,
+ bool *is_date);
+
+NAPI_EXTERN napi_status napi_get_date_value(napi_env env, napi_value value,
+ double *result);
+
+// Add finalizer for pointer
+NAPI_EXTERN napi_status napi_add_finalizer(napi_env env, napi_value js_object,
+ void *native_object,
+ napi_finalize finalize_cb,
+ void *finalize_hint,
+ napi_ref *result);
+
+#endif // NAPI_VERSION >= 5
+
+#if NAPI_VERSION >= 6
+
+// BigInt
+NAPI_EXTERN napi_status napi_create_bigint_int64(napi_env env, int64_t value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_bigint_uint64(napi_env env, uint64_t value,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_create_bigint_words(napi_env env, int sign_bit,
+ size_t word_count,
+ const uint64_t *words,
+ napi_value *result);
+NAPI_EXTERN napi_status napi_get_value_bigint_int64(napi_env env,
+ napi_value value,
+ int64_t *result,
+ bool *lossless);
+NAPI_EXTERN napi_status napi_get_value_bigint_uint64(napi_env env,
+ napi_value value,
+ uint64_t *result,
+ bool *lossless);
+NAPI_EXTERN napi_status napi_get_value_bigint_words(napi_env env,
+ napi_value value,
+ int *sign_bit,
+ size_t *word_count,
+ uint64_t *words);
+
+// Object
+NAPI_EXTERN napi_status napi_get_all_property_names(
+ napi_env env, napi_value object, napi_key_collection_mode key_mode,
+ napi_key_filter key_filter, napi_key_conversion key_conversion,
+ napi_value *result);
+
+// Instance data
+NAPI_EXTERN napi_status napi_set_instance_data(napi_env env, void *data,
+ napi_finalize finalize_cb,
+ void *finalize_hint);
+
+NAPI_EXTERN napi_status napi_get_instance_data(napi_env env, void **data);
+#endif // NAPI_VERSION >= 6
+
+#if NAPI_VERSION >= 7
+// ArrayBuffer detaching
+NAPI_EXTERN napi_status napi_detach_arraybuffer(napi_env env,
+ napi_value arraybuffer);
+
+NAPI_EXTERN napi_status napi_is_detached_arraybuffer(napi_env env,
+ napi_value value,
+ bool *result);
+#endif // NAPI_VERSION >= 7
+
+#if NAPI_VERSION >= 8
+// Type tagging
+NAPI_EXTERN napi_status napi_type_tag_object(napi_env env, napi_value value,
+ const napi_type_tag *type_tag);
+
+NAPI_EXTERN napi_status
+napi_check_object_type_tag(napi_env env, napi_value value,
+ const napi_type_tag *type_tag, bool *result);
+NAPI_EXTERN napi_status napi_object_freeze(napi_env env, napi_value object);
+NAPI_EXTERN napi_status napi_object_seal(napi_env env, napi_value object);
+#endif // NAPI_VERSION >= 8
+
+EXTERN_C_END
+
+#endif // SRC_JS_NATIVE_API_H_