1.0.4 • Published 6 months ago

kontak.ts v1.0.4

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

kontak.ts

Program kontakt using javascript

Introduction

kontak.ts is a npm package written in typescript which enables use of the Kontakt Lua API from node.

The package is based on the Kontakt Lua API A bridging lua script is run within kontakt, which allows commands to be issued from a node environment.

This package enables a more pleasant developer experience with auto-completion and type safety.

The api is scraped from the online docs, and includes functions and constants with type information and descriptions.

Usage

Call Kontakt.run() and place your instructions in the callback. The functions are exposed through the first argument of the callback, and the constants through the second.

All of the exposed functions are async. Since the communication between kontakt and node happens on a single channel a function must always be awaited before calling another.

The constants are preloaded before execution and can be used sychronously as normal, as well as any other node apis.

Example

import { Kontakt } from "kontak.ts";
import path from "path";

Kontakt.run(async (functions, constants) => {
  console.log(constants.VERSION)

  const instr = await functions.addInstrument();
  
  await functions.setInstrumentVolume(instr, 11);
  
  const grp = await functions.addGroup(instr)
  
  await functions.addZone(instr, grp, path.resolve("./my-sample.wav"));

  await functions.saveInstrument(instr, path.resolve('./my-cool-instrument.nki'))
});

Configuration

Kontakt.enableDebugOutput = false
Kontakt.keepAlive = false;

enableDebugOutput Set to true to enable terminal output from kontakt

keepAlive If false, kontakt exits after a run is completed (clean exit)
If true, keeps kontakt alive after a run

Path to kontakt

If using a nonstandard install location, the environment variable KONTAKT_PATH is used to find the Kontakt executable. It can be set using process.env.KONTAKT_PATH

Limitations / Known issues

  • The Lua Filesystem module is intentionally not included, as the fs module included in node will be significantly faster and more fully featured.

  • The communication between kontakt and node happens via disk, open for ideas and PRs changing this

  • Certain functions or constants may be broken or missing, if you find something in particular feel free to open an issue

1.0.4

6 months ago

1.0.3

6 months ago

1.0.2

6 months ago

1.0.1

6 months ago

1.0.0

6 months ago