npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

node-weakauras-parser

v3.2.3

Published

Native module for Node.js that does deserialization/serialization of WeakAuras' strings

Downloads

173

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

v3.1

  • encode() now uses a new serialization algorithm adopted by WA in v2.18.

v3

  • encode() and decode() 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() and decode() are now non-blocking;
  • Old, blocking, implementations are available as encodeSync() and decodeSync().

License

The project is licensed under MIT License, unless stated otherwise in a source file.