mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-01-23 16:30:19 +01:00
Update api.md
- MarkDown and me, such a complicated story. Ready for @paly2
This commit is contained in:
parent
7eddd36dcb
commit
a5bbc6115d
@ -10,34 +10,34 @@ Their datas are stored somewhere in a namespace (see below). You can use multipl
|
|||||||
the rune, its texture(s), etc. Then, once a rune is registered (as an item, for minetest), the most important thing is to connect its handler(s).
|
the rune, its texture(s), etc. Then, once a rune is registered (as an item, for minetest), the most important thing is to connect its handler(s).
|
||||||
Another specific function is used to this, where you pass as an argument the reference to a function receiving the parameters of the item/node's callback
|
Another specific function is used to this, where you pass as an argument the reference to a function receiving the parameters of the item/node's callback
|
||||||
(eg. on_punch, on_dig, on_use, etc). The handler can choose to return "true" in order to manage the use of mana by itself instead of letting the
|
(eg. on_punch, on_dig, on_use, etc). The handler can choose to return "true" in order to manage the use of mana by itself instead of letting the
|
||||||
item's code in minetest.registered_items[<rune>].<callback> do it.
|
item's code in minetest.registered_items[rune].callback do it.
|
||||||
|
|
||||||
# Functions
|
# Functions
|
||||||
|
|
||||||
## `runes.register_rune(parameters)`
|
#### `runes.register_rune(parameters)`
|
||||||
The most important function. This is the function you use to declare your rune and its specifications to minetest itself.
|
The most important function. This is the function you use to declare your rune and its specifications to minetest itself.
|
||||||
It takes one argument, a table. This table can have the following articles :
|
It takes one argument, a table. This table can have the following articles :
|
||||||
- `name` is mandatory, it's the rune's name (which will be used to craft its itemstring : runes:rune_<name>_<level>)
|
- `name` is mandatory, it's the rune's name (which will be used to craft its itemstring : runes:rune_name_level)
|
||||||
- `desc` is the item's description
|
- `desc` is the item's description
|
||||||
- `img` is another table :
|
- `img` is another table :
|
||||||
- ["minor"] = <texture_file>
|
- ["minor"] = texture_file
|
||||||
- ["medium"] = <texture_file>
|
- ["medium"] = texture_file
|
||||||
- ["major"] = <texture_file>
|
- ["major"] = texture_file
|
||||||
None of these parameters are mandatory. Runes can have 1 or 2 or 3 levels (ok, not implemented yet, but it's coming).
|
None of these parameters are mandatory. Runes can have 1 or 2 or 3 levels (ok, not implemented yet, but it's coming).
|
||||||
You can use a single value like `img = <texture_file>` and the texture will be applied for all levels
|
You can use a single value like `img = texture_file` and the texture will be applied for all levels
|
||||||
- `type` is the type of rune. At the moment, three types are available :
|
- `type` is the type of rune. At the moment, three types are available :
|
||||||
- "craftitem" will register a craftitem
|
- "craftitem" will register a craftitem
|
||||||
- "cube" will register a node
|
- "cube" will register a node
|
||||||
- "plate" will register a little slab 0.1 node thin
|
- "plate" will register a little slab 0.1 node thin
|
||||||
- `needed_mana` is yet another table with different levels :
|
- `needed_mana` is yet another table with different levels :
|
||||||
- ["minor"] = <value>
|
- ["minor"] = value
|
||||||
- ["medium"] = <value>
|
- ["medium"] = value
|
||||||
- ["major"] = <value>
|
- ["major"] = value
|
||||||
When using this rune at level "major", the ["major"] value of mana will be taken by default if the player has enough mana,
|
When using this rune at level "major", the ["major"] value of mana will be taken by default if the player has enough mana,
|
||||||
or it will be forbidden for him to use the rune if he doesn't have enough mana.
|
or it will be forbidden for him to use the rune if he doesn't have enough mana.
|
||||||
You don't have to indicate that parameter and just let the handler manage the mana.
|
You don't have to indicate that parameter and just let the handler manage the mana.
|
||||||
|
|
||||||
## `runes.functions.connect(itemname, callback, handler)`
|
#### `runes.functions.connect(itemname, callback, handler)`
|
||||||
This function will connect a registered rune's callback to its handler. It takes three mandatory arguments :
|
This function will connect a registered rune's callback to its handler. It takes three mandatory arguments :
|
||||||
- `itemname` is the rune's identification name (aka. `name` for earlier). The same handler is used for every level
|
- `itemname` is the rune's identification name (aka. `name` for earlier). The same handler is used for every level
|
||||||
of a rune, so it has to determine what level he will handle (it's actually passed to it)
|
of a rune, so it has to determine what level he will handle (it's actually passed to it)
|
||||||
@ -50,9 +50,9 @@ This function will connect a registered rune's callback to its handler. It takes
|
|||||||
- `handler` is the function handling the callback. See below for details.
|
- `handler` is the function handling the callback. See below for details.
|
||||||
Do not hesitate to consult lua_api.txt in order to see which callbacks are handled by what type of runes (craftitems, and nodes).
|
Do not hesitate to consult lua_api.txt in order to see which callbacks are handled by what type of runes (craftitems, and nodes).
|
||||||
|
|
||||||
## `runes.functions.register_amulet(name, desc, maxcount, manadiff)`
|
#### `runes.functions.register_amulet(name, desc, maxcount, manadiff)`
|
||||||
Amulets are special items able to increase the maximum of mana you can stock. Here are the arguments expected to register an amulet :
|
Amulets are special items able to increase the maximum of mana you can stock. Here are the arguments expected to register an amulet :
|
||||||
- `name` is its name, used to create its itemstring : 'runes:<name>_amulet'
|
- `name` is its name, used to create its itemstring : 'runes:name_amulet'
|
||||||
Don't feel forced to use '_amulet' in an amulet name, it's completly useless.
|
Don't feel forced to use '_amulet' in an amulet name, it's completly useless.
|
||||||
- `desc` is the item description.
|
- `desc` is the item description.
|
||||||
- `maxcount` represents the maximum amount of this amulet you can have per stack (aka `stack_max`, see lua_api.txt for this).
|
- `maxcount` represents the maximum amount of this amulet you can have per stack (aka `stack_max`, see lua_api.txt for this).
|
||||||
@ -60,10 +60,19 @@ Amulets are special items able to increase the maximum of mana you can stock. He
|
|||||||
of regulary looking into everyone's rune inventory to calculate every player's max_mana. If you loose amulets, your mana_max
|
of regulary looking into everyone's rune inventory to calculate every player's max_mana. If you loose amulets, your mana_max
|
||||||
will dicrease (and mana may be lost with it).
|
will dicrease (and mana may be lost with it).
|
||||||
|
|
||||||
## `runes.functions.register_detached_inventory(player)`
|
#### `runes.functions.register_detached_inventory(player)`
|
||||||
This function is only important for rune's inners. It registers a detached inventory to contain runes. Do not bother using it, there is no
|
This function is only important for rune's inners. It registers a detached inventory to contain runes. Do not bother using it, there is no
|
||||||
actual use of it out of runes' core.
|
actual use of it out of runes' core.
|
||||||
|
|
||||||
## `runes.functions.save_detached_inventory(player)`
|
#### `runes.functions.save_detached_inventory(player)`
|
||||||
Saves player's rune inventory on hard drive (in minetest.get_worldpath() .. "/runes/" .. player:get_player_name() .. "_rune.inv").
|
Saves player's rune inventory on hard drive (in minetest.get_worldpath() .. "/runes/" .. player:get_player_name() .. "_rune.inv").
|
||||||
|
|
||||||
|
# Namespaces
|
||||||
|
|
||||||
|
Here are a few namespaces that could be useful :
|
||||||
|
- `runes` global namespace, contains everything. Note : When [this](https://github.com/minetest/minetest/pull/2039) is merged, do what we have to do.
|
||||||
|
- `runes.datas` miscellaneous datas, including tables with parameters transmitted to the registration functions.
|
||||||
|
- `runes.datas.item`, the item's datas transmitted to registration
|
||||||
|
- `runes.datas.handlers`, handlers of everynodes (the index of this dictionnary is the rune's name)
|
||||||
|
- `runes.datas.amulets`, amulet's datas, used for the global_step loop and registration
|
||||||
|
- `runes.functions`, multiple useful functions
|
||||||
|
Loading…
Reference in New Issue
Block a user