short farming code and reduce farming texture sizes (adv- and optipng)
10
game_api.txt
|
@ -142,21 +142,17 @@ farming.register_plant(name, Plant definition)
|
||||||
---------------
|
---------------
|
||||||
{
|
{
|
||||||
description = "", -- Description for tooltip
|
description = "", -- Description for tooltip
|
||||||
inventory_image = "unknown_item.png", -- Image to be used as wield- and inventory image
|
inventory_image = , -- Image to be used as wield- and inventory image
|
||||||
max_uses = 30, -- Uses until destroyed
|
max_uses = 30, -- Uses until destroyed
|
||||||
material = "", -- Material for recipes
|
material = "", -- Material for recipes
|
||||||
recipe = { -- Craft recipe, if material isn't used
|
recipe = , -- Craft recipe, if material isn't used
|
||||||
{"air", "air", "air"},
|
|
||||||
{"", "group:stick"},
|
|
||||||
{"", "group:stick"},
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#Plant definition
|
#Plant definition
|
||||||
-----------------
|
-----------------
|
||||||
{
|
{
|
||||||
description = "", -- Description of seed item
|
description = "", -- Description of seed item
|
||||||
inventory_image = "unknown_item.png", -- Image to be used as seed's wield- and inventory image
|
inventory_image = , -- Image to be used as seed's wield- and inventory image
|
||||||
steps = 8, -- How many steps the plant has to grow, until it can be harvested
|
steps = 8, -- How many steps the plant has to grow, until it can be harvested
|
||||||
^ Always provide a plant texture for each step, format: modname_plantname_i.png (i = stepnumber)
|
^ Always provide a plant texture for each step, format: modname_plantname_i.png (i = stepnumber)
|
||||||
minlight = 13, -- Minimum light to grow
|
minlight = 13, -- Minimum light to grow
|
||||||
|
|
|
@ -1,40 +1,32 @@
|
||||||
-- Wear out hoes, place soil
|
-- Wear out hoes, place soil
|
||||||
-- TODO Ignore group:flower
|
-- TODO Ignore group:flower
|
||||||
farming.hoe_on_use = function(itemstack, user, pointed_thing, uses)
|
|
||||||
local pt = pointed_thing
|
local creative = minetest.setting_getbool("creative_mode")
|
||||||
-- check if pointing at a node
|
function farming.hoe_on_use(itemstack, user, pt, uses)
|
||||||
if not pt then
|
-- check if pointing at a node's top
|
||||||
|
if not pt
|
||||||
|
or pt.type ~= "node"
|
||||||
|
or pt.above.y ~= pt.under.y+1 then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if pt.type ~= "node" then
|
|
||||||
|
local above = minetest.get_node(pt.above)
|
||||||
|
if above.name ~= "air"
|
||||||
|
or not minetest.registered_nodes[above.name] then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local under = minetest.get_node(pt.under)
|
local under = minetest.get_node(pt.under)
|
||||||
local p = {x=pt.under.x, y=pt.under.y+1, z=pt.under.z}
|
if not minetest.registered_nodes[under.name]
|
||||||
local above = minetest.get_node(p)
|
or minetest.get_item_group(under.name, "soil") ~= 1 then
|
||||||
|
|
||||||
-- return if any of the nodes is not registered
|
|
||||||
if not minetest.registered_nodes[under.name] then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if not minetest.registered_nodes[above.name] then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- check if the node above the pointed thing is air
|
|
||||||
if above.name ~= "air" then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- check if pointing at soil
|
|
||||||
if minetest.get_item_group(under.name, "soil") ~= 1 then
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- check if (wet) soil defined
|
-- check if (wet) soil defined
|
||||||
local regN = minetest.registered_nodes
|
local soil = minetest.registered_nodes[under.name].soil
|
||||||
if regN[under.name].soil == nil or regN[under.name].soil.wet == nil or regN[under.name].soil.dry == nil then
|
if not soil
|
||||||
|
or not soil.wet
|
||||||
|
or not soil.dry then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -47,41 +39,33 @@ farming.hoe_on_use = function(itemstack, user, pointed_thing, uses)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- turn the node into soil, wear out item and play sound
|
-- turn the node into soil, wear out item and play sound
|
||||||
minetest.set_node(pt.under, {name = regN[under.name].soil.dry})
|
minetest.set_node(pt.under, {name = soil.dry})
|
||||||
minetest.sound_play("default_dig_crumbly", {
|
minetest.sound_play("default_dig_crumbly", {
|
||||||
pos = pt.under,
|
pos = pt.under,
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
})
|
})
|
||||||
|
|
||||||
if not minetest.setting_getbool("creative_mode") then
|
if creative then
|
||||||
itemstack:add_wear(65535/(uses-1))
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
itemstack:add_wear(65535/(uses-1))
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Register new hoes
|
-- Register new hoes
|
||||||
farming.register_hoe = function(name, def)
|
function farming.register_hoe(name, def)
|
||||||
-- Check for : prefix (register new hoes in your mod's namespace)
|
-- Check for : prefix (register new hoes in your mod's namespace)
|
||||||
if name:sub(1,1) ~= ":" then
|
if name:sub(1,1) ~= ":" then
|
||||||
name = ":" .. name
|
name = ":" .. name
|
||||||
end
|
end
|
||||||
-- Check def table
|
-- Check def table
|
||||||
if def.description == nil then
|
if not def.description then
|
||||||
def.description = "Hoe"
|
def.description = "Hoe"
|
||||||
end
|
end
|
||||||
if def.inventory_image == nil then
|
assert(def.inventory_image, "[farming] missing field inventory_image ("..name..")")
|
||||||
def.inventory_image = "unknown_item.png"
|
if not def.max_uses then
|
||||||
end
|
|
||||||
if def.recipe == nil then
|
|
||||||
def.recipe = {
|
|
||||||
{"air","air",""},
|
|
||||||
{"","group:stick",""},
|
|
||||||
{"","group:stick",""}
|
|
||||||
}
|
|
||||||
end
|
|
||||||
if def.max_uses == nil then
|
|
||||||
def.max_uses = 30
|
def.max_uses = 30
|
||||||
end
|
end
|
||||||
-- Register the tool
|
-- Register the tool
|
||||||
|
@ -93,12 +77,15 @@ farming.register_hoe = function(name, def)
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
-- Register its recipe
|
-- Register its recipe
|
||||||
if def.material == nil then
|
if not def.material then
|
||||||
|
if def.recipe then
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = name:sub(2),
|
output = name:sub(2),
|
||||||
recipe = def.recipe
|
recipe = def.recipe
|
||||||
})
|
})
|
||||||
else
|
end
|
||||||
|
return
|
||||||
|
end
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = name:sub(2),
|
output = name:sub(2),
|
||||||
recipe = {
|
recipe = {
|
||||||
|
@ -116,85 +103,60 @@ farming.register_hoe = function(name, def)
|
||||||
{"", "group:stick", ""}
|
{"", "group:stick", ""}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Seed placement
|
-- Seed placement
|
||||||
farming.place_seed = function(itemstack, placer, pointed_thing, plantname)
|
function farming.place_seed(itemstack, placer, pt, plantname)
|
||||||
local pt = pointed_thing
|
-- check if pointing at a node's top
|
||||||
-- check if pointing at a node
|
if not pt
|
||||||
if not pt then
|
or pt.type ~= "node"
|
||||||
return
|
or pt.above.y ~= pt.under.y+1 then
|
||||||
end
|
|
||||||
if pt.type ~= "node" then
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local under = minetest.get_node(pt.under)
|
local playername = placer:get_player_name()
|
||||||
local above = minetest.get_node(pt.above)
|
if minetest.is_protected(pt.under, playername) then
|
||||||
|
minetest.record_protection_violation(pt.under, playername)
|
||||||
if minetest.is_protected(pt.under, placer:get_player_name()) then
|
|
||||||
minetest.record_protection_violation(pt.under, placer:get_player_name())
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if minetest.is_protected(pt.above, placer:get_player_name()) then
|
if minetest.is_protected(pt.above, playername) then
|
||||||
minetest.record_protection_violation(pt.above, placer:get_player_name())
|
minetest.record_protection_violation(pt.above, playername)
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
-- return if any of the nodes is not registered
|
|
||||||
if not minetest.registered_nodes[under.name] then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if not minetest.registered_nodes[above.name] then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- check if pointing at the top of the node
|
|
||||||
if pt.above.y ~= pt.under.y+1 then
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- check if you can replace the node above the pointed node
|
-- check if you can replace the node above the pointed node
|
||||||
if not minetest.registered_nodes[above.name].buildable_to then
|
local above = minetest.get_node(pt.above)
|
||||||
|
if not minetest.registered_nodes[above.name]
|
||||||
|
or not minetest.registered_nodes[above.name].buildable_to then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- check if pointing at soil
|
-- check if pointing at soil
|
||||||
if minetest.get_item_group(under.name, "soil") < 2 then
|
local under = minetest.get_node(pt.under)
|
||||||
|
if not minetest.registered_nodes[under.name]
|
||||||
|
or minetest.get_item_group(under.name, "soil") < 2 then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- add the node and remove 1 item from the itemstack
|
-- add the node and remove 1 item from the itemstack
|
||||||
minetest.add_node(pt.above, {name = plantname, param2 = 1})
|
minetest.add_node(pt.above, {name = plantname, param2 = 1})
|
||||||
if not minetest.setting_getbool("creative_mode") then
|
|
||||||
itemstack:take_item()
|
if creative then
|
||||||
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
itemstack:take_item()
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Register plants
|
-- Register plants
|
||||||
farming.register_plant = function(name, def)
|
function farming.register_plant(name, def)
|
||||||
local mname = name:split(":")[1]
|
if not def.steps then
|
||||||
local pname = name:split(":")[2]
|
return
|
||||||
|
end
|
||||||
|
|
||||||
-- Check def table
|
-- Check def table
|
||||||
if not def.description then
|
assert(def.inventory_image, "[farming] missing field inventory_image ("..name..")")
|
||||||
def.description = "Seed"
|
|
||||||
end
|
|
||||||
if not def.inventory_image then
|
|
||||||
def.inventory_image = "unknown_item.png"
|
|
||||||
end
|
|
||||||
if not def.steps then
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
if not def.minlight then
|
|
||||||
def.minlight = 1
|
|
||||||
end
|
|
||||||
if not def.maxlight then
|
|
||||||
def.maxlight = 14
|
|
||||||
end
|
|
||||||
if not def.fertility then
|
if not def.fertility then
|
||||||
def.fertility = {}
|
def.fertility = {}
|
||||||
end
|
end
|
||||||
|
@ -204,8 +166,11 @@ farming.register_plant = function(name, def)
|
||||||
for k, v in pairs(def.fertility) do
|
for k, v in pairs(def.fertility) do
|
||||||
g[v] = 1
|
g[v] = 1
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local mname, pname = unpack(name:split(":"))
|
||||||
|
|
||||||
minetest.register_node(":" .. mname .. ":seed_" .. pname, {
|
minetest.register_node(":" .. mname .. ":seed_" .. pname, {
|
||||||
description = def.description,
|
description = def.description or "Seed",
|
||||||
tiles = {def.inventory_image},
|
tiles = {def.inventory_image},
|
||||||
inventory_image = def.inventory_image,
|
inventory_image = def.inventory_image,
|
||||||
wield_image = def.inventory_image,
|
wield_image = def.inventory_image,
|
||||||
|
@ -233,16 +198,9 @@ farming.register_plant = function(name, def)
|
||||||
|
|
||||||
-- Register growing steps
|
-- Register growing steps
|
||||||
for i=1,def.steps do
|
for i=1,def.steps do
|
||||||
local drop = {
|
|
||||||
items = {
|
|
||||||
{items = {mname .. ":" .. pname}, rarity = 9 - i},
|
|
||||||
{items = {mname .. ":" .. pname}, rarity= 18 - i * 2},
|
|
||||||
{items = {mname .. ":seed_" .. pname}, rarity = 9 - i},
|
|
||||||
{items = {mname .. ":seed_" .. pname}, rarity = 18 - i * 2},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
local nodegroups = {snappy = 3, flammable = 2, plant = 1, not_in_creative_inventory = 1, attached_node = 1}
|
local nodegroups = {snappy = 3, flammable = 2, plant = 1, not_in_creative_inventory = 1, attached_node = 1}
|
||||||
nodegroups[pname] = i
|
nodegroups[pname] = i
|
||||||
|
|
||||||
minetest.register_node(mname .. ":" .. pname .. "_" .. i, {
|
minetest.register_node(mname .. ":" .. pname .. "_" .. i, {
|
||||||
drawtype = "plantlike",
|
drawtype = "plantlike",
|
||||||
waving = 1,
|
waving = 1,
|
||||||
|
@ -250,7 +208,14 @@ farming.register_plant = function(name, def)
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
walkable = false,
|
walkable = false,
|
||||||
buildable_to = true,
|
buildable_to = true,
|
||||||
drop = drop,
|
drop = {
|
||||||
|
items = {
|
||||||
|
{items = {mname .. ":" .. pname}, rarity = 9 - i},
|
||||||
|
{items = {mname .. ":" .. pname}, rarity= 18 - i * 2},
|
||||||
|
{items = {mname .. ":seed_" .. pname}, rarity = 9 - i},
|
||||||
|
{items = {mname .. ":seed_" .. pname}, rarity = 18 - i * 2},
|
||||||
|
}
|
||||||
|
},
|
||||||
selection_box = {
|
selection_box = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5},
|
||||||
|
@ -260,6 +225,13 @@ farming.register_plant = function(name, def)
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if not def.minlight then
|
||||||
|
def.minlight = 1
|
||||||
|
end
|
||||||
|
if not def.maxlight then
|
||||||
|
def.maxlight = 14
|
||||||
|
end
|
||||||
|
|
||||||
-- Growing ABM
|
-- Growing ABM
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = {"group:" .. pname, "group:seed"},
|
nodenames = {"group:" .. pname, "group:seed"},
|
||||||
|
@ -267,57 +239,61 @@ farming.register_plant = function(name, def)
|
||||||
interval = 90,
|
interval = 90,
|
||||||
chance = 2,
|
chance = 2,
|
||||||
action = function(pos, node)
|
action = function(pos, node)
|
||||||
local plant_height = minetest.get_item_group(node.name, pname)
|
|
||||||
|
|
||||||
-- return if already full grown
|
-- return if already full grown
|
||||||
if plant_height == def.steps then
|
if minetest.get_item_group(node.name, pname) == def.steps then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local node_def = minetest.registered_items[node.name] or nil
|
pos.y = pos.y-1
|
||||||
|
local soil_node = minetest.get_node_or_nil(pos)
|
||||||
-- grow seed
|
|
||||||
if minetest.get_item_group(node.name, "seed") and node_def.fertility then
|
|
||||||
local can_grow = false
|
|
||||||
local soil_node = minetest.get_node_or_nil({x = pos.x, y = pos.y - 1, z = pos.z})
|
|
||||||
if not soil_node then
|
if not soil_node then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
for _, v in pairs(node_def.fertility) do
|
pos.y = pos.y+1
|
||||||
|
|
||||||
|
local fertility = minetest.registered_items[node.name].fertility
|
||||||
|
|
||||||
|
-- grow seed
|
||||||
|
if fertility
|
||||||
|
and minetest.get_item_group(node.name, "seed") then
|
||||||
|
local can_grow
|
||||||
|
for _, v in pairs(fertility) do
|
||||||
if minetest.get_item_group(soil_node.name, v) ~= 0 then
|
if minetest.get_item_group(soil_node.name, v) ~= 0 then
|
||||||
can_grow = true
|
can_grow = true
|
||||||
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if can_grow then
|
if not can_grow then
|
||||||
minetest.set_node(pos, {name = node.name:gsub("seed_", "") .. "_1"})
|
return
|
||||||
end
|
end
|
||||||
|
node.name = node.name:gsub("seed_", "") .. "_1"
|
||||||
|
minetest.set_node(pos, node)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- check if on wet soil
|
-- check if on wet soil
|
||||||
pos.y = pos.y - 1
|
if minetest.get_item_group(soil_node.name, "soil") < 3 then
|
||||||
local n = minetest.get_node(pos)
|
|
||||||
if minetest.get_item_group(n.name, "soil") < 3 then
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
pos.y = pos.y + 1
|
|
||||||
|
|
||||||
-- check light
|
-- check light
|
||||||
local ll = minetest.get_node_light(pos)
|
local ll = minetest.get_node_light(pos)
|
||||||
|
|
||||||
if not ll or ll < def.minlight or ll > def.maxlight then
|
if not ll
|
||||||
|
or ll < def.minlight
|
||||||
|
or ll > def.maxlight then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- grow
|
-- grow
|
||||||
minetest.set_node(pos, {name = mname .. ":" .. pname .. "_" .. plant_height + 1})
|
node.name = mname .. ":" .. pname .. "_" .. plant_height + 1
|
||||||
|
minetest.set_node(pos, node)
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Return
|
-- Return
|
||||||
local r = {
|
return {
|
||||||
seed = mname .. ":seed_" .. pname,
|
seed = mname .. ":seed_" .. pname,
|
||||||
harvest = mname .. ":" .. pname
|
harvest = mname .. ":" .. pname
|
||||||
}
|
}
|
||||||
return r
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -89,62 +89,76 @@ minetest.register_abm({
|
||||||
interval = 15,
|
interval = 15,
|
||||||
chance = 4,
|
chance = 4,
|
||||||
action = function(pos, node)
|
action = function(pos, node)
|
||||||
local n_def = minetest.registered_nodes[node.name] or nil
|
local soil = minetest.registered_nodes[node.name].soil
|
||||||
local wet = n_def.soil.wet or nil
|
if not soil then
|
||||||
local base = n_def.soil.base or nil
|
return
|
||||||
local dry = n_def.soil.dry or nil
|
end
|
||||||
if not n_def or not n_def.soil or not wet or not base or not dry then
|
local wet = soil.wet
|
||||||
|
local base = soil.base
|
||||||
|
local dry = soil.dry
|
||||||
|
if not (wet and base and dry) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
pos.y = pos.y + 1
|
pos.y = pos.y + 1
|
||||||
local nn = minetest.get_node_or_nil(pos)
|
local nn = minetest.get_node_or_nil(pos)
|
||||||
if not nn or not nn.name then
|
if not nn then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local nn_def = minetest.registered_nodes[nn.name] or nil
|
local nn_def = minetest.registered_nodes[nn.name]
|
||||||
pos.y = pos.y - 1
|
pos.y = pos.y - 1
|
||||||
|
|
||||||
if nn_def and nn_def.walkable and minetest.get_item_group(nn.name, "plant") == 0 then
|
if nn_def
|
||||||
minetest.set_node(pos, {name = base})
|
and nn_def.walkable
|
||||||
|
and minetest.get_item_group(nn.name, "plant") == 0 then
|
||||||
|
node.name = base
|
||||||
|
minetest.set_node(pos, node)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- check if there is water nearby
|
-- check if there is water nearby
|
||||||
local wet_lvl = minetest.get_item_group(node.name, "wet")
|
local wet_lvl = minetest.get_item_group(node.name, "wet")
|
||||||
if minetest.find_node_near(pos, 3, {"group:water"}) then
|
if minetest.find_node_near(pos, 3, {"group:water"}) then
|
||||||
-- if it is dry soil and not base node, turn it into wet soil
|
-- if it is dry soil and not base node, turn it into wet soil
|
||||||
if wet_lvl == 0 then
|
if wet_lvl == 0 then
|
||||||
minetest.set_node(pos, {name = wet})
|
node.name = wet
|
||||||
|
minetest.set_node(pos, node)
|
||||||
end
|
end
|
||||||
else
|
return
|
||||||
|
end
|
||||||
|
|
||||||
-- only turn back if there are no unloaded blocks (and therefore
|
-- only turn back if there are no unloaded blocks (and therefore
|
||||||
-- possible water sources) nearby
|
-- possible water sources) nearby
|
||||||
if not minetest.find_node_near(pos, 3, {"ignore"}) then
|
if minetest.find_node_near(pos, 3, {"ignore"}) then
|
||||||
|
return
|
||||||
|
end
|
||||||
-- turn it back into base if it is already dry
|
-- turn it back into base if it is already dry
|
||||||
if wet_lvl == 0 then
|
if wet_lvl == 0 then
|
||||||
-- only turn it back if there is no plant/seed on top of it
|
-- only turn it back if there is no plant/seed on top of it
|
||||||
if minetest.get_item_group(nn.name, "plant") == 0 and minetest.get_item_group(nn.name, "seed") == 0 then
|
if minetest.get_item_group(nn.name, "plant") == 0
|
||||||
minetest.set_node(pos, {name = base})
|
and minetest.get_item_group(nn.name, "seed") == 0 then
|
||||||
|
node.name = base
|
||||||
|
minetest.set_node(pos, node)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- if its wet turn it back into dry soil
|
-- if its wet turn it back into dry soil
|
||||||
elseif wet_lvl == 1 then
|
elseif wet_lvl == 1 then
|
||||||
minetest.set_node(pos, {name = dry})
|
node.name = dry
|
||||||
end
|
minetest.set_node(pos, node)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
for i = 1, 5 do
|
local defchange = {drop = {
|
||||||
minetest.override_item("default:grass_"..i, {drop = {
|
|
||||||
max_items = 1,
|
max_items = 1,
|
||||||
items = {
|
items = {
|
||||||
{items = {'farming:seed_wheat'},rarity = 5},
|
{items = {'farming:seed_wheat'},rarity = 5},
|
||||||
{items = {'default:grass_1'}},
|
{items = {'default:grass_1'}},
|
||||||
}
|
}
|
||||||
}})
|
}}
|
||||||
|
for i = 1, 5 do
|
||||||
|
minetest.override_item("default:grass_"..i, defchange)
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.override_item("default:junglegrass", {drop = {
|
minetest.override_item("default:junglegrass", {drop = {
|
||||||
|
|
Before Width: | Height: | Size: 393 B After Width: | Height: | Size: 388 B |
Before Width: | Height: | Size: 159 B After Width: | Height: | Size: 158 B |
Before Width: | Height: | Size: 170 B After Width: | Height: | Size: 163 B |
Before Width: | Height: | Size: 196 B After Width: | Height: | Size: 192 B |
Before Width: | Height: | Size: 467 B After Width: | Height: | Size: 467 B |
Before Width: | Height: | Size: 351 B After Width: | Height: | Size: 351 B |
Before Width: | Height: | Size: 706 B After Width: | Height: | Size: 703 B |
Before Width: | Height: | Size: 677 B After Width: | Height: | Size: 676 B |
Before Width: | Height: | Size: 212 B After Width: | Height: | Size: 212 B |
Before Width: | Height: | Size: 241 B After Width: | Height: | Size: 240 B |
Before Width: | Height: | Size: 172 B After Width: | Height: | Size: 168 B |
Before Width: | Height: | Size: 191 B After Width: | Height: | Size: 185 B |
Before Width: | Height: | Size: 218 B After Width: | Height: | Size: 208 B |
Before Width: | Height: | Size: 234 B After Width: | Height: | Size: 223 B |
Before Width: | Height: | Size: 253 B After Width: | Height: | Size: 240 B |
Before Width: | Height: | Size: 310 B After Width: | Height: | Size: 310 B |