N-API (pronounced N as in the letter, followed by API) is an API for building native Addons. It is independent from the underlying JavaScript runtime (for example, V8) and is maintained as part of Node.js itself. This API will be Application Binary Interface (ABI) stable across versions of Node.js. It is intended to insulate Addons from changes in the underlying JavaScript engine and allow modules compiled for one major version to run on later major versions of Node.js without recompilation. The ABI Stability guide provides a more in-depth explanation.

Addons are built/packaged with the same approach/tools outlined in the section titled C++ Addons. The only difference is the set of APIs that are used by the native code. Instead of using the V8 or Native Abstractions for Node.js APIs, the functions available in the N-API are used.

APIs exposed by N-API are generally used to create and manipulate JavaScript values. Concepts and operations generally map to ideas specified in the ECMA-262 Language Specification. The APIs have the following properties:

All N-API calls return a status code of type napi_status . This status indicates whether the API call succeeded or failed.

. This status indicates whether the API call succeeded or failed. The API's return value is passed via an out parameter.

All JavaScript values are abstracted behind an opaque type named napi_value .

. In case of an error status code, additional information can be obtained using napi_get_last_error_info . More information can be found in the error handling section Error handling.

The N-API is a C API that ensures ABI stability across Node.js versions and different compiler levels. A C++ API can be easier to use. To support using C++, the project maintains a C++ wrapper module called node-addon-api . This wrapper provides an inlineable C++ API. Binaries built with node-addon-api will depend on the symbols for the N-API C-based functions exported by Node.js. node-addon-api is a more efficient way to write code that calls N-API. Take, for example, the following node-addon-api code. The first section shows the node-addon-api code and the second section shows what actually gets used in the addon.

Object obj = Object::New(env); obj[ "foo" ] = String::New(env, "bar" );

napi_status status; napi_value object, string ; status = napi_create_object(env, &object); if (status != napi_ok) { napi_throw_error(env, ...); return ; } status = napi_create_string_utf8(env, "bar" , NAPI_AUTO_LENGTH, & string ); if (status != napi_ok) { napi_throw_error(env, ...); return ; } status = napi_set_named_property(env, object, "foo" , string ); if (status != napi_ok) { napi_throw_error(env, ...); return ; }

The end result is that the addon only uses the exported C APIs. As a result, it still gets the benefits of the ABI stability provided by the C API.

When using node-addon-api instead of the C APIs, start with the API docs for node-addon-api .

The N-API Resource offers an excellent orientation and tips for developers just getting started with N-API and node-addon-api .

Implications of ABI stability #

Although N-API provides an ABI stability guarantee, other parts of Node.js do not, and any external libraries used from the addon may not. In particular, none of the following APIs provide an ABI stability guarantee across major versions:

the Node.js C++ APIs available via any of

the libuv APIs which are also included with Node.js and available via

the V8 API available via

Thus, for an addon to remain ABI-compatible across Node.js major versions, it must use N-API exclusively by restricting itself to using

and by checking, for all external libraries that it uses, that the external library makes ABI stability guarantees similar to N-API.

Unlike modules written in JavaScript, developing and deploying Node.js native addons using N-API requires an additional set of tools. Besides the basic tools required to develop for Node.js, the native addon developer requires a toolchain that can compile C and C++ code into a binary. In addition, depending upon how the native addon is deployed, the user of the native addon will also need to have a C/C++ toolchain installed.

For Linux developers, the necessary C/C++ toolchain packages are readily available. GCC is widely used in the Node.js community to build and test across a variety of platforms. For many developers, the LLVM compiler infrastructure is also a good choice.

For Mac developers, Xcode offers all the required compiler tools. However, it is not necessary to install the entire Xcode IDE. The following command installs the necessary toolchain:

xcode-select --install

For Windows developers, Visual Studio offers all the required compiler tools. However, it is not necessary to install the entire Visual Studio IDE. The following command installs the necessary toolchain:

npm install --global windows-build-tools

The sections below describe the additional tools available for developing and deploying Node.js native addons.

Build tools

Both the tools listed here require that users of the native addon have a C/C++ toolchain installed in order to successfully install the native addon.

node-gyp is a build system based on Google's GYP tool and comes bundled with npm. GYP, and therefore node-gyp, requires that Python be installed.

Historically, node-gyp has been the tool of choice for building native addons. It has widespread adoption and documentation. However, some developers have run into limitations in node-gyp.

CMake.js is an alternative build system based on CMake.

CMake.js is a good choice for projects that already use CMake or for developers affected by limitations in node-gyp.

Uploading precompiled binaries #

The three tools listed here permit native addon developers and maintainers to create and upload binaries to public or private servers. These tools are typically integrated with CI/CD build systems like Travis CI and AppVeyor to build and upload binaries for a variety of platforms and architectures. These binaries are then available for download by users who do not need to have a C/C++ toolchain installed.

node-pre-gyp is a tool based on node-gyp that adds the ability to upload binaries to a server of the developer's choice. node-pre-gyp has particularly good support for uploading binaries to Amazon S3.

prebuild is a tool that supports builds using either node-gyp or CMake.js. Unlike node-pre-gyp which supports a variety of servers, prebuild uploads binaries only to GitHub releases. prebuild is a good choice for GitHub projects using CMake.js.

prebuildify is a tool based on node-gyp. The advantage of prebuildify is that the built binaries are bundled with the native module when it's uploaded to npm. The binaries are downloaded from npm and are immediately available to the module user when the native module is installed.

In order to use the N-API functions, include the file node_api.h which is located in the src directory in the node development tree:

This will opt into the default NAPI_VERSION for the given release of Node.js. In order to ensure compatibility with specific versions of N-API, the version can be specified explicitly when including the header:

This restricts the N-API surface to just the functionality that was available in the specified (and earlier) versions.

Some of the N-API surface is experimental and requires explicit opt-in:

In this case the entire API surface, including any experimental APIs, will be available to the module code.

N-API version matrix #

N-API versions are additive and versioned independently from Node.js. Version 4 is an extension to version 3 in that it has all of the APIs from version 3 with some additions. This means that it is not necessary to recompile for new versions of Node.js which are listed as supporting a later version.

1 2 3 4 5 6 v6.x v6.14.2* v8.x v8.6.0** v8.10.0* v8.11.2 v8.16.0 v9.x v9.0.0* v9.3.0* v9.11.0* v10.x v10.0.0 v10.0.0 v10.0.0 v10.16.0 v10.17.0 v10.20.0 v11.x v11.0.0 v11.0.0 v11.0.0 v11.8.0 v12.x v12.0.0 v12.0.0 v12.0.0 v12.0.0 v12.11.0 v12.17.0 v13.x v13.0.0 v13.0.0 v13.0.0 v13.0.0 v13.0.0 v14.x v14.0.0 v14.0.0 v14.0.0 v14.0.0 v14.0.0 v14.0.0

* N-API was experimental.

** Node.js 8.0.0 included N-API as experimental. It was released as N-API version 1 but continued to evolve until Node.js 8.6.0. The API is different in versions prior to Node.js 8.6.0. We recommend N-API version 3 or later.

The N-APIs associated strictly with accessing ECMAScript features from native code can be found separately in js_native_api.h and js_native_api_types.h . The APIs defined in these headers are included in node_api.h and node_api_types.h . The headers are structured in this way in order to allow implementations of N-API outside of Node.js. For those implementations the Node.js specific APIs may not be applicable.

The Node.js-specific parts of an addon can be separated from the code that exposes the actual functionality to the JavaScript environment so that the latter may be used with multiple implementations of N-API. In the example below, addon.c and addon.h refer only to js_native_api.h . This ensures that addon.c can be reused to compile against either the Node.js implementation of N-API or any implementation of N-API outside of Node.js.

addon_node.c is a separate file that contains the Node.js specific entry point to the addon and which instantiates the addon by calling into addon.c when the addon is loaded into a Node.js environment.

napi_value create_addon (napi_env env) ;

static napi_value DoSomethingUseful (napi_env env, napi_callback_info info) { return NULL ; } napi_value create_addon (napi_env env) { napi_value result; NAPI_CALL(env, napi_create_object(env, &result)); napi_value exported_function; NAPI_CALL(env, napi_create_function(env, "doSomethingUseful" , NAPI_AUTO_LENGTH, DoSomethingUseful, NULL , &exported_function)); NAPI_CALL(env, napi_set_named_property(env, result, "doSomethingUseful" , exported_function)); return result; }

NAPI_MODULE_INIT() { return create_addon(env); }

Environment life cycle APIs #

Section 8.7 of the ECMAScript Language Specification defines the concept of an "Agent" as a self-contained environment in which JavaScript code runs. Multiple such Agents may be started and terminated either concurrently or in sequence by the process.

A Node.js environment corresponds to an ECMAScript Agent. In the main process, an environment is created at startup, and additional environments can be created on separate threads to serve as worker threads. When Node.js is embedded in another application, the main thread of the application may also construct and destroy a Node.js environment multiple times during the life cycle of the application process such that each Node.js environment created by the application may, in turn, during its life cycle create and destroy additional environments as worker threads.

From the perspective of a native addon this means that the bindings it provides may be called multiple times, from multiple contexts, and even concurrently from multiple threads.

