Skip to content
Permalink
Browse files

🐈

  • Loading branch information...
HybridDog
HybridDog committed Jul 6, 2015
1 parent 2ce0e28 commit 539b7fe1708af39549cfa775e3dbfdf2f944cbe4
Showing with 4 additions and 39 deletions.
  1. +4 −39 whiteshell/init.lua
@@ -1,6 +1,8 @@
-- NODES

-- TODO: override desert sand drop!

--[[
minetest.register_node("whiteshell:whiteshell", {
description = "White shell",
drawtype = "normal",
@@ -37,46 +39,9 @@ minetest.register_ore({
})
local function generate_ore(name, wherein, minp, maxp, seed, chunks_per_volume, chunk_size, ore_per_chunk, height_min, height_max)
if maxp.y < height_min or minp.y > height_max then
return
end
local y_min = math.max(minp.y, height_min)
local y_max = math.min(maxp.y, height_max)
if chunk_size >= y_max - y_min + 1 then
return
end
local volume = (maxp.x-minp.x+1)*(y_max-y_min+1)*(maxp.z-minp.z+1)
local pr = PseudoRandom(seed)
local num_chunks = math.floor(chunks_per_volume * volume)
local inverse_chance = math.floor(chunk_size*chunk_size*chunk_size / ore_per_chunk)
for i=1,num_chunks do
local y0 = pr:next(y_min, y_max-chunk_size+1)
if y0 >= height_min and y0 <= height_max then
local x0 = pr:next(minp.x, maxp.x-chunk_size+1)
local z0 = pr:next(minp.z, maxp.z-chunk_size+1)
local p0 = {x=x0, y=y0, z=z0}
for x1=0,chunk_size-1 do
for y1=0,chunk_size-1 do
for z1=0,chunk_size-1 do
if pr:next(1,inverse_chance) == 1 then
local x2 = x0+x1
local y2 = y0+y1
local z2 = z0+z1
local p2 = {x=x2, y=y2, z=z2}
if minetest.get_node(p2).name == wherein then
minetest.set_node(p2, {name=name})
end
end
end
end
end
end
end
end


]]
-- ALIASES


minetest.register_alias("whiteshell:whiteshell", "default:desert_sand")
minetest.register_alias("clams:whiteshell","whiteshell:whiteshell")

0 comments on commit 539b7fe

Please sign in to comment.
You can’t perform that action at this time.