2019-02-24 10:19:22 -05:00
|
|
|
-- LUALOCALS < ---------------------------------------------------------
|
|
|
|
local error, ipairs, math, minetest, nodecore, pairs
|
|
|
|
= error, ipairs, math, minetest, nodecore, pairs
|
|
|
|
local math_floor, math_random
|
|
|
|
= math.floor, math.random
|
|
|
|
-- LUALOCALS > ---------------------------------------------------------
|
|
|
|
|
2019-03-24 22:51:23 -04:00
|
|
|
local thickness = 128
|
2019-02-24 10:19:22 -05:00
|
|
|
|
|
|
|
nodecore.stratadata = nodecore.memoize(function()
|
|
|
|
local data = {}
|
|
|
|
data.stratbyid = {}
|
|
|
|
data.altsbyid = {}
|
|
|
|
for k, v in pairs(minetest.registered_nodes) do
|
|
|
|
if v.strata then
|
|
|
|
local sn
|
|
|
|
for s, n in ipairs(v.strata) do
|
|
|
|
if n == k then sn = s end
|
|
|
|
end
|
|
|
|
if not sn then error(k .. " not found in own strata") end
|
|
|
|
local cid = minetest.get_content_id(k)
|
|
|
|
data.stratbyid[cid] = sn
|
|
|
|
data.altsbyid[cid] = {}
|
|
|
|
for s, n in ipairs(v.strata) do
|
|
|
|
data.altsbyid[cid][s] = minetest.get_content_id(n)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return data
|
|
|
|
end)
|
|
|
|
|
2019-08-31 09:26:53 -04:00
|
|
|
nodecore.register_mapgen_shared(function(minp, maxp, area, data)
|
2019-02-24 10:19:22 -05:00
|
|
|
if minp.y > -64 then return end
|
|
|
|
|
|
|
|
local ai = area.index
|
|
|
|
local t = nodecore.hard_stone_strata
|
|
|
|
local sd = nodecore.stratadata()
|
|
|
|
local byid = sd.stratbyid
|
|
|
|
local alts = sd.altsbyid
|
|
|
|
|
|
|
|
for z = minp.z, maxp.z do
|
|
|
|
for y = minp.y, maxp.y do
|
|
|
|
local raw = y / -thickness
|
|
|
|
local strat = math_floor(raw)
|
|
|
|
local dither = raw - strat
|
|
|
|
if strat > t then
|
|
|
|
strat = t
|
|
|
|
dither = nil
|
|
|
|
elseif dither > (4 / thickness) then
|
|
|
|
dither = nil
|
|
|
|
else
|
2019-12-01 11:08:12 -05:00
|
|
|
dither = (dither * thickness + 1) / 5
|
2019-02-24 10:19:22 -05:00
|
|
|
end
|
|
|
|
for x = minp.x, maxp.x do
|
|
|
|
local i = ai(area, x, y, z)
|
|
|
|
if byid[data[i]] then
|
|
|
|
if dither and math_random() >= dither then
|
|
|
|
data[i] = alts[data[i]][strat]
|
|
|
|
else
|
|
|
|
data[i] = alts[data[i]][strat + 1]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end,
|
|
|
|
-100)
|