mirror of
				https://github.com/mt-mods/plantlife_modpack.git
				synced 2025-10-31 13:55:25 +01:00 
			
		
		
		
	Compare commits
	
		
			22 Commits
		
	
	
		
			master
			...
			d97f25e112
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d97f25e112 | |||
| 86896848d5 | |||
| 5b66d54632 | |||
| 031260a62d | |||
| d4e83d7e78 | |||
| 8d65559828 | |||
| ec8132b06c | |||
| 4dcf14ce1f | |||
| d7b543f5d7 | |||
| f661500cb3 | |||
| c2681261e0 | |||
| 2c433e0b57 | |||
| 1f52bbea19 | |||
| 10ff005066 | |||
| 80b548535a | |||
| 45a8064d3d | |||
| 1696d8bd8f | |||
| 091ce416d0 | |||
| 5dfa02c037 | |||
| 8b42a45d78 | |||
|  | b6ed0316b7 | ||
|  | 114eaff7f1 | 
| @@ -6,6 +6,8 @@ | |||||||
| -- (Leaf texture created by RealBadAngel or VanessaE) | -- (Leaf texture created by RealBadAngel or VanessaE) | ||||||
| -- Branch textures created by Neuromancer. | -- Branch textures created by Neuromancer. | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| -- support for i18n | -- support for i18n | ||||||
| local S = minetest.get_translator("bushes") | local S = minetest.get_translator("bushes") | ||||||
|   abstract_bushes = {} |   abstract_bushes = {} | ||||||
| @@ -129,33 +131,22 @@ for i in pairs(BushLeafNode) do | |||||||
| end | end | ||||||
|  |  | ||||||
| abstract_bushes.grow_bush = function(pos) | abstract_bushes.grow_bush = function(pos) | ||||||
| 	local leaf_type = math.random(1,2) | 	local leaf_type = random(1,2) | ||||||
| 	local bush_side_height = math.random(0,1) | 	for _, pos_dir in ipairs({ | ||||||
| 		local chance_of_bush_node_right = math.random(1,10) | 		{ pos = {x=pos.x+1, y=pos.y+random(0,1), z=pos.z}, | ||||||
| 		if chance_of_bush_node_right> 5 then | 		  dir = 3}, | ||||||
| 			local right_pos = {x=pos.x+1, y=pos.y+bush_side_height, z=pos.z} | 		{ pos = {x=pos.x-1, y=pos.y+random(0,1), z=pos.z}, | ||||||
| 			abstract_bushes.grow_bush_node(right_pos,3,leaf_type) | 		  dir = 1}, | ||||||
|  | 		{ pos = {x=pos.x, y=pos.y+random(0,1), z=pos.z+1}, | ||||||
|  | 		  dir = 2}, | ||||||
|  | 		{ pos = {x=pos.x, y=pos.y+random(0,1), z=pos.z-1}, | ||||||
|  | 		  dir = 0} | ||||||
|  | 	}) do | ||||||
|  | 		if random(1,10) > 5 then | ||||||
|  | 			abstract_bushes.grow_bush_node(pos_dir.pos, pos_dir.dir, leaf_type) | ||||||
| 		end | 		end | ||||||
| 		local chance_of_bush_node_left = math.random(1,10) | 	end | ||||||
| 		if chance_of_bush_node_left> 5 then | 	abstract_bushes.grow_bush_node(pos,5,leaf_type) | ||||||
| 			bush_side_height = math.random(0,1) |  | ||||||
| 			local left_pos = {x=pos.x-1, y=pos.y+bush_side_height, z=pos.z} |  | ||||||
| 			abstract_bushes.grow_bush_node(left_pos,1,leaf_type) |  | ||||||
| 		end |  | ||||||
| 		local chance_of_bush_node_front = math.random(1,10) |  | ||||||
| 		if chance_of_bush_node_front> 5 then |  | ||||||
| 			bush_side_height = math.random(0,1) |  | ||||||
| 			local front_pos = {x=pos.x, y=pos.y+bush_side_height, z=pos.z+1} |  | ||||||
| 			abstract_bushes.grow_bush_node(front_pos,2,leaf_type) |  | ||||||
| 		end |  | ||||||
| 		local chance_of_bush_node_back = math.random(1,10) |  | ||||||
| 		if chance_of_bush_node_back> 5 then |  | ||||||
| 			bush_side_height = math.random(0,1) |  | ||||||
| 			local back_pos = {x=pos.x, y=pos.y+bush_side_height, z=pos.z-1} |  | ||||||
| 			abstract_bushes.grow_bush_node(back_pos,0,leaf_type) |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| abstract_bushes.grow_bush_node(pos,5,leaf_type) |  | ||||||
| end | end | ||||||
|  |  | ||||||
| abstract_bushes.grow_bush_node = function(pos,dir, leaf_type) | abstract_bushes.grow_bush_node = function(pos,dir, leaf_type) | ||||||
| @@ -187,11 +178,9 @@ abstract_bushes.grow_bush_node = function(pos,dir, leaf_type) | |||||||
| 		minetest.swap_node(right_here, {name="bushes:bushbranches"..bush_branch_type , param2=dir}) | 		minetest.swap_node(right_here, {name="bushes:bushbranches"..bush_branch_type , param2=dir}) | ||||||
| 						--minetest.chat_send_all("leaf_type: (" .. leaf_type .. ")") | 						--minetest.chat_send_all("leaf_type: (" .. leaf_type .. ")") | ||||||
| 		minetest.swap_node(above_right_here, {name="bushes:BushLeaves"..leaf_type}) | 		minetest.swap_node(above_right_here, {name="bushes:BushLeaves"..leaf_type}) | ||||||
| 		local chance_of_high_leaves = math.random(1,10) | 		if random(1,10) > 5 then | ||||||
| 		if chance_of_high_leaves> 5 then |  | ||||||
| 			local two_above_right_here = {x=pos.x, y=pos.y+3, z=pos.z} |  | ||||||
| 							--minetest.chat_send_all("leaf_type: (" .. leaf_type .. ")") | 							--minetest.chat_send_all("leaf_type: (" .. leaf_type .. ")") | ||||||
| 			minetest.swap_node(two_above_right_here, {name="bushes:BushLeaves"..leaf_type}) | 			minetest.swap_node({x=pos.x, y=pos.y+3, z=pos.z}, {name="bushes:BushLeaves"..leaf_type}) | ||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
| @@ -213,8 +202,7 @@ biome_lib:register_generate_plant({ | |||||||
| ) | ) | ||||||
|  |  | ||||||
|  abstract_bushes.grow_youngtree2 = function(pos) |  abstract_bushes.grow_youngtree2 = function(pos) | ||||||
| 	local height = math.random(4,5) | 	abstract_bushes.grow_youngtree_node2(pos, random(4,5)) | ||||||
| 	abstract_bushes.grow_youngtree_node2(pos,height) |  | ||||||
| end | end | ||||||
|  |  | ||||||
| abstract_bushes.grow_youngtree_node2 = function(pos, height) | abstract_bushes.grow_youngtree_node2 = function(pos, height) | ||||||
| @@ -225,19 +213,17 @@ abstract_bushes.grow_youngtree_node2 = function(pos, height) | |||||||
| 	local two_above_right_here = {x=pos.x, y=pos.y+3, z=pos.z} | 	local two_above_right_here = {x=pos.x, y=pos.y+3, z=pos.z} | ||||||
| 	local three_above_right_here = {x=pos.x, y=pos.y+4, z=pos.z} | 	local three_above_right_here = {x=pos.x, y=pos.y+4, z=pos.z} | ||||||
|  |  | ||||||
| 	if minetest.get_node(right_here).name == "air"  -- instead of check_air = true, | 	if height == 4 and | ||||||
| 	or minetest.get_node(right_here).name == "default:junglegrass" then | 		(minetest.get_node(right_here).name == "air"  -- instead of check_air = true, | ||||||
| 		if height == 4 then | 		 or minetest.get_node(right_here).name == "default:junglegrass") then | ||||||
| 				local two_above_right_here_south = {x=pos.x, y=pos.y+3, z=pos.z-1} | 			local two_above_right_here_south = {x=pos.x, y=pos.y+3, z=pos.z-1} | ||||||
| 				local three_above_right_here_south = {x=pos.x, y=pos.y+4, z=pos.z-1} | 			local three_above_right_here_south = {x=pos.x, y=pos.y+4, z=pos.z-1} | ||||||
| 				minetest.swap_node(right_here, {name="bushes:youngtree2_bottom"}) | 			minetest.swap_node(right_here, {name="bushes:youngtree2_bottom"}) | ||||||
| 				minetest.swap_node(above_right_here, {name="bushes:youngtree2_bottom"}) | 			minetest.swap_node(above_right_here, {name="bushes:youngtree2_bottom"}) | ||||||
| 				minetest.swap_node(two_above_right_here, {name="bushes:bushbranches2"  , param2=2}) | 			minetest.swap_node(two_above_right_here, {name="bushes:bushbranches2"  , param2=2}) | ||||||
| 				minetest.swap_node(two_above_right_here_south, {name="bushes:bushbranches2"  , param2=0}) | 			minetest.swap_node(two_above_right_here_south, {name="bushes:bushbranches2"  , param2=0}) | ||||||
| 				minetest.swap_node(three_above_right_here, {name="bushes:BushLeaves1" }) | 			minetest.swap_node(three_above_right_here, {name="bushes:BushLeaves1" }) | ||||||
| 				minetest.swap_node(three_above_right_here_south, {name="bushes:BushLeaves1" }) | 			minetest.swap_node(three_above_right_here_south, {name="bushes:BushLeaves1" }) | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| @@ -258,3 +244,5 @@ biome_lib:register_generate_plant({ | |||||||
| ) | ) | ||||||
|  |  | ||||||
| 		--http://dev.minetest.net/Node_Drawtypes | 		--http://dev.minetest.net/Node_Drawtypes | ||||||
|  |  | ||||||
|  | minetest.log("action", "[bushes] loaded.") | ||||||
|   | |||||||
| @@ -4,6 +4,8 @@ local S = minetest.get_translator("bushes_classic") | |||||||
| plantlife_bushes = {} | plantlife_bushes = {} | ||||||
|  |  | ||||||
| -- TODO: add support for nodebreakers? those dig like mese picks | -- TODO: add support for nodebreakers? those dig like mese picks | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| plantlife_bushes.after_dig_node = function(pos, oldnode, oldmetadata, digger) | plantlife_bushes.after_dig_node = function(pos, oldnode, oldmetadata, digger) | ||||||
| 	if not (digger and pos and oldnode) then | 	if not (digger and pos and oldnode) then | ||||||
| 		return | 		return | ||||||
| @@ -63,7 +65,7 @@ plantlife_bushes.after_dig_node = function(pos, oldnode, oldmetadata, digger) | |||||||
|  |  | ||||||
| 		-- with a chance of 1/3, return 2 bushes | 		-- with a chance of 1/3, return 2 bushes | ||||||
| 		local amount | 		local amount | ||||||
| 		if math.random(1,3) == 1 then | 		if random(1,3) == 1 then | ||||||
| 			amount = "2" | 			amount = "2" | ||||||
| 		else | 		else | ||||||
| 			amount = "1" | 			amount = "1" | ||||||
| @@ -75,7 +77,7 @@ plantlife_bushes.after_dig_node = function(pos, oldnode, oldmetadata, digger) | |||||||
| 	elseif groupcaps.choppy then | 	elseif groupcaps.choppy then | ||||||
|  |  | ||||||
| 		-- the amount of sticks may vary | 		-- the amount of sticks may vary | ||||||
| 		local amount = math.random(4, 20) | 		local amount = random(4, 20) | ||||||
| 		-- return some sticks | 		-- return some sticks | ||||||
| 		harvested = "default:stick " .. amount | 		harvested = "default:stick " .. amount | ||||||
|  |  | ||||||
| @@ -136,7 +138,7 @@ minetest.register_abm({ | |||||||
| 			local dirt = minetest.get_node(dirtpos) | 			local dirt = minetest.get_node(dirtpos) | ||||||
| 			local is_soil = minetest.get_item_group(dirt.name, "soil") or minetest.get_item_group(dirt.name, "potting_soil") | 			local is_soil = minetest.get_item_group(dirt.name, "soil") or minetest.get_item_group(dirt.name, "potting_soil") | ||||||
|  |  | ||||||
| 			if is_soil and (dirt.name == "farming:soil_wet" or math.random(1,3) == 1) then | 			if is_soil and (dirt.name == "farming:soil_wet" or random(1,3) == 1) then | ||||||
| 				minetest.swap_node( pos, {name = "bushes:" .. bush_name .. "_bush"}) | 				minetest.swap_node( pos, {name = "bushes:" .. bush_name .. "_bush"}) | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
|   | |||||||
| @@ -1,5 +1,8 @@ | |||||||
| --Map Generation Stuff | --Map Generation Stuff | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  | local floor = math.floor | ||||||
|  |  | ||||||
| minetest.register_on_generated(function(minp, maxp, seed) | minetest.register_on_generated(function(minp, maxp, seed) | ||||||
| 	if maxp.y >= 2 and minp.y <= 0 then | 	if maxp.y >= 2 and minp.y <= 0 then | ||||||
| 		-- Generate pebbles | 		-- Generate pebbles | ||||||
| @@ -9,12 +12,12 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 		local divs = (maxp.x-minp.x)/divlen+1; | 		local divs = (maxp.x-minp.x)/divlen+1; | ||||||
| 		for divx=0,divs-1 do | 		for divx=0,divs-1 do | ||||||
| 		for divz=0,divs-1 do | 		for divz=0,divs-1 do | ||||||
| 			local x0 = minp.x + math.floor((divx+0)*divlen) | 			local x0 = minp.x + floor((divx+0)*divlen) | ||||||
| 			local z0 = minp.z + math.floor((divz+0)*divlen) | 			local z0 = minp.z + floor((divz+0)*divlen) | ||||||
| 			local x1 = minp.x + math.floor((divx+1)*divlen) | 			local x1 = minp.x + floor((divx+1)*divlen) | ||||||
| 			local z1 = minp.z + math.floor((divz+1)*divlen) | 			local z1 = minp.z + floor((divz+1)*divlen) | ||||||
| 			-- Determine pebble amount from perlin noise | 			-- Determine pebble amount from perlin noise | ||||||
| 			local pebble_amount = math.floor(perlin1:get2d({x=x0, y=z0}) ^ 2 * 2) | 			local pebble_amount = floor(perlin1:get2d({x=x0, y=z0}) ^ 2 * 2) | ||||||
| 			-- Find random positions for pebbles based on this random | 			-- Find random positions for pebbles based on this random | ||||||
| 			local pr = PseudoRandom(seed+1) | 			local pr = PseudoRandom(seed+1) | ||||||
| 			for i=0,pebble_amount do | 			for i=0,pebble_amount do | ||||||
| @@ -38,9 +41,9 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 						nn = minetest.get_node({x=x,y=ground_y,z=z}).name | 						nn = minetest.get_node({x=x,y=ground_y,z=z}).name | ||||||
| 						-- If desert sand, add dry shrub | 						-- If desert sand, add dry shrub | ||||||
| 						if nn == "default:dirt_with_grass" then | 						if nn == "default:dirt_with_grass" then | ||||||
| 							minetest.swap_node(p,{name="cavestuff:pebble_"..pr:next(1,2), param2=math.random(0,3)}) | 							minetest.swap_node(p,{name="cavestuff:pebble_"..pr:next(1,2), param2=random(0,3)}) | ||||||
| 						elseif nn == "default:desert_sand" then | 						elseif nn == "default:desert_sand" then | ||||||
| 							minetest.swap_node(p,{name="cavestuff:desert_pebble_"..pr:next(1,2), param2=math.random(0,3)}) | 							minetest.swap_node(p,{name="cavestuff:desert_pebble_"..pr:next(1,2), param2=random(0,3)}) | ||||||
| 					    end | 					    end | ||||||
| 					end | 					end | ||||||
| 				end | 				end | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
| -- support for i18n | -- support for i18n | ||||||
| local S = minetest.get_translator("cavestuff") | local S = minetest.get_translator("cavestuff") | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| --Rocks | --Rocks | ||||||
|  |  | ||||||
| local cbox = { | local cbox = { | ||||||
| @@ -20,7 +22,7 @@ minetest.register_node("cavestuff:pebble_1",{ | |||||||
|     collision_box = cbox, |     collision_box = cbox, | ||||||
|     on_place = function(itemstack, placer, pointed_thing) |     on_place = function(itemstack, placer, pointed_thing) | ||||||
| 		-- place a random pebble node | 		-- place a random pebble node | ||||||
| 		local stack = ItemStack("cavestuff:pebble_"..math.random(1,2)) | 		local stack = ItemStack("cavestuff:pebble_"..random(1,2)) | ||||||
| 		local ret = minetest.item_place(stack, placer, pointed_thing) | 		local ret = minetest.item_place(stack, placer, pointed_thing) | ||||||
| 		return ItemStack("cavestuff:pebble_1 "..itemstack:get_count()-(1-ret:get_count())) | 		return ItemStack("cavestuff:pebble_1 "..itemstack:get_count()-(1-ret:get_count())) | ||||||
| 	end, | 	end, | ||||||
| @@ -53,7 +55,7 @@ minetest.register_node("cavestuff:desert_pebble_1",{ | |||||||
| 	collision_box = cbox, | 	collision_box = cbox, | ||||||
|     on_place = function(itemstack, placer, pointed_thing) |     on_place = function(itemstack, placer, pointed_thing) | ||||||
| 		-- place a random pebble node | 		-- place a random pebble node | ||||||
| 		local stack = ItemStack("cavestuff:desert_pebble_"..math.random(1,2)) | 		local stack = ItemStack("cavestuff:desert_pebble_"..random(1,2)) | ||||||
| 		local ret = minetest.item_place(stack, placer, pointed_thing) | 		local ret = minetest.item_place(stack, placer, pointed_thing) | ||||||
| 		return ItemStack("cavestuff:desert_pebble_1 "..itemstack:get_count()-(1-ret:get_count())) | 		return ItemStack("cavestuff:desert_pebble_1 "..itemstack:get_count()-(1-ret:get_count())) | ||||||
| 	end, | 	end, | ||||||
| @@ -97,7 +99,7 @@ minetest.register_node("cavestuff:stalactite_1",{ | |||||||
| 		if minetest.get_node(pt.under).name=="default:stone" | 		if minetest.get_node(pt.under).name=="default:stone" | ||||||
| 		and minetest.get_node({x=pt.under.x, y=pt.under.y-1, z=pt.under.z}).name=="air" | 		and minetest.get_node({x=pt.under.x, y=pt.under.y-1, z=pt.under.z}).name=="air" | ||||||
| 		and minetest.get_node({x=pt.under.x, y=pt.under.y-2, z=pt.under.z}).name=="air" then | 		and minetest.get_node({x=pt.under.x, y=pt.under.y-2, z=pt.under.z}).name=="air" then | ||||||
| 			minetest.swap_node({x=pt.under.x, y=pt.under.y-1, z=pt.under.z}, {name="cavestuff:stalactite_"..math.random(1,3)}) | 			minetest.swap_node({x=pt.under.x, y=pt.under.y-1, z=pt.under.z}, {name="cavestuff:stalactite_"..random(1,3)}) | ||||||
| 			if not minetest.setting_getbool("creative_mode") then | 			if not minetest.setting_getbool("creative_mode") then | ||||||
| 				itemstack:take_item() | 				itemstack:take_item() | ||||||
| 			end | 			end | ||||||
|   | |||||||
| @@ -11,8 +11,11 @@ | |||||||
| -- support for i18n | -- support for i18n | ||||||
| local S = minetest.get_translator("dryplants") | local S = minetest.get_translator("dryplants") | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  | local sqrt = math.sqrt | ||||||
|  |  | ||||||
| abstract_dryplants.grow_juncus = function(pos) | abstract_dryplants.grow_juncus = function(pos) | ||||||
| 	local juncus_type = math.random(2,3) | 	local juncus_type = random(2,3) | ||||||
| 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | ||||||
| 	if minetest.get_node(right_here).name == "air"  -- instead of check_air = true, | 	if minetest.get_node(right_here).name == "air"  -- instead of check_air = true, | ||||||
| 	or minetest.get_node(right_here).name == "default:junglegrass" then | 	or minetest.get_node(right_here).name == "default:junglegrass" then | ||||||
| @@ -27,7 +30,7 @@ end | |||||||
| minetest.register_node("dryplants:juncus", { | minetest.register_node("dryplants:juncus", { | ||||||
| 	description = S("Juncus"), | 	description = S("Juncus"), | ||||||
| 	drawtype = "plantlike", | 	drawtype = "plantlike", | ||||||
| 	visual_scale = math.sqrt(8), | 	visual_scale = sqrt(8), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	tiles = {"dryplants_juncus_03.png"}, | 	tiles = {"dryplants_juncus_03.png"}, | ||||||
| 	inventory_image = "dryplants_juncus_inv.png", | 	inventory_image = "dryplants_juncus_inv.png", | ||||||
| @@ -53,7 +56,7 @@ minetest.register_node("dryplants:juncus", { | |||||||
| 			return | 			return | ||||||
| 		end | 		end | ||||||
| 		local pos = pointed_thing.under | 		local pos = pointed_thing.under | ||||||
| 		local juncus_type = math.random(2,3) | 		local juncus_type = random(2,3) | ||||||
| 		local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | 		local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | ||||||
| 		if juncus_type == 2 then | 		if juncus_type == 2 then | ||||||
| 			minetest.swap_node(right_here, {name="dryplants:juncus_02"}) | 			minetest.swap_node(right_here, {name="dryplants:juncus_02"}) | ||||||
| @@ -69,7 +72,7 @@ minetest.register_node("dryplants:juncus", { | |||||||
| minetest.register_node("dryplants:juncus_02", { | minetest.register_node("dryplants:juncus_02", { | ||||||
| 	description = S("Juncus"), | 	description = S("Juncus"), | ||||||
| 	drawtype = "plantlike", | 	drawtype = "plantlike", | ||||||
| 	visual_scale = math.sqrt(8), | 	visual_scale = sqrt(8), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	tiles = {"dryplants_juncus_02.png"}, | 	tiles = {"dryplants_juncus_02.png"}, | ||||||
| 	walkable = false, | 	walkable = false, | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| abstract_dryplants.grow_grass_variation = function(pos) | abstract_dryplants.grow_grass_variation = function(pos) | ||||||
| 	local right_here = {x=pos.x, y=pos.y, z=pos.z} | 	minetest.swap_node(pos, {name="dryplants:grass_short"}) | ||||||
| 	minetest.swap_node(right_here, {name="dryplants:grass_short"}) |  | ||||||
| end | end | ||||||
|  |  | ||||||
| biome_lib:register_generate_plant({ | biome_lib:register_generate_plant({ | ||||||
|   | |||||||
| @@ -7,12 +7,13 @@ | |||||||
| -- Looked at code from:		default | -- Looked at code from:		default | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| abstract_dryplants.grow_grass = function(pos) | abstract_dryplants.grow_grass = function(pos) | ||||||
| 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | ||||||
| 	local grass_size = math.random(1,5) |  | ||||||
| 	if minetest.get_node(right_here).name == "air"  -- instead of check_air = true, | 	if minetest.get_node(right_here).name == "air"  -- instead of check_air = true, | ||||||
| 	or minetest.get_node(right_here).name == "default:junglegrass" then | 	or minetest.get_node(right_here).name == "default:junglegrass" then | ||||||
| 		minetest.swap_node(right_here, {name="default:grass_"..grass_size}) | 		minetest.swap_node(right_here, {name="default:grass_"..random(1,5)}) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,13 +20,16 @@ | |||||||
| -- support for i18n | -- support for i18n | ||||||
| local S = minetest.get_translator("dryplants") | local S = minetest.get_translator("dryplants") | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  | local sqrt = math.sqrt | ||||||
|  |  | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
| -- REEDMACE SHAPES | -- REEDMACE SHAPES | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| abstract_dryplants.grow_reedmace = function(pos) | abstract_dryplants.grow_reedmace = function(pos) | ||||||
| 	local size = math.random(1,3) | 	local size = random(1,3) | ||||||
| 	local spikes = math.random(1,3) | 	local spikes = random(1,3) | ||||||
| 	local pos_01 = {x = pos.x, y = pos.y + 1, z = pos.z} | 	local pos_01 = {x = pos.x, y = pos.y + 1, z = pos.z} | ||||||
| 	local pos_02 = {x = pos.x, y = pos.y + 2, z = pos.z} | 	local pos_02 = {x = pos.x, y = pos.y + 2, z = pos.z} | ||||||
| 	local pos_03 = {x = pos.x, y = pos.y + 3, z = pos.z} | 	local pos_03 = {x = pos.x, y = pos.y + 3, z = pos.z} | ||||||
| @@ -51,8 +54,8 @@ abstract_dryplants.grow_reedmace = function(pos) | |||||||
| end | end | ||||||
|  |  | ||||||
| abstract_dryplants.grow_reedmace_water = function(pos) | abstract_dryplants.grow_reedmace_water = function(pos) | ||||||
| 	local size = math.random(1,3) | 	local size = random(1,3) | ||||||
| 	local spikes = math.random(1,3) | 	local spikes = random(1,3) | ||||||
| 	local pos_01 = {x = pos.x, y = pos.y + 1, z = pos.z} | 	local pos_01 = {x = pos.x, y = pos.y + 1, z = pos.z} | ||||||
| 	local pos_02 = {x = pos.x, y = pos.y + 2, z = pos.z} | 	local pos_02 = {x = pos.x, y = pos.y + 2, z = pos.z} | ||||||
| 	local pos_03 = {x = pos.x, y = pos.y + 3, z = pos.z} | 	local pos_03 = {x = pos.x, y = pos.y + 3, z = pos.z} | ||||||
| @@ -127,7 +130,7 @@ minetest.register_node("dryplants:reedmace_top", { | |||||||
| minetest.register_node("dryplants:reedmace_height_2", { | minetest.register_node("dryplants:reedmace_height_2", { | ||||||
| 	description = S("Reedmace, height: 2"), | 	description = S("Reedmace, height: 2"), | ||||||
| 	drawtype = "plantlike", | 	drawtype = "plantlike", | ||||||
| 	visual_scale = math.sqrt(8), | 	visual_scale = sqrt(8), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	tiles = {"dryplants_reedmace_height_2.png"}, | 	tiles = {"dryplants_reedmace_height_2.png"}, | ||||||
| 	inventory_image = "dryplants_reedmace_top.png", | 	inventory_image = "dryplants_reedmace_top.png", | ||||||
| @@ -150,7 +153,7 @@ minetest.register_node("dryplants:reedmace_height_2", { | |||||||
| minetest.register_node("dryplants:reedmace_height_3", { | minetest.register_node("dryplants:reedmace_height_3", { | ||||||
| 	description = S("Reedmace, height: 3"), | 	description = S("Reedmace, height: 3"), | ||||||
| 	drawtype = "plantlike", | 	drawtype = "plantlike", | ||||||
| 	visual_scale = math.sqrt(8), | 	visual_scale = sqrt(8), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	tiles = {"dryplants_reedmace_height_3.png"}, | 	tiles = {"dryplants_reedmace_height_3.png"}, | ||||||
| 	inventory_image = "dryplants_reedmace_top.png", | 	inventory_image = "dryplants_reedmace_top.png", | ||||||
| @@ -173,7 +176,7 @@ minetest.register_node("dryplants:reedmace_height_3", { | |||||||
| minetest.register_node("dryplants:reedmace_height_3_spikes", { | minetest.register_node("dryplants:reedmace_height_3_spikes", { | ||||||
| 	description = S("Reedmace, height: 3 & Spikes"), | 	description = S("Reedmace, height: 3 & Spikes"), | ||||||
| 	drawtype = "plantlike", | 	drawtype = "plantlike", | ||||||
| 	visual_scale = math.sqrt(8), | 	visual_scale = sqrt(8), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	tiles = {"dryplants_reedmace_height_3_spikes.png"}, | 	tiles = {"dryplants_reedmace_height_3_spikes.png"}, | ||||||
| 	inventory_image = "dryplants_reedmace_top.png", | 	inventory_image = "dryplants_reedmace_top.png", | ||||||
|   | |||||||
| @@ -48,5 +48,5 @@ HAY_DRYING_TIME 					= 	3600 	-- seconds | |||||||
| REED_WILL_DRY 						= 	false	-- wet reed nodes will become dry reed nodes | REED_WILL_DRY 						= 	false	-- wet reed nodes will become dry reed nodes | ||||||
| REED_DRYING_TIME 					= 	3600 	-- seconds | REED_DRYING_TIME 					= 	3600 	-- seconds | ||||||
|  |  | ||||||
| AUTO_ROOF_CORNER 					= 	true | AUTO_ROOF_CORNER 					= 	false | ||||||
| 	 | 	 | ||||||
|   | |||||||
| @@ -252,13 +252,16 @@ minetest.register_node("ferns:fern_trunk_big", { | |||||||
| 	}, | 	}, | ||||||
| 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1}, | 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| 	after_destruct = function(pos,oldnode) | 	after_dig_node = function(pos, node, metadata, digger) | ||||||
|         local node = minetest.get_node({x=pos.x,y=pos.y+1,z=pos.z}) | 		if digger == nil then return end | ||||||
|         if node.name == "ferns:fern_trunk_big" or node.name == "ferns:fern_trunk_big_top" then | 		local np = {x=pos.x,y=pos.y+1,z=pos.z} | ||||||
|             minetest.dig_node({x=pos.x,y=pos.y+1,z=pos.z}) | 		local nn = minetest.get_node(np) | ||||||
|             minetest.add_item(pos,"ferns:fern_trunk_big") | 		if nn.name == "ferns:fern_trunk_big" or | ||||||
|         end | 			nn.name == "ferns:fern_trunk_big_top" | ||||||
|     end, | 		then | ||||||
|  | 			minetest.node_dig(np, nn, digger) | ||||||
|  | 		end | ||||||
|  | 	end, | ||||||
| }) | }) | ||||||
|  |  | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
|   | |||||||
| @@ -11,6 +11,8 @@ local S = minetest.get_translator("ferns") | |||||||
|  |  | ||||||
| assert(abstract_ferns.config.enable_treefern == true) | assert(abstract_ferns.config.enable_treefern == true) | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| abstract_ferns.grow_tree_fern = function(pos) | abstract_ferns.grow_tree_fern = function(pos) | ||||||
|  |  | ||||||
| 	local pos_aux = {x = pos.x, y = pos.y + 1, z = pos.z} | 	local pos_aux = {x = pos.x, y = pos.y + 1, z = pos.z} | ||||||
| @@ -20,12 +22,12 @@ abstract_ferns.grow_tree_fern = function(pos) | |||||||
| 		return | 		return | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	local size = math.random(1, 4) + math.random(1, 4) | 	local size = random(1, 4) + random(1, 4) | ||||||
| 	if (size > 5) then | 	if (size > 5) then | ||||||
| 		size = 10 - size | 		size = 10 - size | ||||||
| 	end | 	end | ||||||
| 	size = size + 1 | 	size = size + 1 | ||||||
| 	local crown = ({ "ferns:tree_fern_leaves", "ferns:tree_fern_leaves_02" })[math.random(1, 2)] | 	local crown = ({ "ferns:tree_fern_leaves", "ferns:tree_fern_leaves_02" })[random(1, 2)] | ||||||
|  |  | ||||||
| 	local i = 1 | 	local i = 1 | ||||||
| 	local brk = false | 	local brk = false | ||||||
| @@ -138,13 +140,9 @@ minetest.register_node("ferns:fern_trunk", { | |||||||
| 	}, | 	}, | ||||||
| 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1}, | 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| 	after_destruct = function(pos,oldnode) | 	after_dig_node = function(pos, node, metadata, digger) | ||||||
|         local node = minetest.get_node({x=pos.x,y=pos.y+1,z=pos.z}) | 		default.dig_up(pos, node, digger) | ||||||
|         if node.name == "ferns:fern_trunk" then | 	end, | ||||||
|             minetest.dig_node({x=pos.x,y=pos.y+1,z=pos.z}) |  | ||||||
|             minetest.add_item(pos,"ferns:fern_trunk") |  | ||||||
|         end |  | ||||||
|     end, |  | ||||||
| }) | }) | ||||||
|  |  | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
|   | |||||||
| @@ -4,6 +4,8 @@ local S = minetest.get_translator("flowers_plus") | |||||||
| -- This file supplies a few additional plants and some related crafts | -- This file supplies a few additional plants and some related crafts | ||||||
| -- for the plantlife modpack.  Last revision:  2013-04-24 | -- for the plantlife modpack.  Last revision:  2013-04-24 | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| flowers_plus = {} | flowers_plus = {} | ||||||
|  |  | ||||||
| local SPAWN_DELAY = 1000 | local SPAWN_DELAY = 1000 | ||||||
| @@ -97,7 +99,7 @@ for i in ipairs(lilies_list) do | |||||||
|  |  | ||||||
| 				if not keys["sneak"] then | 				if not keys["sneak"] then | ||||||
| 					local node = minetest.get_node(pt.under) | 					local node = minetest.get_node(pt.under) | ||||||
| 					local waterlily = math.random(1,8) | 					local waterlily = random(1,8) | ||||||
| 					if waterlily == 1 then | 					if waterlily == 1 then | ||||||
| 						nodename = "flowers:waterlily" | 						nodename = "flowers:waterlily" | ||||||
| 					elseif waterlily == 2 then | 					elseif waterlily == 2 then | ||||||
| @@ -115,7 +117,7 @@ for i in ipairs(lilies_list) do | |||||||
| 					elseif waterlily == 8 then | 					elseif waterlily == 8 then | ||||||
| 						nodename = "flowers:waterlily_s4" | 						nodename = "flowers:waterlily_s4" | ||||||
| 					end | 					end | ||||||
| 					minetest.swap_node(place_pos, {name = nodename, param2 = math.random(0,3) }) | 					minetest.swap_node(place_pos, {name = nodename, param2 = random(0,3) }) | ||||||
| 				else | 				else | ||||||
| 					local fdir = minetest.dir_to_facedir(placer:get_look_dir()) | 					local fdir = minetest.dir_to_facedir(placer:get_look_dir()) | ||||||
| 					minetest.swap_node(place_pos, {name = "flowers:waterlily", param2 = fdir}) | 					minetest.swap_node(place_pos, {name = "flowers:waterlily", param2 = fdir}) | ||||||
| @@ -197,7 +199,7 @@ for i in ipairs(algae_list) do | |||||||
|  |  | ||||||
| 				if not keys["sneak"] then | 				if not keys["sneak"] then | ||||||
| 					--local node = minetest.get_node(pt.under) | 					--local node = minetest.get_node(pt.under) | ||||||
| 					local seaweed = math.random(1,4) | 					local seaweed = random(1,4) | ||||||
| 					if seaweed == 1 then | 					if seaweed == 1 then | ||||||
| 						nodename = "flowers:seaweed" | 						nodename = "flowers:seaweed" | ||||||
| 					elseif seaweed == 2 then | 					elseif seaweed == 2 then | ||||||
| @@ -207,7 +209,7 @@ for i in ipairs(algae_list) do | |||||||
| 					elseif seaweed == 4 then | 					elseif seaweed == 4 then | ||||||
| 						nodename = "flowers:seaweed_4" | 						nodename = "flowers:seaweed_4" | ||||||
| 					end | 					end | ||||||
| 					minetest.swap_node(place_pos, {name = nodename, param2 = math.random(0,3) }) | 					minetest.swap_node(place_pos, {name = nodename, param2 = random(0,3) }) | ||||||
| 				else | 				else | ||||||
| 					local fdir = minetest.dir_to_facedir(placer:get_look_dir()) | 					local fdir = minetest.dir_to_facedir(placer:get_look_dir()) | ||||||
| 					minetest.swap_node(place_pos, {name = "flowers:seaweed", param2 = fdir}) | 					minetest.swap_node(place_pos, {name = "flowers:seaweed", param2 = fdir}) | ||||||
| @@ -285,7 +287,7 @@ minetest.register_alias( "along_shore:seaweed_4"  ,	"flowers:seaweed_4"    ) | |||||||
| flowers_plus.grow_waterlily = function(pos) | flowers_plus.grow_waterlily = function(pos) | ||||||
| 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | ||||||
| 	for i in ipairs(lilies_list) do | 	for i in ipairs(lilies_list) do | ||||||
| 		local chance = math.random(1,8) | 		local chance = random(1,8) | ||||||
| 		local ext = "" | 		local ext = "" | ||||||
| 		local num = lilies_list[i][3] | 		local num = lilies_list[i][3] | ||||||
|  |  | ||||||
| @@ -294,7 +296,7 @@ flowers_plus.grow_waterlily = function(pos) | |||||||
| 		end | 		end | ||||||
|  |  | ||||||
| 		if chance == num then | 		if chance == num then | ||||||
| 			minetest.swap_node(right_here, {name="flowers:waterlily"..ext, param2=math.random(0,3)}) | 			minetest.swap_node(right_here, {name="flowers:waterlily"..ext, param2=random(0,3)}) | ||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
| @@ -318,7 +320,7 @@ biome_lib:register_generate_plant({ | |||||||
|  |  | ||||||
| flowers_plus.grow_seaweed = function(pos) | flowers_plus.grow_seaweed = function(pos) | ||||||
| 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | 	local right_here = {x=pos.x, y=pos.y+1, z=pos.z} | ||||||
| 	minetest.swap_node(right_here, {name="along_shore:seaweed_"..math.random(1,4), param2=math.random(1,3)}) | 	minetest.swap_node(right_here, {name="along_shore:seaweed_"..random(1,4), param2=random(1,3)}) | ||||||
| end | end | ||||||
|  |  | ||||||
| biome_lib:register_generate_plant({ | biome_lib:register_generate_plant({ | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
| minetest.register_alias("junglegrass:shortest", "air") | minetest.register_alias("junglegrass:shortest", "air") | ||||||
| minetest.register_alias("junglegrass:short", "air") | minetest.register_alias("junglegrass:short", "air") | ||||||
| minetest.register_alias("junglegrass:medium", "air") | minetest.register_alias("junglegrass:medium", "air") | ||||||
|  |  | ||||||
|  | minetest.log("action", "[junglegrass] loaded.") | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ | |||||||
| local S = minetest.get_translator("nature_classic") | local S = minetest.get_translator("nature_classic") | ||||||
| -- Blossoms and such | -- Blossoms and such | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| local function spawn_apple_under(pos) | local function spawn_apple_under(pos) | ||||||
|     local below = { |     local below = { | ||||||
| 		x = pos.x, | 		x = pos.x, | ||||||
| @@ -46,7 +48,7 @@ minetest.register_abm({ | |||||||
|     chance = nature.leaves_blossom_chance, |     chance = nature.leaves_blossom_chance, | ||||||
|  |  | ||||||
|     action = function(pos, node, active_object_count, active_object_count_wider) |     action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
| 			if math.random(nature.leaves_blossom_chance) == 1 then | 			if random(nature.leaves_blossom_chance) == 1 then | ||||||
| 				nature.enqueue_node(pos, node, nature.blossom_node) | 				nature.enqueue_node(pos, node, nature.blossom_node) | ||||||
| 			end | 			end | ||||||
|     end |     end | ||||||
| @@ -61,7 +63,7 @@ minetest.register_abm({ | |||||||
|     chance = nature.blossom_leaves_chance, |     chance = nature.blossom_leaves_chance, | ||||||
|  |  | ||||||
|     action = function(pos, node, active_object_count, active_object_count_wider) |     action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
| 			if math.random(nature.blossom_leaves_chance) == 1 then | 			if random(nature.blossom_leaves_chance) == 1 then | ||||||
| 				nature.enqueue_node(pos, node, nature.blossom_leaves) | 				nature.enqueue_node(pos, node, nature.blossom_leaves) | ||||||
| 			end | 			end | ||||||
|     end |     end | ||||||
| @@ -76,7 +78,7 @@ minetest.register_abm({ | |||||||
|     chance = nature.apple_chance, |     chance = nature.apple_chance, | ||||||
|  |  | ||||||
|     action = function(pos, node, active_object_count, active_object_count_wider) |     action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
| 		if math.random(4) == 1 and nature.dtime < 0.2 and not minetest.find_node_near(pos, nature.apple_spread, { "default:apple" }) then | 		if random(4) == 1 and nature.dtime < 0.2 and not minetest.find_node_near(pos, nature.apple_spread, { "default:apple" }) then | ||||||
| 			spawn_apple_under(pos) | 			spawn_apple_under(pos) | ||||||
| 		end | 		end | ||||||
|     end |     end | ||||||
|   | |||||||
| @@ -47,4 +47,4 @@ dofile(minetest.get_modpath(current_mod_name) .. "/config.lua") | |||||||
| dofile(minetest.get_modpath(current_mod_name) .. "/global_function.lua") | dofile(minetest.get_modpath(current_mod_name) .. "/global_function.lua") | ||||||
| dofile(minetest.get_modpath(current_mod_name) .. "/blossom.lua") | dofile(minetest.get_modpath(current_mod_name) .. "/blossom.lua") | ||||||
|  |  | ||||||
| minetest.log("info", S("[Nature Classic] loaded!")) | minetest.log("action", S("[Nature Classic] loaded!")) | ||||||
|   | |||||||
| @@ -4,8 +4,10 @@ | |||||||
| -- TWiGS | -- TWiGS | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| abstract_trunks.place_twig = function(pos) | abstract_trunks.place_twig = function(pos) | ||||||
| 	local twig_size		= math.random(1,27) | 	local twig_size		= random(1,27) | ||||||
|  |  | ||||||
| 	local right_here	= {x=pos.x  , y=pos.y+1, z=pos.z  } | 	local right_here	= {x=pos.x  , y=pos.y+1, z=pos.z  } | ||||||
| 	local north		= {x=pos.x  , y=pos.y+1, z=pos.z+1} | 	local north		= {x=pos.x  , y=pos.y+1, z=pos.z+1} | ||||||
| @@ -28,7 +30,7 @@ abstract_trunks.place_twig = function(pos) | |||||||
| 	local node_n_w		= minetest.get_node(north_west) | 	local node_n_w		= minetest.get_node(north_west) | ||||||
| --	small twigs | --	small twigs | ||||||
| 	if twig_size <= 16 then | 	if twig_size <= 16 then | ||||||
| 		minetest.swap_node(right_here, {name="trunks:twig_"..math.random(1,4), param2=math.random(0,3)}) | 		minetest.swap_node(right_here, {name="trunks:twig_"..random(1,4), param2=random(0,3)}) | ||||||
| 	end | 	end | ||||||
| --	big twigs | --	big twigs | ||||||
| 	if Big_Twigs == true then | 	if Big_Twigs == true then | ||||||
| @@ -147,7 +149,7 @@ abstract_trunks.place_twig = function(pos) | |||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 	elseif twig_size <= 25 then | 	elseif twig_size <= 25 then | ||||||
| 		minetest.swap_node(right_here, {name="trunks:twig_"..math.random(12,13), param2=math.random(0,3)}) | 		minetest.swap_node(right_here, {name="trunks:twig_"..random(12,13), param2=random(0,3)}) | ||||||
| 	end | 	end | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
| @@ -254,10 +256,10 @@ abstract_trunks.place_trunk = function(pos) | |||||||
| 			local	MoD =			TRuNKS[i][1] | 			local	MoD =			TRuNKS[i][1] | ||||||
| 			local	TRuNK =			TRuNKS[i][2] | 			local	TRuNK =			TRuNKS[i][2] | ||||||
| 			local	NR =			TRuNKS[i][3] | 			local	NR =			TRuNKS[i][3] | ||||||
| 			local	chance =		math.random(1, 17) | 			local	chance =		random(1, 17) | ||||||
| 			local	length =		math.random(3,5) | 			local	length =		random(3,5) | ||||||
| 			if chance == NR then | 			if chance == NR then | ||||||
| 				local trunk_type = math.random(1,3) | 				local trunk_type = random(1,3) | ||||||
| 				if trunk_type == 1 then | 				if trunk_type == 1 then | ||||||
| 					if minetest.get_modpath(MoD) ~= nil then | 					if minetest.get_modpath(MoD) ~= nil then | ||||||
| 						minetest.swap_node(right_here, {name=MoD..":"..TRuNK}) | 						minetest.swap_node(right_here, {name=MoD..":"..TRuNK}) | ||||||
| @@ -355,12 +357,12 @@ biome_lib:register_generate_plant({ | |||||||
| if Moss_on_ground == true then | if Moss_on_ground == true then | ||||||
| abstract_trunks.grow_moss_on_ground = function(pos) | abstract_trunks.grow_moss_on_ground = function(pos) | ||||||
| 	local on_ground = {x=pos.x, y=pos.y+1, z=pos.z} | 	local on_ground = {x=pos.x, y=pos.y+1, z=pos.z} | ||||||
| 	local moss_type = math.random(1,21) | 	local moss_type = random(1,21) | ||||||
|  |  | ||||||
| 	if moss_type == 1 then | 	if moss_type == 1 then | ||||||
| 		minetest.swap_node(on_ground, {name="trunks:moss_fungus", param2=math.random(0,3)}) | 		minetest.swap_node(on_ground, {name="trunks:moss_fungus", param2=random(0,3)}) | ||||||
| 	else | 	else | ||||||
| 		minetest.swap_node(on_ground, {name="trunks:moss", param2=math.random(0,3)}) | 		minetest.swap_node(on_ground, {name="trunks:moss", param2=random(0,3)}) | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| end | end | ||||||
| @@ -406,44 +408,44 @@ abstract_trunks.grow_moss_on_trunk = function(pos) | |||||||
| 	local node_under = minetest.get_node(undrneath) | 	local node_under = minetest.get_node(undrneath) | ||||||
|  |  | ||||||
| 	--if minetest.get_item_group(node_under.name, "tree") < 1 then | 	--if minetest.get_item_group(node_under.name, "tree") < 1 then | ||||||
| 		local moss_type = math.random(1,41) | 		local moss_type = random(1,41) | ||||||
| 		if minetest.registered_nodes[node_here.name].buildable_to then -- instead of check_air = true, | 		if minetest.registered_nodes[node_here.name].buildable_to then -- instead of check_air = true, | ||||||
| 			if moss_type == 1 then | 			if moss_type == 1 then | ||||||
| 				minetest.swap_node(on_ground, {name="trunks:moss_fungus", param2=math.random(0,3) --[[1]]}) | 				minetest.swap_node(on_ground, {name="trunks:moss_fungus", param2=random(0,3) --[[1]]}) | ||||||
| 			elseif moss_type < 22 then | 			elseif moss_type < 22 then | ||||||
| 				minetest.swap_node(on_ground, {name="trunks:moss", param2=math.random(0,3) --[[1]]}) | 				minetest.swap_node(on_ground, {name="trunks:moss", param2=random(0,3) --[[1]]}) | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 		local moss_type = math.random(1,31) -- cliche of more moss at north | 		local moss_type = random(1,31) -- cliche of more moss at north | ||||||
| 		if minetest.registered_nodes[node_north.name].buildable_to then -- instead of check_air = true, | 		if minetest.registered_nodes[node_north.name].buildable_to then -- instead of check_air = true, | ||||||
| 			if moss_type == 1 then | 			if moss_type == 1 then | ||||||
| 				minetest.swap_node(at_side_n, {name="trunks:moss_fungus", param2=math.random(4,7)}) -- 5,4,6,7 | 				minetest.swap_node(at_side_n, {name="trunks:moss_fungus", param2=random(4,7)}) -- 5,4,6,7 | ||||||
| 			elseif moss_type < 22 then | 			elseif moss_type < 22 then | ||||||
| 				minetest.swap_node(at_side_n, {name="trunks:moss", param2=math.random(4,7)}) | 				minetest.swap_node(at_side_n, {name="trunks:moss", param2=random(4,7)}) | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 		local moss_type = math.random(1,41) | 		local moss_type = random(1,41) | ||||||
| 		if minetest.registered_nodes[node_east.name].buildable_to then -- instead of check_air = true, | 		if minetest.registered_nodes[node_east.name].buildable_to then -- instead of check_air = true, | ||||||
| 			if moss_type == 1 then | 			if moss_type == 1 then | ||||||
| 				minetest.swap_node(at_side_e, {name="trunks:moss_fungus", param2=math.random(12,15)}) | 				minetest.swap_node(at_side_e, {name="trunks:moss_fungus", param2=random(12,15)}) | ||||||
| 			elseif moss_type < 22 then | 			elseif moss_type < 22 then | ||||||
| 				minetest.swap_node(at_side_e, {name="trunks:moss", param2=math.random(12,15)}) | 				minetest.swap_node(at_side_e, {name="trunks:moss", param2=random(12,15)}) | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 		local moss_type = math.random(1,41) | 		local moss_type = random(1,41) | ||||||
| 		if minetest.registered_nodes[node_south.name].buildable_to then -- instead of check_air = true, | 		if minetest.registered_nodes[node_south.name].buildable_to then -- instead of check_air = true, | ||||||
| 			if moss_type == 1 then | 			if moss_type == 1 then | ||||||
| 				minetest.swap_node(at_side_s, {name="trunks:moss_fungus", param2=math.random(8,11)}) | 				minetest.swap_node(at_side_s, {name="trunks:moss_fungus", param2=random(8,11)}) | ||||||
| 			elseif moss_type < 22 then | 			elseif moss_type < 22 then | ||||||
| 				minetest.swap_node(at_side_s, {name="trunks:moss", param2=math.random(8,11)}) | 				minetest.swap_node(at_side_s, {name="trunks:moss", param2=random(8,11)}) | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 		local moss_type = math.random(1,41) | 		local moss_type = random(1,41) | ||||||
| 		if minetest.registered_nodes[node_west.name].buildable_to then -- instead of check_air = true, | 		if minetest.registered_nodes[node_west.name].buildable_to then -- instead of check_air = true, | ||||||
| 			if moss_type == 1 then | 			if moss_type == 1 then | ||||||
| 				minetest.swap_node(at_side_w, {name="trunks:moss_fungus", param2=math.random(16,19)}) | 				minetest.swap_node(at_side_w, {name="trunks:moss_fungus", param2=random(16,19)}) | ||||||
| 			elseif moss_type < 22 then | 			elseif moss_type < 22 then | ||||||
| 				minetest.swap_node(at_side_w, {name="trunks:moss", param2=math.random(16,19)}) | 				minetest.swap_node(at_side_w, {name="trunks:moss", param2=random(16,19)}) | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 	--end | 	--end | ||||||
| @@ -487,7 +489,7 @@ end | |||||||
| if Roots == true then -- see settings.txt | if Roots == true then -- see settings.txt | ||||||
|  |  | ||||||
| abstract_trunks.grow_roots = function(pos) | abstract_trunks.grow_roots = function(pos) | ||||||
| 	local twig_size		= math.random(1,27) | 	local twig_size		= random(1,27) | ||||||
|  |  | ||||||
| 	local right_here	= {x=pos.x  , y=pos.y  , z=pos.z  } | 	local right_here	= {x=pos.x  , y=pos.y  , z=pos.z  } | ||||||
| 	local below		= {x=pos.x  , y=pos.y-1, z=pos.z  } | 	local below		= {x=pos.x  , y=pos.y-1, z=pos.z  } | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
| -- Code by Mossmanikin & Neuromancer | -- Code by Mossmanikin & Neuromancer | ||||||
| -- support for i18n | -- support for i18n | ||||||
| local S = minetest.get_translator("trunks") | local S = minetest.get_translator("trunks") | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
| -- TWiGS | -- TWiGS | ||||||
| ----------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | ||||||
| @@ -56,7 +58,6 @@ for i in pairs(NoDe) do | |||||||
| 				if not minetest.setting_getbool("creative_mode") then | 				if not minetest.setting_getbool("creative_mode") then | ||||||
| 					itemstack:take_item() | 					itemstack:take_item() | ||||||
| 				end | 				end | ||||||
| 				return itemstack |  | ||||||
| 			end | 			end | ||||||
| 		end, | 		end, | ||||||
| 	}) | 	}) | ||||||
| @@ -79,7 +80,7 @@ minetest.register_node("trunks:moss", { | |||||||
| 	walkable = false, | 	walkable = false, | ||||||
| 	node_box = {type = "fixed", fixed = flat_moss}, | 	node_box = {type = "fixed", fixed = flat_moss}, | ||||||
| 	selection_box = {type = "fixed", fixed = flat_stick},--{type = "wallmounted"}, | 	selection_box = {type = "fixed", fixed = flat_stick},--{type = "wallmounted"}, | ||||||
| 	groups = {snappy = 3, flammable = 3 }, | 	groups = {snappy = 3, flammable = 3, attached_node = 1 }, | ||||||
| 	sounds = default.node_sound_leaves_defaults(), | 	sounds = default.node_sound_leaves_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -98,7 +99,7 @@ minetest.register_node("trunks:moss_fungus", { | |||||||
| 	walkable = false, | 	walkable = false, | ||||||
| 	node_box = {type = "fixed", fixed = flat_moss}, | 	node_box = {type = "fixed", fixed = flat_moss}, | ||||||
| 	selection_box = {type = "fixed", fixed = flat_stick},--{type = "wallmounted"}, | 	selection_box = {type = "fixed", fixed = flat_stick},--{type = "wallmounted"}, | ||||||
| 	groups = {snappy = 3, flammable = 3 }, | 	groups = {snappy = 3, flammable = 3, attached_node = 1 }, | ||||||
| 	sounds = default.node_sound_leaves_defaults(), | 	sounds = default.node_sound_leaves_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -64,7 +64,7 @@ Moss_on_trunk_Max_Count		= 640 -- absolute maximum number in an area of 80x80x80 | |||||||
| Moss_on_trunk_Rarity		= 24 -- larger values makes moss more rare (100 means chance of 0 %) | Moss_on_trunk_Rarity		= 24 -- larger values makes moss more rare (100 means chance of 0 %) | ||||||
|  |  | ||||||
|  |  | ||||||
| Auto_Roof_Corner 		= true -- behavior is similar (not the same!) to the one of minecraft stairs | Auto_Roof_Corner 		= false -- behavior is similar (not the same!) to the one of minecraft stairs | ||||||
|  |  | ||||||
|  |  | ||||||
| Roots					= true | Roots					= true | ||||||
|   | |||||||
| @@ -18,6 +18,8 @@ minetest.register_craftitem("vines:vines", { | |||||||
|  |  | ||||||
| -- FUNCTIONS | -- FUNCTIONS | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| local function dig_down(pos, node, digger) | local function dig_down(pos, node, digger) | ||||||
|  |  | ||||||
| 	if digger == nil then return end | 	if digger == nil then return end | ||||||
| @@ -80,7 +82,7 @@ vines.register_vine = function( name, defs, biome ) | |||||||
|  |  | ||||||
| 			local timer = minetest.get_node_timer(pos) | 			local timer = minetest.get_node_timer(pos) | ||||||
|  |  | ||||||
| 			timer:start(math.random(5, 10)) | 			timer:start(random(5, 10)) | ||||||
| 		end, | 		end, | ||||||
|  |  | ||||||
| 		on_timer = function(pos) | 		on_timer = function(pos) | ||||||
| @@ -91,7 +93,7 @@ vines.register_vine = function( name, defs, biome ) | |||||||
|  |  | ||||||
| 			if bottom_node.name == "air" then | 			if bottom_node.name == "air" then | ||||||
|  |  | ||||||
| 				if not math.random(defs.average_length) == 1 then | 				if not random(defs.average_length) == 1 then | ||||||
|  |  | ||||||
| 					minetest.set_node(pos, { | 					minetest.set_node(pos, { | ||||||
| 							name = vine_name_middle, param2 = node.param2}) | 							name = vine_name_middle, param2 = node.param2}) | ||||||
| @@ -101,7 +103,7 @@ vines.register_vine = function( name, defs, biome ) | |||||||
|  |  | ||||||
| 					local timer = minetest.get_node_timer(bottom_node) | 					local timer = minetest.get_node_timer(bottom_node) | ||||||
|  |  | ||||||
| 					timer:start(math.random(5, 10)) | 					timer:start(random(5, 10)) | ||||||
| 				end | 				end | ||||||
| 			end | 			end | ||||||
| 		end, | 		end, | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
| -- support for i18n | -- support for i18n | ||||||
| local S = minetest.get_translator("youngtrees") | local S = minetest.get_translator("youngtrees") | ||||||
|  |  | ||||||
|  | local random = math.random | ||||||
|  |  | ||||||
| abstract_youngtrees = {} | abstract_youngtrees = {} | ||||||
|  |  | ||||||
| minetest.register_node("youngtrees:bamboo", { | minetest.register_node("youngtrees:bamboo", { | ||||||
| @@ -104,8 +106,7 @@ minetest.register_node("youngtrees:youngtree_bottom", { | |||||||
|  |  | ||||||
|  |  | ||||||
|  abstract_youngtrees.grow_youngtree = function(pos) |  abstract_youngtrees.grow_youngtree = function(pos) | ||||||
| 	local height = math.random(1,3) | 	abstract_youngtrees.grow_youngtree_node(pos, random(1,3)) | ||||||
| 	abstract_youngtrees.grow_youngtree_node(pos,height) |  | ||||||
| end | end | ||||||
|  |  | ||||||
| abstract_youngtrees.grow_youngtree_node = function(pos, height) | abstract_youngtrees.grow_youngtree_node = function(pos, height) | ||||||
| @@ -147,3 +148,5 @@ biome_lib:register_generate_plant({ | |||||||
|   }, |   }, | ||||||
|   abstract_youngtrees.grow_youngtree |   abstract_youngtrees.grow_youngtree | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | minetest.log("action", "[youngtrees] loaded.") | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user