This is an unofficial folk project created for personal use only. It is not affiliated with, endorsed by, or supported by Scenery or Scene Group in any way.
While I have strived to make this code functional, I cannot guarantee its compatibility with all Scenery versions or its suitability for any specific purpose. You are solely responsible for any risks or damages arising from its use.
Please note that I am not obligated to provide any support or assistance for this code.
Typescript definitions for Cavalry
Note
Current supported API version is Cavalry 1.5.6
These definitions describe the whole Cavalry scripting API. Essentially it gives you all the documentation inside your editor. After installation and following the usage guidelines you can simply start writing your script and get suggestions about available methods and parameters.
If you're not sure how to start, follow the usage guidelines and press ctrl-space
, then type cav
and you'll see the cavalry
namespace suggested along with its description. Press enter
and type .
to see a list of all the available methods.
A few pointers:
- Hovering over a namespace, method or parameter will show its documentation along with examples (in most cases).
- Red squiggly lines will appear when methods or parameters don't exist or when they're of the wrong type. Hover over them to find out about the problem.
- Even though there might be errors and warnings in the code, it will still run (with or without errors). This is because the error checking happens only in your editor.
- If you're writing in Typescript, the code will not run in Cavalry. You will have to compile the code first.
Note
This project is still in progress. There are some descriptions and Typescript features missing, but the API is mostly documented. The definition files were written by hand, so there might be some mistakes. Please report any issues you find.
It's recommended that you use the Stallion VSCode extension if you're new to the Node ecosystem. It can insert the Typescript definitions without the need to install them.
Make sure you first initialise a new npm project. In your terminal run:
npm init --yes
then install the Typescript definitions:
npm install @scenery/cavalry-types --save-dev
You can either use Triple-Slash Directives for one-off scripts. Or for more involved projects, you can use a Typescript Config.
Add the following triple-slash directive at the top of your script file.
/// <reference types="@scenery/cavalry-types"/>
Optionally include a @ts-check
comment to enable type checking.
/// <reference types="@scenery/cavalry-types"/>
// @ts-check
Create a tsconfig.json
in your project folder and add @scenery/cavalry-types
.
{
"compilerOptions": {
"types": ["@scenery/cavalry-types"]
}
}
The types will always point to the latest API version. Add a version number to the path to target a specific version.
/// <reference types="@scenery/cavalry-types/versions/1.5.1" />
{
"compilerOptions": {
"types": ["@scenery/cavalry-types/versions/1.5.1"]
}
}
Cavalry has namespaces for specific parts of the app, such as render
for render scripts and ctx
in the Javascript Utility. Add an additional Triple-Slash Directive to expose the types for it.
/// <reference types="@scenery/cavalry-types"/>
/// <reference types="@scenery/cavalry-types/render"/>
/// <reference types="@scenery/cavalry-types/versions/1.5.1"/>
/// <reference types="@scenery/cavalry-types/versions/1.5.1/render"/>
In a Typescript config
{
"compilerOptions": {
"types": ["@scenery/cavalry-types", "@scenery/cavalry-types/render"]
}
}
Huge thanks to Cavalry for sponsoring this project! Interested in sponsoring? Send us a message.