node-weakauras-parser
v3.2.3
Published
Native module for Node.js that does deserialization/serialization of WeakAuras' strings
Downloads
173
Maintainers
Readme
node-weakauras-parser
Installation
npm install node-weakauras-parser
# or
yarn add node-weakauras-parser
The package is pre-built for the following environments (Haswell is used as the target arch):
| OS | Node >=12 | |--------------------------|-----------| | Linux glibc (x86_64) | ✔️ | | Linux musl-libc (x86_64) | ✔️ | | macOS (x86_64) | ✔️ | | Windows (x86_64) | ✔️ |
If you use something else, you will need Rust and zlib in order to build from source code.
If you are getting SIGILL, your CPU does not support some of the instructions that Haswell does. To fix that, you will have to build from source code.
Usage
Non-blocking version:
const parser = require('node-weakauras-parser');
(async function() {
const source = { test: 1 };
const encoded = await parser.encode(source);
const decoded = await parser.decode(encoded);
console.log(JSON.stringify(source) === JSON.stringify(decoded));
}());
Blocking version (slightly faster, but blocks the event loop):
const parser = require('node-weakauras-parser');
const source = { test: 1 };
const encoded = parser.encodeSync(source);
const decoded = parser.decodeSync(encoded);
console.log(JSON.stringify(source) === JSON.stringify(decoded));
Both decode()
and decodeSync()
accept an optional argument to configure the memory usage limit for decompression (in bytes). Default value is 8 MBs. You can pass +Infinity
to disable it.
Both encode
and encodeSync()
accept an optional argument to specify the encoding version. See the definition of FormatVersion in index.d.ts.
Known issues
- Table references from LibSerialize are not fully supported.
For example, self-referential tables (or tables referencing an ancestor) will cause an error.
As far as I know, those cannot be stored in
SavedVariables.lua
, so it shouldn't be an issue with WA strings.
Major changes
v3.2
- This package now uses Node-API v4 (Node.js 10.16.0, 11.8.0, 12.0.0 and later) instead of Native Abstractions for Node.js to ensure ABI compatibility with future versions of Node.js.
v3.1
encode()
now uses a new serialization algorithm adopted by WA in v2.18.
v3
encode()
anddecode()
in v2 still spent majority of their time on the main thread, thus blocking the event loop. This is no longer the case but infinite numbers are no longer supported;- Functions now return proper Error objects instead of strings.
v2
encode()
anddecode()
are now non-blocking;- Old, blocking, implementations are available as
encodeSync()
anddecodeSync()
.
License
The project is licensed under MIT License, unless stated otherwise in a source file.