mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2024-11-29 05:51:05 +01:00
Railcorridors: Use dark oak wood in terracotta
This commit is contained in:
parent
da8729a7a1
commit
3443e68b76
2 changed files with 43 additions and 21 deletions
|
@ -12,15 +12,30 @@ tsm_railcorridors.nodes = {
|
|||
torch_wall = "mcl_torches:torch_wall",
|
||||
cobweb = "mcl_core:cobweb",
|
||||
spawner = "mcl_mobspawners:spawner",
|
||||
}
|
||||
|
||||
local mg_name = minetest.get_mapgen_setting("mg_name")
|
||||
|
||||
if mg_name == "v6" then
|
||||
-- In v6, wood is chosen randomly.
|
||||
--[[ Wood types for the corridors. Corridors are made out of full wood blocks
|
||||
and posts. For each corridor system, a random wood type is chosen with the chance
|
||||
specified in per mille. ]]
|
||||
corridor_woods = {
|
||||
tsm_railcorridors.nodes.corridor_woods = {
|
||||
{ wood = "mcl_core:wood", post = "mcl_fences:fence", chance = 900},
|
||||
{ wood = "mcl_core:darkwood", post = "mcl_fences:dark_oak_fence", chance = 100},
|
||||
},
|
||||
}
|
||||
}
|
||||
else
|
||||
-- This generates dark oak wood in mesa biomes and oak wood everywhere else.
|
||||
tsm_railcorridors.nodes.corridor_woods_function = function(pos, node)
|
||||
if minetest.get_item_group(node.name, "hardened_clay") ~= 0 then
|
||||
return "mcl_core:darkwood", "mcl_fences:dark_oak_fence"
|
||||
else
|
||||
return "mcl_core:wood", "mcl_fences:fence"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
-- TODO: Use minecart with chest instead of normal minecart
|
||||
tsm_railcorridors.carts = { "mcl_minecarts:minecart" }
|
||||
|
@ -41,8 +56,6 @@ function tsm_railcorridors.on_construct_spawner(pos)
|
|||
mcl_mobspawners.setup_spawner(pos, "mobs_mc:cave_spider")
|
||||
end
|
||||
|
||||
local mg_name = minetest.get_mapgen_setting("mg_name")
|
||||
|
||||
-- MineClone 2's treasure function. Gets all treasures for a single chest.
|
||||
-- Based on information from Minecraft Wiki.
|
||||
function tsm_railcorridors.get_treasures(pr)
|
||||
|
|
|
@ -746,6 +746,7 @@ local function place_corridors(main_cave_coords, psra)
|
|||
if not IsGround(main_cave_coords) then
|
||||
return
|
||||
end
|
||||
local center_node = minetest.get_node(main_cave_coords)
|
||||
|
||||
-- Determine if this corridor system is “damaged” (some rails removed) and to which extent
|
||||
local damage = 0
|
||||
|
@ -769,11 +770,17 @@ local function place_corridors(main_cave_coords, psra)
|
|||
local xs = pr:next(0, 2) < 1
|
||||
local zs = pr:next(0, 2) < 1;
|
||||
|
||||
-- Get wood and fence post types, using gameconfig.
|
||||
local wood, post
|
||||
if tsm_railcorridors.nodes.corridor_woods_function then
|
||||
-- Get wood type by gameconfig function
|
||||
wood, post = tsm_railcorridors.nodes.corridor_woods_function(main_cave_coords, center_node)
|
||||
else
|
||||
-- Select random wood type (found in gameconfig.lua)
|
||||
local rnd = pr:next(1,1000)
|
||||
|
||||
local woodtype = 1
|
||||
local accumulated_chance = 0
|
||||
|
||||
for w=1, #tsm_railcorridors.nodes.corridor_woods do
|
||||
local woodtable = tsm_railcorridors.nodes.corridor_woods[w]
|
||||
accumulated_chance = accumulated_chance + woodtable.chance
|
||||
|
@ -786,8 +793,10 @@ local function place_corridors(main_cave_coords, psra)
|
|||
break
|
||||
end
|
||||
end
|
||||
local wood = tsm_railcorridors.nodes.corridor_woods[woodtype].wood
|
||||
local post = tsm_railcorridors.nodes.corridor_woods[woodtype].post
|
||||
wood = tsm_railcorridors.nodes.corridor_woods[woodtype].wood
|
||||
post = tsm_railcorridors.nodes.corridor_woods[woodtype].post
|
||||
end
|
||||
|
||||
start_corridor(main_cave_coords, "x", xs, pr:next(way_min,way_max), psra, wood, post, damage, false)
|
||||
start_corridor(main_cave_coords, "z", zs, pr:next(way_min,way_max), psra, wood, post, damage, false)
|
||||
-- Auch mal die andere Richtung?
|
||||
|
|
Loading…
Reference in a new issue