Difference between revisions of "ReferenceWML"
|  (→WML toplevel tags) | m (→WML toplevel tags:  minor formatting) | ||
| (64 intermediate revisions by 31 users not shown) | |||
| Line 2: | Line 2: | ||
| == The Wesnoth Markup Language == | == The Wesnoth Markup Language == | ||
| − | The Wesnoth Markup Language (WML) is used to code almost everything in Wesnoth, | + | The Wesnoth Markup Language (WML) is used to code almost everything in Wesnoth, including scenarios, units, savefiles, and the user interface layout. WML files are simple, human-readable text files, usually with the .cfg extension, with similarities to INI files and XML. A major feature in WML are macros, which are alike those found in the C language and similarily are handled by a preprocessor. Implementation-wise, WML files are handled mainly by the ''config'' class (and ''simple_wml'' in [[wesnothd]]). | 
| − | including scenarios, units, savefiles, and the user interface layout. | ||
| − | This page is a collection of pointers to different common WML structures | + | This page is a collection of pointers to different common WML structures. | 
| − | |||
| − | |||
| See [[BuildingScenarios]], [[BuildingCampaigns]] and [[BuildingUnits]] | See [[BuildingScenarios]], [[BuildingCampaigns]] and [[BuildingUnits]] | ||
| Line 18: | Line 15: | ||
| == How WML works == | == How WML works == | ||
| + | * [[SyntaxWML]] Description of WML syntax | ||
| + | * [[VariablesWML]] How to use WML variables | ||
| * [[PreprocessorRef]] the WML preprocessor syntax | * [[PreprocessorRef]] the WML preprocessor syntax | ||
| − | + | * [[GrammarWML]] A more formal definition of the WML syntax. More useful for implementing a WML parser than for writing WML documents. | |
| − | * [[ | + | * [[AddonsWML]] Content that can be published and downloaded via the add-ons server | 
| − | |||
| == WML toplevel tags == | == WML toplevel tags == | ||
| + | |||
| + | The following covers most of the possible toplevel tags in a typical main WML file. Some minor and dev-oriented tags (not intended for use by UMC) are omitted. | ||
| * [[GameConfigWML]] the top level '''[game_config]''' tag | * [[GameConfigWML]] the top level '''[game_config]''' tag | ||
| * [[UnitsWML]] the top level '''[units]''' tag | * [[UnitsWML]] the top level '''[units]''' tag | ||
| − | ** [[ | + | ** [[AbilitiesWML]] a list of the different abilities a unit or weapon can have | 
| + | ** [[UnitTypeWML]] how to describe a unit type | ||
| ** [[AnimationWML]] how to animate units | ** [[AnimationWML]] how to animate units | ||
| + | * [[CoreWML]] the top level '''[core]''' tag | ||
| * [[CampaignWML]] the top level '''[campaign]''' tag | * [[CampaignWML]] the top level '''[campaign]''' tag | ||
| − | * [[ | + | ** [[CreditsWML]] how to describe the credits (the '''[about]''' tag) | 
| − | ** [[EventWML]] how to describe an event | + | * [[ScenarioWML]] the top level tags '''[scenario]''', '''[multiplayer]''', and '''[test]''' | 
| − | ** [[SideWML]] how to describe a side | + | ** [[EventWML]] how to describe an event (the '''[event]''' tag) | 
| + | ** [[SideWML]] how to describe a side (the '''[side]''' tag) | ||
| ** [[MapGeneratorWML]] the random map generator | ** [[MapGeneratorWML]] the random map generator | ||
| ** [[TimeWML]] how to describe a day | ** [[TimeWML]] how to describe a day | ||
| − | ** [[IntroWML]] how to describe the intro screen | + | ** [[IntroWML]] how to describe the intro screen (the '''[story]''' and '''[part]''' tags) | 
| − | |||
| − | |||
| − | |||
| − | |||
| * [[EraWML]] the top level '''[era]''' tag | * [[EraWML]] the top level '''[era]''' tag | ||
| − | * [[TerrainWML]] the top level '''[ | + | * [[ModificationWML]] the top level '''[modification]''' and '''[resource]''' tags | 
| + | * [[TerrainWML]] the top level '''[terrain_type]''' tag | ||
| * [[TerrainGraphicsWML]], the top level '''[terrain_graphics]''' tag | * [[TerrainGraphicsWML]], the top level '''[terrain_graphics]''' tag | ||
| * [[ThemeWML]] the top level '''[theme]''' tag | * [[ThemeWML]] the top level '''[theme]''' tag | ||
| * [[LanguageWML]] the top level '''[language]''' tag | * [[LanguageWML]] the top level '''[language]''' tag | ||
| + | * [[LocaleWML]] the top level '''[locale]''' tag | ||
| * [[HelpWML]] the top level '''[help]''' tag | * [[HelpWML]] the top level '''[help]''' tag | ||
| * [[BinaryPathWML]] the top level '''[binary_path]''' tag | * [[BinaryPathWML]] the top level '''[binary_path]''' tag | ||
| * [[FontsWML]] the top level '''[fonts]''' tag | * [[FontsWML]] the top level '''[fonts]''' tag | ||
| + | * [[GettextForWesnothDevelopers#The_textdomain_tag|Textdomains]] the '''[textdomain]''' tag | ||
| + | |||
| + | Some other files use the WML format, but with different tags. | ||
| + | |||
| + | * [[AchievementsWML]] the '''[achievement_group]''' and '''[achievement]''' tags. | ||
| + | * [[SavefileWML]] a description of the format of savegames | ||
| + | ** [[ReplayWML]] a description of the format of player actions such as moving a unit | ||
| + | ** [[StatisticalScenarioWML]] used to generate statistics of a savegame | ||
| + | * [[PblWML]] a description of the format of server-uploadable campaigns | ||
| + | * [[SchemaWML]] a description of WML files that define the structure of other WML files | ||
| + | * [[DiffWML]] used to describe structural differences between preprocessed WML documents | ||
| + | * [[GUIToolkit]] gives an overview of Wesnoth's current UI system and how to create user interfaces with it. | ||
| == Other WML tags == | == Other WML tags == | ||
| * [[EventWML]] how to describe an event | * [[EventWML]] how to describe an event | ||
| − | ** [[FilterWML]] the construct to filter on units, locations, and  | + | ** [[FilterWML]] the construct to filter on [[StandardUnitFilter|units]], [[StandardLocationFilter|locations]], [[StandardSideFilter|sides]], weapons, vision, and WML data. | 
| − | ** [[DirectActionsWML]] actions that directly affect gameplay: for example creating a unit | + | ** [[ActionWML]] to describe the actions which occur when the event is fired | 
| − | ** [[InternalActionsWML]] actions that WML uses internally: for example storing a variable | + | *** [[ConditionalActionsWML]] actions that encapsulate conditional filters and the actions to execute if the conditions are met | 
| − | ** [[InterfaceActionsWML]] actions that do not affect gameplay: for example displaying a message | + | *** [[DirectActionsWML]] actions that directly affect gameplay: for example, creating a unit | 
| − | * [[ | + | **** [[SingleUnitWML]] how to describe a unit (for uses such as placing one on the map with the '''[unit]''' tag) | 
| − | * [[AiWML]] how to describe parameters for AI | + | *** [[InternalActionsWML]] actions that WML uses internally: for example, storing a variable | 
| − | * [[EffectWML]] the construct to modify a unit | + | *** [[InterfaceActionsWML]] actions that do not affect gameplay: for example, displaying a message | 
| − | + | *** [[LuaWML]] how to code actions with the Lua language (BfW 1.14 and earlier) | |
| + | *** [[LuaAPI]] how to code actions with the Lua language (BfW 1.16 and later) | ||
| + | * [[AiWML]] how to describe parameters for AI (the '''[ai]''' tag) | ||
| + | * [[EffectWML]] the construct to modify a unit (the '''[effect]''' tag) | ||
| * [[DescriptionWML]] the structure of WML coded menus like the difficulty chooser of campaigns | * [[DescriptionWML]] the structure of WML coded menus like the difficulty chooser of campaigns | ||
| + | * [[EditorWML]] tags controlling the post-1.4 editor's behavior | ||
| + | * [[MusicListWML]] for playing music (see also [[Available Music]] for a list of what's available) | ||
| == Predefined macros ==   | == Predefined macros ==   | ||
| − | Wesnoth ships with a library of predefined macros you should find useful in  | + | Wesnoth ships with a library of predefined macros you should find useful in writing your own WML. | 
| + | * [https://www.wesnoth.org/macro-reference.html WML Macros] - description of all such macros. | ||
| == Other == | == Other == | ||
| Line 70: | Line 89: | ||
| * [[ReferenceWMLSyntax]] how this wiki and the pages it links to should be formatted | * [[ReferenceWMLSyntax]] how this wiki and the pages it links to should be formatted | ||
| * [[ConventionsWML]] how to make your WML more readable | * [[ConventionsWML]] how to make your WML more readable | ||
| + | * [[Wml_optimisation]] how to make your WML code more efficient | ||
| * [[UsefulWMLFragments]] Various pieces of WML for various purposes. If you have some WML you're proud of that you think others can use, add it here. | * [[UsefulWMLFragments]] Various pieces of WML for various purposes. If you have some WML you're proud of that you think others can use, add it here. | ||
| − | * [[CommandMode]] commands are not strictly speaking part of WML,  | + | * [[Maintenance tools]] for wmlindent, wmllint, wmlscope | 
| + | * [[CommandMode]] commands are not strictly speaking part of WML, but they are useful for debugging it, and could be a little hard to find, so linking to them here makes sense. | ||
| * [[MultiplayerServerWML]] is used when communicating with the multiplayer server. | * [[MultiplayerServerWML]] is used when communicating with the multiplayer server. | ||
| * [[CampaignServerWML]] is used when managing contributed campaigns on the campaign server. | * [[CampaignServerWML]] is used when managing contributed campaigns on the campaign server. | ||
| − | * [[ | + | * [[ImagePathFunctions]] (IPFs) are used when applying the color function to images, such as marking units as belonging to a team or in TerrainGraphics. | 
| − | * [[ | + | * [[Pango formatting]] shows ways to enrich descriptions using pango markup, which can use basic html style formatting tags, such as <nowiki><b>, <i>, <span></nowiki> and others. | 
| + | * [[Wesnoth_Formula_Language|Wesnoth Formula Language (WFL)]] often used with $() formulas. | ||
| + | * [[PreprocessorRef|Syntax of preprocessor mini-language]] : symbols, macros, file inclusions... | ||
| == See Also == | == See Also == | ||
| * [[BuildingMaps]] the text-based format for Wesnoth maps | * [[BuildingMaps]] the text-based format for Wesnoth maps | ||
| − | * [[ | + | * [[TerrainCodeTableWML]] a list of all terrains, and [[TerrainCodesWML]], on how to use them | 
| * [[MultiHexTutorial]] a description of the multi-hex tiling system | * [[MultiHexTutorial]] a description of the multi-hex tiling system | ||
| * [[IGNFileFormat]] a description of the ignore file format | * [[IGNFileFormat]] a description of the ignore file format | ||
| − | + | * [[CompatibilityStandards#Deprecation_levels_-_When_to_remove_deprecated_features|DeprecationLevels]] | |
| + | * [[Environment_variables]] a cheat-sheet for CLI environment variables | ||
| + | * Back to [[Create]] | ||
| [[Category: WML Reference]] | [[Category: WML Reference]] | ||
Latest revision as of 02:47, 30 July 2024
Contents
The Wesnoth Markup Language
The Wesnoth Markup Language (WML) is used to code almost everything in Wesnoth, including scenarios, units, savefiles, and the user interface layout. WML files are simple, human-readable text files, usually with the .cfg extension, with similarities to INI files and XML. A major feature in WML are macros, which are alike those found in the C language and similarily are handled by a preprocessor. Implementation-wise, WML files are handled mainly by the config class (and simple_wml in wesnothd).
This page is a collection of pointers to different common WML structures.
See BuildingScenarios, BuildingCampaigns and BuildingUnits for a tutorial style overview.
Note: this reference may contain slight inaccuracies, might not list all existing keys and tags or might contain some deprecated syntax. If you find that this reference doesn't give you the answer to how to implement some feature in WML, the most reliable way is to look at the WML code of existing units and campaigns that have done so.
How WML works
- SyntaxWML Description of WML syntax
- VariablesWML How to use WML variables
- PreprocessorRef the WML preprocessor syntax
- GrammarWML A more formal definition of the WML syntax. More useful for implementing a WML parser than for writing WML documents.
- AddonsWML Content that can be published and downloaded via the add-ons server
WML toplevel tags
The following covers most of the possible toplevel tags in a typical main WML file. Some minor and dev-oriented tags (not intended for use by UMC) are omitted.
- GameConfigWML the top level [game_config] tag
- UnitsWML the top level [units] tag
- AbilitiesWML a list of the different abilities a unit or weapon can have
- UnitTypeWML how to describe a unit type
- AnimationWML how to animate units
 
- CoreWML the top level [core] tag
- CampaignWML the top level [campaign] tag
- CreditsWML how to describe the credits (the [about] tag)
 
- ScenarioWML the top level tags [scenario], [multiplayer], and [test]
- EventWML how to describe an event (the [event] tag)
- SideWML how to describe a side (the [side] tag)
- MapGeneratorWML the random map generator
- TimeWML how to describe a day
- IntroWML how to describe the intro screen (the [story] and [part] tags)
 
- EraWML the top level [era] tag
- ModificationWML the top level [modification] and [resource] tags
- TerrainWML the top level [terrain_type] tag
- TerrainGraphicsWML, the top level [terrain_graphics] tag
- ThemeWML the top level [theme] tag
- LanguageWML the top level [language] tag
- LocaleWML the top level [locale] tag
- HelpWML the top level [help] tag
- BinaryPathWML the top level [binary_path] tag
- FontsWML the top level [fonts] tag
- Textdomains the [textdomain] tag
Some other files use the WML format, but with different tags.
- AchievementsWML the [achievement_group] and [achievement] tags.
- SavefileWML a description of the format of savegames
- ReplayWML a description of the format of player actions such as moving a unit
- StatisticalScenarioWML used to generate statistics of a savegame
 
- PblWML a description of the format of server-uploadable campaigns
- SchemaWML a description of WML files that define the structure of other WML files
- DiffWML used to describe structural differences between preprocessed WML documents
- GUIToolkit gives an overview of Wesnoth's current UI system and how to create user interfaces with it.
Other WML tags
- EventWML how to describe an event
- FilterWML the construct to filter on units, locations, sides, weapons, vision, and WML data.
- ActionWML to describe the actions which occur when the event is fired
- ConditionalActionsWML actions that encapsulate conditional filters and the actions to execute if the conditions are met
- DirectActionsWML actions that directly affect gameplay: for example, creating a unit
- SingleUnitWML how to describe a unit (for uses such as placing one on the map with the [unit] tag)
 
- InternalActionsWML actions that WML uses internally: for example, storing a variable
- InterfaceActionsWML actions that do not affect gameplay: for example, displaying a message
- LuaWML how to code actions with the Lua language (BfW 1.14 and earlier)
- LuaAPI how to code actions with the Lua language (BfW 1.16 and later)
 
 
- AiWML how to describe parameters for AI (the [ai] tag)
- EffectWML the construct to modify a unit (the [effect] tag)
- DescriptionWML the structure of WML coded menus like the difficulty chooser of campaigns
- EditorWML tags controlling the post-1.4 editor's behavior
- MusicListWML for playing music (see also Available Music for a list of what's available)
Predefined macros
Wesnoth ships with a library of predefined macros you should find useful in writing your own WML.
- WML Macros - description of all such macros.
Other
- ReferenceWMLSyntax how this wiki and the pages it links to should be formatted
- ConventionsWML how to make your WML more readable
- Wml_optimisation how to make your WML code more efficient
- UsefulWMLFragments Various pieces of WML for various purposes. If you have some WML you're proud of that you think others can use, add it here.
- Maintenance tools for wmlindent, wmllint, wmlscope
- CommandMode commands are not strictly speaking part of WML, but they are useful for debugging it, and could be a little hard to find, so linking to them here makes sense.
- MultiplayerServerWML is used when communicating with the multiplayer server.
- CampaignServerWML is used when managing contributed campaigns on the campaign server.
- ImagePathFunctions (IPFs) are used when applying the color function to images, such as marking units as belonging to a team or in TerrainGraphics.
- Pango formatting shows ways to enrich descriptions using pango markup, which can use basic html style formatting tags, such as <b>, <i>, <span> and others.
- Wesnoth Formula Language (WFL) often used with $() formulas.
- Syntax of preprocessor mini-language : symbols, macros, file inclusions...
See Also
- BuildingMaps the text-based format for Wesnoth maps
- TerrainCodeTableWML a list of all terrains, and TerrainCodesWML, on how to use them
- MultiHexTutorial a description of the multi-hex tiling system
- IGNFileFormat a description of the ignore file format
- DeprecationLevels
- Environment_variables a cheat-sheet for CLI environment variables
- Back to Create