-
-
Notifications
You must be signed in to change notification settings - Fork 492
S Expression
SuperTux uses S-Expressions for the majority of its files. Its a datatype mostly known from the Lisp programming language. A Lisp expression is simply a list that contains stuff: integers (= numbers without decimal part), float/real numbers (= numbers with decimal part), symbols, strings, booleans and, most importantly, other lists.
The possibility to nest lists makes the format very flexible and a good choice as a general purpose file format for SuperTux. The list elements are encoded as following:
-
Integer: simply the number
- Examples:
8
,42
or12442
- Examples:
-
Float: simply the number with a dot as the decimal separator
- Examples:
8.5
,23.0
or0.002
- Examples:
-
String (sequences of characters) should be enclosed in quotation marks.
- Examples: “
string
”, “Hello`` ``World
”, “One`` ``day`` ``after`` ``Tux`` ``had`` ``dreamed`` ``about`` ``Penny,`` ``...
”. - Escaping: backslashes (
\
) are handled like C escape sequences and allow to embed quotation marks into a string by writing\"
. This is useful for scripts but also has an obvious downside: backslashes themselves must be escaped (\\
).
- Examples: “
-
Boolean: A boolean is a logical value that has either the value true or false.
#t
stands for true and#f
for false in a Lisp file. -
Symbol: Simply add the symbol. Symbols look like unquoted strings and give the lists their intended meaning. Examples for symbols are
symbol
,sprite
,another-symbol
. They tend to appear at the beginning of lists. -
List: You can nest lists in a Lisp file by enclosing the list in brackets. Example of a list with 2 symbols in it:
(a list)
. A list with a string and three integer numbers:(
“test
”1 2 3)
. A list containing two empty lists:( () () )
.
Whitespace (spaces, new lines and tabs) are ignored (unless they're inside a string, of course).
Comments are initiated with a semicolon (;
). They comment out anything that follows until the end of the line.
Some examples of real files used in SuperTux follow. (Ellipsis (three dots) indicate that we left out some parts of the file.)
(supertux-config
(show_fps #f)
(cheats #f)
(video
(fullscreen #t)
(width 800)
(height 600)
)
(audio
(sound_enabled #t)
(music_enabled #t)
)
)
(supertux-level
(version 2)
(name (_ "Yeti Test"))
(author "Team")
(sector
(name "main")
(music "bossattack.ogg")
(gravity 10.000000)
(tilemap
(layer "background")
(solid #f)
(speed 1.000000)
(width 25)
(height 20)
(tiles 0 0 0 0 ... )
(tilemap
(layer "interactive")
(solid #t)
(speed 1.000000)
(width 25)
(height 20)
(tiles 11 11 11 ... )
(tilemap
(layer "foreground")
(solid #f)
(speed 1.000000)
(width 25)
(height 20)
(tiles 0 0 ... )
(camera
(mode "normal")
)
(background
(image "semi_arctic.jpg")
(speed 0.500000)
)
(yeti
(x 2)
(y 177)
(dead-script "
Sound.play(\"sounds/invincible.wav\");
Text.set_text(\"You made it!\");
Text.set_font(\"big\");
Text.fade_in(1.5);
set_wakeup_time(4);
suspend();
DisplayEffect.fade_out(1.5);
set_wakeup_time(1.5);
suspend();
Level.finish();
")
)
)
)
)
Category:Game Engine Category:File Formats
Home
Guidelines
Game Mechanics
Tools
Engine
- Cameras in other games
- Collision
- Configuration File
- Console
- Cutscenes
- Game_Engine
- Lighting
- Map_transformer
- Portables
- SceneGraph
- Scripting
Specifications
Milestones
- Milestone 1 Analysis
- Milestone 2 Design Document
- Milestone 2 Design Document Old
- Milestone 3 Design Document
Building (mostly outdated)
- INSTALL.md
- Building
- Building on macOS
- Building SuperTux
- Building on Windows
- Building with MXE (cross-compile)
Meetings