26 releases (5 stable)
new 1.0.4 | Jan 13, 2025 |
---|---|
1.0.3 | Nov 20, 2024 |
1.0.1 | Oct 27, 2024 |
1.0.0-beta.5 | Jul 31, 2024 |
0.0.3 | Nov 28, 2023 |
#49 in FFI
3,484 downloads per month
Used in 4 crates
(3 directly)
540KB
16K
SLoC
ohos-rs
Please visit the official website: https://ohos.rs
Discussion
lib.rs
:
High level Node.js N-API binding
napi-rs provides minimal overhead to write N-API modules in Rust
.
Feature flags
napi1 ~ napi8
Because Node.js
N-API has versions. So there are feature flags to choose what version of N-API
you want to build for.
For example, if you want build a library which can be used by node@10.17.0
, you should choose the napi5
or lower.
The details of N-API versions and support matrix: Node-API version matrix
tokio_rt
With tokio_rt
feature, napi-rs
provides a tokio runtime in an additional thread.
And you can easily run tokio future
in it and return promise
.
use futures::prelude::*;
use napi_ohos::{CallContext, Error, JsObject, JsString, Result, Status};
use tokio;
#[napi]
pub async fn tokio_readfile(js_filepath: String) -> Result<JsBuffer> {
ctx.env.execute_tokio_future(
tokio::fs::read(js_filepath)
.map(|v| v.map_err(|e| Error::new(Status::Unknown, format!("failed to read file, {}", e)))),
|&mut env, data| env.create_buffer_with_data(data),
)
}
latin1
Decode latin1 string from JavaScript using encoding_rs.
With this feature, you can use JsString.as_latin1_string
function
serde-json
Enable Serialize/Deserialize data cross JavaScript Object
and Rust struct
.
#[derive(Serialize, Debug, Deserialize)]
struct AnObject {
a: u32,
b: Vec<f64>,
c: String,
}
#[napi]
fn deserialize_from_js(arg0: JsUnknown) -> Result<JsUndefined> {
let de_serialized: AnObject = ctx.env.from_js_value(arg0)?;
...
}
#[napi]
fn serialize(env: Env) -> Result<JsUnknown> {
let value = AnyObject { a: 1, b: vec![0.1, 2.22], c: "hello" };
env.to_js_value(&value)
}
Dependencies
~0.3–10MB
~122K SLoC