As a modder, you are free to write basically about everything and are also relatively free in the presentation of information. There are no restrictions on content whatsoever.
In the Documentation System, everything is built on categories and entries. An entry is a single piece of documentation and is the basis of all actual documentation. Categories group multiple entries of the same topic together.
Categories also define a template function which is used to determine how the final result in the tab “Entry list” looks like. Entries themselves have a data field attached to them, this is a table containing arbitrary metadata which is used to construct the final formspec in the Entry tab. It may also be used for sorting entries in the entry list.
Viewed and hidden entries
The mod keeps track of which entries have been viewed on a per-player basis. Any entry which has been accessed by a player is immediately marked as “viewed”.
Entries can also be hidden. Hidden entries are not visible or otherwise accessible to players until they become revealed by function calls.
Marking an entry as viewed or revealed is not reversible with this API.
The viewed and hidden states are stored in the file doc.mt
inside the
world directory. You can safely delete this file if you want to reset
the player states.
Entry aliases are alternative identifiers for entry identifiers. With the
exception of the alias functions themselves, for functions demanding an
entry_id
you can either supply the original entry_id
or any alias of the
entry_id
.
This section shows some possible use cases to give you a rough idea what this mod is capable of and how these use cases could be implemented.
Let's say you want to write in free form short help texts about the basic concepts of Minetest or your game. First you could define a category called “Basics”, the data for each of its entry is just a free form text. The template function simply creates a formspec where this free form text is displayed.
This is one of the most simple use cases and the mod doc_basics
does
exactly that.
You could create a category called “Blocks”, and this category is supposed to contain entries for every single block (i.e. node) in the game. For this use case, a free form approach would be very inefficient and error-prone, as a lot of data can be reused.
Here the template function comes in handy: The internal entry data contain a lot of different things about a block, like block name, identifier, custom description and most importantly, the definition table of the block.
Finally, the template function takes all that data and turns it into sentences which are just concatenated, telling as many useful facts about this block as possible.
This is a list of all publicly available functions.
The most important functions are doc.add_category
and doc.ad_entry
. All other functions
are mostly used for utility and examination purposes.
If not mentioned otherwise, the return value of all functions is nil
.
These functions are available:
doc.add_category
: Adds a new categorydoc.add_entry
: Adds a new entry
doc.show_entry
: Shows a particular entry to a playerdoc.show_category
: Shows the entry list of a category to a playerdoc.show_doc
: Opens the main help form for a player
doc.get_category_definition
: Returns the definition table of a categorydoc.get_entry_definition
: Returns the definition table of an entrydoc.entry_exists
: Checks whether an entry existsdoc.entry_viewed
: Checks whether an entry has been viewed/read by a playerdoc.entry_revealed
: Checks whether an entry is visible and normally accessible to a playerdoc.get_category_count
: Returns the total number of categoriesdoc.get_entry_count
: Returns the total number of entries in a categorydoc.get_viewed_count
: Returns the number of entries a player has viewed in a categorydoc.get_revealed_count
: Returns the number of entries a player has access to in a categorydoc.get_hidden_count
: Returns the number of entries which are hidden from a player in a categorydoc.get_selection
: Returns the currently viewed entry/category of a player
doc.set_category_order
: Sets the order of categories in the category listdoc.mark_entry_as_viewed
: Manually marks an entry as viewed/read by a playerdoc.mark_entry_as_revealed
: Make a hidden entry visible and accessible to a playerdoc.mark_all_entries_as_revealed
: Make all hidden entries visible and accessible to a player
doc.add_entry_alias
: Add an alternative name which can be used to access an entry
This API provides functions to add unique “widgets” for functionality
you may find useful when creating entry templates. You find these
functions in doc.widgets
.
Currently there is a widget for scrollable multi-line text and a
widget providing an image gallery.
Adds a new category. You have to define an unique identifier, a name and a template function to build the entry formspec from the entry data.
Important: You must call this function before any player joins.
id
: Unique category identifier as a stringdef
: Definition table with the following fields:name
: Category name to be shown in the interfacedescription
: (optional) Short description of the category, will be shown as tooltip. Recommended style (in English): First letter capitalized, no punctuation at the end, max. 100 charactersbuild_formspec
: The template function (see below). Takes entry data as its first parameter (has the data type of the entry data) and the name of the player who views the entry as its second parameter. It must return a formspec which is inserted in the Entry tab.sorting
: (optional) Sorting algorithm for display order of entries"abc"
: Alphabetical (default)"nosort"
: Entries appear in no particular order"custom"
: Manually define the order of entries insorting_data
"function"
: Sort by function defined insorting_data
sorting_data
: (optional) Additional data for special sorting methods.- If
sorting=="custom"
, this field must contain a table (list form) in which the entry IDs are specified in the order they are supposed to appear in the entry list. All entries which are missing in this table will appear in no particular order below the final specified one. - If
sorting=="function"
, this field is a compare function to be used as thecomp
parameter oftable.sort
. The parameters given are two entries. - This field is not required if
sorting
has any other value
- If
hide_entries_by_default
(optional): Iftrue
, all entries added to this category will start as hidden, unless explicitly specified otherwise (default:false
)
Note: For function-based sorting, the entries provided to the compare function will have the following format:
{
eid = e, -- unique entry identifier
name = n, -- entry name
data = d, -- arbitrary entry data
}
For build_formspec
you can either define your own function which
procedurally generates the entry formspec or you use one of the
following predefined convenience functions:
doc.entry_builders.text
: Expects entry data to be a string. It will be inserted directly into the entry. Useful for entries with a free form text.doc.entry_builders.text_and_gallery
: For entries with text and an optional standard gallery (3 rows, 3:2 aspect ratio). Expects entry data to be a table with these fields:text
: The entry textimages
: The images of the gallery, the format is the same as theimagedata
parameter ofdoc.widgets.gallery
. Can benil
, in which case no gallery is shown for the entry
doc.entry_builders.formspec
: Entry data is expected to contain the complete entry formspec as a string. Useful if your entries. Useful if you expect your entries to differ wildly in layouts.
When building your formspec, you have to respect the size limitations. The help form currently uses a size of 15×10.5 and you must make sure all entry widgets are inside a boundary box. The remaining space is reserved for widgets of the help form and should not be used to avoid overlapping. Read from the following variables to calculate the final formspec coordinates:
doc.FORMSPEC.WIDTH
: Width of help formspecdoc.FORMSPEC.HEIGHT
: Height of help formspecdoc.FORMSPEC.ENTRY_START_X
: Leftmost X point of bounding boxdoc.FORMSPEC.ENTRY_START_Y
: Topmost Y point of bounding boxdoc.FORMSPEC.ENTRY_END_X
: Rightmost X point of bounding boxdoc.FORMSPEC.ENTRY_END_Y
: Bottom Y point of bounding boxdoc.FORMSPEC.ENTRY_WIDTH
: Width of the entry widgets bounding boxdoc.FORMSPEC.ENTRY_HEIGHT
: Height of the entry widgets bounding box
Finally, to avoid naming collisions, you must make sure that all identifiers
of your own formspec elements do not begin with “doc_
”.
You can even use the formspec elements you have added with build_formspec
to
receive formspec events, just like with any other formspec. For receiving, use
the standard function minetest.register_on_player_receive_fields
to register
your event handling. The formname
parameter will be doc:entry
. Use
doc.get_selection
to get the category ID and entry ID of the entry in question.
Adds a new entry into an existing category. You have to define the category
to which to insert the entry, the entry's identifier, a name and some
data which defines the entry. Note you do not directly define here how the
end result of an entry looks like, this is done by build_formspec
from
the category definition.
Important: You must call this function before any player joins.
category_id
: Identifier of the category to add the entry intoentry_id
: Unique identifier of the new entry, as a stringdef
: Definition table, it has the following fields:name
: Entry name to be shown in the interfacehidden
: (optional) Iftrue
, entry will not be displayed in entry list initially (default:false
); it can be revealed laterdata
: Arbitrary data attached to the entry. Any data type is allowed; The data in this field will be used to create the actual formspec withbuild_formspec
from the category definition
Sets the order of categories in the category list. The help starts with this default order:
{"basics", "nodes", "tools", "craftitems", "advanced"}
This function can be called at any time, but it recommended to only call this function once for the entire server session and to only call it from game mods, to avoid contradictions. If this function is called a second time by any mod, a warning is written into the log.
category_list
: List of category IDs in the order they should appear in the category list. All unspecified categories will be appended to the end
Opens the main help formspec for the player (“Category list” tab).
playername
: Name of the player to show the formspec to
Opens the help formspec for the player at the specified category (“Entry list” tab).
playername
: Name of the player to show the formspec tocategory_id
: Category identifier of the selected category
doc.show_entry(playername, category_id, entry_id, ignore_hidden)
Opens the help formspec for the player showing the specified entry
of a category (“Entry” tab). If the entry is hidden, an error message
is displayed unless ignore_hidden==true
.
playername
: Name of the player to show the formspec tocategory_id
: Category identifier of the selected categoryentry_id
: Entry identifier of the entry to showignore_hidden
: (optional) Iftrue
, shows entry even if it is still hidden to the player; this will automatically reveal the entry to this player for the rest of the game
Returns the definition of the specified category.
category_id
: Category identifier of the category to the the definition for
The category's definition table as specified in the def
argument of
doc.add_category
. The table fields are the same.
Returns the definition of the specified entry.
category_id
: Category identifier of entry's categoryentry_id
: Entry identifier of the entry to get the definition for
The entry's definition table as specified in the def
argument of
doc.add_entry
. The table fields are the same.
Checks whether the specified entry exists and returns true
or false
.
Entry aliases are taken into account.
category_id
: Category identifier of the category to checkentry_id
: Entry identifier of the entry to check for its existence
Returns true
if and only if:
- The specified category exists
- It contains the specified entry
Otherwise, returns false
.
Tells whether the specified entry is marked as “viewed” (or read) by the player.
playername
: Name of the player to checkcategory_id
: Category identifier of the category to checkentry_id
: Entry identifier of the entry to check
true
, if entry is viewed, false
otherwise.
Tells whether the specified entry is marked as “revealed” to the player and thus visible and accessible to the player.
playername
: Name of the player to checkcategory_id
: Category identifier of the category to checkentry_id
: Entry identifier of the entry to check
true
, if entry is revealed, false
otherwise.
Marks a particular entry as “viewed” (or read) by a player. This will also automatically reveal the entry to the player for the rest of the game.
playername
: Name of the player for whom to mark an entry as “viewed”category_id
: Category identifier of the category of the entry to markentry_id
: Entry identifier of the entry to mark
Marks a particular entry as “revealed” to a player. If the entry is
declared as hidden, it will become visible in the list of entries for
this player and will always be accessible with doc.show_entry
. This
change remains for the rest of the game.
For entries which are not normally hidden, this function has no direct effect.
playername
: Name of the player for whom to reveal the entrycategory_id
: Category identifier of the category of the entry to revealentry_id
: Entry identifier of the entry to reveal
Marks all entries as “revealed” to a player. This change remains for the rest of the game.
playername
: Name of the player for whom to reveal the entries
Adds a single alias for an entry. If an entry has an alias, supplying the
alias to a function which demand category_id
and entry_id
will work as expected.
When using this function, you must make sure the category already exists.
This function could be useful for legacy support after changing an entry ID or moving an entry to a different category.
category_id_orig
: Category identifier of the category of the entry in questionentry_id_orig
: The original (!) entry identifier of the entry to create an alias forcategory_id_alias
: The category ID of the aliasentry_id_alias
: The entry ID of the alias
doc.add_entry_alias("nodes", "test", "craftitems", "test2")
When calling a function with category ID “craftitems” and entry ID “test2”, it will act as if you supplied “nodes” as category ID and “test” as entry ID.
Returns the number of registered categories.
Number of registered categories.
Returns the number of entries in a category.
category_id
: Category identifier of the category in which to count entries
Number of entries in the specified category.
Returns how many entries have been viewed by a player.
playername
: Name of the player to count the viewed entries forcategory_id
: Category identifier of the category in which to count the viewed entries
Amount of entries the player has viewed in the specified category. If the
player does not exist, this function returns nil
.
Returns how many entries the player has access to (non-hidden entries) in this category.
playername
: Name of the player to count the revealed entries forcategory_id
: Category identifier of the category in which to count the revealed entries
Amount of entries the player has access to in the specified category. If the
player does not exist, this function returns nil
.
doc.get_hidden_count(playername, category_id)
Returns how many entries are hidden from the player in this category.
playername
: Name of the player to count the hidden entries forcategory_id
: Category identifier of the category in which to count the hidden entries
Amount of entries hidden from the player. If the player does not exist,
this function returns nil
.
Returns the currently or last viewed entry and/or category of a player.
playername
: Name of the player to query
It returns up to 2 values. The first one is the category ID, the second one
is the entry ID of the entry/category which the player is currently viewing
or is the last entry the player viewed in this session. If the player only
viewed a category so far, the second value is nil
. If the player has not
viewed a category as well, both returned values are nil
.
This is a convenience function for creating a special formspec widget. It creates a widget in which you can insert scrollable multi-line text.
data
: Text to be written inside the widgetx
: Formspec X coordinate (optional)y
: Formspec Y coordinate (optional)width
: Width of the widget in formspec units (optional)height
: Height of the widget in formspec units (optional)
The default values for the optional parameters result in a widget which fills nearly the entire entry page.
Two values are returned, in this order:
- string: Contains a complete formspec definition building the widget
- string: Formspec element ID of the created widget
If you use this function to build a formspec string, do not use identifiers
beginning with doc_widget_text
to avoid naming collisions, as this function
makes use of such identifiers internally.
This function creates an image gallery which allows you to display an arbitrary amount of images aligned horizontally. It is possible to add more images than the space of an entry would normally held, this is done by adding “scroll” buttons to the left and right which allows the user to see more images of the gallery.
This function is useful for adding multiple illustration to your entry without worrying about space too much. Adding illustrations can help you to create entry templates which aren't just lengthy walls of text. ;-)
You can define the position, image aspect ratio, total gallery width and the number of images displayed at once. You can not directly define the image size, nor the resulting height of the overall gallery, those values will be derived from the parameters.
You can only really use this function efficiently inside a custom
build_formspec
function definition. This is because you need to pass a
playername
. You can currently also only add up to one gallery per entry;
adding more galleries is not supported and will lead to bugs.
imagedata
: List of images to be displayed in the specified order. All images must have the same aspect ratio. It's a table of tables with this format:imagetype
: Type of image to be used (optional):"image"
: Texture file (default)"item"
: Item image, specified as itemstring
image
: What to display. Depending onimagetype
, a texture file or itemstring
playername
: Name of the player who is viewing the entry in questionx
: Formspec X coordinate of the top left corner (optional)y
: Formspec Y coordinate of the top left corner (optional)aspect_ratio
: Aspect ratio of all the images (width/height)width
: Total gallery width in formspec units (optional)rows
: Number of images which can be seen at once (optional)align_left
: Iffalse
, gallery is aligned to the left instead of the right (optional)align_right
: Iffalse
, gallery is aligned to the bottom instead of the top (optional)
The default values for the optional parameters result in a gallery with 3 rows which is placed at the top left corner and spans the width of the entry and assumes an aspect ratio of two thirds.
If the number of images is greater than rows
, “scroll” buttons will appear
at the left and right side of the images.
Two values are returned, in this order:
- string: Contains a complete formspec definition building the gallery
- number: The height the gallery occupies in the formspec
If you want to extend this mod with your own functionality, it is recommended
that you put all API functions into doc.sub.<name>
.
As a naming convention, if you mod primarily depends on doc
, it is recommended
to use a short mod name which starts with “doc_
”, like doc_items
,
doc_minetest_game
, or doc_identifier
.
One mod which uses this convention is doc_items
which uses the doc.sub.items
table.