An interface for game data for NovaJS
npm install novadatainterfacenpm, nodenpm 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, 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 is initialized with a
function of type (id: string) => Promise, which it uses to fulfill requests made to it via its .get(id: string): Promise
method. An implementation of Gettable` that caches every requested item is provided, but need not be used, and a different