forked from mtcontrib/farming
		
	removed debug functions
This commit is contained in:
		
							
								
								
									
										75
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								init.lua
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | |||||||
| --[[ | --[[ | ||||||
| 	Minetest Farming Redo Mod 1.24 (28th April 2017) | 	Farming Redo Mod 1.25 (6th May 2017) | ||||||
| 	by TenPlus1 | 	by TenPlus1 | ||||||
| 	NEW growing routine by prestidigitator | 	NEW growing routine by prestidigitator | ||||||
| 	auto-refill by crabman77 | 	auto-refill by crabman77 | ||||||
| @@ -14,38 +14,6 @@ farming.select = { | |||||||
| 	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} | ||||||
| } | } | ||||||
|  |  | ||||||
| farming.DEBUG = false |  | ||||||
| -- farming.DEBUG = {}  -- Uncomment to turn on profiling code/functions |  | ||||||
|  |  | ||||||
| local DEBUG_abm_runs   = 0 |  | ||||||
| local DEBUG_abm_time   = 0 |  | ||||||
| local DEBUG_timer_runs = 0 |  | ||||||
| local DEBUG_timer_time = 0 |  | ||||||
|  |  | ||||||
| if farming.DEBUG then |  | ||||||
|  |  | ||||||
| 	function farming.DEBUG.reset_times() |  | ||||||
| 		DEBUG_abm_runs = 0 |  | ||||||
| 		DEBUG_abm_time = 0 |  | ||||||
| 		DEBUG_timer_runs = 0 |  | ||||||
| 		DEBUG_timer_time = 0 |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	function farming.DEBUG.report_times() |  | ||||||
|  |  | ||||||
| 		local abm_n     = DEBUG_abm_runs |  | ||||||
| 		local abm_dt    = DEBUG_abm_time |  | ||||||
| 		local abm_avg   = (abm_n > 0 and abm_dt / abm_n) or 0 |  | ||||||
| 		local timer_n   = DEBUG_timer_runs |  | ||||||
| 		local timer_dt  = DEBUG_timer_time |  | ||||||
| 		local timer_avg = (timer_n > 0 and timer_dt / timer_n) or 0 |  | ||||||
| 		local dt = abm_dt + timer_dt |  | ||||||
|  |  | ||||||
| 		print("ABM ran for "..abm_dt.."µs over "..abm_n.." runs: "..abm_avg.."µs/run") |  | ||||||
| 		print("Timer ran for "..timer_dt.."µs over "..timer_n.." runs: "..timer_avg.."µs/run") |  | ||||||
| 		print("Total farming time: "..dt.."µs") |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| local statistics = dofile(farming.path.."/statistics.lua") | local statistics = dofile(farming.path.."/statistics.lua") | ||||||
|  |  | ||||||
| @@ -353,23 +321,6 @@ end) | |||||||
|  |  | ||||||
| local abm_func = farming.handle_growth | local abm_func = farming.handle_growth | ||||||
|  |  | ||||||
| if farming.DEBUG then |  | ||||||
|  |  | ||||||
| 	local normal_abm_func = abm_func |  | ||||||
|  |  | ||||||
| 	abm_func = function(...) |  | ||||||
|  |  | ||||||
| 		local t0 = minetest.get_us_time() |  | ||||||
| 		local r = { normal_abm_func(...) } |  | ||||||
| 		local t1 = minetest.get_us_time() |  | ||||||
|  |  | ||||||
| 		DEBUG_abm_runs = DEBUG_abm_runs + 1 |  | ||||||
| 		DEBUG_abm_time = DEBUG_abm_time + (t1 - t0) |  | ||||||
|  |  | ||||||
| 		return unpack(r) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Just in case a growing type or added node is missed (also catches existing | -- Just in case a growing type or added node is missed (also catches existing | ||||||
| -- nodes added to map before timers were incorporated). | -- nodes added to map before timers were incorporated). | ||||||
|  |  | ||||||
| @@ -399,8 +350,7 @@ function farming.plant_growth_timer(pos, elapsed, node_name) | |||||||
|  |  | ||||||
| 	if stages.plant_name == "farming:cocoa" then | 	if stages.plant_name == "farming:cocoa" then | ||||||
|  |  | ||||||
| 		if not minetest.find_node_near(pos, 1, | 		if not minetest.find_node_near(pos, 1, {"default:jungletree"}) then | ||||||
| 			{"default:jungletree", "moretrees:jungletree_leaves_green"}) then |  | ||||||
|  |  | ||||||
| 			return true | 			return true | ||||||
| 		end | 		end | ||||||
| @@ -465,23 +415,6 @@ function farming.plant_growth_timer(pos, elapsed, node_name) | |||||||
| 	return growth ~= max_growth | 	return growth ~= max_growth | ||||||
| end | end | ||||||
|  |  | ||||||
| if farming.DEBUG then |  | ||||||
|  |  | ||||||
| 	local timer_func = farming.plant_growth_timer; |  | ||||||
|  |  | ||||||
| 	farming.plant_growth_timer = function(pos, elapsed, node_name) |  | ||||||
|  |  | ||||||
| 		local t0 = minetest.get_us_time() |  | ||||||
| 		local r = { timer_func(pos, elapsed, node_name) } |  | ||||||
| 		local t1 = minetest.get_us_time() |  | ||||||
|  |  | ||||||
| 		DEBUG_timer_runs = DEBUG_timer_runs + 1 |  | ||||||
| 		DEBUG_timer_time = DEBUG_timer_time + (t1 - t0) |  | ||||||
|  |  | ||||||
| 		return unpack(r) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- refill placed plant by crabman (26/08/2015) | -- refill placed plant by crabman (26/08/2015) | ||||||
| local can_refill_plant = { | local can_refill_plant = { | ||||||
| 	["farming:blueberry_1"] = "farming:blueberries", | 	["farming:blueberry_1"] = "farming:blueberries", | ||||||
| @@ -596,7 +529,7 @@ function farming.place_seed(itemstack, placer, pointed_thing, plantname) | |||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| -- Function to register plants (for compatibility) | -- Function to register plants (default farming compatibility) | ||||||
|  |  | ||||||
| farming.register_plant = function(name, def) | farming.register_plant = function(name, def) | ||||||
|  |  | ||||||
| @@ -681,7 +614,7 @@ farming.register_plant = function(name, def) | |||||||
| 			sounds = default.node_sound_leaves_defaults(), | 			sounds = default.node_sound_leaves_defaults(), | ||||||
| 		}) | 		}) | ||||||
|  |  | ||||||
| --		register_plant_node(node_name) | 		register_plant_node(node_name) | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	-- Return info | 	-- Return info | ||||||
|   | |||||||
							
								
								
									
										192
									
								
								init.lua_orig
									
									
									
									
									
								
							
							
						
						
									
										192
									
								
								init.lua_orig
									
									
									
									
									
								
							| @@ -1,192 +0,0 @@ | |||||||
