@hpcc-js/wasm is now an ESM by default package - this is a good thing, but does require some breaking changes.
This repository contains a collection of useful c++ libraries compiled to WASM for (re)use in Node JS, Web Browsers and JavaScript Libraries:
Built with:
- emsdk - v3.1.47
v1.x.x
import { graphviz, wasmFolder } from "@hpcc-js/wasm";
wasmFolder("https://cdn.jsdelivr.net/npm/@hpcc-js/wasm/dist");
const dot = "digraph G { Hello -> World }";
graphviz.dot(dot).then(svg => {
const div = document.getElementById("placeholder");
div.innerHTML = svg;
});
graphvizVersion.then(version => console.log(version));
v2.x.x - ESM (Modern ECMAScript Modules)
import { Graphviz } from "@hpcc-js/wasm/graphviz";
const graphviz = await Graphviz.load();
const dot = "digraph G { Hello -> World }";
const svg = graphviz.dot(dot);
console.log(graphviz.version());
v2.x.x - CommonJS
const { Graphviz } = require("@hpcc-js/wasm/graphviz");
Graphviz.load().then(graphviz => {
const dot = "digraph G { Hello -> World }";
const svg = graphviz.dot(dot);
console.log(graphviz.version());
});
Notes:
- Import must specify which wasm library you are using
- wasmFolder is no longer needed
- All wasm libraries have the same asynchronous load pattern
const instance = await Wasm.load();