← Back to team overview

widelands-dev team mailing list archive

[Merge] lp:~widelands-dev/widelands/sphinx-buildings into lp:widelands

 

GunChleoc has proposed merging lp:~widelands-dev/widelands/sphinx-buildings into lp:widelands.

Commit message:
Restructured and enhanced the Buildings documentation.

Requested reviews:
  Widelands Developers (widelands-dev)
Related bugs:
  Bug #1512093 in widelands: "Add tribes directory to developer scripting reference"
  https://bugs.launchpad.net/widelands/+bug/1512093

For more details, see:
https://code.launchpad.net/~widelands-dev/widelands/sphinx-buildings/+merge/308704
-- 
Your team Widelands Developers is requested to review the proposed merge of lp:~widelands-dev/widelands/sphinx-buildings into lp:widelands.
=== modified file 'data/tribes/atlanteans.lua'
--- data/tribes/atlanteans.lua	2016-09-01 15:43:01 +0000
+++ data/tribes/atlanteans.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_<tribename>.lua:
+--
 -- <tribename>.lua
 -- ---------------------
 --
@@ -7,7 +9,7 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_tribe(table)
+-- .. function:: new_tribe{table}
 --
 --    This function adds all units to a tribe.
 --

=== modified file 'data/tribes/buildings/militarysites/atlanteans/castle/helptexts.lua'
--- data/tribes/buildings/militarysites/atlanteans/castle/helptexts.lua	2016-09-02 08:27:34 +0000
+++ data/tribes/buildings/militarysites/atlanteans/castle/helptexts.lua	2016-10-18 09:50:49 +0000
@@ -1,68 +1,29 @@
--- RST
--- Building Helptexts
--- ------------------
---
--- Each building has a ``helptexts.lua`` script, which is located in the same directory as its ``init.lua`` script.
--- The functions in this file return texts that are used for buildings by the Tribal Encyclopedia.
---
--- See also the helper functions in ``scripting/help/global_helptexts.lua``
---
+-- The helptext documentation is located in /doc/sphinx/lua_tribes_buildings_rst.org
 
 -- This include can be removed when all help texts have been defined.
 include "tribes/scripting/help/global_helptexts.lua"
 
--- RST
--- .. function:: building_helptext_lore()
---
---    Returns a localized string with a lore helptext for this building.
---    If you don't have a lore text yet, use ``no_lore_text_yet()`` from the ``global_helptexts.lua`` script.
---
---    :returns: Localized lore text
 function building_helptext_lore()
    -- TRANSLATORS#: Lore helptext for a building
    return no_lore_text_yet()
 end
 
--- RST
--- .. function:: building_helptext_lore_author()
---
---    Returns a localized string with a fictional author for the lore helptext for this building. The returned string can be empty.
---    If you don't have an author yet, use ``no_lore_author_text_yet()`` from the ``global_helptexts.lua`` script.
---
 --    :returns: Localized lore author or empty string.
 function building_helptext_lore_author()
    -- TRANSLATORS#: Lore author helptext for a building
    return no_lore_author_text_yet()
 end
 
--- RST
--- .. function:: building_helptext_purpose()
---
---    Returns a localized string with a purpose helptext for this building. This should be individually defined for all buildings. You can use ``no_purpose_text_yet()`` from the ``global_helptexts.lua`` script if you're not ready to define this yet.
---
---    :returns: Localized purpose text
 function building_helptext_purpose()
    -- TRANSLATORS: Purpose helptext for a building
    return pgettext("building", "Garrisons soldiers to expand your territory.")
 end
 
--- RST
--- .. function:: building_helptext_note()
---
---    Returns a localized string with a note that is added to the purpose. This can be empty.
---
---    :returns: Localized note text or empty string.
 function building_helptext_note()
    -- TRANSLATORS: Note helptext for a building
    return pgettext("building", "If you’re low on soldiers to occupy new military sites, use the downward arrow button to decrease the capacity. You can also click on a soldier to send him away.")
 end
 
--- RST
--- .. function:: building_helptext_performance()
---
---    Returns a localized string with a performance helptext for this building. You can use ``no_purpose_text_yet()`` from the ``global_helptexts.lua`` script if the performance hasn't been calculated yet. Leave empty when this isn't applicable (e.g. for militarysites or warehouses).
---
---    :returns: Localized performance text or empty string.
 function building_helptext_performance()
    -- TRANSLATORS#: Performance helptext for a building
    return ""

=== modified file 'data/tribes/buildings/militarysites/atlanteans/castle/init.lua'
--- data/tribes/buildings/militarysites/atlanteans/castle/init.lua	2016-09-22 16:45:02 +0000
+++ data/tribes/buildings/militarysites/atlanteans/castle/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_buildings_militarysites:
+--
 -- Military Sites
 -- --------------
 --
@@ -13,51 +15,37 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_militarysite_type(table)
+-- .. function:: new_militarysite_type{table}
 --
 --    This function adds the definition of a military site building to the engine.
 --
 --    :arg table: This table contains all the data that the game engine will add to this building.
