Creating a Library
A basic guide to creating an external language library (addon) that provides extra syntax or functionality.
The default ByteSkript compiler supports external language libraries which can add new syntax, language features and even runtime dependency classes that will be exported when using the SkriptJarBuilder.
These libraries can be written in Java or other JVM languages, using the ByteSkript API.
Dependency Information
When using Maven, ByteSkript can be added as a dependency with the details below. Remember to change the dependency version to the latest release tag, since this example will not be updated.
ByteSkript's repository also houses all of its dependencies, in case these are needed as well.
For Gradle, the details are below. Again, make sure to check you are using the latest release tag.
Basic Library Structure
All libraries need a core class implementing the org.byteskript.skript.api.Library
interface. An instance of this class will be registered and will provide the syntax and features.
Libraries also need a main class. This has to be specified in the MANIFEST.MF
.
These can be the same class for convenience.
The main class needs a public static void load(Skript skript)
method.
For simplicity, you can extend the ModifiableLibrary
class.
The Library
interface has several important methods you will need to implement if not using the ModifiableLibrary
class.
Method | Description |
---|---|
| Your library's name (for error messages, etc.) |
| An array of types that your library wants to use for |
| An array of language constructs registered by your library. Basic libraries will not register any. This can be used to add entirely new language grammar. |
| An array of syntax classes registered by your library. This is where you register new syntax. |
| A list of properties registered by your library. This is for adding complex property expressions. This is for use with the v2 syntax API. |
| Returns a list of handlers valid for the current state and language element for filtering purposes.
This may simply be a version of |
The org.byteskript.skript.api.ModifiableLibrary
class can be extended to provide a basic Library implementation, where syntax can be manually registered in the constructor. This will mean you do not need to implement the methods.
ByteSkript's built-in SkriptLangSpec
uses the ModifiableLibrary
template internally.
SkriptLangSpec is the built-in implementation of the Skript language.
A modified version of ByteSkript could use a custom language implementation with the default compiler.
Registering a Simple Syntax
Most libraries will want to register syntax. This can be done using either the v1 or the v2 API. Examples in this section are for the v1 API, which allows greater control over registration.
Advanced Syntax
Last updated