AssemblyScript implementation of the JAM PVM (64-bit).
Gray Paper compatibility:
- 0.7.2
- Pineapples are cool.
- JAM is promising.
- PVM is neat.
- Main PVM backend of
typeberryJAM client. - To test out the PVM debugger.
npm install @fluffylabs/anan-asThe package exports multiple builds to suit different use cases:
ESM bindings provide a convenient JavaScript wrapper around the WebAssembly module:
// Default import (optimized release build with ESM bindings)
import ananAs from '@fluffylabs/anan-as';
// Debug build (includes source maps and debug info)
import ananAs from '@fluffylabs/anan-as/debug';
// Explicit release build
import ananAs from '@fluffylabs/anan-as/release';
// Release build with minimal runtime (requires manually calling GC)
import ananAs from '@fluffylabs/anan-as/release-mini';
// make sure to call GC after multiple independent runs
ananAs.__collect();Raw bindings give you direct access to WebAssembly exports without the JavaScript wrapper layer. This is useful for instantiating multiple instances or when you need more control:
// Raw bindings
import { instantiate } from '@fluffylabs/anan-as/raw';
// Import WASM file URLs
import debugWasm from '@fluffylabs/anan-as/debug.wasm';
import releaseWasm from '@fluffylabs/anan-as/release.wasm';
// Use with your own loader
const module = await WebAssembly.instantiateStreaming(
fetch(releaseWasm),
imports
);
const ananAs = await instantiate(module);When installing the package, you can choose between stable releases and bleeding-edge builds:
# Latest stable release
npm install @fluffylabs/anan-as
# Latest build from main branch (includes commit hash)
npm install @fluffylabs/anan-as@nextTo download the dependencies:
npm ciTo build the WASM modules (in ./build/{release,debug}.wasm):
npm run buildTo run the example in the browser at http://localhost:3000.
npm run webTo run JSON test vectors.
npm start ./path/to/tests/*.jsonThe package includes a CLI tool for disassembling and running PVM bytecode:
# Disassemble bytecode to assembly
npx @fluffylabs/anan-as disassemble [--spi] [--no-metadata] <file.(jam|pvm|spi|bin)>
# Run JAM programs
npx @fluffylabs/anan-as run [--spi] [--no-logs] [--no-metadata] [--pc <number>] [--gas <number>] <file.jam> [spi-args.bin]
The `run` command executes PVM bytecode until it encounters a `halt` instruction or the first host call. For full execution including host call handling, use the disassemble command or other tooling.
# Show help
npx @fluffylabs/anan-as --help
npx @fluffylabs/anan-as disassemble --help
npx @fluffylabs/anan-as run --helpdisassemble: Convert PVM bytecode to human-readable assemblyrun: Execute PVM bytecode and show results
--spi: Treat input as JAM SPI format instead of generic PVM--no-metadata: Input does not start with metadata--no-logs: Disable execution logs (run command only)--pc <number>: Set initial program counter (default: 0)--gas <number>: Set initial gas amount (default: 0)--help,-h: Show help information
# Disassemble a JAM file (includes metadata by default)
npx @fluffylabs/anan-as disassemble program.jam
# Disassemble without metadata
npx @fluffylabs/anan-as disassemble --no-metadata program.jam
# Disassemble SPI program
npx @fluffylabs/anan-as disassemble --spi program.spi
# Run a JAM program with logs (includes metadata by default)
npx @fluffylabs/anan-as run program.jam
# Run a JAM program without metadata
npx @fluffylabs/anan-as run --no-metadata program.jam
# Run a JAM program quietly
npx @fluffylabs/anan-as run --no-logs program.jam
# Run a JAM program with custom initial PC and gas
npx @fluffylabs/anan-as run --pc 100 --gas 10000 program.jam
# Run SPI program with arguments
npx @fluffylabs/anan-as run --spi program.spi args.bin