Skip to content

Latest commit

 

History

History
70 lines (52 loc) · 2.39 KB

README.md

File metadata and controls

70 lines (52 loc) · 2.39 KB

@hpcc-js/wasm - Version 2

Tests Coverage Status

@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:

Homepage and Documents

Quick Migration Example

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();