Native addons may need to allocate global state which they use during their entire life cycle such that the state must be unique to each instance of the addon.

To this end, N-API provides a way to allocate data such that its life cycle is tied to the life cycle of the Agent.

Added in: v12.8.0, v10.20.0 N-API version: 6

napi_status napi_set_instance_data (napi_env env, void * data, napi_finalize finalize_cb, void * finalize_hint) ;

[in] env : The environment that the N-API call is invoked under.

: The environment that the N-API call is invoked under. [in] data : The data item to make available to bindings of this instance.

: The data item to make available to bindings of this instance. [in] finalize_cb : The function to call when the environment is being torn down. The function receives data so that it might free it. napi_finalize provides more details.

: The function to call when the environment is being torn down. The function receives so that it might free it. provides more details. [in] finalize_hint : Optional hint to pass to the finalize callback during collection.

Returns napi_ok if the API succeeded.

This API associates data with the currently running Agent. data can later be retrieved using napi_get_instance_data() . Any existing data associated with the currently running Agent which was set by means of a previous call to napi_set_instance_data() will be overwritten. If a finalize_cb was provided by the previous call, it will not be called.

Added in: v12.8.0, v10.20.0 N-API version: 6

napi_status napi_get_instance_data (napi_env env, void ** data) ;

[in] env : The environment that the N-API call is invoked under.

: The environment that the N-API call is invoked under. [out] data : The data item that was previously associated with the currently running Agent by a call to napi_set_instance_data() .

Returns napi_ok if the API succeeded.

This API retrieves data that was previously associated with the currently running Agent via napi_set_instance_data() . If no data is set, the call will succeed and data will be set to NULL .

Basic N-API data types #

N-API exposes the following fundamental datatypes as abstractions that are consumed by the various APIs. These APIs should be treated as opaque, introspectable only with other N-API calls.

Added in: v8.0.0 N-API version: 1

Integral status code indicating the success or failure of a N-API call. Currently, the following status codes are supported.

typedef enum { napi_ok, napi_invalid_arg, napi_object_expected, napi_string_expected, napi_name_expected, napi_function_expected, napi_number_expected, napi_boolean_expected, napi_array_expected, napi_generic_failure, napi_pending_exception, napi_cancelled, napi_escape_called_twice, napi_handle_scope_mismatch, napi_callback_scope_mismatch, napi_queue_full, napi_closing, napi_bigint_expected, napi_date_expected, napi_arraybuffer_expected, napi_detachable_arraybuffer_expected, napi_would_deadlock, } napi_status;

If additional information is required upon an API returning a failed status, it can be obtained by calling napi_get_last_error_info .

Added in: v8.0.0 N-API version: 1

typedef struct { const char * error_message; void * engine_reserved; uint32_t engine_error_code; napi_status error_code; } napi_extended_error_info;

error_message : UTF8-encoded string containing a VM-neutral description of the error.

: UTF8-encoded string containing a VM-neutral description of the error. engine_reserved : Reserved for VM-specific error details. This is currently not implemented for any VM.

: Reserved for VM-specific error details. This is currently not implemented for any VM. engine_error_code : VM-specific error code. This is currently not implemented for any VM.

: VM-specific error code. This is currently not implemented for any VM. error_code : The N-API status code that originated with the last error.

See the Error handling section for additional information.

napi_env is used to represent a context that the underlying N-API implementation can use to persist VM-specific state. This structure is passed to native functions when they're invoked, and it must be passed back when making N-API calls. Specifically, the same napi_env that was passed in when the initial native function was called must be passed to any subsequent nested N-API calls. Caching the napi_env for the purpose of general reuse, and passing the napi_env between instances of the same addon running on different Worker threads is not allowed. The napi_env becomes invalid when an instance of a native addon is unloaded. Notification of this event is delivered through the callbacks given to napi_add_env_cleanup_hook and napi_set_instance_data .

This is an opaque pointer that is used to represent a JavaScript value.

Added in: v10.6.0 N-API version: 4

This is an opaque pointer that represents a JavaScript function which can be called asynchronously from multiple threads via napi_call_threadsafe_function() .

Added in: v10.6.0 N-API version: 4

A value to be given to napi_release_threadsafe_function() to indicate whether the thread-safe function is to be closed immediately ( napi_tsfn_abort ) or merely released ( napi_tsfn_release ) and thus available for subsequent use via napi_acquire_threadsafe_function() and napi_call_threadsafe_function() .

typedef enum { napi_tsfn_release, napi_tsfn_abort } napi_threadsafe_function_release_mode;

Added in: v10.6.0 N-API version: 4

A value to be given to napi_call_threadsafe_function() to indicate whether the call should block whenever the queue associated with the thread-safe function is full.

typedef enum { napi_tsfn_nonblocking, napi_tsfn_blocking } napi_threadsafe_function_call_mode;

N-API memory management types #

This is an abstraction used to control and modify the lifetime of objects created within a particular scope. In general, N-API values are created within the context of a handle scope. When a native method is called from JavaScript, a default handle scope will exist. If the user does not explicitly create a new handle scope, N-API values will be created in the default handle scope. For any invocations of code outside the execution of a native method (for instance, during a libuv callback invocation), the module is required to create a scope before invoking any functions that can result in the creation of JavaScript values.

Handle scopes are created using napi_open_handle_scope and are destroyed using napi_close_handle_scope . Closing the scope can indicate to the GC that all napi_value s created during the lifetime of the handle scope are no longer referenced from the current stack frame.

For more details, review the Object lifetime management.

Added in: v8.0.0 N-API version: 1

Escapable handle scopes are a special type of handle scope to return values created within a particular handle scope to a parent scope.

Added in: v8.0.0 N-API version: 1

This is the abstraction to use to reference a napi_value . This allows for users to manage the lifetimes of JavaScript values, including defining their minimum lifetimes explicitly.

For more details, review the Object lifetime management.

Added in: v14.8.0

A 128-bit value stored as two unsigned 64-bit integers. It serves as a UUID with which JavaScript objects can be "tagged" in order to ensure that they are of a certain type. This is a stronger check than napi_instanceof , because the latter can report a false positive if the object's prototype has been manipulated. Type-tagging is most useful in conjunction with napi_wrap because it ensures that the pointer retrieved from a wrapped object can be safely cast to the native type corresponding to the type tag that had been previously applied to the JavaScript object.

typedef struct { uint64_t lower; uint64_t upper; } napi_type_tag;

Added in: v14.10.0

An opaque value returned by napi_add_async_cleanup_hook . It must be passed to napi_remove_async_cleanup_hook when the chain of asynchronous cleanup events completes.

N-API callback types #

Added in: v8.0.0 N-API version: 1

Opaque datatype that is passed to a callback function. It can be used for getting additional information about the context in which the callback was invoked.

Added in: v8.0.0 N-API version: 1

Function pointer type for user-provided native functions which are to be exposed to JavaScript via N-API. Callback functions should satisfy the following signature:

typedef napi_value (*napi_callback) (napi_env, napi_callback_info) ;

Unless for reasons discussed in Object Lifetime Management, creating a handle and/or callback scope inside a napi_callback is not necessary.

Added in: v8.0.0 N-API version: 1

Function pointer type for add-on provided functions that allow the user to be notified when externally-owned data is ready to be cleaned up because the object with which it was associated with, has been garbage-collected. The user must provide a function satisfying the following signature which would get called upon the object's collection. Currently, napi_finalize can be used for finding out when objects that have external data are collected.

typedef void (*napi_finalize) (napi_env env, void * finalize_data, void * finalize_hint) ;

Unless for reasons discussed in Object Lifetime Management, creating a handle and/or callback scope inside the function body is not necessary.

Added in: v8.0.0 N-API version: 1

Function pointer used with functions that support asynchronous operations. Callback functions must satisfy the following signature:

typedef void (*napi_async_execute_callback) (napi_env env, void * data) ;

Implementations of this function must avoid making N-API calls that execute JavaScript or interact with JavaScript objects. N-API calls should be in the napi_async_complete_callback instead. Do not use the napi_env parameter as it will likely result in execution of JavaScript.

Added in: v8.0.0 N-API version: 1

Function pointer used with functions that support asynchronous operations. Callback functions must satisfy the following signature:

typedef void (*napi_async_complete_callback) (napi_env env, napi_status status, void * data) ;

Unless for reasons discussed in Object Lifetime Management, creating a handle and/or callback scope inside the function body is not necessary.

Added in: v10.6.0 N-API version: 4

Function pointer used with asynchronous thread-safe function calls. The callback will be called on the main thread. Its purpose is to use a data item arriving via the queue from one of the secondary threads to construct the parameters necessary for a call into JavaScript, usually via napi_call_function , and then make the call into JavaScript.

The data arriving from the secondary thread via the queue is given in the data parameter and the JavaScript function to call is given in the js_callback parameter.

N-API sets up the environment prior to calling this callback, so it is sufficient to call the JavaScript function via napi_call_function rather than via napi_make_callback .

Callback functions must satisfy the following signature:

typedef void (*napi_threadsafe_function_call_js) (napi_env env, napi_value js_callback, void * context, void * data) ;

