Code tweak and tidy

This commit is contained in:
TenPlus1 2017-01-15 20:54:28 +00:00
parent bd092c080b
commit cce0337b1c
2 changed files with 113 additions and 112 deletions

181
init.lua
View File

@ -1,72 +1,7 @@
bonemeal = {} bonemeal = {}
-- bone item ----- crops
minetest.register_craftitem("bonemeal:bone", {
description = "Bone",
inventory_image = "bonemeal_bone.png",
})
-- bonemeal recipes
minetest.register_craft({
type = "shapeless",
output = "bonemeal:bonemeal 2",
recipe = {"bonemeal:bone"},
})
minetest.register_craft({
type = "shapeless",
output = "bonemeal:bonemeal 4",
recipe = {"bones:bones"},
})
-- have animalmaterials found, craft bone into bonemeal
if minetest.get_modpath("animalmaterials") then
minetest.register_craft({
type = "shapeless",
output = "bonemeal:bonemeal 2",
recipe = {"animalmaterials:bone"},
})
end
-- add bones to dirt
minetest.override_item("default:dirt", {
drop = {
max_items = 1,
items = {
{
items = {"bonemeal:bone", "default:dirt"},
rarity = 30,
},
{
items = {"default:dirt"},
}
}
},
})
-- particles
local function particle_effect(pos)
minetest.add_particlespawner({
amount = 4,
time = 0.15,
minpos = pos,
maxpos = pos,
minvel = {x = -1, y = 2, z = -1},
maxvel = {x = 1, y = 4, z = 1},
minacc = {x = -1, y = -1, z = -1},
maxacc = {x = 1, y = 1, z = 1},
minexptime = 1,
maxexptime = 1,
minsize = 1,
maxsize = 3,
texture = "bonemeal_particle.png",
})
end
-- default crops -- default crops
local crops = { local crops = {
@ -85,6 +20,7 @@ function bonemeal:add_crop(list)
end end
end end
----- plants
-- default plants -- default plants
local plants = { local plants = {
@ -108,6 +44,7 @@ function bonemeal:add_plant(list)
end end
end end
----- saplings
-- special pine check for snow -- special pine check for snow
local function pine_grow(pos) local function pine_grow(pos)
@ -141,9 +78,31 @@ function bonemeal:add_sapling(list)
end end
end end
----- functions
-- moretrees specific function -- particles
local function more_tree(pos, object) local function particle_effect(pos)
minetest.add_particlespawner({
amount = 4,
time = 0.15,
minpos = pos,
maxpos = pos,
minvel = {x = -1, y = 2, z = -1},
maxvel = {x = 1, y = 4, z = 1},
minacc = {x = -1, y = -1, z = -1},
maxacc = {x = 1, y = 1, z = 1},
minexptime = 1,
maxexptime = 1,
minsize = 1,
maxsize = 3,
texture = "bonemeal_particle.png",
})
end
-- tree type check
local function grow_tree(pos, object)
if type(object) == "table" and object.axiom then if type(object) == "table" and object.axiom then
-- grow L-system tree -- grow L-system tree
@ -211,7 +170,7 @@ local function check_sapling(pos, nodename)
-- check if we can grow sapling -- check if we can grow sapling
if can_grow then if can_grow then
particle_effect(pos) particle_effect(pos)
more_tree(pos, saplings[n][2]) grow_tree(pos, saplings[n][2])
return return
end end
end end
@ -280,10 +239,31 @@ local function check_soil(pos, nodename)
end end
end end
----- items
-- growing routine -- bonemeal item
local function growth(pointed_thing) minetest.register_craftitem("bonemeal:bonemeal", {
description = "Bone Meal",
inventory_image = "bonemeal_item.png",
on_use = function(itemstack, user, pointed_thing)
-- did we point at a node?
if pointed_thing.type ~= "node" then
return
end
-- is area protected?
if minetest.is_protected(pointed_thing.under, user:get_player_name()) then
return
end
-- take item if not in creative
if not minetest.setting_getbool("creative_mode") then
itemstack:take_item()
end
-- get position and node
local pos = pointed_thing.under local pos = pointed_thing.under
local node = minetest.get_node(pos) local node = minetest.get_node(pos)
@ -294,9 +274,7 @@ local function growth(pointed_thing)
-- check for tree growth if pointing at sapling -- check for tree growth if pointing at sapling
if minetest.get_item_group(node.name, "sapling") > 0 then if minetest.get_item_group(node.name, "sapling") > 0 then
check_sapling(pos, node.name) check_sapling(pos, node.name)
return return
end end
@ -307,34 +285,45 @@ local function growth(pointed_thing)
if minetest.get_item_group(node.name, "soil") > 0 then if minetest.get_item_group(node.name, "soil") > 0 then
check_soil(pos, node.name) check_soil(pos, node.name)
end end
end
-- bonemeal item
minetest.register_craftitem("bonemeal:bonemeal", {
description = "Bone Meal",
inventory_image = "bonemeal_item.png",
on_use = function(itemstack, user, pointed_thing)
if pointed_thing.type == "node" then
-- Check if node protected
if minetest.is_protected(pointed_thing.under, user:get_player_name()) then
return
end
if not minetest.setting_getbool("creative_mode") then
itemstack:take_item()
end
growth(pointed_thing)
return itemstack return itemstack
end
end, end,
}) })
-- bone item
minetest.register_craftitem("bonemeal:bone", {
description = "Bone",
inventory_image = "bonemeal_bone.png",
})
-- bonemeal recipes
minetest.register_craft({
type = "shapeless",
output = "bonemeal:bonemeal 2",
recipe = {"bonemeal:bone"},
})
minetest.register_craft({
type = "shapeless",
output = "bonemeal:bonemeal 4",
recipe = {"bones:bones"},
})
-- add bones to dirt
minetest.override_item("default:dirt", {
drop = {
max_items = 1,
items = {
{
items = {"bonemeal:bone", "default:dirt"},
rarity = 30,
},
{
items = {"default:dirt"},
}
}
},
})
-- add support for other mods -- add support for other mods
dofile(minetest.get_modpath("bonemeal") .. "/mods.lua") dofile(minetest.get_modpath("bonemeal") .. "/mods.lua")

View File

@ -1,4 +1,16 @@
-- craft bones from animalmaterials into bonemeal
if minetest.get_modpath("animalmaterials") then
minetest.register_craft({
type = "shapeless",
output = "bonemeal:bonemeal 2",
recipe = {"animalmaterials:bone"},
})
end
if farming and farming.mod and farming.mod == "redo" then if farming and farming.mod and farming.mod == "redo" then
bonemeal:add_crop({ bonemeal:add_crop({