tweak code, fix straw recipe

This commit is contained in:
tenplus1 2024-08-12 14:21:46 +01:00
parent e409fe9ecb
commit 45dd32c102
2 changed files with 23 additions and 54 deletions

View File

@ -1,6 +1,5 @@
--[[
Farming Redo Mod
by TenPlus1
Farming Redo Mod by TenPlus1
NEW growing routine by prestidigitator
auto-refill by crabman77
]]
@ -8,18 +7,14 @@
-- Translation support
local S = minetest.get_translator("farming")
-- set global
-- global
farming = {
mod = "redo",
version = "20240812",
path = minetest.get_modpath("farming"),
select = {
type = "fixed", fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5}
},
select_final = {
type = "fixed", fixed = {-0.5, -0.5, -0.5, 0.5, -2.5/16, 0.5}
},
select = {type = "fixed", fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5}},
select_final = {type = "fixed", fixed = {-0.5, -0.5, -0.5, 0.5, -2.5/16, 0.5}},
registered_plants = {},
min_light = 12,
max_light = 15,
@ -172,8 +167,6 @@ farming.plant_stages = plant_stages
-- @return - The (possibly zero) number of stages of growth the plant will go through
-- before being fully grown, or nil if not a plant.
local register_plant_node
-- Recursive helper
local function reg_plant_stages(plant_name, stage, force_last)
@ -251,9 +244,8 @@ local register_plant_node = function(node)
if plant_name then
local stages = reg_plant_stages(plant_name, stage, false)
return stages and #stages.stages_left
else
return nil
end
end
@ -291,14 +283,6 @@ function farming.handle_growth(pos, node)
if stages_left then set_growing(pos, stages_left) end
end
minetest.after(0, function()
for _, node_def in pairs(minetest.registered_nodes) do
register_plant_node(node_def)
end
end)
-- Just in case a growing type or added node is missed (also catches existing
-- nodes added to map before timers were incorporated).
@ -319,8 +303,7 @@ minetest.register_abm({
if def and def.groups and def.groups.seed then
-- start node timer if found
if def.on_timer then
if def.on_timer then -- start node timer if found
farming.start_seed_timer(pos)
@ -331,24 +314,24 @@ minetest.register_abm({
def = minetest.registered_nodes[next_stage]
-- switch seed without timer to stage_1 of crop
if def then
if def then -- switch seed without timer to stage_1 of crop
local p2 = def.place_param2 or 1
minetest.set_node(pos, {name = next_stage, param2 = p2})
end
else
-- start normal crop timer
farming.handle_growth(pos, node)
farming.handle_growth(pos, node) -- start normal crop timer
end
end
})
-- default check if on wet soil
-- default check crop is on wet soil
farming.can_grow = function(pos)
local below = minetest.get_node({x = pos.x, y = pos.y -1, z = pos.z})
return minetest.get_item_group(below.name, "soil") >= 3
end
@ -367,13 +350,11 @@ function farming.plant_growth_timer(pos, elapsed, node_name)
local chk1 = minetest.registered_nodes[node_name].growth_check -- old
local chk2 = minetest.registered_nodes[node_name].can_grow -- new
-- custom farming redo growth_check function
if chk1 then
if chk1 then -- custom farming redo growth_check function
if not chk1(pos, node_name) then return true end
-- custom mt 5.9x farming can_grow function
elseif chk2 then
elseif chk2 then -- custom mt 5.9x farming can_grow function
if not chk2(pos) then return true end
@ -434,11 +415,7 @@ end
function farming.refill_plant(player, plantname, index)
if not player then return end
local inv = player:get_inventory()
if not inv then return end
local inv = player and player:get_inventory() ; if not inv then return end
local old_stack = inv:get_stack("main", index)
@ -703,9 +680,7 @@ farming.rice = true
local input = io.open(farming.path .. "/farming.conf", "r")
if input then
dofile(farming.path .. "/farming.conf") ; input:close()
end
if input then dofile(farming.path .. "/farming.conf") ; input:close() end
-- load new world-specific settings if found inside world folder
@ -713,9 +688,7 @@ local worldpath = minetest.get_worldpath()
input = io.open(worldpath .. "/farming.conf", "r")
if input then
dofile(worldpath .. "/farming.conf") ; input:close()
end
if input then dofile(worldpath .. "/farming.conf") ; input:close() end
-- helper function to add {eatable} group to food items, also {flammable}
@ -737,7 +710,7 @@ end
dofile(farming.path .. "/item_list.lua")
-- important items
-- setup soil, register hoes, override grass
if minetest.get_modpath("default") then
dofile(farming.path .. "/soil.lua")
@ -746,14 +719,6 @@ end
dofile(farming.path.."/grass.lua")
-- default crops
if not farming.mcl then
dofile(farming.path.."/crops/wheat.lua")
end
dofile(farming.path.."/crops/cotton.lua")
-- disable crops Mineclone already has
if farming.mcl then
@ -764,8 +729,12 @@ if farming.mcl then
farming.beetroot = nil
farming.sunflower = nil
farming.pumpkin = nil
else
dofile(farming.path.."/crops/wheat.lua") -- default crop outwith mineclone
end
dofile(farming.path.."/crops/cotton.lua") -- default crop
-- helper function
local function ddoo(file, check)

View File

@ -1211,7 +1211,7 @@ minetest.register_craft( {
-- straw
local tmp = "group:food_wheat"
local tmp = farming.mcl and "farming:rye" or "farming:wheat"
minetest.register_craft({
output = "farming:straw 3",
@ -1223,7 +1223,7 @@ minetest.register_craft({
})
minetest.register_craft({
output = "farming:wheat 3",
output = tmp .. " 3",
recipe = {{"farming:straw"}}
})