[in] env : The environment to use for API calls, or NULL if the thread-safe function is being torn down and data may need to be freed.

: The environment to use for API calls, or if the thread-safe function is being torn down and may need to be freed. [in] js_callback : The JavaScript function to call, or NULL if the thread-safe function is being torn down and data may need to be freed. It may also be NULL if the thread-safe function was created without js_callback .

: The JavaScript function to call, or if the thread-safe function is being torn down and may need to be freed. It may also be if the thread-safe function was created without . [in] context : The optional data with which the thread-safe function was created.

: The optional data with which the thread-safe function was created. [in] data : Data created by the secondary thread. It is the responsibility of the callback to convert this native data to JavaScript values (with N-API functions) that can be passed as parameters when js_callback is invoked. This pointer is managed entirely by the threads and this callback. Thus this callback should free the data.

Unless for reasons discussed in Object Lifetime Management, creating a handle and/or callback scope inside the function body is not necessary.

Added in: v14.10.0

Function pointer used with napi_add_async_cleanup_hook . It will be called when the environment is being torn down.

Callback functions must satisfy the following signature:

typedef void (*napi_async_cleanup_hook) (napi_async_cleanup_hook_handle handle, void * data) ;

[in] handle : The handle that must be passed to napi_remove_async_cleanup_hook after completion of the asynchronous cleanup.

: The handle that must be passed to after completion of the asynchronous cleanup. [in] data : The data that was passed to napi_add_async_cleanup_hook .

The body of the function should initiate the asynchronous cleanup actions at the end of which handle must be passed in a call to napi_remove_async_cleanup_hook .

Error handling #

N-API uses both return values and JavaScript exceptions for error handling. The following sections explain the approach for each case.

Return values #

All of the N-API functions share the same error handling pattern. The return type of all API functions is napi_status .

The return value will be napi_ok if the request was successful and no uncaught JavaScript exception was thrown. If an error occurred AND an exception was thrown, the napi_status value for the error will be returned. If an exception was thrown, and no error occurred, napi_pending_exception will be returned.

In cases where a return value other than napi_ok or napi_pending_exception is returned, napi_is_exception_pending must be called to check if an exception is pending. See the section on exceptions for more details.

The full set of possible napi_status values is defined in napi_api_types.h .

The napi_status return value provides a VM-independent representation of the error which occurred. In some cases it is useful to be able to get more detailed information, including a string representing the error as well as VM (engine)-specific information.

In order to retrieve this information napi_get_last_error_info is provided which returns a napi_extended_error_info structure. The format of the napi_extended_error_info structure is as follows:

Added in: v8.0.0 N-API version: 1

typedef struct napi_extended_error_info { const char * error_message; void * engine_reserved; uint32_t engine_error_code; napi_status error_code; };

error_message : Textual representation of the error that occurred.

: Textual representation of the error that occurred. engine_reserved : Opaque handle reserved for engine use only.

: Opaque handle reserved for engine use only. engine_error_code : VM specific error code.

: VM specific error code. error_code : n-api status code for the last error.

napi_get_last_error_info returns the information for the last N-API call that was made.

Do not rely on the content or format of any of the extended information as it is not subject to SemVer and may change at any time. It is intended only for logging purposes.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_last_error_info (napi_env env, const napi_extended_error_info** result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : The napi_extended_error_info structure with more information about the error.

Returns napi_ok if the API succeeded.

This API retrieves a napi_extended_error_info structure with information about the last error that occurred.

The content of the napi_extended_error_info returned is only valid up until an n-api function is called on the same env .

Do not rely on the content or format of any of the extended information as it is not subject to SemVer and may change at any time. It is intended only for logging purposes.

This API can be called even if there is a pending JavaScript exception.

Any N-API function call may result in a pending JavaScript exception. This is the case for any of the API functions, even those that may not cause the execution of JavaScript.

If the napi_status returned by a function is napi_ok then no exception is pending and no additional action is required. If the napi_status returned is anything other than napi_ok or napi_pending_exception , in order to try to recover and continue instead of simply returning immediately, napi_is_exception_pending must be called in order to determine if an exception is pending or not.

In many cases when an N-API function is called and an exception is already pending, the function will return immediately with a napi_status of napi_pending_exception . However, this is not the case for all functions. N-API allows a subset of the functions to be called to allow for some minimal cleanup before returning to JavaScript. In that case, napi_status will reflect the status for the function. It will not reflect previous pending exceptions. To avoid confusion, check the error status after every function call.

When an exception is pending one of two approaches can be employed.

The first approach is to do any appropriate cleanup and then return so that execution will return to JavaScript. As part of the transition back to JavaScript, the exception will be thrown at the point in the JavaScript code where the native method was invoked. The behavior of most N-API calls is unspecified while an exception is pending, and many will simply return napi_pending_exception , so do as little as possible and then return to JavaScript where the exception can be handled.

The second approach is to try to handle the exception. There will be cases where the native code can catch the exception, take the appropriate action, and then continue. This is only recommended in specific cases where it is known that the exception can be safely handled. In these cases napi_get_and_clear_last_exception can be used to get and clear the exception. On success, result will contain the handle to the last JavaScript Object thrown. If it is determined, after retrieving the exception, the exception cannot be handled after all it can be re-thrown it with napi_throw where error is the JavaScript Error object to be thrown.

The following utility functions are also available in case native code needs to throw an exception or determine if a napi_value is an instance of a JavaScript Error object: napi_throw_error , napi_throw_type_error , napi_throw_range_error and napi_is_error .

The following utility functions are also available in case native code needs to create an Error object: napi_create_error , napi_create_type_error , and napi_create_range_error , where result is the napi_value that refers to the newly created JavaScript Error object.

The Node.js project is adding error codes to all of the errors generated internally. The goal is for applications to use these error codes for all error checking. The associated error messages will remain, but will only be meant to be used for logging and display with the expectation that the message can change without SemVer applying. In order to support this model with N-API, both in internal functionality and for module specific functionality (as its good practice), the throw_ and create_ functions take an optional code parameter which is the string for the code to be added to the error object. If the optional parameter is NULL then no code will be associated with the error. If a code is provided, the name associated with the error is also updated to be:

originalName [code]

where originalName is the original name associated with the error and code is the code that was provided. For example, if the code is 'ERR_ERROR_1' and a TypeError is being created the name will be:

TypeError [ERR_ERROR_1]

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_throw (napi_env env, napi_value error) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] error : The JavaScript value to be thrown.

Returns napi_ok if the API succeeded.

This API throws the JavaScript value provided.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_throw_error (napi_env env, const char * code, const char * msg) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] code : Optional error code to be set on the error.

: Optional error code to be set on the error. [in] msg : C string representing the text to be associated with the error.

Returns napi_ok if the API succeeded.

This API throws a JavaScript Error with the text provided.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_throw_type_error (napi_env env, const char * code, const char * msg) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] code : Optional error code to be set on the error.

: Optional error code to be set on the error. [in] msg : C string representing the text to be associated with the error.

Returns napi_ok if the API succeeded.

This API throws a JavaScript TypeError with the text provided.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_throw_range_error (napi_env env, const char * code, const char * msg) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] code : Optional error code to be set on the error.

: Optional error code to be set on the error. [in] msg : C string representing the text to be associated with the error.

Returns napi_ok if the API succeeded.

