You're Invited: Meet the Socket team at BSidesSF and RSAC - April 27 - May 1.RSVP
Socket
Sign inDemoInstall
Socket

js-component-tools

Package Overview
Dependencies
Maintainers
1
Versions
11
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

js-component-tools

JavaScript tooling for working with WebAssembly Components

0.2.1
Source
npm
Version published
Weekly downloads
25
-43.18%
Maintainers
1
Weekly downloads
 
Created
Source

js-component-tools

JavaScript tooling for working with WebAssembly Components

A Bytecode Alliance project

build status

Overview

JS Component Tools is a fully native JS tool for working with the emerging WebAssembly Components specification in JavaScript.

Features include:

  • "Transpiling" Wasm Component binaries into ES modules that can run in any JS environment.
  • Optimization helpers for Components, including Binaryen and asm.js support.
  • Component helpers available as a build of Wasm Tools.

This tool is designed primarily for working with already-created Component binaries, and not for creating Component binaries to begin with. For creating Components, see the Cargo Component project for Rust and Wit Bindgen for various guest bindgen helpers.

Note: This is an experimental project, no guarantees are provided for stability or support and breaking changes may be made in future.

Installation

npm install js-component-tools

JS Component Tools can be used as either a library or as a CLI via the jsct CLI command.

Example

See the example workflow page for a full usage example.

API

The below is an outline of the available API functions, see api.d.ts file for the exact options.

$init: Promise<void>

If using a synchronous API function, the $init method should be imported and awaited first:

import { $init } from 'js-component-tools';
await $init;

This is because it is itself transpiled with compatibility for JS environments without top-level await via jsct transpile --tla-compat.

transpile(component: Uint8Array, opts?): Promise<{ files: Record<string, Uint8Array> }>

Transpile a Component to JS.

Transpilation options:

  • name?: string - name for the generated JS file.
  • instantiation?: bool - instead of a direct ES module, output the raw instantiation function for custom virtualization.
  • map?: Record<string, string> - remap component imports
  • validLiftingOptimization?: bool - optimization to reduce code size
  • compat?: bool - enables all compat options
  • noNodejsCompat?: bool - disables Node.js compatible output
  • tlaCompat?: bool - enable compat in JS runtimes without TLA support
  • base64Cutoff?: number - size in bytes, under which Wasm modules get inlined as base64.
  • asm?: bool - use asm.js instead of core WebAssembly for execution.
  • minify?: bool - minify the output JS.
  • optimize?: bool - optimize the component with Binaryen wasm-opt first.
  • optArgs?: string[] - if using optimize, custom optimization options (defaults to best optimization, but this is very slow)
opt(component: Uint8Array, opts?): Promise<{ component: Uint8Array }>

Optimize a Component with the Binaryen Wasm-opt project.

parse(wat: string): Uint8Array

Parse a compoment WAT to output a Component binary.

print(component: Uint8Array): string

Print the WAT for a Component binary.

componentNew(coreWasm: Uint8Array | null, opts?): Uint8Array

"WIT Component" Component creation tool.

componentWit(component: Uint8Array): string

Extract the WIT world from a component binary.

CLI

Usage: jsct <command> [options]

JSCT - WebAssembly JS Component Tools
       JS Component Transpilation Bindgen & Wasm Tools for JS

Options:
  -V, --version                         output the version number
  -h, --help                            display help for command

Commands:
  transpile [options] <component-path>  Transpile a WebAssembly Component to JS + core Wasm for JavaScript execution
  opt [options] <component-file>        optimizes a Wasm component, including running wasm-opt Binaryen optimizations
  wit [options] <component-path>        extract the WIT from a WebAssembly Component [wasm-tools component wit]
  print [options] <input>               print the WebAssembly WAT text for a binary file [wasm-tools print]
  parse [options] <input>               parses the Wasm text format into a binary file [wasm-tools parse]
  new [options] [module]                create a WebAssembly component adapted from a component core Wasm [wasm-tools component new]
  help [command]                        display help for command

License

This project is licensed under the Apache 2.0 license with the LLVM exception. See LICENSE for more details.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be licensed as above, without any additional terms or conditions.

Keywords

Wasm

FAQs

Package last updated on 22 Dec 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts