novadatainterface

An interface for game data for NovaJS

Usage no npm install needed!

<script type="module">
  import novadatainterface from 'https://cdn.skypack.dev/novadatainterface';
</script>

README

NovaDataInterface

A TypeScript interface for NovaJS's data. NovaDataInterface defines the interface for anything that provides game data to NovaJS

Prerequisites

npm, node

Installing

NovaDataInterface is available on npm as novadatainterface.

Development

Installing

After cloning the repository, install dependencies with

npm install

Then, build with

npm run build

Tests can be run with

npm run test

Project Structure

src contains all the project code not used for testing. Compiled typescript definitions end up in the project root directory because that's where they need to be in order for them to be accessable when this package is installed with npm.

src/GameDataInterface.ts is what NovaJS expects all file readers to implement. It has a member ids: Promise<NovaIDs>, which resolves to an object that has a list of available ids for each NovaJS data type (such as Ship or SpriteSheet). It also has as a member a NovaDataInterface, which is where the NovaJS data types are aggregated. These data types are defined in src/.

For each data type, NovaDataInterface has a corresponding Gettable, which is an object used for asynchronously requesting instances of that data type. A Gettable<T> is initialized with a function of type (id: string) => Promise<T>, which it uses to fulfill requests made to it via its .get(id: string): Promise<T> method. An implementation of Gettable that caches every requested item is provided, but need not be used, and a different implementation may be used as long as it conforms to the same type.

See NovaParse (typescript branch) for NovaJS's Nova File parser, which implements this interface.