This API throws a JavaScript RangeError with the text provided.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_is_error (napi_env env, napi_value value, bool * result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : The napi_value to be checked.

: The to be checked. [out] result : Boolean value that is set to true if napi_value represents an error, false otherwise.

Returns napi_ok if the API succeeded.

This API queries a napi_value to check if it represents an error object.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_create_error (napi_env env, napi_value code, napi_value msg, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] code : Optional napi_value with the string for the error code to be associated with the error.

: Optional with the string for the error code to be associated with the error. [in] msg : napi_value that references a JavaScript String to be used as the message for the Error .

: that references a JavaScript to be used as the message for the . [out] result : napi_value representing the error created.

Returns napi_ok if the API succeeded.

This API returns a JavaScript Error with the text provided.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_create_type_error (napi_env env, napi_value code, napi_value msg, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] code : Optional napi_value with the string for the error code to be associated with the error.

: Optional with the string for the error code to be associated with the error. [in] msg : napi_value that references a JavaScript String to be used as the message for the Error .

: that references a JavaScript to be used as the message for the . [out] result : napi_value representing the error created.

Returns napi_ok if the API succeeded.

This API returns a JavaScript TypeError with the text provided.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_create_range_error (napi_env env, napi_value code, napi_value msg, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] code : Optional napi_value with the string for the error code to be associated with the error.

: Optional with the string for the error code to be associated with the error. [in] msg : napi_value that references a JavaScript String to be used as the message for the Error .

: that references a JavaScript to be used as the message for the . [out] result : napi_value representing the error created.

Returns napi_ok if the API succeeded.

This API returns a JavaScript RangeError with the text provided.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_and_clear_last_exception (napi_env env, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : The exception if one is pending, NULL otherwise.

Returns napi_ok if the API succeeded.

This API can be called even if there is a pending JavaScript exception.

Added in: v8.0.0 N-API version: 1

napi_status napi_is_exception_pending (napi_env env, bool * result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : Boolean value that is set to true if an exception is pending.

Returns napi_ok if the API succeeded.

This API can be called even if there is a pending JavaScript exception.

Added in: v9.10.0 N-API version: 3

napi_status napi_fatal_exception (napi_env env, napi_value err) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] err : The error that is passed to 'uncaughtException' .

Trigger an 'uncaughtException' in JavaScript. Useful if an async callback throws an exception with no way to recover.

Fatal errors #

In the event of an unrecoverable error in a native module, a fatal error can be thrown to immediately terminate the process.

Added in: v8.2.0 N-API version: 1

NAPI_NO_RETURN void napi_fatal_error ( const char * location, size_t location_len, const char * message, size_t message_len) ;

[in] location : Optional location at which the error occurred.

: Optional location at which the error occurred. [in] location_len : The length of the location in bytes, or NAPI_AUTO_LENGTH if it is null-terminated.

: The length of the location in bytes, or if it is null-terminated. [in] message : The message associated with the error.

: The message associated with the error. [in] message_len : The length of the message in bytes, or NAPI_AUTO_LENGTH if it is null-terminated.

The function call does not return, the process will be terminated.

This API can be called even if there is a pending JavaScript exception.

Object lifetime management #

As N-API calls are made, handles to objects in the heap for the underlying VM may be returned as napi_values . These handles must hold the objects 'live' until they are no longer required by the native code, otherwise the objects could be collected before the native code was finished using them.

As object handles are returned they are associated with a 'scope'. The lifespan for the default scope is tied to the lifespan of the native method call. The result is that, by default, handles remain valid and the objects associated with these handles will be held live for the lifespan of the native method call.

In many cases, however, it is necessary that the handles remain valid for either a shorter or longer lifespan than that of the native method. The sections which follow describe the N-API functions that can be used to change the handle lifespan from the default.

Making handle lifespan shorter than that of the native method #

It is often necessary to make the lifespan of handles shorter than the lifespan of a native method. For example, consider a native method that has a loop which iterates through the elements in a large array:

for ( int i = 0 ; i < 1000000 ; i++) { napi_value result; napi_status status = napi_get_element(env, object, i, &result); if (status != napi_ok) { break ; } }

This would result in a large number of handles being created, consuming substantial resources. In addition, even though the native code could only use the most recent handle, all of the associated objects would also be kept alive since they all share the same scope.

To handle this case, N-API provides the ability to establish a new 'scope' to which newly created handles will be associated. Once those handles are no longer required, the scope can be 'closed' and any handles associated with the scope are invalidated. The methods available to open/close scopes are napi_open_handle_scope and napi_close_handle_scope .

N-API only supports a single nested hierarchy of scopes. There is only one active scope at any time, and all new handles will be associated with that scope while it is active. Scopes must be closed in the reverse order from which they are opened. In addition, all scopes created within a native method must be closed before returning from that method.

Taking the earlier example, adding calls to napi_open_handle_scope and napi_close_handle_scope would ensure that at most a single handle is valid throughout the execution of the loop:

for ( int i = 0 ; i < 1000000 ; i++) { napi_handle_scope scope; napi_status status = napi_open_handle_scope(env, &scope); if (status != napi_ok) { break ; } napi_value result; status = napi_get_element(env, object, i, &result); if (status != napi_ok) { break ; } status = napi_close_handle_scope(env, scope); if (status != napi_ok) { break ; } }

When nesting scopes, there are cases where a handle from an inner scope needs to live beyond the lifespan of that scope. N-API supports an 'escapable scope' in order to support this case. An escapable scope allows one handle to be 'promoted' so that it 'escapes' the current scope and the lifespan of the handle changes from the current scope to that of the outer scope.

The methods available to open/close escapable scopes are napi_open_escapable_handle_scope and napi_close_escapable_handle_scope .

The request to promote a handle is made through napi_escape_handle which can only be called once.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_open_handle_scope (napi_env env, napi_handle_scope* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : napi_value representing the new scope.

Returns napi_ok if the API succeeded.

This API opens a new scope.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_close_handle_scope (napi_env env, napi_handle_scope scope) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] scope : napi_value representing the scope to be closed.

Returns napi_ok if the API succeeded.

This API closes the scope passed in. Scopes must be closed in the reverse order from which they were created.

This API can be called even if there is a pending JavaScript exception.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_open_escapable_handle_scope (napi_env env, napi_handle_scope* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : napi_value representing the new scope.

Returns napi_ok if the API succeeded.

This API opens a new scope from which one object can be promoted to the outer scope.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_close_escapable_handle_scope (napi_env env, napi_handle_scope scope) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] scope : napi_value representing the scope to be closed.

Returns napi_ok if the API succeeded.

This API closes the scope passed in. Scopes must be closed in the reverse order from which they were created.

This API can be called even if there is a pending JavaScript exception.

Added in: v8.0.0 N-API version: 1

napi_status napi_escape_handle (napi_env env, napi_escapable_handle_scope scope, napi_value escapee, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] scope : napi_value representing the current scope.

: representing the current scope. [in] escapee : napi_value representing the JavaScript Object to be escaped.

: representing the JavaScript to be escaped. [out] result : napi_value representing the handle to the escaped Object in the outer scope.

Returns napi_ok if the API succeeded.

This API promotes the handle to the JavaScript object so that it is valid for the lifetime of the outer scope. It can only be called once per scope. If it is called more than once an error will be returned.

This API can be called even if there is a pending JavaScript exception.

References to objects with a lifespan longer than that of the native method #

In some cases an addon will need to be able to create and reference objects with a lifespan longer than that of a single native method invocation. For example, to create a constructor and later use that constructor in a request to creates instances, it must be possible to reference the constructor object across many different instance creation requests. This would not be possible with a normal handle returned as a napi_value as described in the earlier section. The lifespan of a normal handle is managed by scopes and all scopes must be closed before the end of a native method.

N-API provides methods to create persistent references to an object. Each persistent reference has an associated count with a value of 0 or higher. The count determines if the reference will keep the corresponding object live. References with a count of 0 do not prevent the object from being collected and are often called 'weak' references. Any count greater than 0 will prevent the object from being collected.

References can be created with an initial reference count. The count can then be modified through napi_reference_ref and napi_reference_unref . If an object is collected while the count for a reference is 0, all subsequent calls to get the object associated with the reference napi_get_reference_value will return NULL for the returned napi_value . An attempt to call napi_reference_ref for a reference whose object has been collected will result in an error.

References must be deleted once they are no longer required by the addon. When a reference is deleted it will no longer prevent the corresponding object from being collected. Failure to delete a persistent reference will result in a 'memory leak' with both the native memory for the persistent reference and the corresponding object on the heap being retained forever.

There can be multiple persistent references created which refer to the same object, each of which will either keep the object live or not based on its individual count.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_create_reference (napi_env env, napi_value value, uint32_t initial_refcount, napi_ref* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing the Object to which we want a reference.

: representing the to which we want a reference. [in] initial_refcount : Initial reference count for the new reference.

: Initial reference count for the new reference. [out] result : napi_ref pointing to the new reference.

Returns napi_ok if the API succeeded.

This API create a new reference with the specified reference count to the Object passed in.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_delete_reference (napi_env env, napi_ref ref) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] ref : napi_ref to be deleted.

Returns napi_ok if the API succeeded.

This API deletes the reference passed in.

This API can be called even if there is a pending JavaScript exception.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_reference_ref (napi_env env, napi_ref ref, uint32_t * result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] ref : napi_ref for which the reference count will be incremented.

: for which the reference count will be incremented. [out] result : The new reference count.

Returns napi_ok if the API succeeded.

This API increments the reference count for the reference passed in and returns the resulting reference count.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_reference_unref (napi_env env, napi_ref ref, uint32_t * result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] ref : napi_ref for which the reference count will be decremented.

: for which the reference count will be decremented. [out] result : The new reference count.

Returns napi_ok if the API succeeded.

This API decrements the reference count for the reference passed in and returns the resulting reference count.

Added in: v8.0.0 N-API version: 1

NAPI_EXTERN napi_status napi_get_reference_value (napi_env env, napi_ref ref, napi_value* result) ;

the napi_value passed in or out of these methods is a handle to the object to which the reference is related.

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] ref : napi_ref for which we requesting the corresponding Object .

: for which we requesting the corresponding . [out] result : The napi_value for the Object referenced by the napi_ref .

Returns napi_ok if the API succeeded.

If still valid, this API returns the napi_value representing the JavaScript Object associated with the napi_ref . Otherwise, result will be NULL .

Cleanup on exit of the current Node.js instance #

While a Node.js process typically releases all its resources when exiting, embedders of Node.js, or future Worker support, may require addons to register clean-up hooks that will be run once the current Node.js instance exits.

N-API provides functions for registering and un-registering such callbacks. When those callbacks are run, all resources that are being held by the addon should be freed up.

Added in: v10.2.0 N-API version: 3

NODE_EXTERN napi_status napi_add_env_cleanup_hook (napi_env env, void (*fun)( void * arg), void * arg) ;

Registers fun as a function to be run with the arg parameter once the current Node.js environment exits.

A function can safely be specified multiple times with different arg values. In that case, it will be called multiple times as well. Providing the same fun and arg values multiple times is not allowed and will lead the process to abort.

The hooks will be called in reverse order, i.e. the most recently added one will be called first.

Removing this hook can be done by using napi_remove_env_cleanup_hook . Typically, that happens when the resource for which this hook was added is being torn down anyway.

For asynchronous cleanup, napi_add_async_cleanup_hook is available.

Added in: v10.2.0 N-API version: 3

NAPI_EXTERN napi_status napi_remove_env_cleanup_hook (napi_env env, void (*fun)( void * arg), void * arg) ;

Unregisters fun as a function to be run with the arg parameter once the current Node.js environment exits. Both the argument and the function value need to be exact matches.

The function must have originally been registered with napi_add_env_cleanup_hook , otherwise the process will abort.

History Version Changes v14.10.0 Changed signature of the hook callback. v14.8.0 Added in: v14.8.0

NAPI_EXTERN napi_status napi_add_async_cleanup_hook ( napi_env env, napi_async_cleanup_hook hook, void * arg, napi_async_cleanup_hook_handle* remove_handle) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] hook : The function pointer to call at environment teardown.

