Wurstscript is a delicious programming language which compiles to Jass or Lua code that is used to power WarCraft III maps.
Using WurstScript to build a map is easy! Check out the Setup Guide on how to get started. For users, installation is automated and intended to work out of the box via the official setup. For a formal description of all language features, visit the Manual.
Consider joining the WurstScript community on Discord.
Please report any bugs your encounter with our Issue Tracker.
Include as much information as possible, ideally with logs.
Logfiles are located in your home folder under ~/.wurst/logs.
Find the last modified file and pastebin it's contents.
See https://github.com/wurstscript/WurstScript/blob/master/CONTRIBUTING.md
This repository contains the following sub-projects:
- de.peeeq.wurstscript
- The core wurstscript compiler and directly related tools
- Wurstpack
- (deprecated) Wurst integration for the Warcraft III World Editor
- HelperScripts
- Some external scripts used for generating data e.g. for StdLib
IDE support is provided via a VSCode plugin: https://github.com/wurstscript/wurst4vscode
The source for the wurstscript website can be found here: https://github.com/wurstscript/wurstscript.github.io
For contributing/developing the compiler, Java 25 is required.
End users normally do not need to install/configure Java manually for the standard Wurst setup flow.
Clone the repository and open the de.peeeq.wurstscript folder which contains the compiler project.
Use the gradle wrapper to run required tasks, it will download gradle automatically. Replace [task_name] with the desired task.
.\gradlew [task_name]To update the local compiler installation used by vscode run
.\gradlew make_for_userdirFor deploying .jars and .zips see tasks in deploy.gradle
.\gradlew create_zip_wurstpack_compilerYou can import the compiler project into any IDE that provides a gradle plugin.
For IntelliJ IDEA, you can simply execute ./gradlew openIdea.
To run the Test Suite, execute AllTests.xml with TestNG.
Releases are published via GitHub workflows and GitHub Releases:
- Workflow: https://github.com/wurstscript/WurstScript/actions/workflows/release.yml
- Releases: https://github.com/wurstscript/WurstScript/releases
The version string can be updated in build.gradle.