Skript-Three is a Minecraft plugin for Paper, which allows server owners and other people to modify their servers without learning Java. It can also be useful if you do know Java; some tasks are quicker to do with Skript, and so it can be used for prototyping etc.
This Github fork of Skript is based on SkriptLang's improvements which was built on Njol's original Skript.
To help differentiate between SkriptLang's Skript, we'll be referring to this fork as 'Skript-Three', but internally it is still called 'Skript'.
- Java 21+
- PaperMC server.
You heard it right, CraftBukkit/Spigot does not work.
Skript supports only the latest patch versions of Minecraft 1.20+. For example, this means that 1.20.6 is supported, but 1.20.1 is not. Testing with all old patch versions is not feasible for us.
You can find the downloads for each version with their release notes in the releases page.
Documentation is available HERE for the latest version of Skript.
Please see our contribution guidelines before reporting issues.
We don't support add-ons here, even though some of Skript developers have also developed their own add-ons.
Skript uses Gradle for compilation. Use your command prompt of preference and navigate to Skript's source directory. Then you can just call Gradle to compile and package Skript for you:
./gradlew clean build # on UNIX-based systems (mac, linux)
gradlew clean build # on Windows
You can get source code from the releases page. You may also clone this repository, but that code may or may not be stable.
Skript has some tests written in Skript. Running them requires a Minecraft server, but our build script will create one for you. Running the tests is easy:
./gradlew (quickTest|skriptTest|skriptTestJava21)
quickTest
runs the test suite on newest supported server version.
skriptTestJava21
(1.20.6+) runs the tests on Java 21 supported versions.
skriptTest
runs the tests on all versions.
That is, it runs skriptTestJava11, skriptTestJava17, and skriptTestJava21.
By running the tests, you agree to Mojang's End User License Agreement.
With new Eclipse versions, there is integrated Gradle support, and it actually works now. So, first get latest Eclipse, then import Skript as any Gradle project. Just make sure to keep the configuration when the importer asks for that!
If you encounter strange issues, make sure you follow the instructions above and have actually downloaded latest Eclipse or update your installation correctly. Skript's new Gradle version (starting from dev26) does not work very well with older Eclipse versions. Also, do not use Gradle STS; it is outdated.
You'll need to make sure that nullness annotations are working correctly. Also, when sending pull requests, make sure not to change IDEA configuration files that may have been stored in the repository.
./gradlew clean build
./gradlew <flavor>Release
Available flavors are github and spigot. Please do not abuse flavors by compiling your own test builds as releases.
Please review our contribution guidelines. In addition to that, if you are contributing Java code, check our coding conventions.
Warning
This needs to be updated
If you use Skript as (soft) dependency for your plugin, and use maven or Gradle, this is for you.
First, you need to add the Maven repository at the END of all your repositories. Skript is not available in Maven Central.
repositories {
maven {
url 'https://repo.skriptlang.org/releases'
}
}
Or, if you use Maven:
<repositories>
<repository>
<id>skript-releases</id>
<name>Skript Repository</name>
<url>https://repo.skriptlang.org/releases</url>
</repository>
</repositories>
For versions of Skript after dev37 you might need to add the paper-api repository to prevent build issues.
maven {
url 'https://repo.destroystokyo.com/repository/maven-public/'
}
Or, if you use Maven:
<repository>
<id>destroystokyo-repo</id>
<url>https://repo.destroystokyo.com/content/repositories/snapshots/</url>
</repository>
Then you will also need to add Skript as a dependency.
dependencies {
implementation 'com.github.SkriptLang:Skript:[versionTag]'
}
An example of the version tag would be 2.8.5
.
Note: If Gradle isn't able to resolve Skript's dependencies, just disable the resolution of transitive dependencies for Skript in your project.
Or, if you use Maven:
<dependency>
<groupId>com.github.SkriptLang</groupId>
<artifactId>Skript</artifactId>
<version>[versionTag]</version>
<scope>provided</scope>
</dependency>
Note that these resources are not maintained by Skript's developers. Don't contact us about any problems you might have with them.
You can find all contributors here.
All code is owned by its writer, licensed for others under GPLv3 (see LICENSE) unless otherwise specified.