: The function pointer to call at environment teardown. [in] arg : The pointer to pass to hook when it gets called.

: The pointer to pass to when it gets called. [out] remove_handle : Optional handle that refers to the asynchronous cleanup hook.

Registers hook , which is a function of type napi_async_cleanup_hook , as a function to be run with the remove_handle and arg parameters once the current Node.js environment exits.

Unlike napi_add_env_cleanup_hook , the hook is allowed to be asynchronous.

Otherwise, behavior generally matches that of napi_add_env_cleanup_hook .

If remove_handle is not NULL , an opaque value will be stored in it that must later be passed to napi_remove_async_cleanup_hook , regardless of whether the hook has already been invoked. Typically, that happens when the resource for which this hook was added is being torn down anyway.

History Version Changes v14.10.0 Removed env parameter. v14.8.0 Added in: v14.8.0

NAPI_EXTERN napi_status napi_remove_async_cleanup_hook ( napi_async_cleanup_hook_handle remove_handle) ;

[in] remove_handle : The handle to an asynchronous cleanup hook that was created with napi_add_async_cleanup_hook .

Unregisters the cleanup hook corresponding to remove_handle . This will prevent the hook from being executed, unless it has already started executing. This must be called on any napi_async_cleanup_hook_handle value obtained from napi_add_async_cleanup_hook .

Module registration #

N-API modules are registered in a manner similar to other modules except that instead of using the NODE_MODULE macro the following is used:

NAPI_MODULE(NODE_GYP_MODULE_NAME, Init)

The next difference is the signature for the Init method. For a N-API module it is as follows:

napi_value Init (napi_env env, napi_value exports) ;

The return value from Init is treated as the exports object for the module. The Init method is passed an empty object via the exports parameter as a convenience. If Init returns NULL , the parameter passed as exports is exported by the module. N-API modules cannot modify the module object but can specify anything as the exports property of the module.

To add the method hello as a function so that it can be called as a method provided by the addon:

napi_value Init (napi_env env, napi_value exports) { napi_status status; napi_property_descriptor desc = { "hello" , NULL , Method, NULL , NULL , NULL , napi_default, NULL }; status = napi_define_properties(env, exports, 1 , &desc); if (status != napi_ok) return NULL ; return exports; }

To set a function to be returned by the require() for the addon:

napi_value Init (napi_env env, napi_value exports) { napi_value method; napi_status status; status = napi_create_function(env, "exports" , NAPI_AUTO_LENGTH, Method, NULL , &method); if (status != napi_ok) return NULL ; return method; }

To define a class so that new instances can be created (often used with Object wrap):

napi_value Init (napi_env env, napi_value exports) { napi_status status; napi_property_descriptor properties[] = { { "value" , NULL , NULL , GetValue, SetValue, NULL , napi_default, NULL }, DECLARE_NAPI_METHOD( "plusOne" , PlusOne), DECLARE_NAPI_METHOD( "multiply" , Multiply), }; napi_value cons; status = napi_define_class(env, "MyObject" , New, NULL , 3 , properties, &cons); if (status != napi_ok) return NULL ; status = napi_create_reference(env, cons, 1 , &constructor); if (status != napi_ok) return NULL ; status = napi_set_named_property(env, exports, "MyObject" , cons); if (status != napi_ok) return NULL ; return exports; }

If the module will be loaded multiple times during the lifetime of the Node.js process, use the NAPI_MODULE_INIT macro to initialize the module:

NAPI_MODULE_INIT() { napi_value answer; napi_status result; status = napi_create_int64(env, 42 , &answer); if (status != napi_ok) return NULL ; status = napi_set_named_property(env, exports, "answer" , answer); if (status != napi_ok) return NULL ; return exports; }

This macro includes NAPI_MODULE , and declares an Init function with a special name and with visibility beyond the addon. This will allow Node.js to initialize the module even if it is loaded multiple times.

There are a few design considerations when declaring a module that may be loaded multiple times. The documentation of context-aware addons provides more details.

The variables env and exports will be available inside the function body following the macro invocation.

For more details on setting properties on objects, see the section on Working with JavaScript properties.

For more details on building addon modules in general, refer to the existing API.

Working with JavaScript values #

N-API exposes a set of APIs to create all types of JavaScript values. Some of these types are documented under Section 6 of the ECMAScript Language Specification.

Fundamentally, these APIs are used to do one of the following:

Create a new JavaScript object Convert from a primitive C type to an N-API value Convert from N-API value to a primitive C type Get global instances including undefined and null

N-API values are represented by the type napi_value . Any N-API call that requires a JavaScript value takes in a napi_value . In some cases, the API does check the type of the napi_value up-front. However, for better performance, it's better for the caller to make sure that the napi_value in question is of the JavaScript type expected by the API.

Enum types #

Added in: v13.7.0, v10.20.0 N-API version: 6

typedef enum { napi_key_include_prototypes, napi_key_own_only } napi_key_collection_mode;

Describes the Keys/Properties filter enums:

napi_key_collection_mode limits the range of collected properties.

napi_key_own_only limits the collected properties to the given object only. napi_key_include_prototypes will include all keys of the objects's prototype chain as well.

Added in: v13.7.0, v10.20.0 N-API version: 6

typedef enum { napi_key_all_properties = 0 , napi_key_writable = 1 , napi_key_enumerable = 1 << 1 , napi_key_configurable = 1 << 2 , napi_key_skip_strings = 1 << 3 , napi_key_skip_symbols = 1 << 4 } napi_key_filter;

Property filter bits. They can be or'ed to build a composite filter.

Added in: v13.7.0, v10.20.0 N-API version: 6

typedef enum { napi_key_keep_numbers, napi_key_numbers_to_strings } napi_key_conversion;

napi_key_numbers_to_strings will convert integer indices to strings. napi_key_keep_numbers will return numbers for integer indices.

typedef enum { napi_undefined, napi_null, napi_boolean, napi_number, napi_string, napi_symbol, napi_object, napi_function, napi_external, napi_bigint, } napi_valuetype;

Describes the type of a napi_value . This generally corresponds to the types described in Section 6.1 of the ECMAScript Language Specification. In addition to types in that section, napi_valuetype can also represent Function s and Object s with external data.

A JavaScript value of type napi_external appears in JavaScript as a plain object such that no properties can be set on it, and no prototype.

typedef enum { napi_int8_array, napi_uint8_array, napi_uint8_clamped_array, napi_int16_array, napi_uint16_array, napi_int32_array, napi_uint32_array, napi_float32_array, napi_float64_array, napi_bigint64_array, napi_biguint64_array, } napi_typedarray_type;

This represents the underlying binary scalar datatype of the TypedArray . Elements of this enum correspond to Section 22.2 of the ECMAScript Language Specification.

Object creation functions #

Added in: v8.0.0 N-API version: 1

napi_status napi_create_array (napi_env env, napi_value* result)

[in] env : The environment that the N-API call is invoked under.

: The environment that the N-API call is invoked under. [out] result : A napi_value representing a JavaScript Array .

Returns napi_ok if the API succeeded.

This API returns an N-API value corresponding to a JavaScript Array type. JavaScript arrays are described in Section 22.1 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_array_with_length (napi_env env, size_t length, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] length : The initial length of the Array .

: The initial length of the . [out] result : A napi_value representing a JavaScript Array .

Returns napi_ok if the API succeeded.

This API returns an N-API value corresponding to a JavaScript Array type. The Array 's length property is set to the passed-in length parameter. However, the underlying buffer is not guaranteed to be pre-allocated by the VM when the array is created. That behavior is left to the underlying VM implementation. If the buffer must be a contiguous block of memory that can be directly read and/or written via C, consider using napi_create_external_arraybuffer .

JavaScript arrays are described in Section 22.1 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_arraybuffer (napi_env env, size_t byte_length, void ** data, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] length : The length in bytes of the array buffer to create.

: The length in bytes of the array buffer to create. [out] data : Pointer to the underlying byte buffer of the ArrayBuffer .

: Pointer to the underlying byte buffer of the . [out] result : A napi_value representing a JavaScript ArrayBuffer .

