126 lines
4.9 KiB
Markdown
Raw Normal View History

2017-01-11 13:34:08 +01:00
# API
## Groups
2023-04-06 16:38:55 +02:00
Mineclonia makes very extensive use of groups. Making sure your items and
objects have the correct group memberships is very important. Groups are
explained in `GROUPS.md`.
2017-08-23 16:39:57 +02:00
## Mod naming convention
2023-04-06 16:38:55 +02:00
Mods mods in Mineclonia follow a simple naming convention: Mods with the prefix
`mcl_`” are specific to Mineclonia, although they may be based on an existing
standalone. Mods which lack this prefix are *usually* verbatim copies of a
standalone mod. Some modifications may still have been applied, but the APIs are
held compatible.
2017-01-11 13:34:08 +01:00
2017-08-23 16:39:57 +02:00
## Adding items
### Special fields
Items can have these fields:
2023-04-06 16:38:55 +02:00
* `_mcl_generate_description(itemstack)`: Required for any items which
manipulate their description in any way. This function takes an itemstack of
its own type and must set the proper advanced description for this itemstack.
If you don't do this, anvils will fail at properly restoring the description
when their custom name gets cleared at an anvil. See `mcl_banners` for an
example.
2021-03-16 16:10:57 +01:00
Tools can have these fields:
2023-04-06 16:38:55 +02:00
* `_mcl_diggroups`: Specifies the digging groups that a tool can dig and how
2023-04-06 16:38:55 +02:00
efficiently. See `_mcl_autogroup` for more information.
2021-03-16 16:10:57 +01:00
2017-08-23 16:39:57 +02:00
All nodes can have these fields:
2017-01-11 13:34:08 +01:00
2023-04-06 16:38:55 +02:00
* `_mcl_hardness`: Hardness of the block, ranges from 0 to infinity (represented
by -1). Determines digging times. Default: 0
* `_mcl_blast_resistance`: How well this block blocks and resists explosions.
Default: 0
* `_mcl_falling_node_alternative`: If set to an itemstring, the node will turn
into this node before it starts to fall.
* `_mcl_after_falling(pos)`: Called after a falling node finished falling and
turned into a node.
2017-01-11 13:34:08 +01:00
2023-05-06 22:14:43 +02:00
### Tool Callbacks
Nodes can have "tool callbacks" modifying the on_place function of certain tools.
The first return value should be the itemstack and the second an option bool
i ndicatingif no wear should be added to the tool e.g. because the mod does it
itsself.
* _on_axe_place(itemstack,placer,pointed_thing)
* _on_shovel_place(itemstack,placer,pointed_thing)
* _on_sword_place(itemstack,placer,pointed_thing)
* _on_pickaxe_place(itemstack,placer,pointed_thing)
* _on_shears_place(itemstack,placer,pointed_thing)
2017-08-23 16:39:57 +02:00
Use the `mcl_sounds` mod for the sounds.
## APIs
2023-04-06 16:38:55 +02:00
A lot of things are possible by using one of the APIs in the mods. Note that not
all APIs are documented yet, but it is planned. The following APIs should be
more or less stable but keep in mind that Mineclonia is still unfinished. All
directory names are relative to `mods/`
2017-08-23 16:39:57 +02:00
### Items
* Doors: `ITEMS/mcl_doors`
* Fences and fence gates: `ITEMS/mcl_fences`
* Stairs and slabs: `ITEM/mcl_stairs`
2017-08-23 16:39:57 +02:00
* Walls: `ITEMS/mcl_walls`
* Beds: `ITEMS/mcl_beds`
* Buckets: `ITEMS/mcl_buckets`
2018-02-01 23:00:50 +01:00
* Dispenser support: `ITEMS/REDSTONE/mcl_dispensers`
* Campfires: `ITEMS/mcl_campfires`
2023-10-08 19:22:34 +02:00
* Trees and wood related nodes: `ITEMS/mcl_trees`
2022-06-16 19:37:29 -06:00
### Mobs
2021-03-14 17:03:34 +01:00
* Mobs: `ENTITIES/mcl_mobs`
2017-08-23 16:39:57 +02:00
2023-04-06 16:38:55 +02:00
Mineclonia uses its own mobs framework, called “Mobs Redo: Mineclonia Edition”
or “MRM” for short. This is a fork of Mobs Redo [`mobs`] by TenPlus1.
2018-05-31 18:04:07 +02:00
2023-04-06 16:38:55 +02:00
You can add your own mobs, spawn eggs and spawning rules with this mod. API
documnetation is included in `ENTITIES/mcl_mobs/api.txt`.
2017-08-23 16:39:57 +02:00
2023-04-06 16:38:55 +02:00
This mod includes modificiations from the original Mobs Redo. Some items have
been removed or moved to other mods. The API is mostly identical, but a few
features have been added. Compability is not really a goal, but function and
attribute names of Mobs Redo 1.41 are kept. If you have code for a mod which
works fine under Mobs Redo, it should be easy to make it work in Mineclonia,
2018-05-31 18:04:07 +02:00
chances are good that it works out of the box.
2017-08-23 16:39:57 +02:00
### Help
* Item help texts: `HELP/doc/doc_items`
* Low-level help entry and category framework: `HELP/doc/doc`
* Support for lookup tool (required for all entities): `HELP/doc/doc_identifier`
### HUD
* Statbars: `HUD/hudbars`
### Utility APIs
2018-10-23 18:56:10 +02:00
* Change player physics: `PLAYER/playerphysics`
2017-08-23 16:39:57 +02:00
* Select random treasures: `CORE/mcl_loot`
* Get flowing direction of liquids: `CORE/flowlib`
* `on_walk_over` callback for nodes: `CORE/walkover`
* `_on_arrow_hit` callback when node is hit by an arrow: function(pos, arrow_luaentity)
* `_on_dye_place` callback when node is rickclicked with a dye: function(pos, color_name)
2023-04-06 16:38:55 +02:00
* Get node names close to player (to reduce constant querying):
`PLAYER/mcl_playerinfo`
* Colors and dyes API: `ITEMS/mcl_dyes`
2021-03-14 17:03:34 +01:00
* Explosion API
* Music discs API
* Flowers and flower pots
2017-08-23 16:39:57 +02:00
### Unstable APIs
2023-04-06 16:38:55 +02:00
The following APIs may be subject to change in future. You could already use
these APIs but there will probably be breaking changes in the future, or the API
is not as fleshed out as it should be. Use at your own risk!
2017-01-16 21:21:47 +01:00
2017-08-23 16:39:57 +02:00
* Panes (like glass panes and iron bars): `ITEMS/xpanes`
* `_on_ignite` callback: `ITEMS/mcl_fire`
* Farming: `ITEMS/mcl_farming`
2017-11-24 06:47:19 +01:00
* Anything related to redstone: Don't touch (yet)
* Any other mod not explicitly mentioned above
2017-08-23 16:39:57 +02:00
### Planned APIs
* Custom banner patterns
* Custom dimensions
* Custom portals
* Proper sky and weather APIs