forked from mtcontrib/moretrees
		
	Compare commits
	
		
			22 Commits
		
	
	
		
			aaa0ba123b
			...
			master
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					403b16f5d9 | ||
| 
						 | 
					7c690ed901 | ||
| 
						 | 
					ac3e30ae86 | ||
| 
						 | 
					c15250a03a | ||
| 
						 | 
					458536dbe6 | ||
| 
						 | 
					2c891e6c25 | ||
| 
						 | 
					517c9dc516 | ||
| 
						 | 
					3e424b2797 | ||
| 
						 | 
					1b6914bc26 | ||
| 
						 | 
					f49b1c42c9 | ||
| 
						 | 
					670f7f4e61 | ||
| 
						 | 
					9a6c64d163 | ||
| 
						 | 
					5d7c46c4cf | ||
| 
						 | 
					17f2037218 | ||
| 
						 | 
					b1fe8df038 | ||
| 
						 | 
					b56e22fefd | ||
| 
						 | 
					288870bc8d | ||
| 
						 | 
					393840ba49 | ||
| 
						 | 
					21bdcc360b | ||
| 
						 | 
					7879bd8192 | ||
| 
						 | 
					5bc6bdc3d9 | ||
| 
						 | 
					e476b81cf5 | 
							
								
								
									
										18
									
								
								.github/workflows/luacheck.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/luacheck.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,18 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					name: luacheck
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					on: [push, pull_request]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					jobs:
 | 
				
			||||||
 | 
					  build:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    steps:
 | 
				
			||||||
 | 
					    - uses: actions/checkout@v1
 | 
				
			||||||
 | 
					    - name: apt
 | 
				
			||||||
 | 
					      run: sudo apt-get install -y luarocks
 | 
				
			||||||
 | 
					    - name: luacheck install
 | 
				
			||||||
 | 
					      run: luarocks install --local luacheck
 | 
				
			||||||
 | 
					    - name: luacheck run
 | 
				
			||||||
 | 
					      run: $HOME/.luarocks/bin/luacheck ./
 | 
				
			||||||
							
								
								
									
										38
									
								
								.luacheckrc
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								.luacheckrc
									
									
									
									
									
								
							@@ -1,30 +1,28 @@
 | 
				
			|||||||
std = "lua51+minetest"
 | 
					 | 
				
			||||||
unused_args = false
 | 
					unused_args = false
 | 
				
			||||||
allow_defined_top = true
 | 
					allow_defined_top = true
 | 
				
			||||||
max_line_length = 999
 | 
					 | 
				
			||||||