Returns napi_ok if the API succeeded.

This API returns an N-API value corresponding to a JavaScript ArrayBuffer . ArrayBuffer s are used to represent fixed-length binary data buffers. They are normally used as a backing-buffer for TypedArray objects. The ArrayBuffer allocated will have an underlying byte buffer whose size is determined by the length parameter that's passed in. The underlying buffer is optionally returned back to the caller in case the caller wants to directly manipulate the buffer. This buffer can only be written to directly from native code. To write to this buffer from JavaScript, a typed array or DataView object would need to be created.

JavaScript ArrayBuffer objects are described in Section 24.1 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_buffer (napi_env env, size_t size , void ** data, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] size : Size in bytes of the underlying buffer.

: Size in bytes of the underlying buffer. [out] data : Raw pointer to the underlying buffer.

: Raw pointer to the underlying buffer. [out] result : A napi_value representing a node::Buffer .

Returns napi_ok if the API succeeded.

This API allocates a node::Buffer object. While this is still a fully-supported data structure, in most cases using a TypedArray will suffice.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_buffer_copy (napi_env env, size_t length, const void * data, void ** result_data, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] size : Size in bytes of the input buffer (should be the same as the size of the new buffer).

: Size in bytes of the input buffer (should be the same as the size of the new buffer). [in] data : Raw pointer to the underlying buffer to copy from.

: Raw pointer to the underlying buffer to copy from. [out] result_data : Pointer to the new Buffer 's underlying data buffer.

: Pointer to the new 's underlying data buffer. [out] result : A napi_value representing a node::Buffer .

Returns napi_ok if the API succeeded.

This API allocates a node::Buffer object and initializes it with data copied from the passed-in buffer. While this is still a fully-supported data structure, in most cases using a TypedArray will suffice.

napi_create_date

Added in: v11.11.0, v10.17.0 N-API version: 5

napi_status napi_create_date (napi_env env, double time, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] time : ECMAScript time value in milliseconds since 01 January, 1970 UTC.

: ECMAScript time value in milliseconds since 01 January, 1970 UTC. [out] result : A napi_value representing a JavaScript Date .

Returns napi_ok if the API succeeded.

This API does not observe leap seconds; they are ignored, as ECMAScript aligns with POSIX time specification.

This API allocates a JavaScript Date object.

JavaScript Date objects are described in Section 20.3 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_external (napi_env env, void * data, napi_finalize finalize_cb, void * finalize_hint, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] data : Raw pointer to the external data.

: Raw pointer to the external data. [in] finalize_cb : Optional callback to call when the external value is being collected. napi_finalize provides more details.

: Optional callback to call when the external value is being collected. provides more details. [in] finalize_hint : Optional hint to pass to the finalize callback during collection.

: Optional hint to pass to the finalize callback during collection. [out] result : A napi_value representing an external value.

Returns napi_ok if the API succeeded.

This API allocates a JavaScript value with external data attached to it. This is used to pass external data through JavaScript code, so it can be retrieved later by native code using napi_get_value_external .

The API adds a napi_finalize callback which will be called when the JavaScript object just created is ready for garbage collection. It is similar to napi_wrap() except that:

the native data cannot be retrieved later using napi_unwrap() ,

, nor can it be removed later using napi_remove_wrap() , and

, and the object created by the API can be used with napi_wrap() .

The created value is not an object, and therefore does not support additional properties. It is considered a distinct value type: calling napi_typeof() with an external value yields napi_external .

Added in: v8.0.0 N-API version: 1

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)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] external_data : Pointer to the underlying byte buffer of the ArrayBuffer .

: Pointer to the underlying byte buffer of the . [in] byte_length : The length in bytes of the underlying buffer.

: The length in bytes of the underlying buffer. [in] finalize_cb : Optional callback to call when the ArrayBuffer is being collected. napi_finalize provides more details.

: Optional callback to call when the is being collected. provides more details. [in] finalize_hint : Optional hint to pass to the finalize callback during collection.

: Optional hint to pass to the finalize callback during collection. [out] result : A napi_value representing a JavaScript ArrayBuffer .

Returns napi_ok if the API succeeded.

This API returns an N-API value corresponding to a JavaScript ArrayBuffer . The underlying byte buffer of the ArrayBuffer is externally allocated and managed. The caller must ensure that the byte buffer remains valid until the finalize callback is called.

The API adds a napi_finalize callback which will be called when the JavaScript object just created is ready for garbage collection. It is similar to napi_wrap() except that:

the native data cannot be retrieved later using napi_unwrap() ,

, nor can it be removed later using napi_remove_wrap() , and

, and the object created by the API can be used with napi_wrap() .

JavaScript ArrayBuffer s are described in Section 24.1 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_external_buffer (napi_env env, size_t length, void * data, napi_finalize finalize_cb, void * finalize_hint, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] length : Size in bytes of the input buffer (should be the same as the size of the new buffer).

: Size in bytes of the input buffer (should be the same as the size of the new buffer). [in] data : Raw pointer to the underlying buffer to expose to JavaScript.

: Raw pointer to the underlying buffer to expose to JavaScript. [in] finalize_cb : Optional callback to call when the ArrayBuffer is being collected. napi_finalize provides more details.

: Optional callback to call when the is being collected. provides more details. [in] finalize_hint : Optional hint to pass to the finalize callback during collection.

: Optional hint to pass to the finalize callback during collection. [out] result : A napi_value representing a node::Buffer .

Returns napi_ok if the API succeeded.

This API allocates a node::Buffer object and initializes it with data backed by the passed in buffer. While this is still a fully-supported data structure, in most cases using a TypedArray will suffice.

The API adds a napi_finalize callback which will be called when the JavaScript object just created is ready for garbage collection. It is similar to napi_wrap() except that:

the native data cannot be retrieved later using napi_unwrap() ,

, nor can it be removed later using napi_remove_wrap() , and

, and the object created by the API can be used with napi_wrap() .

For Node.js >=4 Buffers are Uint8Array s.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_object (napi_env env, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : A napi_value representing a JavaScript Object .

Returns napi_ok if the API succeeded.

This API allocates a default JavaScript Object . It is the equivalent of doing new Object() in JavaScript.

The JavaScript Object type is described in Section 6.1.7 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_symbol (napi_env env, napi_value description, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] description : Optional napi_value which refers to a JavaScript String to be set as the description for the symbol.

: Optional which refers to a JavaScript to be set as the description for the symbol. [out] result : A napi_value representing a JavaScript Symbol .

Returns napi_ok if the API succeeded.

This API creates a JavaScript Symbol object from a UTF8-encoded C string.

The JavaScript Symbol type is described in Section 19.4 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

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)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] type : Scalar datatype of the elements within the TypedArray .

: Scalar datatype of the elements within the . [in] length : Number of elements in the TypedArray .

: Number of elements in the . [in] arraybuffer : ArrayBuffer underlying the typed array.

: underlying the typed array. [in] byte_offset : The byte offset within the ArrayBuffer from which to start projecting the TypedArray .

: The byte offset within the from which to start projecting the . [out] result : A napi_value representing a JavaScript TypedArray .

Returns napi_ok if the API succeeded.

This API creates a JavaScript TypedArray object over an existing ArrayBuffer . TypedArray objects provide an array-like view over an underlying data buffer where each element has the same underlying binary scalar datatype.

It's required that (length * size_of_element) + byte_offset should be <= the size in bytes of the array passed in. If not, a RangeError exception is raised.

JavaScript TypedArray objects are described in Section 22.2 of the ECMAScript Language Specification.

Added in: v8.3.0 N-API version: 1

napi_status napi_create_dataview (napi_env env, size_t byte_length, napi_value arraybuffer, size_t byte_offset, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] length : Number of elements in the DataView .

: Number of elements in the . [in] arraybuffer : ArrayBuffer underlying the DataView .

: underlying the . [in] byte_offset : The byte offset within the ArrayBuffer from which to start projecting the DataView .

: The byte offset within the from which to start projecting the . [out] result : A napi_value representing a JavaScript DataView .

Returns napi_ok if the API succeeded.

This API creates a JavaScript DataView object over an existing ArrayBuffer . DataView objects provide an array-like view over an underlying data buffer, but one which allows items of different size and type in the ArrayBuffer .

It is required that byte_length + byte_offset is less than or equal to the size in bytes of the array passed in. If not, a RangeError exception is raised.

JavaScript DataView objects are described in Section 24.3 of the ECMAScript Language Specification.

Functions to convert from C types to N-API #

Added in: v8.4.0 N-API version: 1

