This library aims to fill a gap in interfacing with the WoW add-on ecosystem. A number of add-on developers tend to use a combination of Ace3 Serialize and LibDeflate for serialization/deserialization when conveying information to other users over channels (guild/party/addon-specific), or when storing and retrieving data from LUA.
As it stands, in order to be able to understand most of the information encoded in such strings, we need to be able to parse it into a format that makes sense, and that we can take further.
Ace3 (with Ace serialization revision 1)'s goal is to be able to turn any LUA object into a serialized, but raw, representation. It bears a lot of resemblance to MessagePack, in that it obeys simple rules:
- Every object starts with a field identifying its type, followed by a field with its value
- These fields are always prepended with an opening preamble, but not necessarily explicitly closed
- All LUA types are covered, with map keys being their own sub-type
In terms of implementation, this library takes an Ace serialization string and returns the corresponding object:
string
for stringsnumber
for lua integers, floats and all other numeric typesboolean
for booleansnull
for null valuesRecord<string, unknown>
for maps and arrays (Lua does not have the concept of an array)
This is all done while leveraging the strongly typed nature of typescript, and providing all the tools required to ensure testability.
To serialize, import, and call Serialize
:
import { Ace } from 'mdt-compression';
const ser = async () => {
console.log(await Ace.Serialize("This is a test"));
};
Similarily, to deserialize, call Deserialize
:
import { Ace } from 'mdt-compression';
const ser = async () => {
console.log(await Ace.Deserialize("^1^F3^f-2"));
};