max_comment_line_length = 999
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
stds.minetest = {
 | 
					exclude_files = {".luacheckrc"}
 | 
				
			||||||
	read_globals = {
 | 
					
 | 
				
			||||||
		"minetest",
 | 
					
 | 
				
			||||||
		"vector",
 | 
					globals = {
 | 
				
			||||||
		"VoxelManip",
 | 
						"minetest",
 | 
				
			||||||
		"VoxelArea",
 | 
						"vector",
 | 
				
			||||||
		"PseudoRandom",
 | 
						"VoxelManip",
 | 
				
			||||||
		"ItemStack",
 | 
						"VoxelArea",
 | 
				
			||||||
		"default",
 | 
						"PseudoRandom",
 | 
				
			||||||
		table = {
 | 
						"ItemStack",
 | 
				
			||||||
			fields = {
 | 
						"default",
 | 
				
			||||||
				"copy",
 | 
						"dump",
 | 
				
			||||||
			},
 | 
						"moretrees",
 | 
				
			||||||
		},
 | 
						"ethereal",
 | 
				
			||||||
		"dump",
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
read_globals = {
 | 
					read_globals = {
 | 
				
			||||||
	"biome_lib",
 | 
						string = {fields = {"split"}},
 | 
				
			||||||
 | 
					    table = {fields = {"copy", "getn"}},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"stairsplus",
 | 
						"stairsplus",
 | 
				
			||||||
	"stairs",
 | 
						"stairs",
 | 
				
			||||||
	"doors",
 | 
						"doors",
 | 
				
			||||||
 | 
						"xcompat",
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -8,4 +8,5 @@ jungle trees mod, and big contributions by RealBadAngel.
 | 
				
			|||||||
Brought together into one mod and made L-systems compatible by Vanessa
 | 
					Brought together into one mod and made L-systems compatible by Vanessa
 | 
				
			||||||
Ezekowitz.
 | 
					Ezekowitz.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Dependencies: <a href="https://forum.minetest.net/viewtopic.php?f=11&t=12999">biome_lib</a> and default
 | 
					Dependencies: `xcompat`  
 | 
				
			||||||
 | 
					see mod.conf for more
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										285
									
								
								biome_defs.lua
									
									
									
									
									
								
							
							
						
						
									
										285
									
								
								biome_defs.lua
									
									
									
									
									
								
							@@ -1,302 +1,173 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					-- TODO
 | 
				
			||||||
 | 
					-- Use biomes in the decoration definition depending on their heat_point humidity_point
 | 
				
			||||||
 | 
					-- instead of spawning it with a rather low fill_ratio everywhere
 | 
				
			||||||
 | 
					local ratio_abundant =  0.001
 | 
				
			||||||
 | 
					local ratio_common =    0.0005
 | 
				
			||||||
 | 
					local ratio_normal =    0.0003
 | 
				
			||||||
 | 
					local ratio_uncommon =  0.0002
 | 
				
			||||||
 | 
					local ratio_rare =      0.0001
 | 
				
			||||||
 | 
					local ratio_very_rare = 0.00003
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					local coniferous_place_on = {
 | 
				
			||||||
 | 
						xcompat.materials.dirt_with_grass,
 | 
				
			||||||
 | 
						"default:dirt_with_coniferous_litter"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.beech_biome = {
 | 
					moretrees.beech_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
						fill_ratio = ratio_normal,
 | 
				
			||||||
	avoid_radius = 8,
 | 
					 | 
				
			||||||
	seed_diff = 2,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 20,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.palm_biome = {
 | 
					moretrees.palm_biome = {
 | 
				
			||||||
	surface = "default:sand",
 | 
						place_on = xcompat.materials.sand,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 5,
 | 
					 | 
				
			||||||
	seed_diff = 330,
 | 
					 | 
				
			||||||
	min_elevation = -1,
 | 
						min_elevation = -1,
 | 
				
			||||||
	max_elevation = 1,
 | 
						max_elevation = 1,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						fill_ratio = ratio_abundant,
 | 
				
			||||||
	near_nodes_size = 15,
 | 
					 | 
				
			||||||
	near_nodes_count = 10,
 | 
					 | 
				
			||||||
	temp_min = 0.25,
 | 
					 | 
				
			||||||
	temp_max = -0.15,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.date_palm_biome = {
 | 
					moretrees.date_palm_biome = {
 | 
				
			||||||
	surface = "default:desert_sand",
 | 
						place_on = xcompat.materials.desert_sand,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 339,
 | 
					 | 
				
			||||||
	min_elevation = -1,
 | 
						min_elevation = -1,
 | 
				
			||||||
	max_elevation = 10,
 | 
						max_elevation = 8,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						fill_ratio = ratio_common,
 | 
				
			||||||
	near_nodes_size = 20,
 | 
					 | 
				
			||||||
	near_nodes_count = 100,
 | 
					 | 
				
			||||||
	near_nodes_vertical = 20,
 | 
					 | 
				
			||||||
	temp_min = -0.20,
 | 
					 | 
				
			||||||
	humidity_max = 0.20,
 | 
					 | 
				
			||||||
	rarity = 10,
 | 
					 | 
				
			||||||
	max_count = 30,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.date_palm_biome_2 = {
 | 
					moretrees.date_palm_biome_2 = {
 | 
				
			||||||
	surface = "default:desert_sand",
 | 
						place_on = xcompat.materials.desert_sand,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
						min_elevation = 9,
 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 340,
 | 
					 | 
				
			||||||
	min_elevation = 11,
 | 
					 | 
				
			||||||
	max_elevation = 30,
 | 
						max_elevation = 30,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						spawn_by = {xcompat.materials.water_source},
 | 
				
			||||||
	near_nodes_size = 1,
 | 
						num_spawn_by = 1,
 | 
				
			||||||
	near_nodes_count = 1,
 | 
						fill_ratio = ratio_abundant,
 | 
				
			||||||
	near_nodes_vertical = 30,
 | 
					 | 
				
			||||||
	temp_min = -0.20,
 | 
					 | 
				
			||||||
	humidity_max = 0.20,
 | 
					 | 
				
			||||||
	rarity = 10,
 | 
					 | 
				
			||||||
	max_count = 30,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.apple_tree_biome = {
 | 
					moretrees.apple_tree_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 331,
 | 
					 | 
				
			||||||
	min_elevation = 1,
 | 
						min_elevation = 1,
 | 
				
			||||||
	max_elevation = 10,
 | 
						max_elevation = 10,
 | 
				
			||||||
	temp_min = 0.1,
 | 
						biomes = {"deciduous_forest"},
 | 
				
			||||||
	temp_max = -0.15,
 | 
						fill_ratio = ratio_rare,
 | 
				
			||||||
	rarity = 75,
 | 
					 | 
				
			||||||
	max_count = 5,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.oak_biome = {
 | 
					moretrees.oak_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 15,
 | 
					 | 
				
			||||||
	seed_diff = 332,
 | 
					 | 
				
			||||||
	min_elevation = 0,
 | 
						min_elevation = 0,
 | 
				
			||||||
	max_elevation = 10,
 | 
						max_elevation = 10,
 | 
				
			||||||
	temp_min = 0.4,
 | 
						fill_ratio = ratio_normal,
 | 
				
			||||||
	temp_max = 0.2,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 5,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.sequoia_biome = {
 | 
					moretrees.sequoia_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 333,
 | 
					 | 
				
			||||||
	min_elevation = 0,
 | 
						min_elevation = 0,
 | 
				
			||||||
	max_elevation = 10,
 | 
						max_elevation = 10,
 | 
				
			||||||
	temp_min = 1,
 | 
						fill_ratio = ratio_rare,
 | 
				
			||||||
	temp_max = -0.4,
 | 
					 | 
				
			||||||
	rarity = 90,
 | 
					 | 
				
			||||||
	max_count = 5,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.birch_biome = {
 | 
					moretrees.birch_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 5,
 | 
					 | 
				
			||||||
	seed_diff = 334,
 | 
					 | 
				
			||||||
	min_elevation = 10,
 | 
						min_elevation = 10,
 | 
				
			||||||
	max_elevation = 15,
 | 
						max_elevation = 15,
 | 
				
			||||||
	temp_min = 0.9,
 | 
						fill_ratio = ratio_common,
 | 
				
			||||||
	temp_max = 0.3,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.willow_biome = {
 | 
					moretrees.willow_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 337,
 | 
					 | 
				
			||||||
	min_elevation = -5,
 | 
						min_elevation = -5,
 | 
				
			||||||
	max_elevation = 5,
 | 
						max_elevation = 5,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						fill_ratio = ratio_uncommon,
 | 
				
			||||||
	near_nodes_size = 15,
 | 
					 | 
				
			||||||
	near_nodes_count = 5,
 | 
					 | 
				
			||||||
	rarity = 75,
 | 
					 | 
				
			||||||
	max_count = 5,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.rubber_tree_biome = {
 | 
					moretrees.rubber_tree_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 338,
 | 
					 | 
				
			||||||
	min_elevation = -5,
 | 
						min_elevation = -5,
 | 
				
			||||||
	max_elevation = 5,
 | 
						max_elevation = 8,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						fill_ratio = ratio_normal,
 | 
				
			||||||
	near_nodes_size = 15,
 | 
					 | 
				
			||||||
	near_nodes_count = 10,
 | 
					 | 
				
			||||||
	temp_min = -0.15,
 | 
					 | 
				
			||||||
	rarity = 75,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.jungletree_biome = {
 | 
					moretrees.jungletree_biome = {
 | 
				
			||||||
	surface = {
 | 
						place_on = {
 | 
				
			||||||
		"default:dirt",
 | 
							xcompat.materials.dirt,
 | 
				
			||||||
		"default:dirt_with_grass",
 | 
							xcompat.materials.dirt_with_grass,
 | 
				
			||||||
		"woodsoils:dirt_with_leaves_1",
 | 
							"woodsoils:dirt_with_leaves_1",
 | 
				
			||||||
		"woodsoils:grass_with_leaves_1",
 | 
							"woodsoils:grass_with_leaves_1",
 | 
				
			||||||
		"woodsoils:grass_with_leaves_2"
 | 
							"woodsoils:grass_with_leaves_2",
 | 
				
			||||||
 | 
							"default:dirt_with_rainforest_litter",
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	avoid_nodes = {"moretrees:jungletree_trunk"},
 | 
					 | 
				
			||||||
	max_count = 12,
 | 
					 | 
				
			||||||
	avoid_radius = 3,
 | 
					 | 
				
			||||||
	rarity = 85,
 | 
					 | 
				
			||||||
	seed_diff = 329,
 | 
					 | 
				
			||||||
	min_elevation = 1,
 | 
						min_elevation = 1,
 | 
				
			||||||
	near_nodes = {"default:jungletree"},
 | 
						spawn_by = minetest.get_modpath("default") and {"default:jungletree"} or nil,
 | 
				
			||||||
	near_nodes_size = 6,
 | 
						num_spawn_by = minetest.get_modpath("default") and 1 or nil,
 | 
				
			||||||
	near_nodes_vertical = 2,
 | 
						biomes = {"rainforest", "rainforest_swamp"},
 | 
				
			||||||
	near_nodes_count = 1,
 | 
					 | 
				
			||||||
	plantlife_limit = -0.9,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.spruce_biome = {
 | 
					moretrees.spruce_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = coniferous_place_on,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 335,
 | 
					 | 
				
			||||||
	min_elevation = 20,
 | 
						min_elevation = 20,
 | 
				
			||||||
	temp_min = 0.9,
 | 
						fill_ratio = ratio_uncommon,
 | 
				
			||||||
	temp_max = 0.7,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 5,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.cedar_biome = {
 | 
					moretrees.cedar_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = coniferous_place_on,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 336,
 | 
					 | 
				
			||||||
	min_elevation = 0,  --Added to solve an issue where cedar trees would sometimes spawn deep underground
 | 
						min_elevation = 0,  --Added to solve an issue where cedar trees would sometimes spawn deep underground
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						fill_ratio = ratio_rare,
 | 
				
			||||||
	near_nodes_size = 15,
 | 
					 | 
				
			||||||
	near_nodes_count = 5,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- Poplar requires a lot of water.
 | 
					-- Poplar requires a lot of water.
 | 
				
			||||||
moretrees.poplar_biome = {
 | 
					moretrees.poplar_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 6,
 | 
					 | 
				
			||||||
	seed_diff = 341,
 | 
					 | 
				
			||||||
	min_elevation = 0,
 | 
						min_elevation = 0,
 | 
				
			||||||
	max_elevation = 50,
 | 
						max_elevation = 50,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						spawn_by = {xcompat.materials.water_source},
 | 
				
			||||||
	near_nodes_size = 15,
 | 
						num_spawn_by = 3,
 | 
				
			||||||
	near_nodes_vertical = 5,
 | 
						fill_ratio = ratio_abundant,
 | 
				
			||||||
	near_nodes_count = 1,
 | 
					 | 
				
			||||||
	humidity_min = -0.7,
 | 
					 | 
				
			||||||
	humidity_max = -1,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 15,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- The humidity requirement it quite restrictive (apparently).
 | 
					 | 
				
			||||||
-- Spawn an occasional poplar elsewhere.
 | 
					-- Spawn an occasional poplar elsewhere.
 | 
				
			||||||
moretrees.poplar_biome_2 = {
 | 
					moretrees.poplar_biome_2 = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 6,
 | 
					 | 
				
			||||||
	seed_diff = 341,
 | 
					 | 
				
			||||||
	min_elevation = 0,
 | 
						min_elevation = 0,
 | 
				
			||||||
	max_elevation = 50,
 | 
						max_elevation = 50,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						fill_ratio = ratio_very_rare,
 | 
				
			||||||
	near_nodes_size = 15,
 | 
					 | 
				
			||||||
	near_nodes_vertical = 4,
 | 
					 | 
				
			||||||
	near_nodes_count = 10,
 | 
					 | 
				
			||||||
	humidity_min = 0.1,
 | 
					 | 
				
			||||||
	humidity_max = -0.6,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 1,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- Subterranean lakes provide enough water for poplars to grow
 | 
					-- Subterranean lakes provide enough water for poplars to grow
 | 
				
			||||||
moretrees.poplar_biome_3 = {
 | 
					moretrees.poplar_biome_3 = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
						min_elevation = -50,
 | 
				
			||||||
	avoid_radius = 6,
 | 
						max_elevation = 0,
 | 
				
			||||||
	seed_diff = 342,
 | 
						spawn_by = {xcompat.materials.water_source},
 | 
				
			||||||
	min_elevation = 0,
 | 
						num_spawn_by = 3,
 | 
				
			||||||
	max_elevation = 50,
 | 
						fill_ratio = ratio_abundant,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
					 | 
				
			||||||
	near_nodes_size = 1,
 | 
					 | 
				
			||||||
	near_nodes_vertical = 25,
 | 
					 | 
				
			||||||
	near_nodes_count = 1,
 | 
					 | 
				
			||||||
	humidity_min = -0.5,
 | 
					 | 
				
			||||||
	humidity_max = -1,
 | 
					 | 
				
			||||||
	rarity = 0,
 | 
					 | 
				
			||||||
	max_count = 30,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.poplar_small_biome = {
 | 
					moretrees.poplar_small_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 4,
 | 
					 | 
				
			||||||
	seed_diff = 343,
 | 
					 | 
				
			||||||
	min_elevation = 0,
 | 
						min_elevation = 0,
 | 
				
			||||||
	max_elevation = 50,
 | 
						max_elevation = 50,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						spawn_by = {xcompat.materials.water_source},
 | 
				
			||||||
	near_nodes_size = 10,
 | 
						num_spawn_by = 1,
 | 
				
			||||||
	near_nodes_vertical = 5,
 | 
						fill_ratio = ratio_normal,
 | 
				
			||||||
	near_nodes_count = 1,
 | 
					 | 
				
			||||||
	humidity_min = -0.7,
 | 
					 | 
				
			||||||
	humidity_max = -1,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.poplar_small_biome_2 = {
 | 
					moretrees.poplar_small_biome_2 = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = xcompat.materials.dirt_with_grass,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 4,
 | 
					 | 
				
			||||||
	seed_diff = 343,
 | 
					 | 
				
			||||||
	min_elevation = 0,
 | 
						min_elevation = 0,
 | 
				
			||||||
	max_elevation = 50,
 | 
						max_elevation = 50,
 | 
				
			||||||
	near_nodes = {"default:water_source"},
 | 
						spawn_by = {xcompat.materials.water_source},
 | 
				
			||||||
	near_nodes_size = 10,
 | 
						num_spawn_by = 5,
 | 
				
			||||||
	near_nodes_vertical = 4,
 | 
						fill_ratio = ratio_abundant,
 | 
				
			||||||
	near_nodes_count = 5,
 | 
					 | 
				
			||||||
	humidity_min = 0.1,
 | 
					 | 
				
			||||||
	humidity_max = -0.6,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 3,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.fir_biome = {
 | 
					moretrees.fir_biome = {
 | 
				
			||||||
	surface = "default:dirt_with_grass",
 | 
						place_on = coniferous_place_on,
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
					 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 359,
 | 
					 | 
				
			||||||
	min_elevation = 25,
 | 
						min_elevation = 25,
 | 
				
			||||||
	temp_min = 0.9,
 | 
						fill_ratio = ratio_normal,
 | 
				
			||||||
	temp_max = 0.3,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.fir_biome_snow = {
 | 
					moretrees.fir_biome_snow = {
 | 
				
			||||||
	surface = {"snow:dirt_with_snow", "snow:snow"},
 | 
						place_on = {"snow:dirt_with_snow", "snow:snow"},
 | 
				
			||||||
	below_nodes = {"default:dirt", "default:dirt_with_grass", "snow:dirt_with_snow"},
 | 
						below_nodes = {xcompat.materials.dirt, xcompat.materials.dirt_with_grass, "snow:dirt_with_snow"},
 | 
				
			||||||
	avoid_nodes = moretrees.avoidnodes,
 | 
						fill_ratio = ratio_normal,
 | 
				
			||||||
	avoid_radius = 10,
 | 
					 | 
				
			||||||
	seed_diff = 359,
 | 
					 | 
				
			||||||
	rarity = 50,
 | 
					 | 
				
			||||||
	max_count = 10,
 | 
					 | 
				
			||||||
	check_air = false,
 | 
					 | 
				
			||||||
	delete_above = true,
 | 
					 | 
				
			||||||
	spawn_replace_node = true
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -32,7 +32,7 @@ ftrunk.after_destruct = function(pos, oldnode)
 | 
				
			|||||||
		-- minetest.dig_node(coconutpos) does not cause nearby coconuts to be dropped :-( ...
 | 
							-- minetest.dig_node(coconutpos) does not cause nearby coconuts to be dropped :-( ...
 | 
				
			||||||
		--minetest.dig_node(coconutpos)
 | 
							--minetest.dig_node(coconutpos)
 | 
				
			||||||
		local items = minetest.get_node_drops(minetest.get_node(coconutpos).name)
 | 
							local items = minetest.get_node_drops(minetest.get_node(coconutpos).name)
 | 
				
			||||||
		minetest.swap_node(coconutpos, biome_lib.air)
 | 
							minetest.swap_node(coconutpos, {name = "air"})
 | 
				
			||||||
		for _, itemname in pairs(items) do
 | 
							for _, itemname in pairs(items) do
 | 
				
			||||||
			minetest.add_item(coconutpos, itemname)
 | 
								minetest.add_item(coconutpos, itemname)
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
@@ -82,8 +82,8 @@ minetest.register_abm({
 | 
				
			|||||||
	nodenames = { "moretrees:palm_fruit_trunk_gen" },
 | 
						nodenames = { "moretrees:palm_fruit_trunk_gen" },
 | 
				
			||||||
	interval = 6,
 | 
						interval = 6,
 | 
				
			||||||
	chance = 1,
 | 
						chance = 1,
 | 
				
			||||||
	min_y = biome_lib.mapgen_elevation_limit.min,
 | 
						min_y = -16,
 | 
				
			||||||
	max_y = biome_lib.mapgen_elevation_limit.max,
 | 
						max_y = 48,
 | 
				
			||||||
	label = "converts palm trunk to a regular fruit trunk, and spawns some coconuts",
 | 
						label = "converts palm trunk to a regular fruit trunk, and spawns some coconuts",
 | 
				
			||||||
	action = function(pos, node, active_object_count, active_object_count_wider)
 | 
						action = function(pos, node, active_object_count, active_object_count_wider)
 | 
				
			||||||
		minetest.swap_node(pos, {name="moretrees:palm_fruit_trunk"})
 | 
							minetest.swap_node(pos, {name="moretrees:palm_fruit_trunk"})
 | 
				
			||||||
@@ -130,7 +130,7 @@ local coconut_growfn = function(pos, elapsed)
 | 
				
			|||||||
					minetest.add_item(pos, itemname)
 | 
										minetest.add_item(pos, itemname)
 | 
				
			||||||
				end
 | 
									end
 | 
				
			||||||
			end
 | 
								end
 | 
				
			||||||
			minetest.swap_node(pos, biome_lib.air)
 | 
								minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		-- Grow coconuts to the next stage
 | 
							-- Grow coconuts to the next stage
 | 
				
			||||||
@@ -177,10 +177,11 @@ for _,suffix in ipairs({"_0", "_1", "_2", "_3", ""}) do
 | 
				
			|||||||
		paramtype = "light",
 | 
							paramtype = "light",
 | 
				
			||||||
		sunlight_propagates = true,
 | 
							sunlight_propagates = true,
 | 
				
			||||||
		walkable = false,
 | 
							walkable = false,
 | 
				
			||||||
 | 
							is_ground_content = false,
 | 
				
			||||||
		groups = { fleshy=3, dig_immediate=3, flammable=2, moretrees_coconut=coco_group },
 | 
							groups = { fleshy=3, dig_immediate=3, flammable=2, moretrees_coconut=coco_group },
 | 
				
			||||||
		inventory_image = tile.."^[transformR180",
 | 
							inventory_image = tile.."^[transformR180",
 | 
				
			||||||
		wield_image = tile.."^[transformR180",
 | 
							wield_image = tile.."^[transformR180",
 | 
				
			||||||
		sounds = default.node_sound_defaults(),
 | 
							sounds = xcompat.sounds.node_sound_default(),
 | 
				
			||||||
		drop = drop,
 | 
							drop = drop,
 | 
				
			||||||
		selection_box = {
 | 
							selection_box = {
 | 
				
			||||||
			type = "fixed",
 | 
								type = "fixed",
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										16
									
								
								crafts.lua
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								crafts.lua
									
									
									
									
									
								
							@@ -3,13 +3,15 @@ local S = minetest.get_translator("moretrees")
 | 
				
			|||||||
for i in ipairs(moretrees.treelist) do
 | 
					for i in ipairs(moretrees.treelist) do
 | 
				
			||||||
	local treename = moretrees.treelist[i][1]
 | 
						local treename = moretrees.treelist[i][1]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.register_craft({
 | 
						if moretrees.enable_planks then
 | 
				
			||||||
		type = "shapeless",
 | 
							minetest.register_craft({
 | 
				
			||||||
		output = "moretrees:"..treename.."_planks 4",
 | 
								type = "shapeless",
 | 
				
			||||||
		recipe = {
 | 
								output = "moretrees:"..treename.."_planks 4",
 | 
				
			||||||
			"moretrees:"..treename.."_trunk"
 | 
								recipe = {
 | 
				
			||||||
		}
 | 
									"moretrees:"..treename.."_trunk"
 | 
				
			||||||
	})
 | 
								}
 | 
				
			||||||
 | 
							})
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.register_craft({
 | 
						minetest.register_craft({
 | 
				
			||||||
		type = "fuel",
 | 
							type = "fuel",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -52,7 +52,7 @@ ftrunk.after_destruct = function(pos, oldnode)
 | 
				
			|||||||
	for _,datespos in pairs(dates) do
 | 
						for _,datespos in pairs(dates) do
 | 
				
			||||||
		-- minetest.dig_node(datespos) does not cause nearby dates to be dropped :-( ...
 | 
							-- minetest.dig_node(datespos) does not cause nearby dates to be dropped :-( ...
 | 
				
			||||||
		local items = minetest.get_node_drops(minetest.get_node(datespos).name)
 | 
							local items = minetest.get_node_drops(minetest.get_node(datespos).name)
 | 
				
			||||||
		minetest.swap_node(datespos, biome_lib.air)
 | 
							minetest.swap_node(datespos, {name = "air"})
 | 
				
			||||||
		for _, itemname in pairs(items) do
 | 
							for _, itemname in pairs(items) do
 | 
				
			||||||
			minetest.add_item(datespos, itemname)
 | 
								minetest.add_item(datespos, itemname)
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
@@ -83,7 +83,10 @@ local date_regrow_abm_spec = {
 | 
				
			|||||||
	interval = moretrees.dates_flower_interval,
 | 
						interval = moretrees.dates_flower_interval,
 | 
				
			||||||
	chance = moretrees.dates_flower_chance,
 | 
						chance = moretrees.dates_flower_chance,
 | 
				
			||||||
	action = function(pos, node, active_object_count, active_object_count_wider)
 | 
						action = function(pos, node, active_object_count, active_object_count_wider)
 | 
				
			||||||
		local dates = minetest.find_nodes_in_area({x=pos.x-2, y=pos.y, z=pos.z-2}, {x=pos.x+2, y=pos.y, z=pos.z+2}, "group:moretrees_dates")
 | 
							local dates = minetest.find_nodes_in_area(
 | 
				
			||||||
 | 
								{x=pos.x-2, y=pos.y, z=pos.z-2}, {x=pos.x+2, y=pos.y, z=pos.z+2},
 | 
				
			||||||
 | 
								"group:moretrees_dates"
 | 
				
			||||||
 | 
							)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		-- New blossom interval increases exponentially with number of dates already hanging
 | 
							-- New blossom interval increases exponentially with number of dates already hanging
 | 
				
			||||||
		-- In addition: if more dates are hanging, the chance of picking an empty spot decreases as well...
 | 
							-- In addition: if more dates are hanging, the chance of picking an empty spot decreases as well...
 | 
				
			||||||
@@ -228,7 +231,8 @@ local function find_fruit_trunks_near(ftpos, sect)
 | 
				
			|||||||
	-- Skip the search if it is consuming too much CPU time
 | 
						-- Skip the search if it is consuming too much CPU time
 | 
				
			||||||
	if sect_search_stats.count > 0 and moretrees.dates_blossom_search_iload > 0
 | 
						if sect_search_stats.count > 0 and moretrees.dates_blossom_search_iload > 0
 | 
				
			||||||
			and sect_search_stats.sum / sect_search_stats.count > moretrees.dates_blossom_search_time_treshold
 | 
								and sect_search_stats.sum / sect_search_stats.count > moretrees.dates_blossom_search_time_treshold
 | 
				
			||||||
			and t0us - sect_search_stats.last_us < moretrees.dates_blossom_search_iload * (sect_search_stats.sum / sect_search_stats.count) then
 | 
								and t0us - sect_search_stats.last_us < moretrees.dates_blossom_search_iload
 | 
				
			||||||
 | 
								* (sect_search_stats.sum / sect_search_stats.count) then
 | 
				
			||||||
		sect_search_stats.skip = sect_search_stats.skip + 1
 | 
							sect_search_stats.skip = sect_search_stats.skip + 1
 | 
				
			||||||
		return nil
 | 
							return nil
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
@@ -481,7 +485,10 @@ local function find_male_blossom_with_ftrunk(fbpos,ftpos)
 | 
				
			|||||||
		end
 | 
							end
 | 
				
			||||||
		-- Else do a new search
 | 
							-- Else do a new search
 | 
				
			||||||
		if not mpalms.sect[sect_old] then
 | 
							if not mpalms.sect[sect_old] then
 | 
				
			||||||
			mpalms.sect[sect_old], fpalms_list, all_mpalms_list = find_fruit_trunks_near(ftpos, {x = (sect_old + 4) % 3 - 1, z = (sect_old + 4) / 3 - 1})
 | 
								mpalms.sect[sect_old], fpalms_list, all_mpalms_list = find_fruit_trunks_near(
 | 
				
			||||||
 | 
									ftpos,
 | 
				
			||||||
 | 
									{x = (sect_old + 4) % 3 - 1, z = (sect_old + 4) / 3 - 1}
 | 
				
			||||||
 | 
								)
 | 
				
			||||||
			cache_changed = true
 | 
								cache_changed = true
 | 
				
			||||||
			if sect_old == 0 then
 | 
								if sect_old == 0 then
 | 
				
			||||||
				-- Save the results if it is sector 0
 | 
									-- Save the results if it is sector 0
 | 
				
			||||||
@@ -547,7 +554,7 @@ local dates_growfn = function(pos, elapsed)
 | 
				
			|||||||
		elseif string.find(node.name, "moretrees:dates_m") then
 | 
							elseif string.find(node.name, "moretrees:dates_m") then
 | 
				
			||||||
			minetest.swap_node(pos, {name="moretrees:dates_n"})
 | 
								minetest.swap_node(pos, {name="moretrees:dates_n"})
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			minetest.swap_node(pos, biome_lib.air)
 | 
								minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	elseif node.name == "moretrees:dates_f0" and math.random(100) <= 100 * dates_regrow_prob then
 | 
						elseif node.name == "moretrees:dates_f0" and math.random(100) <= 100 * dates_regrow_prob then
 | 
				
			||||||
@@ -587,7 +594,7 @@ local dates_growfn = function(pos, elapsed)
 | 
				
			|||||||
	elseif string.match(node.name, "n$") then
 | 
						elseif string.match(node.name, "n$") then
 | 
				
			||||||
		-- Remove stems.
 | 
							-- Remove stems.
 | 
				
			||||||
		if math.random(stems_drop_ichance) == 1 then
 | 
							if math.random(stems_drop_ichance) == 1 then
 | 
				
			||||||
			minetest.swap_node(pos, biome_lib.air)
 | 
								minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
			return "stemdrop"
 | 
								return "stemdrop"
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
		action = "nostemdrop"
 | 
							action = "nostemdrop"
 | 
				
			||||||
@@ -716,10 +723,11 @@ for _,suffix in ipairs({"f0", "f1", "f2", "f3", "f4", "m0", "fn", "n"}) do
 | 
				
			|||||||
		paramtype = "light",
 | 
							paramtype = "light",
 | 
				
			||||||
		sunlight_propagates = true,
 | 
							sunlight_propagates = true,
 | 
				
			||||||
		walkable = false,
 | 
							walkable = false,
 | 
				
			||||||
 | 
							is_ground_content = false,
 | 
				
			||||||
		groups = { fleshy=3, dig_immediate=3, flammable=2, moretrees_dates=1 },
 | 
							groups = { fleshy=3, dig_immediate=3, flammable=2, moretrees_dates=1 },
 | 
				
			||||||
		inventory_image = "moretrees_dates_"..suffix..".png^[transformR0",
 | 
							inventory_image = "moretrees_dates_"..suffix..".png^[transformR0",
 | 
				
			||||||
		wield_image = "moretrees_dates_"..suffix..".png^[transformR90",
 | 
							wield_image = "moretrees_dates_"..suffix..".png^[transformR90",
 | 
				
			||||||
		sounds = default.node_sound_defaults(),
 | 
							sounds = xcompat.sounds.node_sound_default(),
 | 
				
			||||||
		drop = dropfn,
 | 
							drop = dropfn,
 | 
				
			||||||
		selection_box = {
 | 
							selection_box = {
 | 
				
			||||||
			type = "fixed",
 | 
								type = "fixed",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,136 +0,0 @@
 | 
				
			|||||||
-- Global configuration variables
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Enable the various kinds of trees.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.enable_apple_tree		= true
 | 
					 | 
				
			||||||
moretrees.enable_oak			= true
 | 
					 | 
				
			||||||
moretrees.enable_sequoia		= true
 | 
					 | 
				
			||||||
moretrees.enable_palm			= true
 | 
					 | 
				
			||||||
moretrees.enable_date_palm		= true
 | 
					 | 
				
			||||||
moretrees.enable_cedar			= true
 | 
					 | 
				
			||||||
moretrees.enable_rubber_tree	= true
 | 
					 | 
				
			||||||
moretrees.enable_willow			= true
 | 
					 | 
				
			||||||
moretrees.enable_birch			= true
 | 
					 | 
				
			||||||
moretrees.enable_spruce			= true
 | 
					 | 
				
			||||||
moretrees.enable_jungle_tree	= true
 | 
					 | 
				
			||||||
moretrees.enable_fir			= true
 | 
					 | 
				
			||||||
moretrees.enable_poplar			= true
 | 
					 | 
				
			||||||
moretrees.enable_beech			= false
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- set this to true to make moretrees spawn saplings at mapgen time instead
 | 
					 | 
				
			||||||
-- of fully-grown trees, which will grow into full trees after a very short
 | 
					 | 
				
			||||||
-- delay.  This reduces mapgen lag in some situations, and fixes situations
 | 
					 | 
				
			||||||
-- where the mapgen conflicts with the tree generator.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.spawn_saplings		= true
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Set this to true to allow defining stairs/slabs/etc.  If Moreblocks is
 | 
					 | 
				
			||||||
-- installed, this will use that mod's Stairs Plus component.  Otherwise, it
 | 
					 | 
				
			||||||
-- will use the default stairs mod in minetest_game, if present
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.enable_stairs			= true
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- If this variable is set to true, register fences for moretrees wood
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.enable_fences         = false
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Set this to true if you want the plantlike drawtype for leaves, which
 | 
					 | 
				
			||||||
-- improves some peoples' framerates without resorting to making leaf nodes opaque.
 | 
					 | 
				
			||||||
-- Affects default leaves and default jungle leaves also.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.plantlike_leaves		= false
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Enable this if you want moretrees to redefine default apples so that they
 | 
					 | 
				
			||||||
-- fall when leaves decay/are dug.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.enable_redefine_apple		= true
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Set this to true to enable leaf decay of all trees except the default ones.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.enable_leafdecay		= true
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- various related settings to configure leaf decay.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.leafdecay_delay		= 2
 | 
					 | 
				
			||||||
moretrees.leafdecay_chance		= 5
 | 
					 | 
				
			||||||
moretrees.leafdecay_radius		= 5
 | 
					 | 
				
			||||||
moretrees.palm_leafdecay_radius		= 10
 | 
					 | 
				
			||||||
moretrees.date_palm_leafdecay_radius	= 14
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Change these settings if you want default trees to be gradually cut down
 | 
					 | 
				
			||||||
-- above the elevation where firs normally generate.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.firs_remove_default_trees	= false
 | 
					 | 
				
			||||||
moretrees.firs_remove_interval		= 2
 | 
					 | 
				
			||||||
moretrees.firs_remove_chance		= 150
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Cocos palm settings
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.coconuts_regrow		= true
 | 
					 | 
				
			||||||
moretrees.coconuts_convert_existing_palms = true	-- Converting existing palm trees will make coconuts regrow on them as well
 | 
					 | 
				
			||||||
							-- Else, they will only regrow on newly-spawned palms
 | 
					 | 
				
			||||||
							-- However, conversion is not an exact science, and although an attempt is
 | 
					 | 
				
			||||||
							-- made to detect whether a trunk belongs to an actual palm, some coconut trunks
 | 
					 | 
				
			||||||
							-- and some coconuts may be incorrectly converted.
 | 
					 | 
				
			||||||
moretrees.coconut_flower_interval	= 59
 | 
					 | 
				
			||||||
moretrees.coconut_flower_chance		= 67
 | 
					 | 
				
			||||||
moretrees.coconut_grow_interval		= 2 * moretrees.coconut_flower_interval * moretrees.coconut_flower_chance
 | 
					 | 
				
			||||||
							-- Actual interval will randomly vary between 67% and 133% of this value
 | 
					 | 
				
			||||||
							-- 2 * 59 * 67 ~ 2 hours. So flowers become coconuts in about 6 hours
 | 
					 | 
				
			||||||
moretrees.coconut_item_drop_ichance	= 10 		-- inverse probability of ripe coconuts dropping as items (instead of disappearing)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Date palm settings
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Suggested configuration alternatives:
 | 
					 | 
				
			||||||
-- - Dates grow only when pollinated:
 | 
					 | 
				
			||||||
--   - Set dates_regrow_pollinated to true
 | 
					 | 
				
			||||||
--   - Set dates_regrow_unpollinated_percent to 0
 | 
					 | 
				
			||||||
-- - Dates grow without pollination. Pollination disabled:
 | 
					 | 
				
			||||||
--   - Set dates_regrow_pollinated to false
 | 
					 | 
				
			||||||
--   - Set dates_regrow_unpollinated_percent to some larger positive value, e.g. 95
 | 
					 | 
				
			||||||
-- - Dates grow, but more and faster if male flowers are nearby
 | 
					 | 
				
			||||||
--   - Set dates_regrow_pollinated to true
 | 
					 | 
				
			||||||
--   - Set dates_regrow_unpollinated_percent to some small positive value, e.g. 33
 | 
					 | 
				
			||||||
--   - Optional but recommended: Reduce the pollination distance, e.g. to 30
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Note that it should not be necessary to disable pollination for performance
 | 
					 | 
				
			||||||
-- reasons. A lot of effort has gone into ensuring that date growing will not cause lag.
 | 
					 | 
				
			||||||
--
 | 
					 | 
				
			||||||
-- If lag is suspected, use the chat command '/dates_stats' to obtain the male dates
 | 
					 | 
				
			||||||
-- search time, as well as the counts of total number of searches requested and the
 | 
					 | 
				
			||||||
-- number of searches actually performed.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.dates_regrow_pollinated	= true		-- Enable pollination. If enabled, male trees are required for dates to grow.
 | 
					 | 
				
			||||||
							-- If disabled, dates_regrow_unpollinated_percent must be non-zero for dates to regrow.
 | 
					 | 
				
			||||||
moretrees.dates_regrow_unpollinated_percent	= 0	-- Percentage of female dates becoming dates without being pollinated.
 | 
					 | 
				
			||||||
							-- If 0, dates_regrow_pollinated must be enabled for dates to grow.
 | 
					 | 
				
			||||||
moretrees.dates_female_percent		= 57		-- Ratio of female to male trees - tune this to improve # of generated trees that actually bear fruit
 | 
					 | 
				
			||||||
							-- ~57% gives near optimal results for groups of 3 random trees, while it is only slightly suboptimal
 | 
					 | 
				
			||||||
							-- for groups of 2 and 4 random trees (~2% less fruit than optimal).
 | 
					 | 
				
			||||||
							-- Optimal values per group size: 2: 50%, 3: 57.78%, 4: 63%, 5: 66.9%, 6: 69.9%, [...], 12: 79.8%
 | 
					 | 
				
			||||||
							-- So 57% is optimal for small groups of trees. As larger groups have more female palms anyway, a
 | 
					 | 
				
			||||||
							-- less than optimal proportion of female to male trees is not a problem.
 | 
					 | 
				
			||||||
moretrees.dates_pollination_distance	= 120
 | 
					 | 
				
			||||||
moretrees.dates_blossom_search_time_treshold = 1000	-- If average male blossom search time (in microseconds) exceeds this, start limiting the search load.
 | 
					 | 
				
			||||||
moretrees.dates_blossom_search_iload = 10		-- Inverse fraction of CPU time that male blossom searching search may consume.
 | 
					 | 
				
			||||||
							-- As searching a large area (radius: dates_pollination_distance/3 per attempt) can cause lag,
 | 
					 | 
				
			||||||
							-- this limits the search frequency server-wide so that the impact on server lag is minimised
 | 
					 | 
				
			||||||
							-- For personal servers, this can be set lower, or even to 1 or 0 (0 disables load limiting).
 | 
					 | 
				
			||||||
							-- Obtain the current average search time using /dates_stats
 | 
					 | 
				
			||||||
moretrees.dates_flower_interval		= 59
 | 
					 | 
				
			||||||
moretrees.dates_flower_chance		= 181
 | 
					 | 
				
			||||||
moretrees.dates_grow_interval		= 2 * moretrees.dates_flower_interval * moretrees.dates_flower_chance
 | 
					 | 
				
			||||||
							-- As date palms have a high yield, don't grow dates too fast
 | 
					 | 
				
			||||||
							-- The actual interval will vary randomly between 67% and 133% of this value.
 | 
					 | 
				
			||||||
							-- 2 * 59 * 181 ~ 6 hours. So by default flowers become dates in about one (human) day.
 | 
					 | 
				
			||||||
moretrees.dates_item_drop_ichance	= 10 		-- inverse probability of ripe dates dropping as items (instead of disappearing)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Sapling settings
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.sapling_interval		= 100
 | 
					 | 
				
			||||||
moretrees.sapling_chance		= 5
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- If this variable is set to true, drop leaves out as entities during leaf
 | 
					 | 
				
			||||||
-- decay, rather than just disappearing them.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
moretrees.decay_leaves_as_items = false
 | 
					 | 
				
			||||||
							
								
								
									
										291
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										291
									
								
								init.lua
									
									
									
									
									
								
							@@ -15,37 +15,41 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
moretrees = {}
 | 
					moretrees = {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.override_item("default:sapling", {
 | 
					local S = minetest.get_translator("moretrees")
 | 
				
			||||||
	description = "Sapling"
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.override_item("default:tree", {
 | 
					if minetest.get_modpath("default") then
 | 
				
			||||||
	description = "Tree"
 | 
						minetest.override_item("default:sapling", {
 | 
				
			||||||
})
 | 
							description = S("Sapling")
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.override_item("default:wood", {
 | 
						minetest.override_item("default:tree", {
 | 
				
			||||||
	description = "Wooden Planks"
 | 
							description = S("Tree")
 | 
				
			||||||
})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.override_item("default:leaves", {
 | 
						minetest.override_item("default:wood", {
 | 
				
			||||||
	description = "Leaves"
 | 
							description = S("Wooden Planks")
 | 
				
			||||||
})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.override_item("default:fence_wood", {
 | 
						minetest.override_item("default:leaves", {
 | 
				
			||||||
	description = "Wooden Fence"
 | 
							description = S("Leaves")
 | 
				
			||||||
})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.override_item("default:fence_rail_wood", {
 | 
						minetest.override_item("default:fence_wood", {
 | 
				
			||||||
	description = "Wooden Fence Rail"
 | 
							description = S("Wooden Fence")
 | 
				
			||||||
})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						minetest.override_item("default:fence_rail_wood", {
 | 
				
			||||||
 | 
							description = S("Wooden Fence Rail")
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if minetest.get_modpath("doors") then
 | 
					if minetest.get_modpath("doors") then
 | 
				
			||||||
	minetest.override_item("doors:gate_wood_closed", {
 | 
						minetest.override_item("doors:gate_wood_closed", {
 | 
				
			||||||
		description = "Wooden Fence Gate"
 | 
							description = S("Wooden Fence Gate")
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.override_item("doors:gate_wood_open", {
 | 
						minetest.override_item("doors:gate_wood_open", {
 | 
				
			||||||
		description = "Wooden Fence Gate"
 | 
							description = S("Wooden Fence Gate")
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -55,13 +59,27 @@ end
 | 
				
			|||||||
local worldpath=minetest.get_worldpath()
 | 
					local worldpath=minetest.get_worldpath()
 | 
				
			||||||
local modpath=minetest.get_modpath("moretrees")
 | 
					local modpath=minetest.get_modpath("moretrees")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
dofile(modpath.."/default_settings.txt")
 | 
					dofile(modpath.."/settings.lua")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if io.open(worldpath.."/moretrees_settings.txt","r") then
 | 
					if io.open(worldpath.."/moretrees_settings.txt","r") then
 | 
				
			||||||
	io.close()
 | 
						io.close()
 | 
				
			||||||
	dofile(worldpath.."/moretrees_settings.txt")
 | 
						dofile(worldpath.."/moretrees_settings.txt")
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- Validate that if ethereal exists, that it's version is greater than 20220424.
 | 
				
			||||||
 | 
					-- Lower versions of ethereal clear registered biomes and decorations during
 | 
				
			||||||
 | 
					-- initialization which results in lost content from this mod (and others)
 | 
				
			||||||
 | 
					-- depending on where they are in the mod load order.
 | 
				
			||||||
 | 
					minetest.register_on_mods_loaded(function()
 | 
				
			||||||
 | 
						if minetest.global_exists("ethereal") then
 | 
				
			||||||
 | 
							local ethereal_ver = tonumber(ethereal.version)
 | 
				
			||||||
 | 
							if (ethereal_ver and ethereal_ver < 20220424) then
 | 
				
			||||||
 | 
								error("[moretrees] The version of ethereal detected can result " ..
 | 
				
			||||||
 | 
									  "in parts of this mod and others disappearing due to mod " ..
 | 
				
			||||||
 | 
									  "load order. Please update ethereal.");
 | 
				
			||||||
 | 
							end
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- infinite stacks checking
 | 
					-- infinite stacks checking
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -75,10 +93,10 @@ end
 | 
				
			|||||||
-- tables, load other files
 | 
					-- tables, load other files
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.cutting_tools = {
 | 
					moretrees.cutting_tools = {
 | 
				
			||||||
	"default:axe_bronze",
 | 
					 | 
				
			||||||
	"default:axe_diamond",
 | 
					 | 
				
			||||||
	"default:axe_mese",
 | 
						"default:axe_mese",
 | 
				
			||||||
	"default:axe_steel",
 | 
						xcompat.materials.axe_steel,
 | 
				
			||||||
 | 
						xcompat.materials.axe_diamond,
 | 
				
			||||||
 | 
						xcompat.materials.axe_bronze,
 | 
				
			||||||
	"glooptest:axe_alatro",
 | 
						"glooptest:axe_alatro",
 | 
				
			||||||
	"glooptest:axe_arol",
 | 
						"glooptest:axe_arol",
 | 
				
			||||||
	"moreores:axe_mithril",
 | 
						"moreores:axe_mithril",
 | 
				
			||||||
@@ -95,111 +113,103 @@ dofile(modpath.."/saplings.lua")
 | 
				
			|||||||
dofile(modpath.."/crafts.lua")
 | 
					dofile(modpath.."/crafts.lua")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- tree spawning setup
 | 
					-- tree spawning setup
 | 
				
			||||||
 | 
					moretrees.spawn_beech_object = moretrees.beech_model
 | 
				
			||||||
 | 
					moretrees.spawn_apple_tree_object = moretrees.apple_tree_model
 | 
				
			||||||
 | 
					moretrees.spawn_oak_object = moretrees.oak_model
 | 
				
			||||||
 | 
					moretrees.spawn_sequoia_object = moretrees.sequoia_model
 | 
				
			||||||
 | 
					moretrees.spawn_palm_object = moretrees.palm_model
 | 
				
			||||||
 | 
					moretrees.spawn_date_palm_object = moretrees.date_palm_model
 | 
				
			||||||
 | 
					moretrees.spawn_cedar_object = moretrees.cedar_model
 | 
				
			||||||
 | 
					moretrees.spawn_rubber_tree_object = moretrees.rubber_tree_model
 | 
				
			||||||
 | 
					moretrees.spawn_willow_object = moretrees.willow_model
 | 
				
			||||||
 | 
					moretrees.spawn_birch_object = "moretrees.grow_birch"
 | 
				
			||||||
 | 
					moretrees.spawn_spruce_object = "moretrees.grow_spruce"
 | 
				
			||||||
 | 
					moretrees.spawn_jungletree_object = "moretrees.grow_jungletree"
 | 
				
			||||||
 | 
					moretrees.spawn_fir_object = "moretrees.grow_fir"
 | 
				
			||||||
 | 
					moretrees.spawn_fir_snow_object = "moretrees.grow_fir_snow"
 | 
				
			||||||
 | 
					moretrees.spawn_poplar_object = moretrees.poplar_model
 | 
				
			||||||
 | 
					moretrees.spawn_poplar_small_object = moretrees.poplar_small_model
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.spawn_saplings then
 | 
					local deco_ids = {}
 | 
				
			||||||
	moretrees.spawn_beech_object = "moretrees:beech_sapling_ongen"
 | 
					
 | 
				
			||||||
	moretrees.spawn_apple_tree_object = "moretrees:apple_tree_sapling_ongen"
 | 
					function translate_biome_defs(def, treename, index)
 | 
				
			||||||
	moretrees.spawn_oak_object = "moretrees:oak_sapling_ongen"
 | 
						if not index then index = 1 end
 | 
				
			||||||
	moretrees.spawn_sequoia_object = "moretrees:sequoia_sapling_ongen"
 | 
						local deco_def = {
 | 
				
			||||||
	moretrees.spawn_palm_object = "moretrees:palm_sapling_ongen"
 | 
							name = treename .. "_" .. index,
 | 
				
			||||||
	moretrees.spawn_date_palm_object = "moretrees:date_palm_sapling_ongen"
 | 
							deco_type = "simple",
 | 
				
			||||||
	moretrees.spawn_cedar_object = "moretrees:cedar_sapling_ongen"
 | 
							place_on = def.place_on,
 | 
				
			||||||
	moretrees.spawn_rubber_tree_object = "moretrees:rubber_tree_sapling_ongen"
 | 
							sidelen = 16,
 | 
				
			||||||
	moretrees.spawn_willow_object = "moretrees:willow_sapling_ongen"
 | 
							fill_ratio = def.fill_ratio or 0.001,
 | 
				
			||||||
	moretrees.spawn_birch_object = "moretrees:birch_sapling_ongen"
 | 
							--biomes eventually?
 | 
				
			||||||
	moretrees.spawn_spruce_object = "moretrees:spruce_sapling_ongen"
 | 
							y_min = def.min_elevation,
 | 
				
			||||||
	moretrees.spawn_jungletree_object = "moretrees:jungletree_sapling_ongen"
 | 
							y_max = def.max_elevation,
 | 
				
			||||||
	moretrees.spawn_fir_object = "moretrees:fir_sapling_ongen"
 | 
							spawn_by = def.spawn_by,
 | 
				
			||||||
	moretrees.spawn_fir_snow_object = "snow:sapling_pine"
 | 
							num_spawn_by = def.num_spawn_by,
 | 
				
			||||||
	moretrees.spawn_poplar_object = "moretrees:poplar_sapling_ongen"
 | 
							decoration = "moretrees:"..treename.."_sapling_ongen"
 | 
				
			||||||
	moretrees.spawn_poplar_small_object = "moretrees:poplar_small_sapling_ongen"
 | 
						}
 | 
				
			||||||
else
 | 
					
 | 
				
			||||||
	moretrees.spawn_beech_object = moretrees.beech_model
 | 
						deco_ids[#deco_ids+1] = treename .. ("_" .. index or "_1")
 | 
				
			||||||
	moretrees.spawn_apple_tree_object = moretrees.apple_tree_model
 | 
					
 | 
				
			||||||
	moretrees.spawn_oak_object = moretrees.oak_model
 | 
						return deco_def
 | 
				
			||||||
	moretrees.spawn_sequoia_object = moretrees.sequoia_model
 | 
					 | 
				
			||||||
	moretrees.spawn_palm_object = moretrees.palm_model
 | 
					 | 
				
			||||||
	moretrees.spawn_date_palm_object = moretrees.date_palm_model
 | 
					 | 
				
			||||||
	moretrees.spawn_cedar_object = moretrees.cedar_model
 | 
					 | 
				
			||||||
	moretrees.spawn_rubber_tree_object = moretrees.rubber_tree_model
 | 
					 | 
				
			||||||
	moretrees.spawn_willow_object = moretrees.willow_model
 | 
					 | 
				
			||||||
	moretrees.spawn_birch_object = "moretrees.grow_birch"
 | 
					 | 
				
			||||||
	moretrees.spawn_spruce_object = "moretrees.grow_spruce"
 | 
					 | 
				
			||||||
	moretrees.spawn_jungletree_object = "moretrees.grow_jungletree"
 | 
					 | 
				
			||||||
	moretrees.spawn_fir_object = "moretrees.grow_fir"
 | 
					 | 
				
			||||||
	moretrees.spawn_fir_snow_object = "moretrees.grow_fir_snow"
 | 
					 | 
				
			||||||
	moretrees.spawn_poplar_object = moretrees.poplar_model
 | 
					 | 
				
			||||||
	moretrees.spawn_poplar_small_object = moretrees.poplar_small_model
 | 
					 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.enable_beech then
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.beech_biome, "beech"))
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.beech_biome, moretrees.spawn_beech_object)
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.apple_tree_biome, "apple_tree"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.oak_biome, "oak"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.sequoia_biome, "sequoia"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.palm_biome, "palm"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.date_palm_biome, "date_palm", 1))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.date_palm_biome_2, "date_palm", 2))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.cedar_biome, "cedar"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.rubber_tree_biome, "rubber_tree"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.willow_biome, "willow"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.birch_biome, "birch"))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.spruce_biome, "spruce"))
 | 
				
			||||||
 | 
					if minetest.get_modpath("default") then
 | 
				
			||||||
 | 
						minetest.register_decoration(translate_biome_defs(moretrees.jungletree_biome, "jungletree"))
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.fir_biome, "fir", 1))
 | 
				
			||||||
if moretrees.enable_apple_tree then
 | 
					if minetest.get_modpath("snow") then
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.apple_tree_biome, moretrees.spawn_apple_tree_object)
 | 
						minetest.register_decoration(translate_biome_defs(moretrees.fir_biome_snow, "fir", 2))
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.poplar_biome, "poplar", 1))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.poplar_biome_2, "poplar", 2))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.poplar_biome_3, "poplar", 3))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.poplar_small_biome, "poplar_small", 4))
 | 
				
			||||||
 | 
					minetest.register_decoration(translate_biome_defs(moretrees.poplar_small_biome_2, "poplar_small", 5))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.enable_oak then
 | 
					--[[
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.oak_biome, moretrees.spawn_oak_object)
 | 
						this is purposefully wrapped in a on mods loaded callback to that it gets the proper ids
 | 
				
			||||||
end
 | 
						if other mods clear the registered decorations
 | 
				
			||||||
 | 
					]]
 | 
				
			||||||
if moretrees.enable_sequoia then
 | 
					minetest.register_on_mods_loaded(function()
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.sequoia_biome, moretrees.spawn_sequoia_object)
 | 
						for k, v in pairs(deco_ids) do
 | 
				
			||||||
end
 | 
							deco_ids[k] = minetest.get_decoration_id(v)
 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_palm then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.palm_biome, moretrees.spawn_palm_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_date_palm then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.date_palm_biome, moretrees.spawn_date_palm_object)
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.date_palm_biome_2, moretrees.spawn_date_palm_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_cedar then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.cedar_biome, moretrees.spawn_cedar_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_rubber_tree then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.rubber_tree_biome, moretrees.spawn_rubber_tree_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_willow then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.willow_biome, moretrees.spawn_willow_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_birch then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.birch_biome, moretrees.spawn_birch_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_spruce then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.spruce_biome, moretrees.spawn_spruce_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_jungle_tree then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.jungletree_biome, moretrees.spawn_jungletree_object)
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if moretrees.enable_fir then
 | 
					 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.fir_biome, moretrees.spawn_fir_object)
 | 
					 | 
				
			||||||
	if minetest.get_modpath("snow") then
 | 
					 | 
				
			||||||
		biome_lib:register_generate_plant(moretrees.fir_biome_snow, moretrees.spawn_fir_snow_object)
 | 
					 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
end
 | 
						minetest.set_gen_notify("decoration", deco_ids)
 | 
				
			||||||
 | 
					end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.enable_poplar then
 | 
					minetest.register_on_generated(function(minp, maxp, blockseed)
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.poplar_biome, moretrees.spawn_poplar_object)
 | 
					    local g = minetest.get_mapgen_object("gennotify")
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.poplar_biome_2, moretrees.spawn_poplar_object)
 | 
					    local locations = {}
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.poplar_biome_3, moretrees.spawn_poplar_object)
 | 
						for _, id in pairs(deco_ids) do
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.poplar_small_biome, moretrees.spawn_poplar_small_object)
 | 
							local deco_locations = g["decoration#" .. id] or {}
 | 
				
			||||||
	biome_lib:register_generate_plant(moretrees.poplar_small_biome_2, moretrees.spawn_poplar_small_object)
 | 
							for _, pos in pairs(deco_locations) do
 | 
				
			||||||
end
 | 
								locations[#locations+1] = pos
 | 
				
			||||||
 | 
							end
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if #locations == 0 then return end
 | 
				
			||||||
 | 
					    for _, pos in ipairs(locations) do
 | 
				
			||||||
 | 
					        local timer = minetest.get_node_timer({x=pos.x, y=pos.y+1, z=pos.z})
 | 
				
			||||||
 | 
					        timer:start(math.random(2,10))
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- Code to spawn a birch tree
 | 
					-- Code to spawn a birch tree
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function moretrees.grow_birch(pos)
 | 
					function moretrees.grow_birch(pos)
 | 
				
			||||||
	minetest.swap_node(pos, biome_lib.air)
 | 
						minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
	if math.random(1,2) == 1 then
 | 
						if math.random(1,2) == 1 then
 | 
				
			||||||
		minetest.spawn_tree(pos, moretrees.birch_model1)
 | 
							minetest.spawn_tree(pos, moretrees.birch_model1)
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -210,7 +220,7 @@ end
 | 
				
			|||||||
-- Code to spawn a spruce tree
 | 
					-- Code to spawn a spruce tree
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function moretrees.grow_spruce(pos)
 | 
					function moretrees.grow_spruce(pos)
 | 
				
			||||||
	minetest.swap_node(pos, biome_lib.air)
 | 
						minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
	if math.random(1,2) == 1 then
 | 
						if math.random(1,2) == 1 then
 | 
				
			||||||
		minetest.spawn_tree(pos, moretrees.spruce_model1)
 | 
							minetest.spawn_tree(pos, moretrees.spruce_model1)
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -225,6 +235,7 @@ moretrees.jt_rules_a1 = "FFF[&&-FBf[&&&Ff]^^^Ff][&&+FBFf[&&&FFf]^^^Ff][&&---FBFf
 | 
				
			|||||||
moretrees.jt_rules_b1 = "[-Ff&f][+Ff&f]B"
 | 
					moretrees.jt_rules_b1 = "[-Ff&f][+Ff&f]B"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.jt_axiom2 = "FFFFFA"
 | 
					moretrees.jt_axiom2 = "FFFFFA"
 | 
				
			||||||
 | 
					-- luacheck: no max line length
 | 
				
			||||||
moretrees.jt_rules_a2 = "FFFFF[&&-FFFBF[&&&FFff]^^^FFf][&&+FFFBFF[&&&FFff]^^^FFf][&&---FFFBFF[&&&FFff]^^^FFf][&&+++FFFBFF[&&&FFff]^^^FFf]FF/A"
 | 
					moretrees.jt_rules_a2 = "FFFFF[&&-FFFBF[&&&FFff]^^^FFf][&&+FFFBFF[&&&FFff]^^^FFf][&&---FFFBFF[&&&FFff]^^^FFf][&&+++FFFBFF[&&&FFff]^^^FFf]FF/A"
 | 
				
			||||||
moretrees.jt_rules_b2 = "[-FFf&ff][+FFf&ff]B"
 | 
					moretrees.jt_rules_b2 = "[-FFf&ff][+FFf&ff]B"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -264,10 +275,13 @@ function moretrees.grow_jungletree(pos)
 | 
				
			|||||||
		moretrees.jungletree_model.rules_b = moretrees.jt_rules_b2
 | 
							moretrees.jungletree_model.rules_b = moretrees.jt_rules_b2
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.swap_node(pos, biome_lib.air)
 | 
						minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
	local leaves = minetest.find_nodes_in_area({x = pos.x-1, y = pos.y, z = pos.z-1}, {x = pos.x+1, y = pos.y+10, z = pos.z+1}, "default:leaves")
 | 
						local leaves = minetest.find_nodes_in_area(
 | 
				
			||||||
 | 
							{x = pos.x-1, y = pos.y, z = pos.z-1}, {x = pos.x+1, y = pos.y+10, z = pos.z+1},
 | 
				
			||||||
 | 
							xcompat.materials.apple_leaves
 | 
				
			||||||
 | 
						)
 | 
				
			||||||
	for leaf in ipairs(leaves) do
 | 
						for leaf in ipairs(leaves) do
 | 
				
			||||||
			minetest.swap_node(leaves[leaf], biome_lib.air)
 | 
								minetest.swap_node(leaves[leaf], {name = "air"})
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
	minetest.spawn_tree(pos, moretrees.jungletree_model)
 | 
						minetest.spawn_tree(pos, moretrees.jungletree_model)
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
@@ -291,10 +305,14 @@ function moretrees.grow_fir(pos)
 | 
				
			|||||||
	moretrees.fir_model.iterations = 7
 | 
						moretrees.fir_model.iterations = 7
 | 
				
			||||||
	moretrees.fir_model.random_level = 5
 | 
						moretrees.fir_model.random_level = 5
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.swap_node(pos, biome_lib.air)
 | 
						minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
	local leaves = minetest.find_nodes_in_area({x = pos.x, y = pos.y, z = pos.z}, {x = pos.x, y = pos.y+5, z = pos.z}, "default:leaves")
 | 
						local leaves = minetest.find_nodes_in_area(
 | 
				
			||||||
 | 
							{x = pos.x, y = pos.y, z = pos.z},
 | 
				
			||||||
 | 
							{x = pos.x, y = pos.y+5, z = pos.z},
 | 
				
			||||||
 | 
							xcompat.materials.apple_leaves
 | 
				
			||||||
 | 
						)
 | 
				
			||||||
	for leaf in ipairs(leaves) do
 | 
						for leaf in ipairs(leaves) do
 | 
				
			||||||
		minetest.swap_node(leaves[leaf], biome_lib.air)
 | 
							minetest.swap_node(leaves[leaf], {name = "air"})
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
	minetest.spawn_tree(pos,moretrees.fir_model)
 | 
						minetest.spawn_tree(pos,moretrees.fir_model)
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
@@ -318,12 +336,29 @@ function moretrees.grow_fir_snow(pos)
 | 
				
			|||||||
	moretrees.fir_model.iterations = 2
 | 
						moretrees.fir_model.iterations = 2
 | 
				
			||||||
	moretrees.fir_model.random_level = 2
 | 
						moretrees.fir_model.random_level = 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.swap_node(pos, biome_lib.air)
 | 
						minetest.swap_node(pos, {name = "air"})
 | 
				
			||||||
	local leaves = minetest.find_nodes_in_area({x = pos.x, y = pos.y, z = pos.z}, {x = pos.x, y = pos.y+5, z = pos.z}, "default:leaves")
 | 
						local leaves = minetest.find_nodes_in_area(
 | 
				
			||||||
 | 
							{x = pos.x, y = pos.y, z = pos.z},
 | 
				
			||||||
 | 
							{x = pos.x, y = pos.y+5, z = pos.z},
 | 
				
			||||||
 | 
							xcompat.materials.apple_leaves
 | 
				
			||||||
 | 
						)
 | 
				
			||||||
	for leaf in ipairs(leaves) do
 | 
						for leaf in ipairs(leaves) do
 | 
				
			||||||
			minetest.swap_node(leaves[leaf], biome_lib.air)
 | 
								minetest.swap_node(leaves[leaf], {name = "air"})
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
	minetest.spawn_tree(pos,moretrees.fir_model)
 | 
						minetest.spawn_tree(pos,moretrees.fir_model)
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
print("[Moretrees] Loaded (2013-02-11)")
 | 
					if moretrees.grow_legacy_saplings then
 | 
				
			||||||
 | 
						minetest.register_lbm({
 | 
				
			||||||
 | 
							name = "moretrees:grow_ongen_saplings",
 | 
				
			||||||
 | 
							label = "Grow legacy ongen saplings",
 | 
				
			||||||
 | 
							nodenames = {"group:moretrees_ongen"},
 | 
				
			||||||
 | 
							run_at_every_load = true,
 | 
				
			||||||
 | 
							action = function(pos)
 | 
				
			||||||
 | 
								minetest.log("info", "[moretrees] Starting growth timer for legacy ongen sapling at "..minetest.pos_to_string(pos, 0))
 | 
				
			||||||
 | 
								minetest.get_node_timer(pos):start(math.random(2, 10))
 | 
				
			||||||
 | 
							end
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					minetest.log("info", "[moretrees] Loading done")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -61,7 +61,7 @@ Birch Tree Fence=Birkenholz-Zaun
 | 
				
			|||||||
Birch Tree Fence Gate=Birkenholz-Tor
 | 
					Birch Tree Fence Gate=Birkenholz-Tor
 | 
				
			||||||
Birch Tree Fence Rail=Birkenholz-Schiene
 | 
					Birch Tree Fence Rail=Birkenholz-Schiene
 | 
				
			||||||
Birch Tree Leaves=Birkenlaub
 | 
					Birch Tree Leaves=Birkenlaub
 | 
				
			||||||
Birch Tree Planks=Birkebretter
 | 
					Birch Tree Planks=Birkenbretter
 | 
				
			||||||
Birch Tree Planks Slab=Birkenholzplatte
 | 
					Birch Tree Planks Slab=Birkenholzplatte
 | 
				
			||||||
Birch Tree Planks Stair=Birkeholzstufe
 | 
					Birch Tree Planks Stair=Birkeholzstufe
 | 
				
			||||||
Birch Tree Sapling=Birkensetzling
 | 
					Birch Tree Sapling=Birkensetzling
 | 
				
			||||||
@@ -209,3 +209,12 @@ Willow Tree Trunk=Weidenstamm
 | 
				
			|||||||
Willow Tree Trunk Slab=Weidenstammplatte
 | 
					Willow Tree Trunk Slab=Weidenstammplatte
 | 
				
			||||||
Willow Tree Trunk Stair=Weidenstammstufe
 | 
					Willow Tree Trunk Stair=Weidenstammstufe
 | 
				
			||||||
Yellow=gelb
 | 
					Yellow=gelb
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# init.lua
 | 
				
			||||||
 | 
					Sapling=Setzling
 | 
				
			||||||
 | 
					Tree=Baum
 | 
				
			||||||
 | 
					Wooden Planks=Holzbretter
 | 
				
			||||||
 | 
					Leaves=Blätter
 | 
				
			||||||
 | 
					Wooden Fence=Holzzaun
 | 
				
			||||||
 | 
					Wooden Fence Rail=Holzschiene
 | 
				
			||||||
 | 
					Wooden Fence Gate=Holztor
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,11 +1,11 @@
 | 
				
			|||||||
# textdomain: moretrees
 | 
					# textdomain: moretrees
 | 
				
			||||||
# Translation by Carlos Barraza
 | 
					# Translation by Carlos Barraza, improvements by David Leal.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### cocos_palm.lua ###
 | 
					### cocos_palm.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Coconut=Coco
 | 
					Coconut=Coco
 | 
				
			||||||
Coconut Flower=
 | 
					Coconut Flower=Flor de Coco
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### crafts.lua ###
 | 
					### crafts.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -17,8 +17,8 @@ Date & nut snack=Datilera y Nueces
 | 
				
			|||||||
Date-nut cake=Pastel de Datilera
 | 
					Date-nut cake=Pastel de Datilera
 | 
				
			||||||
Date-nut cake batter=Pasta de torta de Datilera
 | 
					Date-nut cake batter=Pasta de torta de Datilera
 | 
				
			||||||
Date-nut energy bar=Barra energetica de Datilera
 | 
					Date-nut energy bar=Barra energetica de Datilera
 | 
				
			||||||
Raw Coconut=Coco crudo
 | 
					Raw Coconut=Coco Crudo
 | 
				
			||||||
Roasted Cedar Cone Nuts=Coco de Alamo Tostado
 | 
					Roasted Cedar Cone Nuts=Coco de Álamo Tostado
 | 
				
			||||||
Roasted Fir Cone Nuts=Cono de Abeto Tostado
 | 
					Roasted Fir Cone Nuts=Cono de Abeto Tostado
 | 
				
			||||||
Roasted Spruce Cone Nuts=Cono de Picea Tostado
 | 
					Roasted Spruce Cone Nuts=Cono de Picea Tostado
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -30,182 +30,191 @@ Dates=Datilera
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
### node_defs.lua ###
 | 
					### node_defs.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@1 (fast growth)=
 | 
					@1 (fast growth)=@1 (crecimiento rápido)
 | 
				
			||||||
Acorn=Bellota
 | 
					Acorn=Bellota
 | 
				
			||||||
Apple Tree=
 | 
					Apple Tree=Árbol de manzana
 | 
				
			||||||
Apple Tree Fence=
 | 
					Apple Tree Fence=Valla de manzano
 | 
				
			||||||
Apple Tree Fence Gate=
 | 
					Apple Tree Fence Gate=Puerta de Valla de Manzano
 | 
				
			||||||
Apple Tree Fence Rail=
 | 
					Apple Tree Fence Rail=Riel de Valla de Manzano
 | 
				
			||||||
Apple Tree Leaves=Hojas de Arbol de Manzana
 | 
					Apple Tree Leaves=Hojas de Árbol de Manzana
 | 
				
			||||||
Apple Tree Planks=Madera de Arbol de Manzana
 | 
					Apple Tree Planks=Madera de Árbol de Manzana
 | 
				
			||||||
Apple Tree Planks Slab=
 | 
					Apple Tree Planks Slab=Losa de Tablones de Manzano
 | 
				
			||||||
Apple Tree Planks Stair=
 | 
					Apple Tree Planks Stair=Escalera de Tablones de Manzano
 | 
				
			||||||
Apple Tree Sapling=Retoño de Arbol de Manzana
 | 
					Apple Tree Sapling=Retoño de Árbol de Manzana
 | 
				
			||||||
Apple Tree Trunk=Tronco de Arbol de Manzana
 | 
					Apple Tree Trunk=Tronco de Árbol de Manzana
 | 
				
			||||||
Apple Tree Trunk Slab=
 | 
					Apple Tree Trunk Slab=Losa de Tronco de Manzano
 | 
				
			||||||
Apple Tree Trunk Stair=
 | 
					Apple Tree Trunk Stair=Escalera de Tronco de Manzano
 | 
				
			||||||
Beech Tree=
 | 
					Beech Tree=Haya
 | 
				
			||||||
Beech Tree Fence=
 | 
					Beech Tree Fence=Valla de Haya
 | 
				
			||||||
Beech Tree Fence Gate=
 | 
					Beech Tree Fence Gate=Puerta de Valla de Haya
 | 
				
			||||||
Beech Tree Fence Rail=
 | 
					Beech Tree Fence Rail=Riel de Valla de Haya
 | 
				
			||||||
Beech Tree Leaves=Hojas de Arbol de Haya
 | 
					Beech Tree Leaves=Hojas de Arbol de Haya
 | 
				
			||||||
Beech Tree Planks=Madera de Arbol de Haya
 | 
					Beech Tree Planks=Madera de Arbol de Haya
 | 
				
			||||||
Beech Tree Planks Slab=
 | 
					Beech Tree Planks Slab=Losa de Tablones de Haya
 | 
				
			||||||
Beech Tree Planks Stair=
 | 
					Beech Tree Planks Stair=Escalera de Tablones de Haya
 | 
				
			||||||
Beech Tree Sapling=Retoño de Arbol de Haya
 | 
					Beech Tree Sapling=Retoño de Árbol de Haya
 | 
				
			||||||
Beech Tree Trunk=Tronco de Arbol de Haya
 | 
					Beech Tree Trunk=Tronco de Árbol de Haya
 | 
				
			||||||
Beech Tree Trunk Slab=
 | 
					Beech Tree Trunk Slab=Losa de Tronco de Haya
 | 
				
			||||||
Beech Tree Trunk Stair=
 | 
					Beech Tree Trunk Stair=Escalera de Tronco de Haya
 | 
				
			||||||
Birch Tree=
 | 
					Birch Tree=Abedul
 | 
				
			||||||
Birch Tree Fence=
 | 
					Birch Tree Fence=Valla de Abedul
 | 
				
			||||||
Birch Tree Fence Gate=
 | 
					Birch Tree Fence Gate=Puerta de Valla de Abedul
 | 
				
			||||||
Birch Tree Fence Rail=
 | 
					Birch Tree Fence Rail=Riel de Valla de Abedul
 | 
				
			||||||
Birch Tree Leaves=Hojas de Arbol de Abedul
 | 
					Birch Tree Leaves=Hojas de Arbol de Abedul
 | 
				
			||||||
Birch Tree Planks=Madera de Arbol de Abedul
 | 
					Birch Tree Planks=Madera de Arbol de Abedul
 | 
				
			||||||
Birch Tree Planks Slab=
 | 
					Birch Tree Planks Slab=Losa de Tablones de Abedul
 | 
				
			||||||
Birch Tree Planks Stair=
 | 
					Birch Tree Planks Stair=Escalera de Tablones de Abedul
 | 
				
			||||||
Birch Tree Sapling=Retoño de Arbol de Abedul
 | 
					Birch Tree Sapling=Retoño de Árbol de Abedul
 | 
				
			||||||
Birch Tree Trunk=Tronco de Arbol de Abedul
 | 
					Birch Tree Trunk=Tronco de Árbol de Abedul
 | 
				
			||||||
Birch Tree Trunk Slab=
 | 
					Birch Tree Trunk Slab=Losa de Tronco de Abedul
 | 
				
			||||||
Birch Tree Trunk Stair=
 | 
					Birch Tree Trunk Stair=Escalera de Tronco de Abedul
 | 
				
			||||||
Cedar Cone=Coco de Alamo
 | 
					Cedar Cone=Coco de Álamo
 | 
				
			||||||
Cedar Tree=
 | 
					Cedar Tree=Árbol de Cedro
 | 
				
			||||||
Cedar Tree Fence=
 | 
					Cedar Tree Fence=Valla de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Fence Gate=
 | 
					Cedar Tree Fence Gate=Puerta de Valla de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Fence Rail=
 | 
					Cedar Tree Fence Rail=Riel de Valla de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Leaves=Hojas de Arbol de Cedro
 | 
					Cedar Tree Leaves=Hojas de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Planks=Madera de Arbol de Cedro
 | 
					Cedar Tree Planks=Madera de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Planks Slab=
 | 
					Cedar Tree Planks Slab=Losa de Tablones de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Planks Stair=
 | 
					Cedar Tree Planks Stair=Escalera de Tablones de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Sapling=Retoño de Arbol de Cedro
 | 
					Cedar Tree Sapling=Retoño de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Trunk=Tronco de Arbol de Cedro
 | 
					Cedar Tree Trunk=Tronco de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Trunk Slab=
 | 
					Cedar Tree Trunk Slab=Losa de Tronco de Árbol de Cedro
 | 
				
			||||||
Cedar Tree Trunk Stair=
 | 
					Cedar Tree Trunk Stair=Escalera de Tronco de Árbol de Cedro
 | 
				
			||||||
Date Palm Tree=
 | 
					Date Palm Tree=Palmera Datilera
 | 
				
			||||||
Date Palm Tree Fence=
 | 
					Date Palm Tree Fence=Valla de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Fence Gate=
 | 
					Date Palm Tree Fence Gate=Puerta de Valla de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Fence Rail=
 | 
					Date Palm Tree Fence Rail=Riel de Valla de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Leaves=
 | 
					Date Palm Tree Leaves=Hojas de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Planks=Madera de Palmera Datilera
 | 
					Date Palm Tree Planks=Madera de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Planks Slab=
 | 
					Date Palm Tree Planks Slab=Losa de Tablones de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Planks Stair=
 | 
					Date Palm Tree Planks Stair=Escalera de Tablones de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Sapling=
 | 
					Date Palm Tree Sapling=Retoño de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Trunk=Tronco de Palmera Datilera
 | 
					Date Palm Tree Trunk=Tronco de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Trunk Slab=
 | 
					Date Palm Tree Trunk Slab=Losa de Tronco de Palmera Datilera
 | 
				
			||||||
Date Palm Tree Trunk Stair=
 | 
					Date Palm Tree Trunk Stair=Escalera de Tronco de Palmera Datilera
 | 
				
			||||||
Douglas Fir=
 | 
					Douglas Fir=Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Fence=
 | 
					Douglas Fir Fence=Valla de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Fence Gate=
 | 
					Douglas Fir Fence Gate=Puerta de Valla de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Fence Rail=
 | 
					Douglas Fir Fence Rail=Riel de Valla de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Leaves=Hojas de Arbol de Abeto de Douglas
 | 
					Douglas Fir Leaves=Hojas de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Leaves (Bright)=Hojas de Arbol de Abeto de Douglas (Brillante)
 | 
					Douglas Fir Leaves (Bright)=Hojas de Árbol de Abeto de Douglas (Brillante)
 | 
				
			||||||
Douglas Fir Planks=Madera de Arbol de Abeto de Douglas
 | 
					Douglas Fir Planks=Madera de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Planks Slab=
 | 
					Douglas Fir Planks Slab=Losa de Tablones de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Planks Stair=
 | 
					Douglas Fir Planks Stair=Escalera de Tablones de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Sapling=Retoño de Arbol de Abeto de Douglas
 | 
					Douglas Fir Sapling=Retoño de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Trunk=Tronco de Arbol de Abeto de Douglas
 | 
					Douglas Fir Trunk=Tronco de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Trunk Slab=
 | 
					Douglas Fir Trunk Slab=Losa de Tronco de Árbol de Abeto de Douglas
 | 
				
			||||||
Douglas Fir Trunk Stair=
 | 
					Douglas Fir Trunk Stair=Escalera de Tronco de Árbol de Abeto de Douglas
 | 
				
			||||||
Fir Cone=Coco de Abeto
 | 
					Fir Cone=Coco de Abeto
 | 
				
			||||||
Giant Sequoia=
 | 
					Giant Sequoia=Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Fence=
 | 
					Giant Sequoia Fence=Valla de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Fence Gate=
 | 
					Giant Sequoia Fence Gate=Puerta de Valla de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Fence Rail=
 | 
					Giant Sequoia Fence Rail=Riel de Valla de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Leaves=Hojas de Sequoia Gigante
 | 
					Giant Sequoia Leaves=Hojas de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Planks=Madera de Sequoia Gigante
 | 
					Giant Sequoia Planks=Madera de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Planks Slab=
 | 
					Giant Sequoia Planks Slab=Losa de Tablones de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Planks Stair=
 | 
					Giant Sequoia Planks Stair=Escalera de Tablones de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Sapling=Retoño de Arbol de Sequoia Gigante
 | 
					Giant Sequoia Sapling=Retoño de Árbol de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Trunk=Tronco de Sequoia Gigante
 | 
					Giant Sequoia Trunk=Tronco de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Trunk Slab=
 | 
					Giant Sequoia Trunk Slab=Losa de Tronco de Secuoya Gigante
 | 
				
			||||||
Giant Sequoia Trunk Stair=
 | 
					Giant Sequoia Trunk Stair=Escalera de Tronco de Secuoya Gigante
 | 
				
			||||||
Jungle Tree=Tronco de Arbol de Arbol de la Selva
 | 
					Jungle Tree=Árbol de la Selva
 | 
				
			||||||
Jungle Tree Fence=
 | 
					Jungle Tree Fence=Valla de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Fence Gate=
 | 
					Jungle Tree Fence Gate=Puerta de Valla de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Fence Rail=
 | 
					Jungle Tree Fence Rail=Riel de Valla de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Leaves=Hojas de Arbol de la Selva
 | 
					Jungle Tree Leaves=Hojas de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Leaves (@1)=Hojas de Arbol de la Selva (@1)
 | 
					Jungle Tree Leaves (@1)=Hojas de Árbol de la Selva (@1)
 | 
				
			||||||
Jungle Tree Planks=
 | 
					Jungle Tree Planks=Madera de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Planks Slab=
 | 
					Jungle Tree Planks Slab=Losa de Tablones de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Planks Stair=
 | 
					Jungle Tree Planks Stair=Escalera de Tablones de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Sapling=
 | 
					Jungle Tree Sapling=Retoño de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Trunk=
 | 
					Jungle Tree Trunk=Tronco de Árbol de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Trunk Slab=
 | 
					Jungle Tree Trunk Slab=Losa de Tronco de Árbol de la Selva
 | 
				
			||||||
Jungle Tree Trunk Stair=
 | 
					Jungle Tree Trunk Stair=Escalera de Tronco de Árbol de la Selva
 | 
				
			||||||
Oak Tree=
 | 
					Oak Tree=Árbol de Roble
 | 
				
			||||||
Oak Tree Fence=
 | 
					Oak Tree Fence=Valla de Árbol de Roble
 | 
				
			||||||
Oak Tree Fence Gate=
 | 
					Oak Tree Fence Gate=Puerta de Valla de Árbol de Roble
 | 
				
			||||||
Oak Tree Fence Rail=
 | 
					Oak Tree Fence Rail=Riel de Valla de Árbol de Roble
 | 
				
			||||||
Oak Tree Leaves=Hojas de Arbol de Roble
 | 
					Oak Tree Leaves=Hojas de Árbol de Roble
 | 
				
			||||||
Oak Tree Planks=Madera de Arbol de Roble
 | 
					Oak Tree Planks=Madera de Árbol de Roble
 | 
				
			||||||
Oak Tree Planks Slab=
 | 
					Oak Tree Planks Slab=Losa de Tablones de Árbol de Roble
 | 
				
			||||||
Oak Tree Planks Stair=
 | 
					Oak Tree Planks Stair=Escalera de Tablones de Árbol de Roble
 | 
				
			||||||
Oak Tree Sapling=Retoño de Arbol de Roble
 | 
					Oak Tree Sapling=Retoño de Árbol de Roble
 | 
				
			||||||
Oak Tree Trunk=Tronco de Arbol de Roble
 | 
					Oak Tree Trunk=Tronco de Árbol de Roble
 | 
				
			||||||
Oak Tree Trunk Slab=
 | 
					Oak Tree Trunk Slab=Losa de Tronco de Árbol de Roble
 | 
				
			||||||
Oak Tree Trunk Stair=
 | 
					Oak Tree Trunk Stair=Escalera de Tronco de Árbol de Roble
 | 
				
			||||||
Palm Tree=
 | 
					Palm Tree=Palmera
 | 
				
			||||||
Palm Tree Fence=
 | 
					Palm Tree Fence=Valla de Palmera
 | 
				
			||||||
Palm Tree Fence Gate=
 | 
					Palm Tree Fence Gate=Puerta de Valla de Palmera
 | 
				
			||||||
Palm Tree Fence Rail=
 | 
					Palm Tree Fence Rail=Riel de Valla de Palmera
 | 
				
			||||||
Palm Tree Leaves=Hojas de Palmera
 | 
					Palm Tree Leaves=Hojas de Palmera
 | 
				
			||||||
Palm Tree Planks=Madera de Palmera
 | 
					Palm Tree Planks=Madera de Palmera
 | 
				
			||||||
Palm Tree Planks Slab=
 | 
					Palm Tree Planks Slab=Losa de Tablones de Palmera
 | 
				
			||||||
Palm Tree Planks Stair=
 | 
					Palm Tree Planks Stair=Escalera de Tablones de Palmera
 | 
				
			||||||
Palm Tree Sapling=Retoño de Palmera
 | 
					Palm Tree Sapling=Retoño de Palmera
 | 
				
			||||||
Palm Tree Trunk=Tronco de Palmera
 | 
					Palm Tree Trunk=Tronco de Palmera
 | 
				
			||||||
Palm Tree Trunk Slab=
 | 
					Palm Tree Trunk Slab=Losa de Troncos de Palmera
 | 
				
			||||||
Palm Tree Trunk Stair=
 | 
					Palm Tree Trunk Stair=Escalera de Troncos de Palmera
 | 
				
			||||||
Poplar Tree=
 | 
					Poplar Tree=Árbol de Alamo
 | 
				
			||||||
Poplar Tree Fence=
 | 
					Poplar Tree Fence=Valla de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Fence Gate=
 | 
					Poplar Tree Fence Gate=Puerta de Valla de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Fence Rail=
 | 
					Poplar Tree Fence Rail=Riel de Valla de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Leaves=Hojas de Arbol de Alamo
 | 
					Poplar Tree Leaves=Hojas de Arbol de Alamo
 | 
				
			||||||
Poplar Tree Planks=Madera de Arbol de Alamo
 | 
					Poplar Tree Planks=Madera de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Planks Slab=
 | 
					Poplar Tree Planks Slab=Losa de Tablones de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Planks Stair=
 | 
					Poplar Tree Planks Stair=Escalera de Tablones de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Sapling=Retoño de Arbol de Alamo
 | 
					Poplar Tree Sapling=Retoño de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Trunk=Tronco de Arbol de Alamo
 | 
					Poplar Tree Trunk=Tronco de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Trunk Slab=
 | 
					Poplar Tree Trunk Slab=Losa de Tronco de Árbol de Alamo
 | 
				
			||||||
Poplar Tree Trunk Stair=
 | 
					Poplar Tree Trunk Stair=Escalera de Tronco de Árbol de Alamo
 | 
				
			||||||
Red=Roja
 | 
					Red=Rojo
 | 
				
			||||||
Rubber Tree=
 | 
					Rubber Tree=Árbol del Caucho
 | 
				
			||||||
Rubber Tree Fence=
 | 
					Rubber Tree Fence=Valla de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Fence Gate=
 | 
					Rubber Tree Fence Gate=Puerta de Valla de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Fence Rail=
 | 
					Rubber Tree Fence Rail=Riel de Valla de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Leaves=Hojas de Arbol de Arbol de Goma
 | 
					Rubber Tree Leaves=Hojas de Árbol de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Planks=Madera de Arbol de Arbol de Goma
 | 
					Rubber Tree Planks=Madera de Árbol de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Planks Slab=
 | 
					Rubber Tree Planks Slab=Losa de Tablones de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Planks Stair=
 | 
					Rubber Tree Planks Stair=Escalera de Tablones de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Sapling=Retoño de Arbol de Arbol de Goma
 | 
					Rubber Tree Sapling=Retoño de Árbol de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Trunk=Tronco de Arbol de Arbol de Goma
 | 
					Rubber Tree Trunk=Tronco de Árbol de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Trunk (Empty)=Tronco de Arbol de Goma (Vacio)
 | 
					Rubber Tree Trunk (Empty)=Tronco de Árbol del Caucho (Vacío)
 | 
				
			||||||
Rubber Tree Trunk Slab=
 | 
					Rubber Tree Trunk Slab=Losa de Tronco de Árbol del Caucho
 | 
				
			||||||
Rubber Tree Trunk Stair=
 | 
					Rubber Tree Trunk Stair=Escalera de Tronco de Árbol del Caucho
 | 
				
			||||||
Small poplar Tree Sapling=
 | 
					Small poplar Tree Sapling=Pequeño Retoño de Álamo
 | 
				
			||||||
Spruce Cone=Coco de Picea
 | 
					Spruce Cone=Coco de Picea
 | 
				
			||||||
Spruce Tree=
 | 
					Spruce Tree=Árbol de Abeto
 | 
				
			||||||
Spruce Tree Fence=
 | 
					Spruce Tree Fence=Valla de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Fence Gate=
 | 
					Spruce Tree Fence Gate=Puerta de Valla de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Fence Rail=
 | 
					Spruce Tree Fence Rail=Riel de Valla de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Leaves=Hojas de Arbol de Abeto
 | 
					Spruce Tree Leaves=Hojas de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Planks=Madera de Arbol de Abeto
 | 
					Spruce Tree Planks=Madera de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Planks Slab=
 | 
					Spruce Tree Planks Slab=Losa de Tablones de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Planks Stair=
 | 
					Spruce Tree Planks Stair=Escalera de Tablones de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Sapling=Retoño de Arbol de Abeto
 | 
					Spruce Tree Sapling=Retoño de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Trunk=Tronco de Arbol de Abeto
 | 
					Spruce Tree Trunk=Tronco de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Trunk Slab=
 | 
					Spruce Tree Trunk Slab=Losa de Tronco de Árbol de Abeto
 | 
				
			||||||
Spruce Tree Trunk Stair=
 | 
					Spruce Tree Trunk Stair=Escalera de Tronco de Árbol de Abeto
 | 
				
			||||||
Willow Tree=
 | 
					Willow Tree=Árbol de Sauce
 | 
				
			||||||
Willow Tree Fence=
 | 
					Willow Tree Fence=Valla de Árbol de Sauce
 | 
				
			||||||
Willow Tree Fence Gate=
 | 
					Willow Tree Fence Gate=Puerta de Valla de Árbol de Sauce
 | 
				
			||||||
Willow Tree Fence Rail=
 | 
					Willow Tree Fence Rail=Riel de Valla de Árbol de Sauce
 | 
				
			||||||
Willow Tree Leaves=Hojas de Arbol de Sauce
 | 
					Willow Tree Leaves=Hojas de Árbol de Sauce
 | 
				
			||||||
Willow Tree Planks=Madera de Arbol de Sauce
 | 
					Willow Tree Planks=Madera de Árbol de Sauce
 | 
				
			||||||
Willow Tree Planks Slab=
 | 
					Willow Tree Planks Slab=Losa de Tablones de Árbol de Sauce
 | 
				
			||||||
Willow Tree Planks Stair=
 | 
					Willow Tree Planks Stair=Escalera de Tablones de Árbol de Sauce
 | 
				
			||||||
Willow Tree Sapling=Retoño de Arbol de Sauce
 | 
					Willow Tree Sapling=Retoño de Árbol de Sauce
 | 
				
			||||||
Willow Tree Trunk=Tronco de Arbol de Sauce
 | 
					Willow Tree Trunk=Tronco de Árbol de Sauce
 | 
				
			||||||
Willow Tree Trunk Slab=
 | 
					Willow Tree Trunk Slab=Losa de Tronco de Árbol de Sauce
 | 
				
			||||||
Willow Tree Trunk Stair=
 | 
					Willow Tree Trunk Stair=Escalera de Tronco de Árbol de Sauce
 | 
				
			||||||
Yellow=Amarilla
 | 
					Yellow=Amarillo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# init.lua
 | 
				
			||||||
 | 
					Sapling=Retoño
 | 
				
			||||||
 | 
					Tree=Árbol
 | 
				
			||||||
 | 
					Wooden Planks=Tablones
 | 
				
			||||||
 | 
					Leaves=Hojas
 | 
				
			||||||
 | 
					Wooden Fence=Valla
 | 
				
			||||||
 | 
					Wooden Fence Rail=Riel de Valla
 | 
				
			||||||
 | 
					Wooden Fence Gate=Puerta de Valla
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -209,3 +209,12 @@ Willow Tree Trunk=Tronc d'arbre de saule
 | 
				
			|||||||
Willow Tree Trunk Slab=Dalle en tronc de saule
 | 
					Willow Tree Trunk Slab=Dalle en tronc de saule
 | 
				
			||||||
Willow Tree Trunk Stair=Escalier en tronc de saule
 | 
					Willow Tree Trunk Stair=Escalier en tronc de saule
 | 
				
			||||||
Yellow=jaune
 | 
					Yellow=jaune
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# init.lua
 | 
				
			||||||
 | 
					Sapling=Jeune Arbre
 | 
				
			||||||
 | 
					Tree=Arbre
 | 
				
			||||||
 | 
					Wooden Planks=Planches
 | 
				
			||||||
 | 
					Leaves=Feuilles
 | 
				
			||||||
 | 
					Wooden Fence=Barrière en bois
 | 
				
			||||||
 | 
					Wooden Fence Rail=Rail de clôture en bois
 | 
				
			||||||
 | 
					Wooden Fence Gate=Porte de clôture en bois
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										219
									
								
								locale/moretrees.ru.tr
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										219
									
								
								locale/moretrees.ru.tr
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,219 @@
 | 
				
			|||||||
 | 
					# textdomain: moretrees
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### cocos_palm.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Coconut=Кокос
 | 
				
			||||||
 | 
					Coconut Flower=Цветок кокоса
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### crafts.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Acorn Muffin=Маффин с желудями
 | 
				
			||||||
 | 
					Acorn Muffin batter=Тесто для маффина с желудями
 | 
				
			||||||
 | 
					Coconut Milk=Кокосовое молоко
 | 
				
			||||||
 | 
					Date=Финик
 | 
				
			||||||
 | 
					Date & nut snack=Закуска из фиников и орехов
 | 
				
			||||||
 | 
					Date-nut cake=Финиково-ореховый пирог
 | 
				
			||||||
 | 
					Date-nut cake batter=Тесто для финиково-орехового пирога
 | 
				
			||||||
 | 
					Date-nut energy bar=Финиково-ореховый батончик
 | 
				
			||||||
 | 
					Raw Coconut=Сырой кокос
 | 
				
			||||||
 | 
					Roasted Cedar Cone Nuts=Жареные кедровые орешки
 | 
				
			||||||
 | 
					Roasted Fir Cone Nuts=Жареные орешки пихты
 | 
				
			||||||
 | 
					Roasted Spruce Cone Nuts=Жареные еловые орешки
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### date_palm.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Date Flowers=Цветки фиников
 | 
				
			||||||
 | 
					Date Stem=Стебель финика
 | 
				
			||||||
 | 
					Dates=Финики
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### node_defs.lua ###
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@1 (fast growth)=@1 (бестрый рост)
 | 
				
			||||||
 | 
					Acorn=Желудь
 | 
				
			||||||
 | 
					Apple Tree=Яблоня
 | 
				
			||||||
 | 
					Apple Tree Fence=Яблоневый забор
 | 
				
			||||||
 | 
					Apple Tree Fence Gate=Яблоневые ворота
 | 
				
			||||||
 | 
					Apple Tree Fence Rail=Яблоневые перила
 | 
				
			||||||
 | 
					Apple Tree Leaves=Листья яблони
 | 
				
			||||||
 | 
					Apple Tree Planks=Яблоневые доски
 | 
				
			||||||
 | 
					Apple Tree Planks Slab=Яблоневые доски (плита)
 | 
				
			||||||
 | 
					Apple Tree Planks Stair=Яблоневые доски (ступени)
 | 
				
			||||||
 | 
					Apple Tree Sapling=Саженец яблони
 | 
				
			||||||
 | 
					Apple Tree Trunk=Ствол яблони
 | 
				
			||||||
 | 
					Apple Tree Trunk Slab=Ствол яблони (плита)
 | 
				
			||||||
 | 
					Apple Tree Trunk Stair=Ствол яблони (ступени)
 | 
				
			||||||
 | 
					Beech Tree=Бук
 | 
				
			||||||
 | 
					Beech Tree Fence=Забор из бука
 | 
				
			||||||
 | 
					Beech Tree Fence Gate=Ворота из бука
 | 
				
			||||||
 | 
					Beech Tree Fence Rail=Перила из бука
 | 
				
			||||||
 | 
					Beech Tree Leaves=Листья бука
 | 
				
			||||||
 | 
					Beech Tree Planks=Доски из бука
 | 
				
			||||||
 | 
					Beech Tree Planks Slab=Доски из бука (плита)
 | 
				
			||||||
 | 
					Beech Tree Planks Stair=Доски из бука (ступени)
 | 
				
			||||||
 | 
					Beech Tree Sapling=Саженец бука
 | 
				
			||||||
 | 
					Beech Tree Trunk=Ствол бука
 | 
				
			||||||
 | 
					Beech Tree Trunk Slab=Ствол бука (плита)
 | 
				
			||||||
 | 
					Beech Tree Trunk Stair=Ствол бука (ступени)
 | 
				
			||||||
 | 
					Birch Tree=Береза
 | 
				
			||||||
 | 
					Birch Tree Fence=Березовый забор
 | 
				
			||||||
 | 
					Birch Tree Fence Gate=Березовые ворота
 | 
				
			||||||
 | 
					Birch Tree Fence Rail=Березовые перила
 | 
				
			||||||
 | 
					Birch Tree Leaves=Березовые листья
 | 
				
			||||||
 | 
					Birch Tree Planks=Березовые доски
 | 
				
			||||||
 | 
					Birch Tree Planks Slab=Березовые доски (плита)
 | 
				
			||||||
 | 
					Birch Tree Planks Stair=Березовые доски (ступени)
 | 
				
			||||||
 | 
					Birch Tree Sapling=Саженец березы
 | 
				
			||||||
 | 
					Birch Tree Trunk=Ствол березы
 | 
				
			||||||
 | 
					Birch Tree Trunk Slab=Ствол березы (плита)
 | 
				
			||||||
 | 
					Birch Tree Trunk Stair=Ствол березы (ступени)
 | 
				
			||||||
 | 
					Cedar Cone=Кедровая шишка
 | 
				
			||||||
 | 
					Cedar Tree=Кедр
 | 
				
			||||||
 | 
					Cedar Tree Fence=Забор из кедра
 | 
				
			||||||
 | 
					Cedar Tree Fence Gate=Ворота из кедра
 | 
				
			||||||
 | 
					Cedar Tree Fence Rail=Перила из кедра
 | 
				
			||||||
 | 
					Cedar Tree Leaves=Кедровая хвоя
 | 
				
			||||||
 | 
					Cedar Tree Planks=Доски из кедра
 | 
				
			||||||
 | 
					Cedar Tree Planks Slab=Доски из кедра (плита)
 | 
				
			||||||
 | 
					Cedar Tree Planks Stair=Доски из кедра (ступени)
 | 
				
			||||||
 | 
					Cedar Tree Sapling=Саженец кедра
 | 
				
			||||||
 | 
					Cedar Tree Trunk=Ствол кедра
 | 
				
			||||||
 | 
					Cedar Tree Trunk Slab=Ствол кедра (плита)
 | 
				
			||||||
 | 
					Cedar Tree Trunk Stair=Ствол кедра (ступени)
 | 
				
			||||||
 | 
					Date Palm Tree=Финиковая пальма
 | 
				
			||||||
 | 
					Date Palm Tree Fence=Забор из финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Fence Gate=Ворота из финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Fence Rail=Перила из финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Leaves=Листья финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Planks=Доски из финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Planks Slab=Доски из финиковой пальмы (плита)
 | 
				
			||||||
 | 
					Date Palm Tree Planks Stair=Доски из финиковой пальмы (ступени)
 | 
				
			||||||
 | 
					Date Palm Tree Sapling=Саженец финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Trunk=Ствол финиковой пальмы
 | 
				
			||||||
 | 
					Date Palm Tree Trunk Slab=Ствол финиковой пальмы (плита)
 | 
				
			||||||
 | 
					Date Palm Tree Trunk Stair=Ствол финиковой пальмы (ступени)
 | 
				
			||||||
 | 
					Douglas Fir=Дугласова пихта
 | 
				
			||||||
 | 
					Douglas Fir Fence=Забор из дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Fence Gate=Ворота из дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Fence Rail=Перила из дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Leaves=Хвоя дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Leaves (Bright)=Листья дугласовой пихты (яркие)
 | 
				
			||||||
 | 
					Douglas Fir Planks=Доски из дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Planks Slab=Доски из дугласовой пихты (плита)
 | 
				
			||||||
 | 
					Douglas Fir Planks Stair=Доски из дугласовой пихты (ступени)
 | 
				
			||||||
 | 
					Douglas Fir Sapling=Саженец дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Trunk=Ствол дугласовой пихты
 | 
				
			||||||
 | 
					Douglas Fir Trunk Slab=Ствол дугласовой пихты (плита)
 | 
				
			||||||
 | 
					Douglas Fir Trunk Stair=Ствол дугласовой пихты (ступени)
 | 
				
			||||||
 | 
					Fir Cone=Пихтовая шишка
 | 
				
			||||||
 | 
					Giant Sequoia=Гигантская секвойя
 | 
				
			||||||
 | 
					Giant Sequoia Fence=Забор из гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Fence Gate=Ворота из гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Fence Rail=Перила из гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Leaves=Хвоя гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Planks=Доски из гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Planks Slab=Доски из гигантской секвойи (плита)
 | 
				
			||||||
 | 
					Giant Sequoia Planks Stair=Доски из гигантской секвойи (ступени)
 | 
				
			||||||
 | 
					Giant Sequoia Sapling=Саженец гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Trunk=Ствол гигантской секвойи
 | 
				
			||||||
 | 
					Giant Sequoia Trunk Slab=Ствол гигантской секвойи (плита)
 | 
				
			||||||
 | 
					Giant Sequoia Trunk Stair=Ствол гигантской секвойи (ступени)
 | 
				
			||||||
 | 
					Jungle Tree=Тропическое дерево
 | 
				
			||||||
 | 
					Jungle Tree Fence=Забор из тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Fence Gate=Ворота из тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Fence Rail=Перила из тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Leaves=Листья тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Leaves (@1)=Листья тропического дерева (@1)
 | 
				
			||||||
 | 
					Jungle Tree Planks=Доски из тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Planks Slab=Доски из тропического дерева (плита)
 | 
				
			||||||
 | 
					Jungle Tree Planks Stair=Доски из тропического дерева (ступени)
 | 
				
			||||||
 | 
					Jungle Tree Sapling=Саженец тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Trunk=Ствол тропического дерева
 | 
				
			||||||
 | 
					Jungle Tree Trunk Slab=Ствол тропического дерева (плита)
 | 
				
			||||||
 | 
					Jungle Tree Trunk Stair=Ствол тропического дерева (ступени)
 | 
				
			||||||
 | 
					Oak Tree=Дуб
 | 
				
			||||||
 | 
					Oak Tree Fence=Дубовый забор
 | 
				
			||||||
 | 
					Oak Tree Fence Gate=Дубовые ворота
 | 
				
			||||||
 | 
					Oak Tree Fence Rail=Дубовые перила
 | 
				
			||||||
 | 
					Oak Tree Leaves=Листья дуба
 | 
				
			||||||
 | 
					Oak Tree Planks=Дубовые доски
 | 
				
			||||||
 | 
					Oak Tree Planks Slab=Дубовые доски (плита)
 | 
				
			||||||
 | 
					Oak Tree Planks Stair=Дубовые доски (ступени)
 | 
				
			||||||
 | 
					Oak Tree Sapling=Саженец дуба
 | 
				
			||||||
 | 
					Oak Tree Trunk=Ствол дуба
 | 
				
			||||||
 | 
					Oak Tree Trunk Slab=Ствол дуба (плита)
 | 
				
			||||||
 | 
					Oak Tree Trunk Stair=Ствол дуба (ступени)
 | 
				
			||||||
 | 
					Palm Tree=Пальма
 | 
				
			||||||
 | 
					Palm Tree Fence=Пальмовый забор
 | 
				
			||||||
 | 
					Palm Tree Fence Gate=Пальмовые ворота
 | 
				
			||||||
 | 
					Palm Tree Fence Rail=Пальмовые перила
 | 
				
			||||||
 | 
					Palm Tree Leaves=Листья пальмы
 | 
				
			||||||
 | 
					Palm Tree Planks=Пальмовые доски
 | 
				
			||||||
 | 
					Palm Tree Planks Slab=Пальмовые доски (плита)
 | 
				
			||||||
 | 
					Palm Tree Planks Stair=Пальмовые доски (ступени)
 | 
				
			||||||
 | 
					Palm Tree Sapling=Саженец пальмы
 | 
				
			||||||
 | 
					Palm Tree Trunk=Ствол пальмы
 | 
				
			||||||
 | 
					Palm Tree Trunk Slab=Ствол пальмы (плита)
 | 
				
			||||||
 | 
					Palm Tree Trunk Stair=Ствол пальмы (ступени)
 | 
				
			||||||
 | 
					Poplar Tree=Тополь
 | 
				
			||||||
 | 
					Poplar Tree Fence=Забор из тополя
 | 
				
			||||||
 | 
					Poplar Tree Fence Gate=Ворота из тополя
 | 
				
			||||||
 | 
					Poplar Tree Fence Rail=Перила из тополя
 | 
				
			||||||
 | 
					Poplar Tree Leaves=Листья тополя
 | 
				
			||||||
 | 
					Poplar Tree Planks=Доски из тополя
 | 
				
			||||||
 | 
					Poplar Tree Planks Slab=Доски из тополя (плита)
 | 
				
			||||||
 | 
					Poplar Tree Planks Stair=Доски из тополя (ступени)
 | 
				
			||||||
 | 
					Poplar Tree Sapling=Саженец тополя
 | 
				
			||||||
 | 
					Poplar Tree Trunk=Ствол тополя
 | 
				
			||||||
 | 
					Poplar Tree Trunk Slab=Ствол тополя (плита)
 | 
				
			||||||
 | 
					Poplar Tree Trunk Stair=Ствол тополя (ступени)
 | 
				
			||||||
 | 
					Red=красные
 | 
				
			||||||
 | 
					Rubber Tree=Каучуковое дерево
 | 
				
			||||||
 | 
					Rubber Tree Fence=Забор из каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Fence Gate=Ворота из каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Fence Rail=Перила из каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Leaves=Листья каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Planks=Доски из каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Planks Slab=Доски из каучукового дерева (плита)
 | 
				
			||||||
 | 
					Rubber Tree Planks Stair=Доски из каучукового дерева (ступени)
 | 
				
			||||||
 | 
					Rubber Tree Sapling=Саженец каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Trunk=Ствол каучукового дерева
 | 
				
			||||||
 | 
					Rubber Tree Trunk (Empty)=Ствол каучукового дерева (пусто)
 | 
				
			||||||
 | 
					Rubber Tree Trunk Slab=Ствол каучукового дерева (плита)
 | 
				
			||||||
 | 
					Rubber Tree Trunk Stair=Ствол каучукового дерева (ступени)
 | 
				
			||||||
 | 
					Small poplar Tree Sapling=Малы саженец тополя
 | 
				
			||||||
 | 
					Spruce Cone=Еловая шишка
 | 
				
			||||||
 | 
					Spruce Tree=Ель
 | 
				
			||||||
 | 
					Spruce Tree Fence=Еловый забор
 | 
				
			||||||
 | 
					Spruce Tree Fence Gate=Еловые ворота
 | 
				
			||||||
 | 
					Spruce Tree Fence Rail=Еловые перила
 | 
				
			||||||
 | 
					Spruce Tree Leaves=Еловая хвоя
 | 
				
			||||||
 | 
					Spruce Tree Planks=Еловые доски
 | 
				
			||||||
 | 
					Spruce Tree Planks Slab=Еловые доски (плита)
 | 
				
			||||||
 | 
					Spruce Tree Planks Stair=Еловые доски (ступени)
 | 
				
			||||||
 | 
					Spruce Tree Sapling=Саженец ели
 | 
				
			||||||
 | 
					Spruce Tree Trunk=Ствол ели
 | 
				
			||||||
 | 
					Spruce Tree Trunk Slab=Ствол ели (плита)
 | 
				
			||||||
 | 
					Spruce Tree Trunk Stair=Ствол ели (ступени)
 | 
				
			||||||
 | 
					Willow Tree=Ива
 | 
				
			||||||
 | 
					Willow Tree Fence=Ивовый забор
 | 
				
			||||||
 | 
					Willow Tree Fence Gate=Ивовые ворота
 | 
				
			||||||
 | 
					Willow Tree Fence Rail=Ивовые перила
 | 
				
			||||||
 | 
					Willow Tree Leaves=Листья ивы
 | 
				
			||||||
 | 
					Willow Tree Planks=Ивовые доски
 | 
				
			||||||
 | 
					Willow Tree Planks Slab=Ивовые доски (плита)
 | 
				
			||||||
 | 
					Willow Tree Planks Stair=Ивовые доски (ступени)
 | 
				
			||||||
 | 
					Willow Tree Sapling=Саженец ивы
 | 
				
			||||||
 | 
					Willow Tree Trunk=Ствол ивы
 | 
				
			||||||
 | 
					Willow Tree Trunk Slab=Ствол ивы (плита)
 | 
				
			||||||
 | 
					Willow Tree Trunk Stair=Ствол ивы (ступени)
 | 
				
			||||||
 | 
					Yellow=желтые
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# init.lua
 | 
				
			||||||
 | 
					Sapling=Саженец
 | 
				
			||||||
 | 
					Tree=Дерево
 | 
				
			||||||
 | 
					Wooden Planks=Деревянные доски
 | 
				
			||||||
 | 
					Leaves=Листья
 | 
				
			||||||
 | 
					Wooden Fence=Деревянный забор
 | 
				
			||||||
 | 
					Wooden Fence Rail=Деревянные перила
 | 
				
			||||||
 | 
					Wooden Fence Gate=Деревянные ворота
 | 
				
			||||||
@@ -208,3 +208,12 @@ Willow Tree Trunk=
 | 
				
			|||||||
Willow Tree Trunk Slab=
 | 
					Willow Tree Trunk Slab=
 | 
				
			||||||
Willow Tree Trunk Stair=
 | 
					Willow Tree Trunk Stair=
 | 
				
			||||||
Yellow=
 | 
					Yellow=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# init.lua
 | 
				
			||||||
 | 
					Sapling=
 | 
				
			||||||
 | 
					Tree=
 | 
				
			||||||
 | 
					Wooden Planks=
 | 
				
			||||||
 | 
					Leaves=
 | 
				
			||||||
 | 
					Wooden Fence=
 | 
				
			||||||
 | 
					Wooden Fence Rail=
 | 
				
			||||||
 | 
					Wooden Fence Gate=
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								mod.conf
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								mod.conf
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
name = moretrees
 | 
					name = moretrees
 | 
				
			||||||
depends = default, biome_lib, vessels
 | 
					depends = xcompat
 | 
				
			||||||
optional_depends = doors, stairs, moreblocks, farming
 | 
					optional_depends = doors, stairs, moreblocks, farming, default, vessels
 | 
				
			||||||
min_minetest_version = 5.2.0
 | 
					min_minetest_version = 5.2.0
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										355
									
								
								node_defs.lua
									
									
									
									
									
								
							
							
						
						
									
										355
									
								
								node_defs.lua
									
									
									
									
									
								
							@@ -2,22 +2,25 @@ local S = minetest.get_translator("moretrees")
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
moretrees.avoidnodes = {}
 | 
					moretrees.avoidnodes = {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					local jungle_sapling_texture = minetest.get_modpath("default") and "default_junglesapling.png"
 | 
				
			||||||
 | 
						or "moretrees_cedar_sapling.png"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.treelist = {
 | 
					moretrees.treelist = {
 | 
				
			||||||
	{"beech",        S("Beech Tree")},
 | 
						{"beech",        S("Beech Tree")},
 | 
				
			||||||
	{"apple_tree",   S("Apple Tree")},
 | 
						{"apple_tree",   S("Apple Tree")},
 | 
				
			||||||
	{"oak",          S("Oak Tree"),       "acorn",                 S("Acorn"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
						{"oak",          S("Oak Tree"),       "acorn",                S("Acorn"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
				
			||||||
	{"sequoia",      S("Giant Sequoia")},
 | 
						{"sequoia",      S("Giant Sequoia")},
 | 
				
			||||||
	{"birch",        S("Birch Tree")},
 | 
						{"birch",        S("Birch Tree")},
 | 
				
			||||||
	{"palm",         S("Palm Tree"),      "palm_fruit_trunk_gen",  S("Palm Tree"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 1.0 },
 | 
						{"palm",         S("Palm Tree"),      "palm_fruit_trunk_gen", S("Palm Tree"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 1.0 },
 | 
				
			||||||
	{"date_palm",    S("Date Palm Tree"), "date_palm_fruit_trunk", S("Date Palm Tree"), {0, 0, 0, 0, 0, 0}, 0.0 },
 | 
						{"date_palm",    S("Date Palm Tree"), "date_palm_fruit_trunk",S("Date Palm Tree"), {0, 0, 0, 0, 0, 0}, 0.0 },
 | 
				
			||||||
	{"spruce",       S("Spruce Tree"),    "spruce_cone",           S("Spruce Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
						{"spruce",       S("Spruce Tree"),    "spruce_cone",          S("Spruce Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
				
			||||||
	{"cedar",        S("Cedar Tree"),     "cedar_cone",            S("Cedar Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
						{"cedar",        S("Cedar Tree"),     "cedar_cone",           S("Cedar Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
				
			||||||
	{"poplar",       S("Poplar Tree")},
 | 
						{"poplar",       S("Poplar Tree")},
 | 
				
			||||||
	{"poplar_small", S("Poplar Tree")},
 | 
						{"poplar_small", S("Poplar Tree")},
 | 
				
			||||||
	{"willow",       S("Willow Tree")},
 | 
						{"willow",       S("Willow Tree")},
 | 
				
			||||||
	{"rubber_tree",  S("Rubber Tree")},
 | 
						{"rubber_tree",  S("Rubber Tree")},
 | 
				
			||||||
	{"fir",          S("Douglas Fir"),    "fir_cone",              S("Fir Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
						{"fir",          S("Douglas Fir"),    "fir_cone",             S("Fir Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
 | 
				
			||||||
	{"jungletree",   S("Jungle Tree"),     nil,                    nil, nil, nil, "default_junglesapling.png"  },
 | 
						{"jungletree",   S("Jungle Tree"),     nil,                   nil, nil, nil, jungle_sapling_texture  },
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.treedesc = {
 | 
					moretrees.treedesc = {
 | 
				
			||||||
@@ -223,8 +226,8 @@ end
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
-- redefine default leaves to handle plantlike and/or leaf decay options
 | 
					-- redefine default leaves to handle plantlike and/or leaf decay options
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.plantlike_leaves then
 | 
					if minetest.get_modpath("default") and moretrees.plantlike_leaves then
 | 
				
			||||||
	minetest.override_item("default:leaves", {
 | 
						minetest.override_item(xcompat.materials.apple_leaves, {
 | 
				
			||||||
		inventory_image = minetest.inventorycube("default_leaves.png"),
 | 
							inventory_image = minetest.inventorycube("default_leaves.png"),
 | 
				
			||||||
		drawtype = "plantlike",
 | 
							drawtype = "plantlike",
 | 
				
			||||||
		visual_scale = math.sqrt(2)
 | 
							visual_scale = math.sqrt(2)
 | 
				
			||||||
@@ -233,8 +236,8 @@ end
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
-- redefine default jungle leaves for same
 | 
					-- redefine default jungle leaves for same
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.plantlike_leaves then
 | 
					if minetest.get_modpath("default") and moretrees.plantlike_leaves then
 | 
				
			||||||
	minetest.override_item("default:jungleleaves", {
 | 
						minetest.override_item(xcompat.materials.jungle_leaves, {
 | 
				
			||||||
		inventory_image = minetest.inventorycube("default_jungleleaves.png"),
 | 
							inventory_image = minetest.inventorycube("default_jungleleaves.png"),
 | 
				
			||||||
		drawtype = "plantlike",
 | 
							drawtype = "plantlike",
 | 
				
			||||||
		visual_scale = math.sqrt(2)
 | 
							visual_scale = math.sqrt(2)
 | 
				
			||||||
@@ -264,9 +267,9 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
		decay = moretrees.date_palm_leafdecay_radius
 | 
							decay = moretrees.date_palm_leafdecay_radius
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if treename ~= "jungletree"  -- the default game provides jungle tree and pine trunk/planks nodes.
 | 
						-- dont register planks/nodes for trees from default and small varients for trees
 | 
				
			||||||
		and treename ~= "poplar_small"
 | 
						local split_tn = treename:split("_")
 | 
				
			||||||
		and treename ~= "pine" then
 | 
						if treename ~= "jungletree" and treename ~= "pine" and split_tn[2]~="small" then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		saptex = "moretrees_"..treename.."_sapling.png"
 | 
							saptex = "moretrees_"..treename.."_sapling.png"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -280,46 +283,19 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
			paramtype2 = "facedir",
 | 
								paramtype2 = "facedir",
 | 
				
			||||||
			is_ground_content = false,
 | 
								is_ground_content = false,
 | 
				
			||||||
			groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
 | 
								groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
 | 
				
			||||||
			sounds = default.node_sound_wood_defaults(),
 | 
								sounds = xcompat.sounds.node_sound_wood_defaults(),
 | 
				
			||||||
			on_place = minetest.rotate_node,
 | 
								on_place = minetest.rotate_node,
 | 
				
			||||||
		})
 | 
							})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		minetest.register_node("moretrees:"..treename.."_planks", {
 | 
							if moretrees.enable_planks then
 | 
				
			||||||
			description = moretrees.treedesc[treename].planks,
 | 
								minetest.register_node("moretrees:"..treename.."_planks", {
 | 
				
			||||||
			tiles = {"moretrees_"..treename.."_wood.png"},
 | 
									description = moretrees.treedesc[treename].planks,
 | 
				
			||||||
			is_ground_content = false,
 | 
									tiles = {"moretrees_"..treename.."_wood.png"},
 | 
				
			||||||
			groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1},
 | 
									is_ground_content = false,
 | 
				
			||||||
			sounds = default.node_sound_wood_defaults(),
 | 
									groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1},
 | 
				
			||||||
		})
 | 
									sounds = xcompat.sounds.node_sound_wood_defaults(),
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
		minetest.register_node("moretrees:"..treename.."_sapling", {
 | 
							end
 | 
				
			||||||
			description = moretrees.treedesc[treename].sapling,
 | 
					 | 
				
			||||||
			drawtype = "plantlike",
 | 
					 | 
				
			||||||
			tiles = {saptex},
 | 
					 | 
				
			||||||
			inventory_image = saptex,
 | 
					 | 
				
			||||||
			paramtype = "light",
 | 
					 | 
				
			||||||
			paramtype2 = "waving",
 | 
					 | 
				
			||||||
			walkable = false,
 | 
					 | 
				
			||||||
			is_ground_content = true,
 | 
					 | 
				
			||||||
			selection_box = {
 | 
					 | 
				
			||||||
				type = "fixed",
 | 
					 | 
				
			||||||
				fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3}
 | 
					 | 
				
			||||||
			},
 | 
					 | 
				
			||||||
			groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,sapling=1},
 | 
					 | 
				
			||||||
			sounds = default.node_sound_defaults(),
 | 
					 | 
				
			||||||
			on_place = function(itemstack, placer, pointed_thing)
 | 
					 | 
				
			||||||
				itemstack = default.sapling_on_place(itemstack, placer, pointed_thing,
 | 
					 | 
				
			||||||
					"moretrees:" ..treename.. "_sapling",
 | 
					 | 
				
			||||||
					-- minp, maxp to be checked, relative to sapling pos
 | 
					 | 
				
			||||||
					-- minp_relative.y = 1 because sapling pos has been checked
 | 
					 | 
				
			||||||
					{x = -3, y = 1, z = -3},
 | 
					 | 
				
			||||||
					{x = 3, y = 6, z = 3},
 | 
					 | 
				
			||||||
					-- maximum interval of interior volume check
 | 
					 | 
				
			||||||
					4)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				return itemstack
 | 
					 | 
				
			||||||
			end,
 | 
					 | 
				
			||||||
		})
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		local moretrees_leaves_inventory_image = nil
 | 
							local moretrees_leaves_inventory_image = nil
 | 
				
			||||||
		local moretrees_new_leaves_waving = nil
 | 
							local moretrees_new_leaves_waving = nil
 | 
				
			||||||
@@ -340,7 +316,7 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
			paramtype = "light",
 | 
								paramtype = "light",
 | 
				
			||||||
			is_ground_content = false,
 | 
								is_ground_content = false,
 | 
				
			||||||
			groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 1},
 | 
								groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 1},
 | 
				
			||||||
			sounds = default.node_sound_leaves_defaults(),
 | 
								sounds = xcompat.sounds.node_sound_leaves_defaults(),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			drop = {
 | 
								drop = {
 | 
				
			||||||
				max_items = 1,
 | 
									max_items = 1,
 | 
				
			||||||
@@ -351,27 +327,25 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
			},
 | 
								},
 | 
				
			||||||
		})
 | 
							})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if moretrees.enable_stairs then
 | 
							if minetest.get_modpath("moreblocks") then
 | 
				
			||||||
			if minetest.get_modpath("moreblocks") then
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	--			stairsplus:register_all(modname, subname, recipeitem, {fields})
 | 
								stairsplus:register_all(
 | 
				
			||||||
 | 
									"moretrees",
 | 
				
			||||||
				stairsplus:register_all(
 | 
									treename.."_trunk",
 | 
				
			||||||
					"moretrees",
 | 
									"moretrees:"..treename.."_trunk",
 | 
				
			||||||
					treename.."_trunk",
 | 
									{
 | 
				
			||||||
					"moretrees:"..treename.."_trunk",
 | 
										groups = { snappy=1, choppy=2, oddly_breakable_by_hand=1, flammable=2, not_in_creative_inventory=1 },
 | 
				
			||||||
					{
 | 
										tiles =	{
 | 
				
			||||||
						groups = { snappy=1, choppy=2, oddly_breakable_by_hand=1, flammable=2, not_in_creative_inventory=1 },
 | 
											"moretrees_"..treename.."_trunk_top.png",
 | 
				
			||||||
						tiles =	{
 | 
											"moretrees_"..treename.."_trunk_top.png",
 | 
				
			||||||
							"moretrees_"..treename.."_trunk_top.png",
 | 
											"moretrees_"..treename.."_trunk.png"
 | 
				
			||||||
							"moretrees_"..treename.."_trunk_top.png",
 | 
										},
 | 
				
			||||||
							"moretrees_"..treename.."_trunk.png"
 | 
										description = moretrees.treedesc[treename].trunk,
 | 
				
			||||||
						},
 | 
										drop = treename.."_trunk",
 | 
				
			||||||
						description = moretrees.treedesc[treename].trunk,
 | 
									}
 | 
				
			||||||
						drop = treename.."_trunk",
 | 
								)
 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if moretrees.enable_planks then
 | 
				
			||||||
				stairsplus:register_all(
 | 
									stairsplus:register_all(
 | 
				
			||||||
					"moretrees",
 | 
										"moretrees",
 | 
				
			||||||
					treename.."_planks",
 | 
										treename.."_planks",
 | 
				
			||||||
@@ -383,20 +357,22 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
						drop = treename.."_planks",
 | 
											drop = treename.."_planks",
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
				)
 | 
									)
 | 
				
			||||||
			elseif minetest.get_modpath("stairs") then
 | 
								end
 | 
				
			||||||
				stairs.register_stair_and_slab(
 | 
							elseif minetest.get_modpath("stairs") then
 | 
				
			||||||
					"moretrees_"..treename.."_trunk",
 | 
								stairs.register_stair_and_slab(
 | 
				
			||||||
					"moretrees:"..treename.."_trunk",
 | 
									"moretrees_"..treename.."_trunk",
 | 
				
			||||||
					{ snappy=1, choppy=2, oddly_breakable_by_hand=1, flammable=2 },
 | 
									"moretrees:"..treename.."_trunk",
 | 
				
			||||||
					{	"moretrees_"..treename.."_trunk_top.png",
 | 
									{ snappy=1, choppy=2, oddly_breakable_by_hand=1, flammable=2 },
 | 
				
			||||||
						"moretrees_"..treename.."_trunk_top.png",
 | 
									{	"moretrees_"..treename.."_trunk_top.png",
 | 
				
			||||||
						"moretrees_"..treename.."_trunk.png"
 | 
										"moretrees_"..treename.."_trunk_top.png",
 | 
				
			||||||
					},
 | 
										"moretrees_"..treename.."_trunk.png"
 | 
				
			||||||
					moretrees.treedesc[treename].trunk_stair,
 | 
									},
 | 
				
			||||||
					moretrees.treedesc[treename].trunk_slab,
 | 
									moretrees.treedesc[treename].trunk_stair,
 | 
				
			||||||
					default.node_sound_wood_defaults()
 | 
									moretrees.treedesc[treename].trunk_slab,
 | 
				
			||||||
				)
 | 
									xcompat.sounds.node_sound_wood_defaults()
 | 
				
			||||||
 | 
								)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if moretrees.enable_planks then
 | 
				
			||||||
				stairs.register_stair_and_slab(
 | 
									stairs.register_stair_and_slab(
 | 
				
			||||||
					"moretrees_"..treename.."_planks",
 | 
										"moretrees_"..treename.."_planks",
 | 
				
			||||||
					"moretrees:"..treename.."_planks",
 | 
										"moretrees:"..treename.."_planks",
 | 
				
			||||||
@@ -404,13 +380,13 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
					{ "moretrees_"..treename.."_wood.png" },
 | 
										{ "moretrees_"..treename.."_wood.png" },
 | 
				
			||||||
					moretrees.treedesc[treename].planks_stair,
 | 
										moretrees.treedesc[treename].planks_stair,
 | 
				
			||||||
					moretrees.treedesc[treename].planks_slab,
 | 
										moretrees.treedesc[treename].planks_slab,
 | 
				
			||||||
					default.node_sound_wood_defaults()
 | 
										xcompat.sounds.node_sound_wood_defaults()
 | 
				
			||||||
				)
 | 
									)
 | 
				
			||||||
 | 
					 | 
				
			||||||
			end
 | 
								end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if moretrees.enable_fences then
 | 
							if minetest.get_modpath("default") and moretrees.enable_planks then
 | 
				
			||||||
			local planks_name = "moretrees:" .. treename .. "_planks"
 | 
								local planks_name = "moretrees:" .. treename .. "_planks"
 | 
				
			||||||
			local planks_tile = "moretrees_" .. treename .. "_wood.png"
 | 
								local planks_tile = "moretrees_" .. treename .. "_wood.png"
 | 
				
			||||||
			default.register_fence("moretrees:" .. treename .. "_fence", {
 | 
								default.register_fence("moretrees:" .. treename .. "_fence", {
 | 
				
			||||||
@@ -422,7 +398,7 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
										"^default_fence_overlay.png^[makealpha:255,126,126",
 | 
															"^default_fence_overlay.png^[makealpha:255,126,126",
 | 
				
			||||||
				material = planks_name,
 | 
									material = planks_name,
 | 
				
			||||||
				groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2},
 | 
									groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2},
 | 
				
			||||||
				sounds = default.node_sound_wood_defaults()
 | 
									sounds = xcompat.sounds.node_sound_wood_defaults()
 | 
				
			||||||
			})
 | 
								})
 | 
				
			||||||
			default.register_fence_rail("moretrees:" .. treename .. "_fence_rail", {
 | 
								default.register_fence_rail("moretrees:" .. treename .. "_fence_rail", {
 | 
				
			||||||
				description = moretrees.treedesc[treename].fence_rail,
 | 
									description = moretrees.treedesc[treename].fence_rail,
 | 
				
			||||||
@@ -433,7 +409,7 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
										"^default_fence_rail_overlay.png^[makealpha:255,126,126",
 | 
															"^default_fence_rail_overlay.png^[makealpha:255,126,126",
 | 
				
			||||||
				material = planks_name,
 | 
									material = planks_name,
 | 
				
			||||||
				groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2},
 | 
									groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2},
 | 
				
			||||||
				sounds = default.node_sound_wood_defaults()
 | 
									sounds = xcompat.sounds.node_sound_wood_defaults()
 | 
				
			||||||
			})
 | 
								})
 | 
				
			||||||
			if minetest.global_exists("doors") then
 | 
								if minetest.global_exists("doors") then
 | 
				
			||||||
				doors.register_fencegate("moretrees:" .. treename .. "_gate", {
 | 
									doors.register_fencegate("moretrees:" .. treename .. "_gate", {
 | 
				
			||||||
@@ -446,25 +422,30 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
		end
 | 
							end
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.register_node("moretrees:"..treename.."_sapling_ongen", {
 | 
						-- the default game provides jungle tree and pine saplings.
 | 
				
			||||||
		description = S("@1 (fast growth)", moretrees.treedesc[treename].sapling),
 | 
						if treename~="jungletree" and treename ~= "pine" then
 | 
				
			||||||
		drawtype = "plantlike",
 | 
							local regular_groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,sapling=1}
 | 
				
			||||||
		tiles = {saptex},
 | 
							if minetest.settings:get_bool("creative_mode", false) then
 | 
				
			||||||
		inventory_image = saptex,
 | 
								regular_groups["not_in_creative_inventory"]=1
 | 
				
			||||||
		paramtype = "light",
 | 
							end
 | 
				
			||||||
		paramtype2 = "waving",
 | 
					
 | 
				
			||||||
		walkable = false,
 | 
							minetest.register_node("moretrees:"..treename.."_sapling", {
 | 
				
			||||||
		is_ground_content = true,
 | 
								description = moretrees.treedesc[treename].sapling,
 | 
				
			||||||
		selection_box = {
 | 
								drawtype = "plantlike",
 | 
				
			||||||
			type = "fixed",
 | 
								tiles = {split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex},
 | 
				
			||||||
			fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3}
 | 
								inventory_image = split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex,
 | 
				
			||||||
		},
 | 
								paramtype = "light",
 | 
				
			||||||
		groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,sapling=1},
 | 
								walkable = false,
 | 
				
			||||||
		sounds = default.node_sound_defaults(),
 | 
								is_ground_content = true,
 | 
				
			||||||
		drop = "moretrees:"..treename.."_sapling",
 | 
								selection_box = {
 | 
				
			||||||
		on_place = function(itemstack, placer, pointed_thing)
 | 
									type = "fixed",
 | 
				
			||||||
				itemstack = default.sapling_on_place(itemstack, placer, pointed_thing,
 | 
									fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3}
 | 
				
			||||||
					"moretrees:" ..treename.. "_sapling_ongen",
 | 
								},
 | 
				
			||||||
 | 
								groups = regular_groups,
 | 
				
			||||||
 | 
								sounds = xcompat.sounds.node_sound_default(),
 | 
				
			||||||
 | 
								on_place = function(itemstack, placer, pointed_thing)
 | 
				
			||||||
 | 
									itemstack = xcompat.functions.sapling_on_place(itemstack, placer, pointed_thing,
 | 
				
			||||||
 | 
										"moretrees:" ..treename.. "_sapling",
 | 
				
			||||||
					-- minp, maxp to be checked, relative to sapling pos
 | 
										-- minp, maxp to be checked, relative to sapling pos
 | 
				
			||||||
					-- minp_relative.y = 1 because sapling pos has been checked
 | 
										-- minp_relative.y = 1 because sapling pos has been checked
 | 
				
			||||||
					{x = -3, y = 1, z = -3},
 | 
										{x = -3, y = 1, z = -3},
 | 
				
			||||||
@@ -474,6 +455,82 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
				return itemstack
 | 
									return itemstack
 | 
				
			||||||
			end,
 | 
								end,
 | 
				
			||||||
 | 
								on_construct = function(pos)
 | 
				
			||||||
 | 
									minetest.get_node_timer(pos):start(300)
 | 
				
			||||||
 | 
								end,
 | 
				
			||||||
 | 
								on_timer = function(pos, elapsed)
 | 
				
			||||||
 | 
									if moretrees.can_grow(pos, treename) then
 | 
				
			||||||
 | 
										--moretrees["grow_" .. treename](pos)
 | 
				
			||||||
 | 
										minetest.set_node(pos, {name="air"})
 | 
				
			||||||
 | 
										if type(moretrees["spawn_" .. treename .. "_object"])=="string" then
 | 
				
			||||||
 | 
											local split = moretrees["spawn_" .. treename .. "_object"]:split(".")
 | 
				
			||||||
 | 
											moretrees[split[2]](pos)
 | 
				
			||||||
 | 
										else
 | 
				
			||||||
 | 
											minetest.spawn_tree(pos, moretrees["spawn_" .. treename .. "_object"])
 | 
				
			||||||
 | 
										end
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										minetest.get_node_timer(pos):start(300)
 | 
				
			||||||
 | 
									end
 | 
				
			||||||
 | 
								end,
 | 
				
			||||||
 | 
							})
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						local ongen_groups = {
 | 
				
			||||||
 | 
							snappy = 2,
 | 
				
			||||||
 | 
							dig_immediate = 3,
 | 
				
			||||||
 | 
							flammable = 2,
 | 
				
			||||||
 | 
							attached_node = 1,
 | 
				
			||||||
 | 
							sapling = 1,
 | 
				
			||||||
 | 
							moretrees_ongen = 1,
 | 
				
			||||||
 | 
							not_in_creative_inventory = 1
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if minetest.settings:get_bool("creative_mode", false) then
 | 
				
			||||||
 | 
							ongen_groups["not_in_creative_inventory"]=nil
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
						minetest.register_node("moretrees:"..treename.."_sapling_ongen", {
 | 
				
			||||||
 | 
							description = S("@1 (fast growth)", moretrees.treedesc[treename].sapling),
 | 
				
			||||||
 | 
							drawtype = "plantlike",
 | 
				
			||||||
 | 
							tiles = {split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex,},
 | 
				
			||||||
 | 
							inventory_image = split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex,
 | 
				
			||||||
 | 
							paramtype = "light",
 | 
				
			||||||
 | 
							walkable = false,
 | 
				
			||||||
 | 
							is_ground_content = true,
 | 
				
			||||||
 | 
							selection_box = {
 | 
				
			||||||
 | 
								type = "fixed",
 | 
				
			||||||
 | 
								fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							groups = ongen_groups,
 | 
				
			||||||
 | 
							sounds = xcompat.sounds.node_sound_default(),
 | 
				
			||||||
 | 
							drop = "moretrees:"..treename.."_sapling",
 | 
				
			||||||
 | 
							on_place = function(itemstack, placer, pointed_thing)
 | 
				
			||||||
 | 
								itemstack = xcompat.functions.sapling_on_place(itemstack, placer, pointed_thing,
 | 
				
			||||||
 | 
									"moretrees:" ..treename.. "_sapling_ongen",
 | 
				
			||||||
 | 
									-- minp, maxp to be checked, relative to sapling pos
 | 
				
			||||||
 | 
									-- minp_relative.y = 1 because sapling pos has been checked
 | 
				
			||||||
 | 
									{x = -3, y = 1, z = -3},
 | 
				
			||||||
 | 
									{x = 3, y = 6, z = 3},
 | 
				
			||||||
 | 
									-- maximum interval of interior volume check
 | 
				
			||||||
 | 
									4)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								return itemstack
 | 
				
			||||||
 | 
							end,
 | 
				
			||||||
 | 
							on_construct = function(pos)
 | 
				
			||||||
 | 
								minetest.get_node_timer(pos):start(2)
 | 
				
			||||||
 | 
							end,
 | 
				
			||||||
 | 
							on_timer = function(pos, elapsed)
 | 
				
			||||||
 | 
								if moretrees.can_grow(pos, treename) then
 | 
				
			||||||
 | 
									--moretrees["grow_" .. treename](pos)
 | 
				
			||||||
 | 
									minetest.set_node(pos, {name="air"})
 | 
				
			||||||
 | 
									if type(moretrees["spawn_" .. treename .. "_object"])=="string" then
 | 
				
			||||||
 | 
										local split = moretrees["spawn_" .. treename .. "_object"]:split(".")
 | 
				
			||||||
 | 
										moretrees[split[2]](pos)
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										minetest.spawn_tree(pos, moretrees["spawn_" .. treename .. "_object"])
 | 
				
			||||||
 | 
									end
 | 
				
			||||||
 | 
								else
 | 
				
			||||||
 | 
									minetest.get_node_timer(pos):start(300)
 | 
				
			||||||
 | 
								end
 | 
				
			||||||
 | 
							end,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	local fruitname = nil
 | 
						local fruitname = nil
 | 
				
			||||||
@@ -495,13 +552,19 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
					fixed = selbox
 | 
										fixed = selbox
 | 
				
			||||||
				},
 | 
									},
 | 
				
			||||||
			groups = {fleshy=3,dig_immediate=3,flammable=2, attached_node=1, leafdecay = 1, leafdecay_drop = 1},
 | 
								groups = {fleshy=3,dig_immediate=3,flammable=2, attached_node=1, leafdecay = 1, leafdecay_drop = 1},
 | 
				
			||||||
			sounds = default.node_sound_defaults(),
 | 
								sounds = xcompat.sounds.node_sound_default(),
 | 
				
			||||||
 | 
								after_place_node = function(pos, placer)
 | 
				
			||||||
 | 
									if placer:is_player() then
 | 
				
			||||||
 | 
										minetest.set_node(pos, {name = "moretrees:"..fruit, param2 = 1})
 | 
				
			||||||
 | 
									end
 | 
				
			||||||
 | 
								end
 | 
				
			||||||
		})
 | 
							})
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if treename ~= "jungletree"
 | 
						if treename ~= "jungletree"
 | 
				
			||||||
		and treename ~= "poplar_small"
 | 
							and treename ~= "poplar_small"
 | 
				
			||||||
		and treename ~= "pine" then
 | 
							and treename ~= "pine"
 | 
				
			||||||
 | 
							and minetest.get_modpath("default") then
 | 
				
			||||||
			default.register_leafdecay({
 | 
								default.register_leafdecay({
 | 
				
			||||||
				trunks = { "moretrees:"..treename.."_trunk" },
 | 
									trunks = { "moretrees:"..treename.."_trunk" },
 | 
				
			||||||
				leaves = { "moretrees:"..treename.."_leaves", fruitname },
 | 
									leaves = { "moretrees:"..treename.."_leaves", fruitname },
 | 
				
			||||||
@@ -528,33 +591,7 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
	end
 | 
						end
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- Add small poplar saplings
 | 
					-- poplar saplings leaves
 | 
				
			||||||
 | 
					 | 
				
			||||||
local poplar_sapling = minetest.registered_nodes["moretrees:poplar_sapling"]
 | 
					 | 
				
			||||||
local poplar_sapling_ongen = minetest.registered_nodes["moretrees:poplar_sapling_ongen"]
 | 
					 | 
				
			||||||
local poplar_small_sapling = {}
 | 
					 | 
				
			||||||
local poplar_small_sapling_ongen = {}
 | 
					 | 
				
			||||||
for k,v in pairs(poplar_sapling) do
 | 
					 | 
				
			||||||
	poplar_small_sapling[k] = v
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
for k,v in pairs(poplar_sapling_ongen) do
 | 
					 | 
				
			||||||
	poplar_small_sapling_ongen[k] = v
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
poplar_small_sapling.tiles = {"moretrees_poplar_small_sapling.png"}
 | 
					 | 
				
			||||||
poplar_small_sapling.inventory_image = "moretrees_poplar_small_sapling.png"
 | 
					 | 
				
			||||||
poplar_small_sapling.is_ground_content = true
 | 
					 | 
				
			||||||
poplar_small_sapling_ongen.tiles_ongen = {"moretrees_poplar_small_sapling.png"}
 | 
					 | 
				
			||||||
poplar_small_sapling_ongen.inventory_image_ongen = "moretrees_poplar_small_sapling.png"
 | 
					 | 
				
			||||||
poplar_small_sapling_ongen.drop = "moretrees:poplar_small_sapling"
 | 
					 | 
				
			||||||
poplar_small_sapling_ongen.is_ground_content = true
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
minetest.register_node("moretrees:poplar_small_sapling", poplar_small_sapling)
 | 
					 | 
				
			||||||
minetest.register_node("moretrees:poplar_small_sapling_ongen", poplar_small_sapling_ongen)
 | 
					 | 
				
			||||||
if moretrees.spawn_saplings then
 | 
					 | 
				
			||||||
	table.insert(moretrees.avoidnodes, "moretrees:poplar_sapling")
 | 
					 | 
				
			||||||
	table.insert(moretrees.avoidnodes, "moretrees:poplar_small_sapling_ongen")
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
local poplar_leaves_drop = minetest.registered_nodes["moretrees:poplar_leaves"].drop
 | 
					local poplar_leaves_drop = minetest.registered_nodes["moretrees:poplar_leaves"].drop
 | 
				
			||||||
minetest.override_item("moretrees:poplar_leaves", {
 | 
					minetest.override_item("moretrees:poplar_leaves", {
 | 
				
			||||||
	drop = {
 | 
						drop = {
 | 
				
			||||||
@@ -592,29 +629,31 @@ for color = 1, #jungleleaves do
 | 
				
			|||||||
		paramtype = "light",
 | 
							paramtype = "light",
 | 
				
			||||||
		is_ground_content = false,
 | 
							is_ground_content = false,
 | 
				
			||||||
		groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 3 },
 | 
							groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 3 },
 | 
				
			||||||
		drop = {
 | 
							drop = minetest.get_modpath("default") and {
 | 
				
			||||||
			max_items = 1,
 | 
								max_items = 1,
 | 
				
			||||||
			items = {
 | 
								items = {
 | 
				
			||||||
				{items = {"default:junglesapling"}, rarity = 100 },
 | 
									{items = {"default:junglesapling"}, rarity = 100 },
 | 
				
			||||||
				{items = {"moretrees:jungletree_leaves_"..jungleleaves[color]} }
 | 
									{items = {"moretrees:jungletree_leaves_"..jungleleaves[color]} }
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		},
 | 
							} or nil,
 | 
				
			||||||
		sounds = default.node_sound_leaves_defaults(),
 | 
							sounds = xcompat.sounds.node_sound_leaves_defaults(),
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- To get Moretrees to generate its own jungle trees among the default mapgen
 | 
					-- To get Moretrees to generate its own jungle trees among the default mapgen
 | 
				
			||||||
-- we need our own copy of that node, which moretrees will match against.
 | 
					-- we need our own copy of that node, which moretrees will match against.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local jungle_tree = table.copy(minetest.registered_nodes["default:jungletree"])
 | 
					if minetest.get_modpath("default") then
 | 
				
			||||||
jungle_tree.drop = "default:jungletree"
 | 
						local jungle_tree = table.copy(minetest.registered_nodes["default:jungletree"])
 | 
				
			||||||
minetest.register_node("moretrees:jungletree_trunk", jungle_tree)
 | 
						jungle_tree.drop = "default:jungletree"
 | 
				
			||||||
 | 
						minetest.register_node("moretrees:jungletree_trunk", jungle_tree)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
default.register_leafdecay({
 | 
						default.register_leafdecay({
 | 
				
			||||||
	trunks = { "default:jungletree", "moretrees:jungletree_trunk" },
 | 
							trunks = { "default:jungletree", "moretrees:jungletree_trunk" },
 | 
				
			||||||
	leaves = { "default:jungleleaves", "moretrees:jungletree_leaves_yellow", "moretrees:jungletree_leaves_red" },
 | 
							leaves = { xcompat.materials.jungle_leaves, "moretrees:jungletree_leaves_yellow", "moretrees:jungletree_leaves_red" },
 | 
				
			||||||
	radius = moretrees.leafdecay_radius,
 | 
							radius = moretrees.leafdecay_radius,
 | 
				
			||||||
})
 | 
						})
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- Extra needles for firs
 | 
					-- Extra needles for firs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -641,17 +680,19 @@ minetest.register_node("moretrees:fir_leaves_bright", {
 | 
				
			|||||||
			{items = {'moretrees:fir_leaves_bright'} }
 | 
								{items = {'moretrees:fir_leaves_bright'} }
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	sounds = default.node_sound_leaves_defaults()
 | 
						sounds = xcompat.sounds.node_sound_leaves_defaults()
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
default.register_leafdecay({
 | 
					if minetest.get_modpath("default") then
 | 
				
			||||||
	trunks = { "moretrees:fir_trunk" },
 | 
						default.register_leafdecay({
 | 
				
			||||||
	leaves = { "moretrees:fir_leaves", "moretrees:fir_leaves_bright" },
 | 
							trunks = { "moretrees:fir_trunk" },
 | 
				
			||||||
	radius = moretrees.leafdecay_radius,
 | 
							leaves = { "moretrees:fir_leaves", "moretrees:fir_leaves_bright" },
 | 
				
			||||||
})
 | 
							radius = moretrees.leafdecay_radius,
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if moretrees.enable_redefine_apple then
 | 
					if minetest.get_modpath("default") and moretrees.enable_redefine_apple then
 | 
				
			||||||
	local appledef = table.copy(minetest.registered_nodes["default:apple"])
 | 
						local appledef = table.copy(minetest.registered_nodes["default:apple"])
 | 
				
			||||||
	appledef.groups.attached_node = 1
 | 
						appledef.groups.attached_node = 1
 | 
				
			||||||
	minetest.register_node(":default:apple", appledef)
 | 
						minetest.register_node(":default:apple", appledef)
 | 
				
			||||||
@@ -679,7 +720,7 @@ minetest.register_node("moretrees:rubber_tree_trunk_empty", {
 | 
				
			|||||||
		"moretrees_rubber_tree_trunk_empty.png"
 | 
							"moretrees_rubber_tree_trunk_empty.png"
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
 | 
						groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
 | 
				
			||||||
	sounds = default.node_sound_wood_defaults(),
 | 
						sounds = xcompat.sounds.node_sound_wood_defaults(),
 | 
				
			||||||
	paramtype2 = "facedir",
 | 
						paramtype2 = "facedir",
 | 
				
			||||||
	is_ground_content = false,
 | 
						is_ground_content = false,
 | 
				
			||||||
	on_place = minetest.rotate_node,
 | 
						on_place = minetest.rotate_node,
 | 
				
			||||||
@@ -725,7 +766,7 @@ minetest.register_alias("conifers:sapling",						"moretrees:fir_sapling")
 | 
				
			|||||||
minetest.register_alias("moretrees:jungletree_sapling",			"default:junglesapling")
 | 
					minetest.register_alias("moretrees:jungletree_sapling",			"default:junglesapling")
 | 
				
			||||||
minetest.register_alias("moretrees:jungletree_trunk_sideways",	"moreblocks:horizontal_jungle_tree")
 | 
					minetest.register_alias("moretrees:jungletree_trunk_sideways",	"moreblocks:horizontal_jungle_tree")
 | 
				
			||||||
minetest.register_alias("moretrees:jungletree_planks",			"default:junglewood")
 | 
					minetest.register_alias("moretrees:jungletree_planks",			"default:junglewood")
 | 
				
			||||||
minetest.register_alias("moretrees:jungletree_leaves_green",	"default:jungleleaves")
 | 
					minetest.register_alias("moretrees:jungletree_leaves_green",	xcompat.materials.jungle_leaves)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_alias("moretrees:acacia_trunk",				"default:acacia_tree")
 | 
					minetest.register_alias("moretrees:acacia_trunk",				"default:acacia_tree")
 | 
				
			||||||
minetest.register_alias("moretrees:acacia_planks",				"default:acacia_wood")
 | 
					minetest.register_alias("moretrees:acacia_planks",				"default:acacia_wood")
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										37
									
								
								saplings.lua
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								saplings.lua
									
									
									
									
									
								
							@@ -5,8 +5,8 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
local dirt_surfaces = {
 | 
					local dirt_surfaces = {
 | 
				
			||||||
	set = true,
 | 
						set = true,
 | 
				
			||||||
	["default:dirt"] = true,
 | 
						[xcompat.materials.dirt] = true,
 | 
				
			||||||
	["default:dirt_with_grass"] = true,
 | 
						[xcompat.materials.dirt_with_grass] = true,
 | 
				
			||||||
	["default:dirt_with_dry_grass"] = true,
 | 
						["default:dirt_with_dry_grass"] = true,
 | 
				
			||||||
	["default:dirt_with_coniferous_litter"] = true,
 | 
						["default:dirt_with_coniferous_litter"] = true,
 | 
				
			||||||
	["default:dirt_with_rainforest_litter"] = true,
 | 
						["default:dirt_with_rainforest_litter"] = true,
 | 
				
			||||||
@@ -18,8 +18,8 @@ local dirt_surfaces = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
local conifer_surfaces =  {
 | 
					local conifer_surfaces =  {
 | 
				
			||||||
	set = true,
 | 
						set = true,
 | 
				
			||||||
	["default:dirt"] = true,
 | 
						[xcompat.materials.dirt] = true,
 | 
				
			||||||
	["default:dirt_with_grass"] = true,
 | 
						[xcompat.materials.dirt_with_grass] = true,
 | 
				
			||||||
	["default:dirt_with_dry_grass"] = true,
 | 
						["default:dirt_with_dry_grass"] = true,
 | 
				
			||||||
	["default:dirt_with_coniferous_litter"] = true,
 | 
						["default:dirt_with_coniferous_litter"] = true,
 | 
				
			||||||
	["default:dirt_with_rainforest_litter"] = true,
 | 
						["default:dirt_with_rainforest_litter"] = true,
 | 
				
			||||||
@@ -32,14 +32,35 @@ local conifer_surfaces =  {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
local sand_surfaces = {
 | 
					local sand_surfaces = {
 | 
				
			||||||
	set = true,
 | 
						set = true,
 | 
				
			||||||
	["default:sand"] = true,
 | 
						[xcompat.materials.sand] = true,
 | 
				
			||||||
	["default:desert_sand"] = true,
 | 
						[xcompat.materials.desert_sand] = true,
 | 
				
			||||||
	["cottages:loam"] = true,
 | 
						["cottages:loam"] = true,
 | 
				
			||||||
	-- note, no silver sand here.
 | 
						-- note, no silver sand here.
 | 
				
			||||||
	-- too cold for a palm, too... well... sandy for anything else.
 | 
						-- too cold for a palm, too... well... sandy for anything else.
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
for i in ipairs(moretrees.treelist) do
 | 
					function moretrees.can_grow(pos, treename)
 | 
				
			||||||
 | 
						local surfaces
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if treename == "spruce"
 | 
				
			||||||
 | 
						  or treename == "fir"
 | 
				
			||||||
 | 
						  or treename == "cedar"
 | 
				
			||||||
 | 
						  or treename == "pine" then
 | 
				
			||||||
 | 
							surfaces = conifer_surfaces
 | 
				
			||||||
 | 
						elseif string.find(treename, "palm") then
 | 
				
			||||||
 | 
							surfaces = sand_surfaces
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							surfaces = dirt_surfaces
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if surfaces[minetest.get_node(vector.new(pos.x, pos.y-1, pos.z)).name] then
 | 
				
			||||||
 | 
							return true
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							return false
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--[[ for i in ipairs(moretrees.treelist) do
 | 
				
			||||||
	local treename = moretrees.treelist[i][1]
 | 
						local treename = moretrees.treelist[i][1]
 | 
				
			||||||
	local tree_model = treename.."_model"
 | 
						local tree_model = treename.."_model"
 | 
				
			||||||
	local tree_biome = treename.."_biome"
 | 
						local tree_biome = treename.."_biome"
 | 
				
			||||||
@@ -81,4 +102,4 @@ for i in ipairs(moretrees.treelist) do
 | 
				
			|||||||
		grow_nodes = surfaces,
 | 
							grow_nodes = surfaces,
 | 
				
			||||||
		grow_function = grow_function,
 | 
							grow_function = grow_function,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
end
 | 
					end ]]
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -145,7 +145,8 @@ minetest.register_chatcommand("make-scene", {
 | 
				
			|||||||
The following is a search/replace command suitable for vi (/vim) or sed, to convert minetest log
 | 
					The following is a search/replace command suitable for vi (/vim) or sed, to convert minetest log
 | 
				
			||||||
messages to equivalent lua commands:
 | 
					messages to equivalent lua commands:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
s/.*\(\(moretrees\|default\)[^ ]*\) at (\([-0-9]\+\),\([-0-9]\+\),\([-0-9]\+\)).*/\t\tminetest.place_node({x=\3, y=\4, z=\5}, {name="\1"})/
 | 
					s/.*\(\(moretrees\|default\)[^ ]*\) at
 | 
				
			||||||
 | 
						(\([-0-9]\+\),\([-0-9]\+\),\([-0-9]\+\)).*/\t\tminetest.place_node({x=\3, y=\4, z=\5}, {name="\1"})/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
E.g. a minetest log line of the following kind:
 | 
					E.g. a minetest log line of the following kind:
 | 
				
			||||||
		2016-07-03 11:30:50: ACTION[Server]: singleplayer places node moretrees:rubber_tree_sapling at  (760,5,-223)
 | 
							2016-07-03 11:30:50: ACTION[Server]: singleplayer places node moretrees:rubber_tree_sapling at  (760,5,-223)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										57
									
								
								settings.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								settings.lua
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,57 @@
 | 
				
			|||||||
 | 
					local stg = minetest.settings
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--spawns tree on mapgen as saplings, legacy setting
 | 
				
			||||||
 | 
					moretrees.spawn_saplings		= stg:get_bool("moretrees.spawn_saplings", true)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--enable plantlike drawtype for leaves
 | 
				
			||||||
 | 
					moretrees.plantlike_leaves		= stg:get_bool("moretrees.plantlike_leaves", false)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- Enable this if you want moretrees to redefine default apples so that they
 | 
				
			||||||
 | 
					-- fall when leaves decay/are dug.
 | 
				
			||||||
 | 
					moretrees.enable_redefine_apple		= stg:get_bool("moretrees.enable_redefine_apple", true)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- various related settings to configure leaf decay.
 | 
				
			||||||
 | 
					moretrees.leafdecay_radius		= tonumber(stg:get("moretrees.leafdecay_radius")) or 5
 | 
				
			||||||
 | 
					moretrees.palm_leafdecay_radius		= tonumber(stg:get("moretrees.palm_leafdecay_radius")) or 10
 | 
				
			||||||
 | 
					moretrees.date_palm_leafdecay_radius	= tonumber(stg:get("moretrees.date_palm_leafdecay_radius")) or 14
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- Cocos palm settings
 | 
				
			||||||
 | 
					moretrees.coconuts_regrow		= stg:get_bool("moretrees.coconuts_regrow", true)
 | 
				
			||||||
 | 
					moretrees.coconuts_convert_existing_palms = stg:get_bool("moretrees.coconuts_convert_existing_palms", true)
 | 
				
			||||||
 | 
					moretrees.coconut_flower_interval	= tonumber(stg:get("moretrees.coconut_flower_interval")) or 59
 | 
				
			||||||
 | 
					moretrees.coconut_flower_chance		= tonumber(stg:get("moretrees.coconut_flower_chance")) or 67
 | 
				
			||||||
 | 
					moretrees.coconut_grow_interval		= tonumber(stg:get("moretrees.coconut_grow_interval")) or
 | 
				
			||||||
 | 
					    2 * moretrees.coconut_flower_interval * moretrees.coconut_flower_chance
 | 
				
			||||||
 | 
					moretrees.coconut_item_drop_ichance	= tonumber(stg:get("moretrees.coconut_item_drop_ichance")) or 10
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- Date palm settings
 | 
				
			||||||
 | 
					moretrees.dates_regrow_pollinated	= stg:get_bool("moretrees.dates_regrow_pollinated", true)
 | 
				
			||||||
 | 
					moretrees.dates_regrow_unpollinated_percent	= tonumber(stg:get("moretrees.dates_regrow_unpollinated_percent")) or 0
 | 
				
			||||||
 | 
					moretrees.dates_female_percent		= tonumber(stg:get("moretrees.dates_female_percent")) or 57
 | 
				
			||||||
 | 
					moretrees.dates_pollination_distance	= tonumber(stg:get("moretrees.dates_pollination_distance")) or 120
 | 
				
			||||||
 | 
					moretrees.dates_blossom_search_time_treshold = tonumber(stg:get("moretrees.dates_blossom_search_time_treshold")) or 1000
 | 
				
			||||||
 | 
					moretrees.dates_blossom_search_iload = tonumber(stg:get("moretrees.dates_blossom_search_iload")) or 10
 | 
				
			||||||
 | 
					moretrees.dates_flower_interval		= tonumber(stg:get("moretrees.dates_flower_interval")) or 59
 | 
				
			||||||
 | 
					moretrees.dates_flower_chance		= tonumber(stg:get("moretrees.dates_flower_chance")) or 181
 | 
				
			||||||
 | 
					moretrees.dates_grow_interval		= tonumber(stg:get("moretrees.dates_grow_interval")) or
 | 
				
			||||||
 | 
					    2 * moretrees.dates_flower_interval * moretrees.dates_flower_chance
 | 
				
			||||||
 | 
					moretrees.dates_item_drop_ichance	= tonumber(stg:get("moretrees.dates_item_drop_ichance")) or 10
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- Sapling settings
 | 
				
			||||||
 | 
					moretrees.sapling_interval		= 100
 | 
				
			||||||
 | 
					moretrees.sapling_chance		= 5
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- Enable this only if you have used an old moretrees version which was using biome_lib
 | 
				
			||||||
 | 
					-- and when you notice large areas with ongen saplings that don't grow
 | 
				
			||||||
 | 
					moretrees.grow_legacy_saplings	= stg:get_bool("moretrees.grow_legacy_saplings", false)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- If this variable is set to true, drop leaves out as entities during leaf
 | 
				
			||||||
 | 
					-- decay, rather than just disappearing them.
 | 
				
			||||||
 | 
					moretrees.decay_leaves_as_items = stg:get_bool("moretrees.decay_leaves_as_items", false)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- this is an internal setting for games that only have one type of planks
 | 
				
			||||||
 | 
					if type(minetest.get_game_info) == "function" then
 | 
				
			||||||
 | 
					    moretrees.enable_planks = minetest.get_game_info().id~="voxelgarden"
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					    moretrees.enable_planks = true
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
@@ -1,5 +1,6 @@
 | 
				
			|||||||
moretrees.beech_model={
 | 
					moretrees.beech_model={
 | 
				
			||||||
	axiom="FFFFFBFB",
 | 
						axiom="FFFFFBFB",
 | 
				
			||||||
 | 
						-- luacheck: no max line length
 | 
				
			||||||
	rules_a="[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fdd]]",
 | 
						rules_a="[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fdd]]",
 | 
				
			||||||
	rules_b="[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&Fd]//d[+^d][--&d]]",
 | 
						rules_b="[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&Fd]//d[+^d][--&d]]",
 | 
				
			||||||
	rules_c="/",
 | 
						rules_c="/",
 | 
				
			||||||
@@ -24,8 +25,8 @@ moretrees.apple_tree_model={
 | 
				
			|||||||
	random_level=0,
 | 
						random_level=0,
 | 
				
			||||||
	trunk_type="single",
 | 
						trunk_type="single",
 | 
				
			||||||
	thin_branches=true,
 | 
						thin_branches=true,
 | 
				
			||||||
	fruit="default:apple",
 | 
						fruit=minetest.get_modpath("default") and "default:apple" or nil,
 | 
				
			||||||
	fruit_chance=15,
 | 
						fruit_chance=minetest.get_modpath("default") and 15 or nil,
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.oak_model={
 | 
					moretrees.oak_model={
 | 
				
			||||||
@@ -75,6 +76,7 @@ moretrees.poplar_small_model={
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
moretrees.sequoia_model={
 | 
					moretrees.sequoia_model={
 | 
				
			||||||
	axiom="FFFFFFFFFFddccA///cccFddcFA///ddFcFA/cFFddFcdBddd/A/ccdcddd/ccAddddcFBcccAccFdFcFBcccc/BFdFFcFFdcccc/B",
 | 
						axiom="FFFFFFFFFFddccA///cccFddcFA///ddFcFA/cFFddFcdBddd/A/ccdcddd/ccAddddcFBcccAccFdFcFBcccc/BFdFFcFFdcccc/B",
 | 
				
			||||||
 | 
						-- luacheck: no max line length
 | 
				
			||||||
	rules_a="[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]",
 | 
						rules_a="[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]",
 | 
				
			||||||
	rules_b="[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]",
 | 
						rules_b="[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]",
 | 
				
			||||||
	rules_c="/",
 | 
						rules_c="/",
 | 
				
			||||||
@@ -166,6 +168,7 @@ moretrees.date_palm_model={
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.spruce_model1={
 | 
					moretrees.spruce_model1={
 | 
				
			||||||
 | 
						-- luacheck: no max line length
 | 
				
			||||||
	axiom="FFFFFAFFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]",
 | 
						axiom="FFFFFAFFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]",
 | 
				
			||||||
	rules_a="[&&&FFFFFF^^FFF][&&&++FFFFFF^^FFF][&&&++++FFFFFF^^FFF][&&&++++++FFFFFF^^FFF][&&&--FFFFFF^^FFF][&&&----FFFFFF^^FFF]",
 | 
						rules_a="[&&&FFFFFF^^FFF][&&&++FFFFFF^^FFF][&&&++++FFFFFF^^FFF][&&&++++++FFFFFF^^FFF][&&&--FFFFFF^^FFF][&&&----FFFFFF^^FFF]",
 | 
				
			||||||
	rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]",
 | 
						rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]",
 | 
				
			||||||
@@ -183,6 +186,7 @@ moretrees.spruce_model1={
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
moretrees.spruce_model2={
 | 
					moretrees.spruce_model2={
 | 
				
			||||||
 | 
						-- luacheck: no max line length
 | 
				
			||||||
	axiom="FFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]",
 | 
						axiom="FFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]",
 | 
				
			||||||
	rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]",
 | 
						rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]",
 | 
				
			||||||
	rules_c="[&&&FFFF^^FFF][&&&++FFFF^^FFF][&&&++++FFFF^^FFF][&&&++++++FFFF^^FFF][&&&--FFFF^^FFF][&&&----FFFF^^FFF]",
 | 
						rules_c="[&&&FFFF^^FFF][&&&++FFFF^^FFF][&&&++++FFFF^^FFF][&&&++++++FFFF^^FFF][&&&--FFFF^^FFF][&&&----FFFF^^FFF]",
 | 
				
			||||||
@@ -217,6 +221,7 @@ moretrees.cedar_model={
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
moretrees.willow_model={
 | 
					moretrees.willow_model={
 | 
				
			||||||
	axiom="FFFFFFFFccA",
 | 
						axiom="FFFFFFFFccA",
 | 
				
			||||||
 | 
						-- luacheck: no max line length
 | 
				
			||||||
	rules_a="[&FF&FFFF&&F&FFFFFFFdddd][**&FF&FFFF&&F&FFFFFFFdddd][//&FF&FFFF&&F&FFFFFFFdddd][////&FF&FFFF&&F&FFFFFFFdddd][//////&FF&FFFF&&F&FFFFFFFdddd][////////&FF&FFFF&&F&FFFFFFFdddd]",
 | 
						rules_a="[&FF&FFFF&&F&FFFFFFFdddd][**&FF&FFFF&&F&FFFFFFFdddd][//&FF&FFFF&&F&FFFFFFFdddd][////&FF&FFFF&&F&FFFFFFFdddd][//////&FF&FFFF&&F&FFFFFFFdddd][////////&FF&FFFF&&F&FFFFFFFdddd]",
 | 
				
			||||||
	rules_c="/",
 | 
						rules_c="/",
 | 
				
			||||||
	rules_d="F",
 | 
						rules_d="F",
 | 
				
			||||||
@@ -247,7 +252,7 @@ moretrees.jungletree_model={
 | 
				
			|||||||
	rules_a=nil,
 | 
						rules_a=nil,
 | 
				
			||||||
	rules_b=nil,
 | 
						rules_b=nil,
 | 
				
			||||||
	trunk="moretrees:jungletree_trunk",
 | 
						trunk="moretrees:jungletree_trunk",
 | 
				
			||||||
	leaves="default:jungleleaves",
 | 
						leaves=xcompat.materials.jungle_leaves,
 | 
				
			||||||
	leaves2=nil,
 | 
						leaves2=nil,
 | 
				
			||||||
	leaves2_chance=nil,
 | 
						leaves2_chance=nil,
 | 
				
			||||||
	angle=45,
 | 
						angle=45,
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user