47 lines
1.5 KiB
Markdown
47 lines
1.5 KiB
Markdown
# Mineclone Oxidization API
|
|
This document explains the API of this mod.
|
|
|
|
### `register_oxidation_abm(abm_name, node_name)`
|
|
Registers the ABM for the oxidization of nodes. It expects that the variable
|
|
`_mcl_oxidized_variant` be set with the node name of the oxidized version.
|
|
|
|
#### Parameters:
|
|
`abm_name`: A unique name for the abm to register.
|
|
|
|
`node_name`: the name of the node to check, and to oxidize.
|
|
|
|
#### Usage:
|
|
To use this API, add `_mcl_oxidized_variant = my_oxidized_node_name,` to the node
|
|
definition of the desired node, and then call
|
|
`register_oxidation_abm(my_oxidizable_node_abm, my_oxidizable_node)` in your code.
|
|
This abm will swap out the nodes with the more oxidized version of the node, one
|
|
stage at a time.
|
|
|
|
#### Example of Usage:
|
|
From mcl_copper:
|
|
```lua
|
|
local block_oxidation = {
|
|
{ "", "_exposed" },
|
|
{ "_cut", "_exposed_cut" },
|
|
{ "_exposed", "_weathered" },
|
|
{ "_exposed_cut", "_weathered_cut" },
|
|
{ "_weathered", "_oxidized" },
|
|
{ "_weathered_cut", "_oxidized_cut" }
|
|
}
|
|
|
|
for _, b in pairs(block_oxidation) do
|
|
register_oxidation_abm("Copper oxidation", "mcl_copper:block" .. b[1], "mcl_copper:block" .. b[2])
|
|
end
|
|
```
|
|
|
|
### Oxidization Removal
|
|
Make sure that the Oxidized Node has this in its definition:
|
|
|
|
`_mcl_stripped_variant = my_less_oxidized_node,`
|
|
|
|
And axes in mineclone will scrape the oxidization level down, usually by one stage.
|
|
An example of usage: `_mcl_stripped_variant = "mcl_copper:block",`
|
|
|
|
Implementation of other tools for scraping does not yet exist, but may in the future.
|
|
|