forked from mtcontrib/farming
optimize
This commit is contained in:
parent
fd205e10fc
commit
85c5c9abab
7
api.txt
7
api.txt
@ -63,3 +63,10 @@ end,
|
|||||||
This is a function to add items to a list that scythes will not drop, e.g. farming:trellis or farming:beanpole.
|
This is a function to add items to a list that scythes will not drop, e.g. farming:trellis or farming:beanpole.
|
||||||
|
|
||||||
farming.add_to_scythe_not_drops(item_name)
|
farming.add_to_scythe_not_drops(item_name)
|
||||||
|
|
||||||
|
### Start timer function
|
||||||
|
|
||||||
|
A handy function that starts a crops timer with a randomly selected time set by using
|
||||||
|
stage_length setting. This is mostly used for special functions or 3rd party mods.
|
||||||
|
|
||||||
|
farming.start_seed_timer(pos)
|
||||||
|
36
init.lua
36
init.lua
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
farming = {
|
farming = {
|
||||||
mod = "redo",
|
mod = "redo",
|
||||||
version = "20230911",
|
version = "20230912",
|
||||||
path = minetest.get_modpath("farming"),
|
path = minetest.get_modpath("farming"),
|
||||||
select = {
|
select = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
@ -53,6 +53,9 @@ local S = minetest.get_translator("farming")
|
|||||||
|
|
||||||
farming.translate = S
|
farming.translate = S
|
||||||
|
|
||||||
|
-- localise
|
||||||
|
local random = math.random
|
||||||
|
local floor = math.floor
|
||||||
|
|
||||||
-- Utility Function
|
-- Utility Function
|
||||||
local time_speed = tonumber(minetest.settings:get("time_speed")) or 72
|
local time_speed = tonumber(minetest.settings:get("time_speed")) or 72
|
||||||
@ -92,7 +95,7 @@ local function day_or_night_time(dt, count_day)
|
|||||||
local dt_c = clamp(t2_c, 0, 0.5) - clamp(t1_c, 0, 0.5) -- this cycle
|
local dt_c = clamp(t2_c, 0, 0.5) - clamp(t1_c, 0, 0.5) -- this cycle
|
||||||
|
|
||||||
if t1_c < -0.5 then
|
if t1_c < -0.5 then
|
||||||
local nc = math.floor(-t1_c)
|
local nc = floor(-t1_c)
|
||||||
t1_c = t1_c + nc
|
t1_c = t1_c + nc
|
||||||
dt_c = dt_c + 0.5 * nc + clamp(-t1_c - 0.5, 0, 0.5)
|
dt_c = dt_c + 0.5 * nc + clamp(-t1_c - 0.5, 0, 0.5)
|
||||||
end
|
end
|
||||||
@ -111,7 +114,7 @@ local STAGE_LENGTH_DEV = STAGE_LENGTH_AVG / 6
|
|||||||
farming.start_seed_timer = function(pos)
|
farming.start_seed_timer = function(pos)
|
||||||
|
|
||||||
local timer = minetest.get_node_timer(pos)
|
local timer = minetest.get_node_timer(pos)
|
||||||
local grow_time = math.floor(math.random(STAGE_LENGTH_DEV, STAGE_LENGTH_AVG))
|
local grow_time = floor(random(STAGE_LENGTH_DEV, STAGE_LENGTH_AVG))
|
||||||
|
|
||||||
timer:start(grow_time)
|
timer:start(grow_time)
|
||||||
end
|
end
|
||||||
@ -277,7 +280,7 @@ local function set_growing(pos, stages_left)
|
|||||||
|
|
||||||
stage_length = clamp(stage_length, 0.5 * STAGE_LENGTH_AVG, 3.0 * STAGE_LENGTH_AVG)
|
stage_length = clamp(stage_length, 0.5 * STAGE_LENGTH_AVG, 3.0 * STAGE_LENGTH_AVG)
|
||||||
|
|
||||||
timer:set(stage_length, -0.5 * math.random() * STAGE_LENGTH_AVG)
|
timer:set(stage_length, -0.5 * random() * STAGE_LENGTH_AVG)
|
||||||
end
|
end
|
||||||
|
|
||||||
elseif timer:is_started() then
|
elseif timer:is_started() then
|
||||||
@ -319,30 +322,37 @@ minetest.register_abm({
|
|||||||
catch_up = false,
|
catch_up = false,
|
||||||
action = function(pos, node)
|
action = function(pos, node)
|
||||||
|
|
||||||
|
-- skip if node timer already active
|
||||||
|
if minetest.get_node_timer(pos):is_started() then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
-- check if group:growing node is a seed
|
-- check if group:growing node is a seed
|
||||||
local def = minetest.registered_nodes[node.name]
|
local def = minetest.registered_nodes[node.name]
|
||||||
|
|
||||||
if def and def.groups and def.groups.seed then
|
if def and def.groups and def.groups.seed then
|
||||||
|
|
||||||
|
-- start node timer if found
|
||||||
|
if def.on_timer then
|
||||||
|
|
||||||
|
farming.start_seed_timer(pos)
|
||||||
|
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local next_stage = def.next_plant
|
local next_stage = def.next_plant
|
||||||
|
|
||||||
def = minetest.registered_nodes[next_stage]
|
def = minetest.registered_nodes[next_stage]
|
||||||
|
|
||||||
local timer = minetest.get_node_timer(pos):is_started()
|
-- switch seed without timer to stage_1 of crop
|
||||||
|
if def then
|
||||||
-- if seed has timer function that isn't started then start timer
|
|
||||||
if def and def.on_timer and not timer then
|
|
||||||
|
|
||||||
farming.start_seed_timer(pos)
|
|
||||||
|
|
||||||
-- otherwise switch seed to stage_1 of crop
|
|
||||||
elseif def then
|
|
||||||
|
|
||||||
local p2 = def.place_param2 or 1
|
local p2 = def.place_param2 or 1
|
||||||
|
|
||||||
minetest.set_node(pos, {name = next_stage, param2 = p2})
|
minetest.set_node(pos, {name = next_stage, param2 = p2})
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
|
-- start normal crop timer
|
||||||
farming.handle_growth(pos, node)
|
farming.handle_growth(pos, node)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user