| --[[ |  | ||||||
| 	Minetest Farming Redo Mod 1.14 (11th May 2015) |  | ||||||
| 	by TenPlus1 |  | ||||||
| ]] |  | ||||||
|  |  | ||||||
| farming = {} |  | ||||||
| farming.mod = "redo" |  | ||||||
| farming.path = minetest.get_modpath("farming") |  | ||||||
| farming.hoe_on_use = default.hoe_on_use |  | ||||||
|  |  | ||||||
| dofile(farming.path.."/soil.lua") |  | ||||||
| dofile(farming.path.."/hoes.lua") |  | ||||||
| dofile(farming.path.."/grass.lua") |  | ||||||
| dofile(farming.path.."/wheat.lua") |  | ||||||
| dofile(farming.path.."/cotton.lua") |  | ||||||
| dofile(farming.path.."/carrot.lua") |  | ||||||
| dofile(farming.path.."/potato.lua") |  | ||||||
| dofile(farming.path.."/tomato.lua") |  | ||||||
| dofile(farming.path.."/cucumber.lua") |  | ||||||
| dofile(farming.path.."/corn.lua") |  | ||||||
| dofile(farming.path.."/coffee.lua") |  | ||||||
| dofile(farming.path.."/melon.lua") |  | ||||||
| dofile(farming.path.."/sugar.lua") |  | ||||||
| dofile(farming.path.."/pumpkin.lua") |  | ||||||
| dofile(farming.path.."/cocoa.lua") |  | ||||||
| dofile(farming.path.."/raspberry.lua") |  | ||||||
| dofile(farming.path.."/blueberry.lua") |  | ||||||
| dofile(farming.path.."/rhubarb.lua") |  | ||||||
| dofile(farming.path.."/beanpole.lua") |  | ||||||
| dofile(farming.path.."/donut.lua") |  | ||||||
| dofile(farming.path.."/mapgen.lua") |  | ||||||
| dofile(farming.path.."/compatibility.lua") -- Farming Plus compatibility |  | ||||||
|  |  | ||||||
| -- Place Seeds on Soil |  | ||||||
|  |  | ||||||
| function farming.place_seed(itemstack, placer, pointed_thing, plantname) |  | ||||||
| 	local pt = pointed_thing |  | ||||||
|  |  | ||||||
| 	-- check if pointing at a node |  | ||||||
| 	if not pt and pt.type ~= "node" then |  | ||||||
| 		return |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	local under = minetest.get_node(pt.under) |  | ||||||
| 	local above = minetest.get_node(pt.above) |  | ||||||
|  |  | ||||||
| 	-- check if pointing at the top of the node |  | ||||||
| 	if pt.above.y ~= pt.under.y+1 then |  | ||||||
| 		return |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- return if any of the nodes is not registered |  | ||||||
| 	if not minetest.registered_nodes[under.name] |  | ||||||
| 	or not minetest.registered_nodes[above.name] then |  | ||||||
| 		return |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- can I replace above node, and am I pointing at soil |  | ||||||
| 	if not minetest.registered_nodes[above.name].buildable_to |  | ||||||
| 	or minetest.get_item_group(under.name, "soil") < 2  |  | ||||||
| 	or minetest.get_item_group(above.name, "plant") ~= 0 then -- ADDED this line for multiple seed placement bug |  | ||||||
| 		return |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- add the node and remove 1 item from the itemstack |  | ||||||
| 	if not minetest.is_protected(pt.above, placer:get_player_name()) then |  | ||||||
| 		minetest.add_node(pt.above, {name=plantname}) |  | ||||||
| 		if not minetest.setting_getbool("creative_mode") then |  | ||||||
| 			itemstack:take_item() |  | ||||||
| 		end |  | ||||||
| 		return itemstack |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Single ABM Handles Growing of All Plants |  | ||||||
|  |  | ||||||
| minetest.register_abm({ |  | ||||||
| 	nodenames = {"group:growing"}, |  | ||||||
| 	neighbors = {"farming:soil_wet", "default:jungletree"}, |  | ||||||
| 	interval = 80, |  | ||||||
| 	chance = 2, |  | ||||||
|  |  | ||||||
| 	action = function(pos, node) |  | ||||||
|  |  | ||||||
| 		-- split plant name (e.g. farming:wheat_1) |  | ||||||
| 		local plant = node.name:split("_")[1].."_" |  | ||||||
| 		local numb = node.name:split("_")[2] |  | ||||||
|  |  | ||||||
| 		-- fully grown ? |  | ||||||
| 		if not minetest.registered_nodes[plant..(numb + 1)] then return end |  | ||||||
| 		 |  | ||||||
| 		-- cocoa pod on jungle tree ? |  | ||||||
| 		if plant ~= "farming:cocoa_" then |  | ||||||
|  |  | ||||||
| 			-- growing on wet soil ? |  | ||||||
| 			if minetest.get_node({x=pos.x,y=pos.y-1,z=pos.z}).name ~= "farming:soil_wet" then return end |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		-- enough light ? |  | ||||||
| 		if minetest.get_node_light(pos) < 13 then return end |  | ||||||
|  |  | ||||||
| 		-- grow |  | ||||||
| 		minetest.set_node(pos, {name=plant..(numb + 1)}) |  | ||||||
|  |  | ||||||
| 	end |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| -- Function to register plants (for compatibility) |  | ||||||
|  |  | ||||||
| farming.register_plant = function(name, def) |  | ||||||
| 	local mname = name:split(":")[1] |  | ||||||
| 	local pname = name:split(":")[2] |  | ||||||
|  |  | ||||||
| 	-- Check def table |  | ||||||
| 	if not def.description then |  | ||||||
| 		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 |  | ||||||
|  |  | ||||||
| 	-- Register seed |  | ||||||
| 	minetest.register_node(":" .. mname .. ":seed_" .. pname, { |  | ||||||
| 		description = def.description, |  | ||||||
| 		tiles = {def.inventory_image}, |  | ||||||
| 		inventory_image = def.inventory_image, |  | ||||||
| 		wield_image = def.inventory_image, |  | ||||||
| 		drawtype = "signlike", |  | ||||||
| 		groups = {seed = 1, snappy = 3, attached_node = 1}, |  | ||||||
| 		paramtype = "light", |  | ||||||
| 		paramtype2 = "wallmounted", |  | ||||||
| 		walkable = false, |  | ||||||
| 		sunlight_propagates = true, |  | ||||||
| 		selection_box = {type = "fixed", fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5},}, |  | ||||||
| 		on_place = function(itemstack, placer, pointed_thing) |  | ||||||
| 			return farming.place_seed(itemstack, placer, pointed_thing, mname .. ":"..pname.."_1") |  | ||||||
| 		end |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	-- Register harvest |  | ||||||
| 	minetest.register_craftitem(":" .. mname .. ":" .. pname, { |  | ||||||
| 		description = pname:gsub("^%l", string.upper), |  | ||||||
| 		inventory_image = mname .. "_" .. pname .. ".png", |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	-- Register growing steps |  | ||||||
| 	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 g = {snappy = 3, flammable = 2, plant = 1, not_in_creative_inventory = 1, attached_node = 1, growing = 1} |  | ||||||
| 		-- Last step doesn't need growing=1 so Abm never has to check these |  | ||||||
| 		if i == def.steps then |  | ||||||
| 			g = {snappy = 3, flammable = 2, plant = 1, not_in_creative_inventory = 1, attached_node = 1} |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		minetest.register_node(mname .. ":" .. pname .. "_" .. i, { |  | ||||||
| 			drawtype = "plantlike", |  | ||||||
| 			waving = 1, |  | ||||||
| 			tiles = {mname .. "_" .. pname .. "_" .. i .. ".png"}, |  | ||||||
| 			paramtype = "light", |  | ||||||
| 			walkable = false, |  | ||||||
| 			buildable_to = true, |  | ||||||
| 			is_ground_content = true, |  | ||||||
| 			drop = drop, |  | ||||||
| 			selection_box = {type = "fixed", fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5},}, |  | ||||||
| 			groups = g, |  | ||||||
| 			sounds = default.node_sound_leaves_defaults(), |  | ||||||
| 		}) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- Return info |  | ||||||
| 	local r = {seed = mname .. ":seed_" .. pname, harvest = mname .. ":" .. pname} |  | ||||||
| 	return r |  | ||||||
| end |  | ||||||
|  |  | ||||||
| --[[ Cotton (example, is already registered in cotton.lua) |  | ||||||
| farming.register_plant("farming:cotton", { |  | ||||||
| 	description = "Cotton seed", |  | ||||||
| 	inventory_image = "farming_cotton_seed.png", |  | ||||||
| 	steps = 8, |  | ||||||
| }) |  | ||||||
| --]] |  | ||||||
		Reference in New Issue
	
	Block a user