Wares¶
Wares are used to build buildings, produce other wares and recruit units.
Wares are defined in
data/tribes/wares/<ware_name>/init.lua
.
The ware will also need its help texts,
which are defined in data/tribes/initialization/<tribe_name>/units.lua
- new_ware_type(table)¶
This function adds the definition of a ware to the engine.
- Parameters:
table – This table contains all the data that the game engine will add to this ware. It contains the following entries:
name: A string containing the internal name of this ware.
descname: The translatable display name. Use
pgettext
to fetch the string.icon: The full path to the menu icon for this ware.
default_target_quantity: A table listing the default target quantity for each tribe’s economy. For example,
{ atlanteans = 3, empire = 1 }
This table does not need to have an entry for each tribe. (Can be completely empty) If not set for a tribe the economy will always demand this ware. If set to zero the economy will not demand this ware unless it is required in a production building. If not set or set to zero the actual target quantity will not be available in the economy settings window. NOTE: This parameter has been shifted to tribes initialization in the current development version.preciousness: How precious this ware is to each tribe. For example,
{ atlanteans = 0, empire = 1 }
. We recommend not going higher than25
. NOTE: This parameter has been shifted to tribes initialization in the current development version.animations: A table containing all animations for this ware. Wares have an “idle” animation.
For making the UI texts translateable, we also need to push/pop the correct textdomain.
Example:
push_textdomain("tribes")
dirname = path.dirname(__file__)
wl.Descriptions():new_ware_type {
name = "armor",
descname = pgettext("ware", "Armor"),
animation_directory = dirname,
icon = dirname .. "menu.png",
animations = {
idle = {
hotspot = { 3, 11 },
},
}
}
pop_textdomain()
Help Texts¶
See Helptexts.