napi_status napi_create_int32 (napi_env env, int32_t value, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : Integer value to be represented in JavaScript.

: Integer value to be represented in JavaScript. [out] result : A napi_value representing a JavaScript Number .

Returns napi_ok if the API succeeded.

This API is used to convert from the C int32_t type to the JavaScript Number type.

The JavaScript Number type is described in Section 6.1.6 of the ECMAScript Language Specification.

Added in: v8.4.0 N-API version: 1

napi_status napi_create_uint32 (napi_env env, uint32_t value, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : Unsigned integer value to be represented in JavaScript.

: Unsigned integer value to be represented in JavaScript. [out] result : A napi_value representing a JavaScript Number .

Returns napi_ok if the API succeeded.

This API is used to convert from the C uint32_t type to the JavaScript Number type.

The JavaScript Number type is described in Section 6.1.6 of the ECMAScript Language Specification.

Added in: v8.4.0 N-API version: 1

napi_status napi_create_int64 (napi_env env, int64_t value, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : Integer value to be represented in JavaScript.

: Integer value to be represented in JavaScript. [out] result : A napi_value representing a JavaScript Number .

Returns napi_ok if the API succeeded.

This API is used to convert from the C int64_t type to the JavaScript Number type.

The JavaScript Number type is described in Section 6.1.6 of the ECMAScript Language Specification. Note the complete range of int64_t cannot be represented with full precision in JavaScript. Integer values outside the range of Number.MIN_SAFE_INTEGER -(2**53 - 1) - Number.MAX_SAFE_INTEGER (2**53 - 1) will lose precision.

Added in: v8.4.0 N-API version: 1

napi_status napi_create_double (napi_env env, double value, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : Double-precision value to be represented in JavaScript.

: Double-precision value to be represented in JavaScript. [out] result : A napi_value representing a JavaScript Number .

Returns napi_ok if the API succeeded.

This API is used to convert from the C double type to the JavaScript Number type.

The JavaScript Number type is described in Section 6.1.6 of the ECMAScript Language Specification.

Added in: v10.7.0 N-API version: 6

napi_status napi_create_bigint_int64 (napi_env env, int64_t value, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : Integer value to be represented in JavaScript.

: Integer value to be represented in JavaScript. [out] result : A napi_value representing a JavaScript BigInt .

Returns napi_ok if the API succeeded.

This API converts the C int64_t type to the JavaScript BigInt type.

Added in: v10.7.0 N-API version: 6

napi_status napi_create_bigint_uint64 (napi_env env, uint64_t value, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : Unsigned integer value to be represented in JavaScript.

: Unsigned integer value to be represented in JavaScript. [out] result : A napi_value representing a JavaScript BigInt .

Returns napi_ok if the API succeeded.

This API converts the C uint64_t type to the JavaScript BigInt type.

Added in: v10.7.0 N-API version: 6

napi_status napi_create_bigint_words (napi_env env, int sign_bit, size_t word_count, const uint64_t * words, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] sign_bit : Determines if the resulting BigInt will be positive or negative.

: Determines if the resulting will be positive or negative. [in] word_count : The length of the words array.

: The length of the array. [in] words : An array of uint64_t little-endian 64-bit words.

: An array of little-endian 64-bit words. [out] result : A napi_value representing a JavaScript BigInt .

Returns napi_ok if the API succeeded.

This API converts an array of unsigned 64-bit words into a single BigInt value.

The resulting BigInt is calculated as: (–1) sign_bit ( words[0] × (264)0 + words[1] × (264)1 + …)

Added in: v8.0.0 N-API version: 1

napi_status napi_create_string_latin1 (napi_env env, const char * str, size_t length, napi_value* result) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] str : Character buffer representing an ISO-8859-1-encoded string.

: Character buffer representing an ISO-8859-1-encoded string. [in] length : The length of the string in bytes, or NAPI_AUTO_LENGTH if it is null-terminated.

: The length of the string in bytes, or if it is null-terminated. [out] result : A napi_value representing a JavaScript String .

Returns napi_ok if the API succeeded.

This API creates a JavaScript String object from an ISO-8859-1-encoded C string. The native string is copied.

The JavaScript String type is described in Section 6.1.4 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_string_utf16 (napi_env env, const char16_t * str, size_t length, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] str : Character buffer representing a UTF16-LE-encoded string.

: Character buffer representing a UTF16-LE-encoded string. [in] length : The length of the string in two-byte code units, or NAPI_AUTO_LENGTH if it is null-terminated.

: The length of the string in two-byte code units, or if it is null-terminated. [out] result : A napi_value representing a JavaScript String .

Returns napi_ok if the API succeeded.

This API creates a JavaScript String object from a UTF16-LE-encoded C string. The native string is copied.

The JavaScript String type is described in Section 6.1.4 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_create_string_utf8 (napi_env env, const char * str, size_t length, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] str : Character buffer representing a UTF8-encoded string.

: Character buffer representing a UTF8-encoded string. [in] length : The length of the string in bytes, or NAPI_AUTO_LENGTH if it is null-terminated.

: The length of the string in bytes, or if it is null-terminated. [out] result : A napi_value representing a JavaScript String .

Returns napi_ok if the API succeeded.

This API creates a JavaScript String object from a UTF8-encoded C string. The native string is copied.

The JavaScript String type is described in Section 6.1.4 of the ECMAScript Language Specification.

Functions to convert from N-API to C types #

Added in: v8.0.0 N-API version: 1

napi_status napi_get_array_length (napi_env env, napi_value value, uint32_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing the JavaScript Array whose length is being queried.

: representing the JavaScript whose length is being queried. [out] result : uint32 representing length of the array.

Returns napi_ok if the API succeeded.

This API returns the length of an array.

Array length is described in Section 22.1.4.1 of the ECMAScript Language Specification.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_arraybuffer_info (napi_env env, napi_value arraybuffer, void ** data, size_t * byte_length)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] arraybuffer : napi_value representing the ArrayBuffer being queried.

: representing the being queried. [out] data : The underlying data buffer of the ArrayBuffer . If byte_length is 0 , this may be NULL or any other pointer value.

: The underlying data buffer of the . If byte_length is , this may be or any other pointer value. [out] byte_length : Length in bytes of the underlying data buffer.

Returns napi_ok if the API succeeded.

This API is used to retrieve the underlying data buffer of an ArrayBuffer and its length.

WARNING: Use caution while using this API. The lifetime of the underlying data buffer is managed by the ArrayBuffer even after it's returned. A possible safe way to use this API is in conjunction with napi_create_reference , which can be used to guarantee control over the lifetime of the ArrayBuffer . It's also safe to use the returned data buffer within the same callback as long as there are no calls to other APIs that might trigger a GC.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_buffer_info (napi_env env, napi_value value, void ** data, size_t * length)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing the node::Buffer being queried.

: representing the being queried. [out] data : The underlying data buffer of the node::Buffer . If length is 0 , this may be NULL or any other pointer value.

: The underlying data buffer of the . If length is , this may be or any other pointer value. [out] length : Length in bytes of the underlying data buffer.

Returns napi_ok if the API succeeded.

This API is used to retrieve the underlying data buffer of a node::Buffer and it's length.

Warning: Use caution while using this API since the underlying data buffer's lifetime is not guaranteed if it's managed by the VM.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_prototype (napi_env env, napi_value object, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] object : napi_value representing JavaScript Object whose prototype to return. This returns the equivalent of Object.getPrototypeOf (which is not the same as the function's prototype property).

: representing JavaScript whose prototype to return. This returns the equivalent of (which is not the same as the function's property). [out] result : napi_value representing prototype of the given object.

Returns napi_ok if the API succeeded.

Added in: v8.0.0 N-API version: 1

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)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] typedarray : napi_value representing the TypedArray whose properties to query.

: representing the whose properties to query. [out] type : Scalar datatype of the elements within the TypedArray .

: Scalar datatype of the elements within the . [out] length : The number of elements in the TypedArray .

: The number of elements in the . [out] data : The data buffer underlying the TypedArray adjusted by the byte_offset value so that it points to the first element in the TypedArray . If the length of the array is 0 , this may be NULL or any other pointer value.

: The data buffer underlying the adjusted by the value so that it points to the first element in the . If the length of the array is , this may be or any other pointer value. [out] arraybuffer : The ArrayBuffer underlying the TypedArray .

: The underlying the . [out] byte_offset : The byte offset within the underlying native array at which the first element of the arrays is located. The value for the data parameter has already been adjusted so that data points to the first element in the array. Therefore, the first byte of the native array would be at data - byte_offset .

Returns napi_ok if the API succeeded.

This API returns various properties of a typed array.

Warning: Use caution while using this API since the underlying data buffer is managed by the VM.

Added in: v8.3.0 N-API version: 1

napi_status napi_get_dataview_info (napi_env env, napi_value dataview, size_t * byte_length, void ** data, napi_value* arraybuffer, size_t * byte_offset)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] dataview : napi_value representing the DataView whose properties to query.

: representing the whose properties to query. [out] byte_length : Number of bytes in the DataView .

: of bytes in the . [out] data : The data buffer underlying the DataView . If byte_length is 0 , this may be NULL or any other pointer value.

: The data buffer underlying the . If byte_length is , this may be or any other pointer value. [out] arraybuffer : ArrayBuffer underlying the DataView .

: underlying the . [out] byte_offset : The byte offset within the data buffer from which to start projecting the DataView .

Returns napi_ok if the API succeeded.

This API returns various properties of a DataView .

napi_get_date_value

Added in: v11.11.0, v10.17.0 N-API version: 5

napi_status napi_get_date_value (napi_env env, napi_value value, double * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing a JavaScript Date .

: representing a JavaScript . [out] result : Time value as a double represented as milliseconds since midnight at the beginning of 01 January, 1970 UTC.

This API does not observe leap seconds; they are ignored, as ECMAScript aligns with POSIX time specification.

Returns napi_ok if the API succeeded. If a non-date napi_value is passed in it returns napi_date_expected .

This API returns the C double primitive of time value for the given JavaScript Date .

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_bool (napi_env env, napi_value value, bool * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript Boolean .

: representing JavaScript . [out] result : C boolean primitive equivalent of the given JavaScript Boolean .

Returns napi_ok if the API succeeded. If a non-boolean napi_value is passed in it returns napi_boolean_expected .

This API returns the C boolean primitive equivalent of the given JavaScript Boolean .

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_double (napi_env env, napi_value value, double * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript Number .

: representing JavaScript . [out] result : C double primitive equivalent of the given JavaScript Number .

Returns napi_ok if the API succeeded. If a non-number napi_value is passed in it returns napi_number_expected .

This API returns the C double primitive equivalent of the given JavaScript Number .

Added in: v10.7.0 N-API version: 6

napi_status napi_get_value_bigint_int64 (napi_env env, napi_value value, int64_t * result, bool * lossless) ;

[in] env : The environment that the API is invoked under

: The environment that the API is invoked under [in] value : napi_value representing JavaScript BigInt .

: representing JavaScript . [out] result : C int64_t primitive equivalent of the given JavaScript BigInt .

: C primitive equivalent of the given JavaScript . [out] lossless : Indicates whether the BigInt value was converted losslessly.

Returns napi_ok if the API succeeded. If a non- BigInt is passed in it returns napi_bigint_expected .

This API returns the C int64_t primitive equivalent of the given JavaScript BigInt . If needed it will truncate the value, setting lossless to false .

Added in: v10.7.0 N-API version: 6

napi_status napi_get_value_bigint_uint64 (napi_env env, napi_value value, uint64_t * result, bool * lossless) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript BigInt .

: representing JavaScript . [out] result : C uint64_t primitive equivalent of the given JavaScript BigInt .

: C primitive equivalent of the given JavaScript . [out] lossless : Indicates whether the BigInt value was converted losslessly.

Returns napi_ok if the API succeeded. If a non- BigInt is passed in it returns napi_bigint_expected .

This API returns the C uint64_t primitive equivalent of the given JavaScript BigInt . If needed it will truncate the value, setting lossless to false .

Added in: v10.7.0 N-API version: 6

napi_status napi_get_value_bigint_words (napi_env env, napi_value value, int * sign_bit, size_t * word_count, uint64_t * words) ;

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript BigInt .

: representing JavaScript . [out] sign_bit : Integer representing if the JavaScript BigInt is positive or negative.

: Integer representing if the JavaScript is positive or negative. [in/out] word_count : Must be initialized to the length of the words array. Upon return, it will be set to the actual number of words that would be needed to store this BigInt .

: Must be initialized to the length of the array. Upon return, it will be set to the actual number of words that would be needed to store this . [out] words : Pointer to a pre-allocated 64-bit word array.

Returns napi_ok if the API succeeded.

This API converts a single BigInt value into a sign bit, 64-bit little-endian array, and the number of elements in the array. sign_bit and words may be both set to NULL , in order to get only word_count .

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_external (napi_env env, napi_value value, void ** result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript external value.

: representing JavaScript external value. [out] result : Pointer to the data wrapped by the JavaScript external value.

Returns napi_ok if the API succeeded. If a non-external napi_value is passed in it returns napi_invalid_arg .

This API retrieves the external data pointer that was previously passed to napi_create_external() .

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_int32 (napi_env env, napi_value value, int32_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript Number .

: representing JavaScript . [out] result : C int32 primitive equivalent of the given JavaScript Number .

Returns napi_ok if the API succeeded. If a non-number napi_value is passed in napi_number_expected .

This API returns the C int32 primitive equivalent of the given JavaScript Number .

If the number exceeds the range of the 32 bit integer, then the result is truncated to the equivalent of the bottom 32 bits. This can result in a large positive number becoming a negative number if the value is > 231 - 1.

Non-finite number values ( NaN , +Infinity , or -Infinity ) set the result to zero.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_int64 (napi_env env, napi_value value, int64_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript Number .

: representing JavaScript . [out] result : C int64 primitive equivalent of the given JavaScript Number .

Returns napi_ok if the API succeeded. If a non-number napi_value is passed in it returns napi_number_expected .

This API returns the C int64 primitive equivalent of the given JavaScript Number .

Number values outside the range of Number.MIN_SAFE_INTEGER -(2**53 - 1) - Number.MAX_SAFE_INTEGER (2**53 - 1) will lose precision.

Non-finite number values ( NaN , +Infinity , or -Infinity ) set the result to zero.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_string_latin1 (napi_env env, napi_value value, char * buf, size_t bufsize, size_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript string.

: representing JavaScript string. [in] buf : Buffer to write the ISO-8859-1-encoded string into. If NULL is passed in, the length of the string (in bytes) is returned.

: Buffer to write the ISO-8859-1-encoded string into. If is passed in, the length of the string (in bytes) is returned. [in] bufsize : Size of the destination buffer. When this value is insufficient, the returned string will be truncated.

: Size of the destination buffer. When this value is insufficient, the returned string will be truncated. [out] result : Number of bytes copied into the buffer, excluding the null terminator.

Returns napi_ok if the API succeeded. If a non- String napi_value is passed in it returns napi_string_expected .

This API returns the ISO-8859-1-encoded string corresponding the value passed in.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_string_utf8 (napi_env env, napi_value value, char * buf, size_t bufsize, size_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript string.

: representing JavaScript string. [in] buf : Buffer to write the UTF8-encoded string into. If NULL is passed in, the length of the string (in bytes) is returned.

: Buffer to write the UTF8-encoded string into. If is passed in, the length of the string (in bytes) is returned. [in] bufsize : Size of the destination buffer. When this value is insufficient, the returned string will be truncated.

: Size of the destination buffer. When this value is insufficient, the returned string will be truncated. [out] result : Number of bytes copied into the buffer, excluding the null terminator.

Returns napi_ok if the API succeeded. If a non- String napi_value is passed in it returns napi_string_expected .

This API returns the UTF8-encoded string corresponding the value passed in.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_string_utf16 (napi_env env, napi_value value, char16_t * buf, size_t bufsize, size_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript string.

: representing JavaScript string. [in] buf : Buffer to write the UTF16-LE-encoded string into. If NULL is passed in, the length of the string (in 2-byte code units) is returned.

: Buffer to write the UTF16-LE-encoded string into. If is passed in, the length of the string (in 2-byte code units) is returned. [in] bufsize : Size of the destination buffer. When this value is insufficient, the returned string will be truncated.

: Size of the destination buffer. When this value is insufficient, the returned string will be truncated. [out] result : Number of 2-byte code units copied into the buffer, excluding the null terminator.

Returns napi_ok if the API succeeded. If a non- String napi_value is passed in it returns napi_string_expected .

This API returns the UTF16-encoded string corresponding the value passed in.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_value_uint32 (napi_env env, napi_value value, uint32_t * result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : napi_value representing JavaScript Number .

: representing JavaScript . [out] result : C primitive equivalent of the given napi_value as a uint32_t .

Returns napi_ok if the API succeeded. If a non-number napi_value is passed in it returns napi_number_expected .

This API returns the C primitive equivalent of the given napi_value as a uint32_t .

Functions to get global instances #

Added in: v8.0.0 N-API version: 1

napi_status napi_get_boolean (napi_env env, bool value, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : The value of the boolean to retrieve.

: The value of the boolean to retrieve. [out] result : napi_value representing JavaScript Boolean singleton to retrieve.

Returns napi_ok if the API succeeded.

This API is used to return the JavaScript singleton object that is used to represent the given boolean value.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_global (napi_env env, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : napi_value representing JavaScript global object.

Returns napi_ok if the API succeeded.

This API returns the global object.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_null (napi_env env, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : napi_value representing JavaScript null object.

Returns napi_ok if the API succeeded.

This API returns the null object.

Added in: v8.0.0 N-API version: 1

napi_status napi_get_undefined (napi_env env, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [out] result : napi_value representing JavaScript Undefined value.

Returns napi_ok if the API succeeded.

This API returns the Undefined object.

Working with JavaScript values and abstract operations #

N-API exposes a set of APIs to perform some abstract operations on JavaScript values. Some of these operations are documented under Section 7 of the ECMAScript Language Specification.

These APIs support doing one of the following:

Coerce JavaScript values to specific JavaScript types (such as Number or String ). Check the type of a JavaScript value. Check for equality between two JavaScript values.

Added in: v8.0.0 N-API version: 1

napi_status napi_coerce_to_bool (napi_env env, napi_value value, napi_value* result)

[in] env : The environment that the API is invoked under.

: The environment that the API is invoked under. [in] value : The JavaScript value to coerce.

: The JavaScript value to coerce. [out] result : napi_value representing the coerced JavaScript Boolean .

Returns napi_ok if the API succeeded.

This API implements the abstract operation ToBoolean() as defined in Section 7.1.2 of the ECMAScript Language Specification. This API can be re-entrant if get