@ducquyen/trie-wasm 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +17 -0
- package/trie_wasm.d.ts +16 -0
- package/trie_wasm.js +9 -0
- package/trie_wasm_bg.js +180 -0
- package/trie_wasm_bg.wasm +0 -0
package/package.json
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@ducquyen/trie-wasm",
|
|
3
|
+
"type": "module",
|
|
4
|
+
"version": "0.1.0",
|
|
5
|
+
"files": [
|
|
6
|
+
"trie_wasm_bg.wasm",
|
|
7
|
+
"trie_wasm.js",
|
|
8
|
+
"trie_wasm_bg.js",
|
|
9
|
+
"trie_wasm.d.ts"
|
|
10
|
+
],
|
|
11
|
+
"main": "trie_wasm.js",
|
|
12
|
+
"types": "trie_wasm.d.ts",
|
|
13
|
+
"sideEffects": [
|
|
14
|
+
"./trie_wasm.js",
|
|
15
|
+
"./snippets/*"
|
|
16
|
+
]
|
|
17
|
+
}
|
package/trie_wasm.d.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/* tslint:disable */
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
|
|
4
|
+
export class Trie {
|
|
5
|
+
free(): void;
|
|
6
|
+
[Symbol.dispose](): void;
|
|
7
|
+
/**
|
|
8
|
+
* insert key + payload(JSON string)
|
|
9
|
+
*/
|
|
10
|
+
insert(key: string, payload_json: string): void;
|
|
11
|
+
constructor();
|
|
12
|
+
/**
|
|
13
|
+
* search prefix -> return JSON string array
|
|
14
|
+
*/
|
|
15
|
+
search_prefix(prefix: string): string;
|
|
16
|
+
}
|
package/trie_wasm.js
ADDED
package/trie_wasm_bg.js
ADDED
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
export class Trie {
|
|
2
|
+
__destroy_into_raw() {
|
|
3
|
+
const ptr = this.__wbg_ptr;
|
|
4
|
+
this.__wbg_ptr = 0;
|
|
5
|
+
TrieFinalization.unregister(this);
|
|
6
|
+
return ptr;
|
|
7
|
+
}
|
|
8
|
+
free() {
|
|
9
|
+
const ptr = this.__destroy_into_raw();
|
|
10
|
+
wasm.__wbg_trie_free(ptr, 0);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* insert key + payload(JSON string)
|
|
14
|
+
* @param {string} key
|
|
15
|
+
* @param {string} payload_json
|
|
16
|
+
*/
|
|
17
|
+
insert(key, payload_json) {
|
|
18
|
+
const ptr0 = passStringToWasm0(key, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
19
|
+
const len0 = WASM_VECTOR_LEN;
|
|
20
|
+
const ptr1 = passStringToWasm0(payload_json, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
21
|
+
const len1 = WASM_VECTOR_LEN;
|
|
22
|
+
wasm.trie_insert(this.__wbg_ptr, ptr0, len0, ptr1, len1);
|
|
23
|
+
}
|
|
24
|
+
constructor() {
|
|
25
|
+
const ret = wasm.trie_new();
|
|
26
|
+
this.__wbg_ptr = ret >>> 0;
|
|
27
|
+
TrieFinalization.register(this, this.__wbg_ptr, this);
|
|
28
|
+
return this;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* search prefix -> return JSON string array
|
|
32
|
+
* @param {string} prefix
|
|
33
|
+
* @returns {string}
|
|
34
|
+
*/
|
|
35
|
+
search_prefix(prefix) {
|
|
36
|
+
let deferred2_0;
|
|
37
|
+
let deferred2_1;
|
|
38
|
+
try {
|
|
39
|
+
const ptr0 = passStringToWasm0(prefix, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
40
|
+
const len0 = WASM_VECTOR_LEN;
|
|
41
|
+
const ret = wasm.trie_search_prefix(this.__wbg_ptr, ptr0, len0);
|
|
42
|
+
deferred2_0 = ret[0];
|
|
43
|
+
deferred2_1 = ret[1];
|
|
44
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
45
|
+
} finally {
|
|
46
|
+
wasm.__wbindgen_free(deferred2_0, deferred2_1, 1);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
if (Symbol.dispose) Trie.prototype[Symbol.dispose] = Trie.prototype.free;
|
|
51
|
+
export function __wbg___wbindgen_throw_39bc967c0e5a9b58(arg0, arg1) {
|
|
52
|
+
throw new Error(getStringFromWasm0(arg0, arg1));
|
|
53
|
+
}
|
|
54
|
+
export function __wbg_error_a6fa202b58aa1cd3(arg0, arg1) {
|
|
55
|
+
let deferred0_0;
|
|
56
|
+
let deferred0_1;
|
|
57
|
+
try {
|
|
58
|
+
deferred0_0 = arg0;
|
|
59
|
+
deferred0_1 = arg1;
|
|
60
|
+
console.error(getStringFromWasm0(arg0, arg1));
|
|
61
|
+
} finally {
|
|
62
|
+
wasm.__wbindgen_free(deferred0_0, deferred0_1, 1);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
export function __wbg_new_227d7c05414eb861() {
|
|
66
|
+
const ret = new Error();
|
|
67
|
+
return ret;
|
|
68
|
+
}
|
|
69
|
+
export function __wbg_stack_3b0d974bbf31e44f(arg0, arg1) {
|
|
70
|
+
const ret = arg1.stack;
|
|
71
|
+
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
72
|
+
const len1 = WASM_VECTOR_LEN;
|
|
73
|
+
getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true);
|
|
74
|
+
getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true);
|
|
75
|
+
}
|
|
76
|
+
export function __wbindgen_init_externref_table() {
|
|
77
|
+
const table = wasm.__wbindgen_externrefs;
|
|
78
|
+
const offset = table.grow(4);
|
|
79
|
+
table.set(0, undefined);
|
|
80
|
+
table.set(offset + 0, undefined);
|
|
81
|
+
table.set(offset + 1, null);
|
|
82
|
+
table.set(offset + 2, true);
|
|
83
|
+
table.set(offset + 3, false);
|
|
84
|
+
}
|
|
85
|
+
const TrieFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
86
|
+
? { register: () => {}, unregister: () => {} }
|
|
87
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_trie_free(ptr >>> 0, 1));
|
|
88
|
+
|
|
89
|
+
let cachedDataViewMemory0 = null;
|
|
90
|
+
function getDataViewMemory0() {
|
|
91
|
+
if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) {
|
|
92
|
+
cachedDataViewMemory0 = new DataView(wasm.memory.buffer);
|
|
93
|
+
}
|
|
94
|
+
return cachedDataViewMemory0;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
function getStringFromWasm0(ptr, len) {
|
|
98
|
+
ptr = ptr >>> 0;
|
|
99
|
+
return decodeText(ptr, len);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
let cachedUint8ArrayMemory0 = null;
|
|
103
|
+
function getUint8ArrayMemory0() {
|
|
104
|
+
if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {
|
|
105
|
+
cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);
|
|
106
|
+
}
|
|
107
|
+
return cachedUint8ArrayMemory0;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
function passStringToWasm0(arg, malloc, realloc) {
|
|
111
|
+
if (realloc === undefined) {
|
|
112
|
+
const buf = cachedTextEncoder.encode(arg);
|
|
113
|
+
const ptr = malloc(buf.length, 1) >>> 0;
|
|
114
|
+
getUint8ArrayMemory0().subarray(ptr, ptr + buf.length).set(buf);
|
|
115
|
+
WASM_VECTOR_LEN = buf.length;
|
|
116
|
+
return ptr;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
let len = arg.length;
|
|
120
|
+
let ptr = malloc(len, 1) >>> 0;
|
|
121
|
+
|
|
122
|
+
const mem = getUint8ArrayMemory0();
|
|
123
|
+
|
|
124
|
+
let offset = 0;
|
|
125
|
+
|
|
126
|
+
for (; offset < len; offset++) {
|
|
127
|
+
const code = arg.charCodeAt(offset);
|
|
128
|
+
if (code > 0x7F) break;
|
|
129
|
+
mem[ptr + offset] = code;
|
|
130
|
+
}
|
|
131
|
+
if (offset !== len) {
|
|
132
|
+
if (offset !== 0) {
|
|
133
|
+
arg = arg.slice(offset);
|
|
134
|
+
}
|
|
135
|
+
ptr = realloc(ptr, len, len = offset + arg.length * 3, 1) >>> 0;
|
|
136
|
+
const view = getUint8ArrayMemory0().subarray(ptr + offset, ptr + len);
|
|
137
|
+
const ret = cachedTextEncoder.encodeInto(arg, view);
|
|
138
|
+
|
|
139
|
+
offset += ret.written;
|
|
140
|
+
ptr = realloc(ptr, len, offset, 1) >>> 0;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
WASM_VECTOR_LEN = offset;
|
|
144
|
+
return ptr;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
let cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });
|
|
148
|
+
cachedTextDecoder.decode();
|
|
149
|
+
const MAX_SAFARI_DECODE_BYTES = 2146435072;
|
|
150
|
+
let numBytesDecoded = 0;
|
|
151
|
+
function decodeText(ptr, len) {
|
|
152
|
+
numBytesDecoded += len;
|
|
153
|
+
if (numBytesDecoded >= MAX_SAFARI_DECODE_BYTES) {
|
|
154
|
+
cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });
|
|
155
|
+
cachedTextDecoder.decode();
|
|
156
|
+
numBytesDecoded = len;
|
|
157
|
+
}
|
|
158
|
+
return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
const cachedTextEncoder = new TextEncoder();
|
|
162
|
+
|
|
163
|
+
if (!('encodeInto' in cachedTextEncoder)) {
|
|
164
|
+
cachedTextEncoder.encodeInto = function (arg, view) {
|
|
165
|
+
const buf = cachedTextEncoder.encode(arg);
|
|
166
|
+
view.set(buf);
|
|
167
|
+
return {
|
|
168
|
+
read: arg.length,
|
|
169
|
+
written: buf.length
|
|
170
|
+
};
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
let WASM_VECTOR_LEN = 0;
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
let wasm;
|
|
178
|
+
export function __wbg_set_wasm(val) {
|
|
179
|
+
wasm = val;
|
|
180
|
+
}
|
|
Binary file
|