---                It contains the following entries:
---
---    **msgctxt**: The context that Gettext will use to disambiguate the translations for strings in this table.
---
---    **name**: A string containing the internal name of this building.
---
---    **descname**: The translatable display name. Use ``pgettext`` with the ``msgctxt`` above to fetch the string.
---
---    **helptext_script**: The full path to the ``helptexts.lua`` script for this building.
---
---    **icon**: The full path to the menu icon for this building.
---
---    **size**: The size of this building: ``"small"``, ``"medium"``, or ``"big"``.
---
---    **buildcost**: A table with the wares used to build this building, containing warename - amount pairs, e.g. ``buildcost = { log = 4, granite = 2 }``.
---
---    **return_on_dismantle**: The wares that this building will give back to the player when it is dismantled, e.g. ``buildcost = { log = 2, granite = 1 }``.
---
---    **enhancement_cost**: The wares needed to upgrade this building, e.g. ``enhancement_cost = { log = 1, granite = 1 }``.
---
---    **return_on_dismantle_on_enhanced**: The wares that this enhanced building will give back to the player when it is dismantled, e.g. ``return_on_dismantle_on_enhanced = { granite = 1 }``.
---
---    **animations**: A table containing all animations for this building.
---
---    **aihints**: A list of name - value pairs with hints for the AI.
---
---    **max_soldiers**: The maximum number of solders that can be garrisoned at this building.
---
---    **heal_per_second**: The number of health points that a garrisoned soldier will heal each second.
---
---    **conquers**: The conquer radius for this building.
---
---    **prefer_heroes**: Whether this building prefers heroes or rookies per default. Set to ``true`` or ``false``.
---
---    **messages**: Messages that this building will send to the user. The following messages need to ne defined:
---         * *occupied*: Shown when your soldiers occupy a new building
---         * *aggressor*: Shown when this building sees enemy soldiers
---         * *attack*: Shown when this building is being attacked by an enemy
---         * *defeated_enemy*: Shown when you lose this building to an enemy
---         * *defeated_you*: Shown when you take this building from an enemy
+--                In addition to the :ref:`lua_tribes_buildings_common`, it contains the following entries:
+--
+--    **max_soldiers**
+--        *Mandatory*. The maximum number of solders that can be garrisoned at this building.
+--
+--    **heal_per_second**
+--        *Mandatory*. The number of health points that a garrisoned soldier will heal each second.
+--
+--    **conquers**
+--        *Mandatory*. The conquer radius for this building.
+--
+--    **prefer_heroes**
+--        *Mandatory*. Whether this building prefers heroes or rookies per default.
+--        Set to ``true`` or ``false``.
+--
+--    **messages**
+--        *Mandatory*. Messages that this building will send to the user. There are 5 messages,
+--        defined like this::
+--
+--            messages = {
+--                occupied = _"Your soldiers have occupied your fortress.",
+--                aggressor = _"Your fortress discovered an aggressor.",
+--                attack = _"Your fortress is under attack.",
+--                defeated_enemy = _"The enemy defeated your soldiers at the fortress.",
+--                defeated_you = _"Your soldiers defeated the enemy at the fortress."
+--            }
 tribes:new_militarysite_type {
    msgctxt = "atlanteans_building",
    name = "atlanteans_castle",

=== modified file 'data/tribes/buildings/partially_finished/constructionsite/init.lua'
--- data/tribes/buildings/partially_finished/constructionsite/init.lua	2016-09-22 16:45:02 +0000
+++ data/tribes/buildings/partially_finished/constructionsite/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_buildings_constructionsites:
+--
 -- Construction Sites
 -- ------------------
 --
@@ -14,30 +16,12 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_constructionsite_type(table)
+-- .. function:: new_constructionsite_type{table}
 --
 --    This function adds the definition of the construction site building to the engine.
 --
 --    :arg table: This table contains all the data that the game engine will add to this building.
---                It contains the following entries:
---
---    **msgctxt**: The context that Gettext will use to disambiguate the translations for strings in this table.
---
---    **name**: A string containing the internal name of this building.
---
---    **descname**: The translatable display name. Use ``pgettext`` with the ``msgctxt`` above to fetch the string.
---
---    **helptext_script**: The full path to the ``helptexts.lua`` script for this building.
---
---    **icon**: The full path to the menu icon for this building.
---
---    **vision_range**: The size of the radious that the building sees.
---
---    **size**: The size of this building: ``"small"``, ``"medium"``, or ``"big"``.
---
---    **animations**: A table containing all animations for this building.
---
---    **aihints**: A list of name - value pairs with hints for the AI.
+--                It only contains :ref:`lua_tribes_buildings_common`.
 --
 tribes:new_constructionsite_type {
    msgctxt = "building",

=== modified file 'data/tribes/buildings/partially_finished/dismantlesite/init.lua'
--- data/tribes/buildings/partially_finished/dismantlesite/init.lua	2016-09-22 16:45:02 +0000
+++ data/tribes/buildings/partially_finished/dismantlesite/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_buildings_dismantlesites:
+--
 -- Dismantle Sites
 -- ---------------
 --
@@ -14,30 +16,12 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_dismantlesite_type(table)
+-- .. function:: new_dismantlesite_type{table}
 --
 --    This function adds the definition of the dismantle site building to the engine.
 --
 --    :arg table: This table contains all the data that the game engine will add to this building.
---                It contains the following entries:
---
---    **msgctxt**: The context that Gettext will use to disambiguate the translations for strings in this table.
---
---    **name**: A string containing the internal name of this building.
---
---    **descname**: The translatable display name. Use ``pgettext`` with the ``msgctxt`` above to fetch the string.
---
---    **helptext_script**: The full path to the ``helptexts.lua`` script for this building.
---
---    **icon**: The full path to the menu icon for this building.
---
---    **vision_range**: The size of the radious that the building sees.
---
---    **size**: The size of this building: ``"small"``, ``"medium"``, or ``"big"``.
---
---    **animations**: A table containing all animations for this building.
---
---    **aihints**: A list of name - value pairs with hints for the AI.
+--                It only contains :ref:`lua_tribes_buildings_common`.
 --
 tribes:new_dismantlesite_type {
    msgctxt = "building",

=== modified file 'data/tribes/buildings/productionsites/atlanteans/armorsmithy/init.lua'
--- data/tribes/buildings/productionsites/atlanteans/armorsmithy/init.lua	2016-09-22 16:45:02 +0000
+++ data/tribes/buildings/productionsites/atlanteans/armorsmithy/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_buildings_productionsites:
+--
 -- Production Sites
 -- ----------------
 --
@@ -15,58 +17,70 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_productionsite_type(table)
+-- .. function:: new_productionsite_type{table}
 --
 --    This function adds the definition of a production site building to the engine.
 --
 --    :arg table: This table contains all the data that the game engine will add to this building.
---                It contains the following entries:
---
---    **msgctxt**: The context that Gettext will use to disambiguate the translations for strings in this table.
---
---    **name**: A string containing the internal name of this building.
---
---    **descname**: The translatable display name. Use ``pgettext`` with the ``msgctxt`` above to fetch the string.
---
---    **helptext_script**: The full path to the ``helptexts.lua`` script for this building.
---
---    **icon**: The full path to the menu icon for this building.
---
---    **size**: The size of this building: ``"small"``, ``"medium"``, ``"big"`` or ``"mine"``.
---
---    **buildcost**: A table with the wares used to build this building, containing warename - amount pairs, e.g. ``buildcost = { log = 4, granite = 2 }``.
---
---    **return_on_dismantle**: The wares that this building will give back to the player when it is dismantled, e.g. ``buildcost = { log = 2, granite = 1 }``.
---
---    **enhancement_cost**: The wares needed to upgrade this building, e.g. ``enhancement_cost = { log = 1, granite = 1 }``.
---
---    **return_on_dismantle_on_enhanced**: The wares that this enhanced building will give back to the player when it is dismantled, e.g. ``return_on_dismantle_on_enhanced = { granite = 1 }``.
---
---    **animations**: A table containing all animations for this building.
---
---    **aihints**: A list of name - value pairs with hints for the AI.
---
---    **working_positions**: The name and amount for each worker type working at this building.
---
---    **inputs**: The name and amount for each ware input queue.
---
---    **outputs**: The wares/workers produced by this building.
---
---    **programs**: The production site programs that define what preconditions
---    a building needs to fulfil in order to produce its wares and how it's done,
---    including any animations and sounds played. See also :doc:`productionsite_program`.
---
---    **out_of_resource_notification**: This optional table defines the message
---    sent by the productionsite to the player if it has run out of a resource to
---    collect. Table keys are:
---
---        *title*: A concise message title for the list in the inbox.
---
---        *heading*: A longer version of the title, shown in the message body.
---
---        *message*: The actual message. Translation needs to be fetched with pgettext.
---
---        *productivity_threshold*: An optional int value in percent to trigger the message.
+--                In addition to the :ref:`lua_tribes_buildings_common`, it contains the following entries:
+--
+--    **size**
+--        *Mandatory*. In addition to the common size values ``"small"``,
+--        ``"medium"``, or ``"big"``, production sites can also have size ``"mine"``
+--        for defining a mine building to be built on mountains.
+--
+--    **working_positions**
+--        *Mandatory*. The name and amount for each worker type working at this
+--        building, e.g.::
+--
+--            working_positions = { atlanteans_armorsmith = 1 },
+--
+--    **inputs**
+--        *Optional*. The name and amount for each ware input queue, e.g.::
+--
+--            inputs = {
+--                { name = "coal", amount = 10 },
+--                { name = "iron", amount = 8 },
+--                { name = "gold", amount = 8 }
+--            },
+--
+--    **outputs**
+--        *Optional*. The wares/workers produced by this building, e.g.::
+--
+--            outputs = { "shield_advanced", "shield_steel" },
+--
+--    **programs**.
+--        *Mandatory*. The production site programs that define what preconditions
+--        a building needs to fulfil in order to produce its wares and how it's
+--        done, including any animations and sounds played.
+--        See :doc:`productionsite_program`.
+--
+--    **out_of_resource_notification**.
+--        *Optional*. This table defines the message sent by the productionsite
+--        to the player if it has run out of a resource to collect. There are 4
+--        entries:
+--
+--        **title**
+--            *Mandatory*. A concise message title for the list in the inbox.
+--
+--        **heading**
+--            *Mandatory*. A longer version of the title, shown in the message body.
+--
+--        **message**
+--            *Mandatory*. The actual message. Translation needs to be fetched with pgettext.
+--
+--        **productivity_threshold**
+--            *Optional. Default:* ``100``. An int value in percent to trigger the message.
+--
+--        Example::
+--
+--            out_of_resource_notification = {
+--                -- Translators: Short for "Out of ..." for a resource
+--                title = _"No Fields",
+--                heading = _"Out of Fields",
+--                message = pgettext("atlanteans_building", "The farmer working at this farm has no cleared soil to plant his seeds."),
+--                productivity_threshold = 30
+--            },
 --
 tribes:new_productionsite_type {
    msgctxt = "atlanteans_building",

=== modified file 'data/tribes/buildings/trainingsites/atlanteans/dungeon/init.lua'
--- data/tribes/buildings/trainingsites/atlanteans/dungeon/init.lua	2016-09-10 16:50:51 +0000
+++ data/tribes/buildings/trainingsites/atlanteans/dungeon/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_buildings_trainingsites:
+--
 -- Training Sites
 -- --------------
 --
@@ -14,39 +16,66 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_trainingsite_type(table)
+-- .. function:: new_trainingsite_type{table}
 --
 --    This function adds the definition of a training site building to the engine.
 --
 --    :arg table: This table contains all the data that the game engine will add to this building.
---                It contains everything that a productionsite contains, plus the following entries:
---
---    **soldier_capacity**: An int describing how many soldiers this building can house.
---
---    **trainer_patience**: An int describing how patient the trainer is.
---    If trainer patience runs out, a soldier will be kicked out.
---
---    **soldier attack**: A table describing what is needed to train a soldier in attack.
---    It contains the following entries:
---
---        *min_level*: The minimum attack level that a soldier needs before it
---        can be trained in attack at this training site.
---
---        *max_level*: The maximum level of attack that a soldier can be trained in.
---
---        *food*: A table with the types food needed to train a soldier in attack.
---        It contains subtables with alternatives, e.g. ``{"fish", "meat"}``
---        means that fish OR meat is needed, ``{"fish"}, {"meat"}`` means that fish
---        AND meat are needed.
---
---        *weapons*: A table with the list of weapons that are used for attack
---        training at the various levels.
---
---   **soldier defense**: Just like ``soldier attack``, but for defense training
---
---   **soldier health**: Just like ``soldier attack``, but for health training
---
---   **soldier evade**: Just like ``soldier attack``, but for evade training
+--                It is a special type of production site, so it has all the entries that :ref:`lua_tribes_buildings_productionsites` can have, plus the following entries:
+--
+--    **soldier_capacity**
+--        *Mandatory*. An int describing how many soldiers this building can house.
+--
+--    **trainer_patience**
+--        *Mandatory*. An int describing how patient the trainer is.
+--        If trainer patience runs out, a soldier will be kicked out.
+--
+--    **soldier attack**
+--        *Optional*. A table describing what is needed to train a soldier in attack.
+--        It contains the following entries:
+--
+--        **min_level**
+--            *Mandatory*. The minimum attack level that a soldier needs before it
+--            can be trained in attack at this training site.
+--
+--        **max_level**
+--            *Mandatory*. The maximum level of attack that a soldier can be trained in.
+--
+--        **food**
+--            *Optional*. A table with the types of food needed to train a
+--            soldier in attack. It contains subtables with alternatives, e.g.
+--            ``{"fish", "meat"}`` means that fish OR meat is needed,
+--            ``{"fish"}, {"meat"}`` means that fish AND meat are needed.
+--
+--        **weapons**
+--            *Optional*. A table with the list of weapons that are used for
+--            attack training at the various levels.
+--
+--        Example::
+--
+--            ["soldier attack"] = {
+--                min_level = 0,
+--                max_level = 3,
+--                food = {
+--                    {"smoked_fish", "smoked_meat"},
+--                    {"atlanteans_bread"}
+--                },
+--                weapons = {
+--                    "trident_long",
+--                    "trident_steel",
+--                    "trident_double",
+--                    "trident_heavy_double"
+--                }
+--            },
+--
+--    **soldier defense**
+--            *Optional*. Just like ``soldier attack``, but for defense training.
+--
+--    **soldier health**
+--            *Optional*. Just like ``soldier attack``, but for health training.
+--
+--    **soldier evade**
+--            *Optional*. Just like ``soldier attack``, but for evade training.
 --
 tribes:new_trainingsite_type {
    msgctxt = "atlanteans_building",

=== modified file 'data/tribes/buildings/warehouses/atlanteans/headquarters/init.lua'
--- data/tribes/buildings/warehouses/atlanteans/headquarters/init.lua	2016-09-22 16:45:02 +0000
+++ data/tribes/buildings/warehouses/atlanteans/headquarters/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_buildings_warehouses:
+--
 -- Headquarters, Warehouses and Ports
 -- ----------------------------------
 --
@@ -17,43 +19,27 @@
 dirname = path.dirname(__file__)
 
 -- RST
--- .. function:: new_warehouse_type(table)
+-- .. function:: new_warehouse_type{table}
 --
 --    This function adds the definition of a warehouse building to the engine.
 --
 --    :arg table: This table contains all the data that the game engine will add to this building.
---                It contains the following entries:
---
---    **msgctxt**: The context that Gettext will use to disambiguate the translations for strings in this table.
---
---    **name**: A string containing the internal name of this building.
---
---    **descname**: The translatable display name. Use ``pgettext`` with the ``msgctxt`` above to fetch the string.
---
---    **helptext_script**: The full path to the ``helptexts.lua`` script for this building.
---
---    **icon**: The full path to the menu icon for this building.
---
---    **size**: The size of this building: ``"small"``, ``"medium"``, ``"big"`` or ``"port"``.
---
---    **destructible**: Set this to ``false`` for headquarters, leave blank otherwise.
---
---    **buildcost**: A table with the wares used to build this building, containing warename - amount pairs, e.g. ``buildcost = { log = 4, granite = 2 }``. If this table isn't defined, the building will be a headquarters.
---
---    **return_on_dismantle**: The wares that this building will give back to the player when it is dismantled, e.g. ``buildcost = { log = 2, granite = 1 }``. If this table isn't defined, the building will be a headquarters.
---
---    **enhancement_cost**: The wares needed to upgrade this building, e.g. ``enhancement_cost = { log = 1, granite = 1 }``. If this table isn't defined, the building will be a headquarters.
---
---    **return_on_dismantle_on_enhanced**: The wares that this enhanced building will give back to the player when it is dismantled, e.g. ``return_on_dismantle_on_enhanced = { granite = 1 }``. If this table isn't defined, the building will be a headquarters.
---
---    **animations**: A table containing all animations for this building.
---
---    **aihints**: A list of name - value pairs with hints for the AI.
---
---    **heal_per_second**: The number of health points that a garrisoned soldier will heal each second.
---
---    **conquers**: The conquer radius for this building. This is used for headquarters and ports.
---
+--                In addition to the :ref:`lua_tribes_buildings_common`, it contains the following entries:
+--
+--    **size**
+--        *Mandatory*. In addition to the common size values ``"small"``,
+--        ``"medium"``, or ``"big"``, warehouses can also have size ``"port"``
+--        for defining a port building.
+--
+--    **heal_per_second**
+--        *Mandatory*. The number of health points that a garrisoned soldier will heal each second.
+--
+--    **conquers**
+--        *Optional. Default:* ``0``. The conquer radius for this building.
+--
+--    **destructible**
+--        *Optional. Default:* ``true``. Set this to ``false`` for headquarters.
+
 tribes:new_warehouse_type {
    msgctxt = "atlanteans_building",
    name = "atlanteans_headquarters",

=== modified file 'data/tribes/immovables/ashes/init.lua'
--- data/tribes/immovables/ashes/init.lua	2016-09-26 11:37:54 +0000
+++ data/tribes/immovables/ashes/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_immovables:
+--
 -- Tribe Immovables
 -- ----------------
 --

=== modified file 'data/tribes/scripting/help/global_helptexts.lua'
--- data/tribes/scripting/help/global_helptexts.lua	2016-09-01 15:23:25 +0000
+++ data/tribes/scripting/help/global_helptexts.lua	2016-10-18 09:50:49 +0000
@@ -3,6 +3,8 @@
 --  =======================================================
 
 -- RST
+-- .. _lua_tribes_global_helptexts.lua:
+--
 -- global_helptexts.lua
 -- --------------------
 --

=== modified file 'data/tribes/ships/atlanteans/init.lua'
--- data/tribes/ships/atlanteans/init.lua	2016-09-26 11:37:54 +0000
+++ data/tribes/ships/atlanteans/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_ships:
+--
 -- Ships
 -- -----
 --

=== modified file 'data/tribes/wares/armor/init.lua'
--- data/tribes/wares/armor/init.lua	2016-09-22 16:45:48 +0000
+++ data/tribes/wares/armor/init.lua	2016-10-18 09:50:49 +0000
@@ -1,4 +1,6 @@
 -- RST
+-- .. _lua_tribes_wares:
+--
 -- Wares
 -- -----
 --

=== modified file 'doc/sphinx/extract_rst.py'
--- doc/sphinx/extract_rst.py	2016-09-22 16:45:48 +0000
+++ doc/sphinx/extract_rst.py	2016-10-18 09:50:49 +0000
@@ -36,17 +36,17 @@
     ('data/tribes/scripting/mapobject_info', '', 'lua_tribes_other'),
     ('data/tribes/scripting/help', '', 'lua_tribes_other'),
     ('data/tribes/buildings/militarysites/atlanteans/castle',
-     'militarysite', 'lua_tribes_units'),
+     'militarysite', 'lua_tribes_buildings'),
     ('data/tribes/buildings/productionsites/atlanteans/armorsmithy',
-     'productionsite', 'lua_tribes_units'),
+     'productionsite', 'lua_tribes_buildings'),
     ('data/tribes/buildings/trainingsites/atlanteans/dungeon',
-     'trainingsite', 'lua_tribes_units'),
+     'trainingsite', 'lua_tribes_buildings'),
     ('data/tribes/buildings/warehouses/atlanteans/headquarters',
-     'warehouse', 'lua_tribes_units'),
+     'warehouse', 'lua_tribes_buildings'),
     ('data/tribes/buildings/partially_finished/constructionsite',
-     'constructionsite', 'lua_tribes_units'),
+     'constructionsite', 'lua_tribes_buildings'),
     ('data/tribes/buildings/partially_finished/dismantlesite',
-     'dismantlesite', 'lua_tribes_units'),
+     'dismantlesite', 'lua_tribes_buildings'),
      ('data/tribes/immovables/ashes',
      'immovables', 'lua_tribes_units'),
      ('data/tribes/ships/atlanteans',

=== added file 'doc/sphinx/source/animations.rst'
--- doc/sphinx/source/animations.rst	1970-01-01 00:00:00 +0000
+++ doc/sphinx/source/animations.rst	2016-10-18 09:50:49 +0000
@@ -0,0 +1,34 @@
+Animations
+==========
+
+Animations are defined as Lua tables. They look like this::
+
+   animations = {
+      idle = {
+         pictures = path.list_files(path.dirname(__file__) .. "idle_??.png"),
+         hotspot = { 5, 7 },
+         fps = 4,
+         sound_effect = {
+            directory = "sound/foo",
+            name = "bar",
+         },
+      },
+      working = ...
+   }
+
+Let's have a detailed look at the ``idle`` animation:
+
+idle
+   *Mandatory*. This is the name of the animation. It can be referenced by this name e.g. if you want to call it in a production program.
+
+pictures
+   *Mandatory*. A template for the image names. Our example will pick up any image from ``idle_00.png`` through ``idle_99.png`` in the specified directory path – the current path in our example. These images can optionally have corresponding player color mask images called ``idle_00_pc.png`` through ``idle_99_pc.png``.
+
+hotspot
+   *Mandatory*. The x, y coordinates for adjusting the placement of the animation. Increase ``x`` to shift the animation to the left and ``y`` to shift it upwards.
+
+fps
+   *Optional*. The frames per second for this animation if you want to deviate from the default fps. Do not specify this value if you have only 1 animation frame.
+
+sound_effect
+   *Optional*. Our example will look for the sound files ``bar_00.ogg`` through ``bar_99.ogg`` in the directory ``data/sound/foo`` and play them in sequence.

=== modified file 'doc/sphinx/source/lua_tribes.rst'
--- doc/sphinx/source/lua_tribes.rst	2016-09-01 18:32:58 +0000
+++ doc/sphinx/source/lua_tribes.rst	2016-10-18 09:50:49 +0000
@@ -1,3 +1,5 @@
+.. _lua_tribes:
+
 Scripts for Tribes
 ==================
 

=== added file 'doc/sphinx/source/lua_tribes_buildings.rst.org'
--- doc/sphinx/source/lua_tribes_buildings.rst.org	1970-01-01 00:00:00 +0000
+++ doc/sphinx/source/lua_tribes_buildings.rst.org	2016-10-18 09:50:49 +0000
@@ -0,0 +1,142 @@
+Buildings
+=========
+
+Buildings are defined in their ``init.lua`` file. They also have a corresponding ``helptexts.lua`` file that contains their help texts.
+
+Types of Buildings
+------------------
+
+Widelands knows about the following types of buildings:
+
+.. toctree::
+   :maxdepth: 3
+
+REPLACE_ME
+
+.. _lua_tribes_buildings_common:
+
+Common Building Properties
+--------------------------
+
+Buildings are defined with Lua functions called ``new_<building_type>_type{table}``. The contents of ``table`` depend on the type of building that you are defining. The common properties shared by all buildings are:
+
+
+**msgctxt**
+    *Mandatory*. The context that Gettext will use to disambiguate the translations for
+    strings in this table, e.g.::
+
+        msgctxt = "atlanteans_building",
+
+**name**
+    *Mandatory*. A string containing the internal name of this building, e.g.::
+
+        name = "atlanteans_fortress",
+
+**descname**
+    *Mandatory*. The translatable display name. Use ``pgettext`` with the ``msgctxt``
+    above to fetch the string, e.g.::
+
+        descname = pgettext("atlanteans_building", "Fortress"),
+
+**helptext_script**
+    *Mandatory*. The full path to the ``helptexts.lua`` script for this building.
+
+**icon**
+    *Mandatory*. The full path to the menu icon for this building.
+
+**size**
+    *Mandatory*. The size of this building: ``"small"``, ``"medium"``, or ``"big"``.
+
+**vision_range**
+    *Optional. Default:* ``0``. The size of the radius that the building sees.
+
+**buildcost**
+    *Optional*. A table with the wares used to build this building, containing
+    warename - amount pairs, e.g.::
+
+        buildcost = { log = 4, granite = 2 }
+
+    When ``buildcost`` is defined, you also need to define ``return_on_dismantle``.
+
+**return_on_dismantle**
+    *Optional*. The wares that this building will give back to the player when it is
+    dismantled, e.g.::
+
+        buildcost = { log = 2, granite = 1 }
+
+**enhancement**
+    *Optional*. The name of a building that this building can be enhanced to, e.g.::
+
+        enhancement = "atlanteans_fancy_building",
+
+    If ``enhancement`` is defined, the building that this building enhances
+    to will need to define ``enhancement_cost`` and
+    ``return_on_dismantle_on_enhanced``.
+
+**enhancement_cost**
+    *Optional*. The wares needed to upgrade this building, e.g.::
+
+        enhancement_cost = { log = 1, granite = 1 }
+
+**return_on_dismantle_on_enhanced**
+    *Optional*. The wares that this enhanced building will give back to the player
+    when it is dismantled, e.g.::
+
+        return_on_dismantle_on_enhanced = { granite = 1 }
+
+**animations**
+    *Mandatory*. A table containing all animations for this building. Every building
+    needs to have an ``idle`` animation. Other animations that a building
+    can have are ``build``, ``working``, ``unoccupied``. Mines also have
+    an ``unoccupied`` animation.
+    See :doc:`animations` for a detailed description of the animation format.
+
+**needs_seafaring**
+    *Optional. Default:* ``false``. Set to ``true`` if this building will only be available on seafaring maps.
+
+**aihints**
+    *Mandatory*. A list of name - value pairs with hints for the AI. Can be empty.
+
+
+Help Texts
+----------
+
+Each building has a ``helptexts.lua`` script, which is located in the same directory as its ``init.lua`` script.
+The functions in this file return texts that are used for buildings by the Tribal Encyclopedia.
+
+See also the helper functions in :ref:`lua_tribes_global_helptexts.lua`.
+
+
+.. function:: building_helptext_lore()
+
+   Returns a localized string with a lore helptext for this building.
+   If you don't have a lore text yet, use ``no_lore_text_yet()`` from the ``lua_tribes_global_helptexts.lua`` script.
+
+
+.. function:: building_helptext_lore_author()
+
+   Returns a localized string with a fictional author for the lore helptext for this building. The returned string can be empty.
+   If you don't have an author yet, use ``no_lore_author_text_yet()`` from the :ref:`lua_tribes_global_helptexts.lua` script.
+
+   :returns: Localized lore text
+
+
+.. function:: building_helptext_purpose()
+
+   Returns a localized string with a purpose helptext for this building. This should be individually defined for all buildings. You can use ``no_purpose_text_yet()`` from the :ref:`lua_tribes_global_helptexts.lua` script if you're not ready to define this yet.
+
+   :returns: Localized purpose text
+
+
+.. function:: building_helptext_note()
+
+   Returns a localized string with a note that is added to the purpose. This can be empty.
+
+   :returns: Localized note text or empty string.
+
+
+.. function:: building_helptext_performance()
+
+   Returns a localized string with a performance helptext for this building. You can use ``no_purpose_text_yet()`` from the :ref:`lua_tribes_global_helptexts.lua` script if the performance hasn't been calculated yet. Leave empty when this isn't applicable (e.g. for militarysites or warehouses).
+
+   :returns: Localized performance text or empty string.

=== modified file 'doc/sphinx/source/lua_tribes_units.rst.org'
--- doc/sphinx/source/lua_tribes_units.rst.org	2016-09-01 18:32:58 +0000
+++ doc/sphinx/source/lua_tribes_units.rst.org	2016-10-18 09:50:49 +0000
@@ -15,4 +15,5 @@
 .. toctree::
    :maxdepth: 3
 
+   autogen_toc_lua_tribes_buildings
 REPLACE_ME

=== added file 'doc/sphinx/source/map_objects.rst'
--- doc/sphinx/source/map_objects.rst	1970-01-01 00:00:00 +0000
+++ doc/sphinx/source/map_objects.rst	2016-10-18 09:50:49 +0000
@@ -0,0 +1,9 @@
+World and Tribes
+================
+
+.. toctree::
+   :maxdepth: 3
+
+   animations
+   autogen_toc_lua_world
+   lua_tribes

=== modified file 'doc/sphinx/source/reference.rst'
--- doc/sphinx/source/reference.rst	2016-09-01 18:32:58 +0000
+++ doc/sphinx/source/reference.rst	2016-10-18 09:50:49 +0000
@@ -5,6 +5,5 @@
    :maxdepth: 3
 
    core
-   autogen_toc_lua_world
-   lua_tribes
+   map_objects
    autogen_toc_auxiliary

=== modified file 'src/logic/map_objects/immovable.cc'
--- src/logic/map_objects/immovable.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/immovable.cc	2016-10-18 09:50:49 +0000
@@ -266,6 +266,9 @@
 
 /**
  * Parse a tribes immovable from its init file.
+ *
+ * The contents of 'table' are documented in
+ * /data/tribes/immovables/ashes/init.lua
  */
 ImmovableDescr::ImmovableDescr(const std::string& init_descname,
                                const LuaTable& table,

=== modified file 'src/logic/map_objects/tribes/building.cc'
--- src/logic/map_objects/tribes/building.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/building.cc	2016-10-18 09:50:49 +0000
@@ -50,7 +50,9 @@
 namespace Widelands {
 
 static const int32_t BUILDING_LEAVE_INTERVAL = 1000;
-
+/**
+  * The contents of 'table' are documented in doc/sphinx/source/lua_tribes_buildings.rst.org
+  */
 BuildingDescr::BuildingDescr(const std::string& init_descname,
                              const MapObjectType init_type,
                              const LuaTable& table,

=== modified file 'src/logic/map_objects/tribes/constructionsite.cc'
--- src/logic/map_objects/tribes/constructionsite.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/constructionsite.cc	2016-10-18 09:50:49 +0000
@@ -41,6 +41,10 @@
 
 namespace Widelands {
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/buildings/partially_finished/constructionsite/init.lua
+  */
 ConstructionSiteDescr::ConstructionSiteDescr(const std::string& init_descname,
                                              const LuaTable& table,
                                              const EditorGameBase& egbase)

=== modified file 'src/logic/map_objects/tribes/dismantlesite.cc'
--- src/logic/map_objects/tribes/dismantlesite.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/dismantlesite.cc	2016-10-18 09:50:49 +0000
@@ -39,6 +39,11 @@
 
 namespace Widelands {
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/buildings/partially_finished/dismantlesite/init.lua
+  */
+
 DismantleSiteDescr::DismantleSiteDescr(const std::string& init_descname,
                                        const LuaTable& table,
                                        const EditorGameBase& egbase)

=== modified file 'src/logic/map_objects/tribes/militarysite.cc'
--- src/logic/map_objects/tribes/militarysite.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/militarysite.cc	2016-10-18 09:50:49 +0000
@@ -43,6 +43,10 @@
 
 namespace Widelands {
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/buildings/militarysites/atlanteans/castle/init.lua
+  */
 MilitarySiteDescr::MilitarySiteDescr(const std::string& init_descname,
                                      const LuaTable& table,
                                      const EditorGameBase& egbase)

=== modified file 'src/logic/map_objects/tribes/productionsite.cc'
--- src/logic/map_objects/tribes/productionsite.cc	2016-09-02 11:48:37 +0000
+++ src/logic/map_objects/tribes/productionsite.cc	2016-10-18 09:50:49 +0000
@@ -53,6 +53,10 @@
 ==============================================================================
 */
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/buildings/productionsites/atlanteans/armorsmithy/init.lua
+  */
 ProductionSiteDescr::ProductionSiteDescr(const std::string& init_descname,
                                          const std::string& msgctxt,
                                          MapObjectType init_type,

=== modified file 'src/logic/map_objects/tribes/ship.cc'
--- src/logic/map_objects/tribes/ship.cc	2016-09-07 09:30:49 +0000
+++ src/logic/map_objects/tribes/ship.cc	2016-10-18 09:50:49 +0000
@@ -105,6 +105,10 @@
 
 }  // namespace
 
+/**
+ * The contents of 'table' are documented in
+ * /data/tribes/ships/atlanteans/init.lua
+ */
 ShipDescr::ShipDescr(const std::string& init_descname, const LuaTable& table)
    : BobDescr(init_descname, MapObjectType::SHIP, MapObjectDescr::OwnerType::kTribe, table) {
 

=== modified file 'src/logic/map_objects/tribes/trainingsite.cc'
--- src/logic/map_objects/tribes/trainingsite.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/trainingsite.cc	2016-10-18 09:50:49 +0000
@@ -41,6 +41,10 @@
 
 const uint32_t TrainingSite::training_state_multiplier_ = 12;
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/buildings/trainingsites/atlanteans/dungeon/init.lua
+  */
 TrainingSiteDescr::TrainingSiteDescr(const std::string& init_descname,
                                      const LuaTable& table,
                                      const EditorGameBase& egbase)

=== modified file 'src/logic/map_objects/tribes/tribe_descr.cc'
--- src/logic/map_objects/tribes/tribe_descr.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/tribe_descr.cc	2016-10-18 09:50:49 +0000
@@ -51,6 +51,10 @@
 
 namespace Widelands {
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/atlanteans.lua
+  */
 TribeDescr::TribeDescr(const LuaTable& table, const TribeBasicInfo& info, const Tribes& init_tribes)
    : name_(table.get_string("name")), descname_(info.descname), tribes_(init_tribes) {
 

=== modified file 'src/logic/map_objects/tribes/ware_descr.cc'
--- src/logic/map_objects/tribes/ware_descr.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/ware_descr.cc	2016-10-18 09:50:49 +0000
@@ -31,6 +31,10 @@
 
 namespace Widelands {
 
+/**
+ * The contents of 'table' are documented in
+ * /data/tribes/wares/armor/init.lua
+ */
 WareDescr::WareDescr(const std::string& init_descname, const LuaTable& table)
    : MapObjectDescr(MapObjectType::WARE, table.get_string("name"), init_descname, table) {
 

=== modified file 'src/logic/map_objects/tribes/warehouse.cc'
--- src/logic/map_objects/tribes/warehouse.cc	2016-08-04 15:49:05 +0000
+++ src/logic/map_objects/tribes/warehouse.cc	2016-10-18 09:50:49 +0000
@@ -231,6 +231,10 @@
 ==============================
 */
 
+/**
+  * The contents of 'table' are documented in
+  * /data/tribes/buildings/warehouses/atlanteans/headquarters/init.lua
+  */
 WarehouseDescr::WarehouseDescr(const std::string& init_descname,
                                const LuaTable& table,
                                const EditorGameBase& egbase)

=== modified file 'src/scripting/lua_root.cc'
--- src/scripting/lua_root.cc	2016-08-04 15:49:05 +0000
+++ src/scripting/lua_root.cc	2016-10-18 09:50:49 +0000
@@ -518,8 +518,8 @@
 
 .. class:: Tribes
 
-   This offers access to the objects available for the tribes and allows to add
-   new objects.
+	This offers access to the objects available for the tribes and allows to add
+	new objects. See :ref:`lua_tribes` for detailed documentation.
 */
 
 const char LuaTribes::className[] = "Tribes";
@@ -568,12 +568,13 @@
  */
 
 /* RST
-   .. method:: new_constructionsite_type(table)
-
-      Adds a new constructionsite building type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_constructionsite_type{table}
+
+		Adds a new constructionsite building type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_buildings_constructionsites` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_constructionsite_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -591,12 +592,13 @@
 }
 
 /* RST
-   .. method:: new_dismantlesite_type(table)
-
-      Adds a new disnamtlesite building type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_dismantlesite_type{table}
+
+		Adds a new disnamtlesite building type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_buildings_dismantlesites` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_dismantlesite_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -614,12 +616,13 @@
 }
 
 /* RST
-   .. method:: new_militarysite_type(table)
-
-      Adds a new militarysite building type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_militarysite_type{table}
+
+		Adds a new militarysite building type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_buildings_militarysites` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_militarysite_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -637,12 +640,13 @@
 }
 
 /* RST
-   .. method:: new_productionsite_type(table)
-
-      Adds a new productionsite building type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_productionsite_type{table}
+
+		Adds a new productionsite building type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_buildings_productionsites` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_productionsite_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -660,12 +664,13 @@
 }
 
 /* RST
-   .. method:: new_trainingsite_type(table)
-
-      Adds a new trainingsite building type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_trainingsite_type{table}
+
+		Adds a new trainingsite building type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_buildings_trainingsites` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_trainingsite_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -683,12 +688,13 @@
 }
 
 /* RST
-   .. method:: new_warehouse_type(table)
-
-      Adds a new warehouse building type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_warehouse_type{table}
+
+		Adds a new warehouse building type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_buildings_warehouses` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_warehouse_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -706,12 +712,13 @@
 }
 
 /* RST
-   .. method:: new_immovable_type(table)
-
-      Adds a new immovable type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_immovable_type{table}
+
+		Adds a new immovable type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_immovables` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_immovable_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -728,12 +735,13 @@
 }
 
 /* RST
-   .. method:: new_ship_type(table)
-
-      Adds a new ship type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_ship_type{table}
+
+		Adds a new ship type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_ships` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_ship_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -750,12 +758,13 @@
 }
 
 /* RST
-   .. method:: new_ware_type(table)
-
-      Adds a new ware type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_ware_type{table}
+
+		Adds a new ware type. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_wares` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_ware_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -772,12 +781,12 @@
 }
 
 /* RST
-   .. method:: new_carrier_type(table)
-
-      Adds a new carrier worker type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_carrier_type{table}
+
+		Adds a new carrier worker type. Takes a single argument, a table with
+		the descriptions. See the files in tribes/ for usage examples.
+
+		:returns: :const:`nil`
 */
 int LuaTribes::new_carrier_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -795,12 +804,12 @@
 }
 
 /* RST
-   .. method:: new_soldier_type(table)
-
-      Adds a new soldier worker type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_soldier_type{table}
+
+		Adds a new soldier worker type. Takes a single argument, a table with
+		the descriptions. See the files in tribes/ for usage examples.
+
+		:returns: :const:`nil`
 */
 int LuaTribes::new_soldier_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -818,12 +827,12 @@
 }
 
 /* RST
-   .. method:: new_worker_type(table)
-
-      Adds a new worker type. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_worker_type{table}
+
+		Adds a new worker type. Takes a single argument, a table with
+		the descriptions. See the files in tribes/ for usage examples.
+
+		:returns: :const:`nil`
 */
 int LuaTribes::new_worker_type(lua_State* L) {
 	if (lua_gettop(L) != 2) {
@@ -841,12 +850,13 @@
 }
 
 /* RST
-   .. method:: new_tribe(table)
-
-      Adds a new tribe. Takes a single argument, a table with
-      the descriptions. See the files in tribes/ for usage examples.
-
-      :returns: :const:`nil`
+	.. method:: new_tribe{table}
+
+		Adds a new tribe. Takes a single argument, a table with
+		the descriptions. See :ref:`lua_tribes_<tribename>.lua` for detailed
+		documentation.
+
+		:returns: :const:`0`
 */
 int LuaTribes::new_tribe(lua_State* L) {
 	if (lua_gettop(L) != 2) {


Follow ups