Hiroshi Ogawa 61543c0f45
fix(napi): handle nul byte in object key (#2385)
* fix: fix to_napi_value

* test: add test

* fix: fix from_napi_value

* fix: fix object.get/set

* test: test plain object

* test: snapshot
2024-12-03 14:17:18 +08:00

68 lines
1.5 KiB
Rust

use rustc_hash::FxBuildHasher;
use std::collections::{BTreeMap, HashMap};
use indexmap::IndexMap;
#[napi]
fn get_mapping() -> HashMap<String, u32> {
let mut map = HashMap::new();
map.insert("a".to_string(), 101);
map.insert("b".to_string(), 102);
map.insert("\0c".to_string(), 103);
map
}
#[napi]
fn sum_mapping(nums: HashMap<String, u32>) -> u32 {
nums.into_values().sum()
}
#[napi]
fn get_mapping_with_hasher() -> HashMap<String, u32, FxBuildHasher> {
let mut map = HashMap::with_hasher(FxBuildHasher);
map.insert("a".to_string(), 101);
map.insert("b".to_string(), 102);
map
}
#[napi]
fn get_btree_mapping() -> BTreeMap<String, u32> {
let mut map = BTreeMap::new();
map.insert("a".to_string(), 101);
map.insert("b".to_string(), 102);
map.insert("\0c".to_string(), 103);
map
}
#[napi]
fn sum_btree_mapping(nums: BTreeMap<String, u32>) -> u32 {
nums.into_values().sum()
}
#[napi]
fn get_index_mapping() -> IndexMap<String, u32> {
let mut map = IndexMap::new();
map.insert("a".to_string(), 101);
map.insert("b".to_string(), 102);
map.insert("\0c".to_string(), 103);
map
}
#[napi]
fn get_index_mapping_with_hasher() -> IndexMap<String, u32, FxBuildHasher> {
let mut map = IndexMap::with_hasher(FxBuildHasher);
map.insert("a".to_string(), 101);
map.insert("b".to_string(), 102);
map
}
#[napi]
fn sum_index_mapping(nums: IndexMap<String, u32>) -> u32 {
nums.into_values().sum()
}
#[napi]
fn indexmap_passthrough(fixture: IndexMap<String, u32>) -> IndexMap<String, u32> {
fixture
}