SurgeScript is a scripting language for games. Use it to unleash your creativity and build your own amazing interactive content! It's such a joy to use SurgeScript! You will love it!
First time here?
Go to the Welcome page.
Where to get it?
Get it on the Download page.
Need help?
Feel free to contact the developer.
The following script prints a message to the screen:
// My first application
object "Application"
{
state "main"
{
Console.print("Hello, world!");
Application.exit();
}
}
To test the script, save it to hello.ss and run:
surgescript /path/to/hello.ss
SurgeScript is a scripting language for games. It lets you unleash your creativity and build your own amazing interactive content!
Go to the SurgeScript Crash Course. Also take a look at the video tutorials and check the examples.
Unlike other programming languages, SurgeScript has been designed with the specific needs of games in mind. Its features include:
- The state-machine pattern: objects are state machines, making it easy to create in-game entities
- The composition approach: you may design complex objects and behaviors by means of composition
- The hierarchy system: objects have a parent and may have children, in a tree-like structure
- The game loop: it's defined implicitly
- Automatic garbage collection, object tagging and more!
SurgeScript is meant to be used in games and in interactive applications. It's easy to integrate it into existing code, it's easy to extend, it features a C-like syntax, and it's free and open-source software.
SurgeScript has been designed based on the experience of its developer dealing with game engines, applications related to computer graphics and so on. Some of the best practices have been incorporated into the language itself, making things really easy for developers and modders.
SurgeScript has been created by Alexandre Martins, a computer scientist from Brazil. He has also created the Open Surge game engine, hence the name SurgeScript.
If you're using Open Surge, you don't need to compile SurgeScript. It's compiled for you.
If you want to compile SurgeScript by yourself, you need a C compiler and CMake. First of all, get the source code and extract the package. Next, compile SurgeScript as follows:
cd /path/to/sources
mkdir build && cd build
cmake ..
make
A surgescript executable will be available in the project folder. Additionally, SurgeScript will also be compiled as a library (libsurgescript). To perform a system-wide installation, run:
sudo make install
To test a script:
surgescript examples/hello.ss
Note: use ccmake or cmake-gui to play around with different options for compiling SurgeScript.
*nix users: the installation directory defaults to /usr. You may change it by calling cmake .. -DCMAKE_INSTALL_PREFIX=/path/to/install
before make
.
You need mkdocs. After extracting the sources, go to the project folder and run:
mkdocs build
The documentation will be available in the site/ subdirectory.
SurgeScript is available as a library. If you're a C/C++ developer, you may embed SurgeScript into your project by studying file src/main.c. The steps are as follows:
- Create a SurgeScript Virtual Machine (VM).
- Compile the scripts you want.
- Launch the VM.
- In your game loop, update the VM.
- Once you're done, release the VM.
You need to #include <surgescript.h>
in your code and link your project with -lsurgescript
. Additionally, you may call C/C++ code from SurgeScript via binding. Explore src/surgescript/runtime/sslib/ for more information.
Tip: to print the command-line options required to link your project with SurgeScript, run:
pkg-config --cflags --libs surgescript
If you prefer static linking, run:
pkg-config --cflags --libs --static surgescript-static
These may be combined with command substitution:
gcc example.c -o example $(pkg-config --cflags --libs surgescript)