mirror of
git://repo.or.cz/tsm_mines.git
synced 2025-01-25 01:10:33 +01:00
Import mines 0.3 by BlockMen
This commit is contained in:
commit
22e18d03a2
43
README.txt
Normal file
43
README.txt
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
Minetest mod "Mines"
|
||||||
|
====================
|
||||||
|
version: 0.3 Beta
|
||||||
|
|
||||||
|
License of source code and textures: WTFPL
|
||||||
|
-----------------------------------------
|
||||||
|
(c) Copyright BlockMen (2013)
|
||||||
|
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
-------------
|
||||||
|
cHyper (mine deep can be set by .conf)
|
||||||
|
|
||||||
|
This program is free software. It comes without any warranty, to
|
||||||
|
the extent permitted by applicable law. You can redistribute it
|
||||||
|
and/or modify it under the terms of the Do What The Fuck You Want
|
||||||
|
To Public License, Version 2, as published by Sam Hocevar. See
|
||||||
|
http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
|
||||||
|
|
||||||
|
Using the mod:
|
||||||
|
--------------
|
||||||
|
|
||||||
|
This mod adds abandoned mines, similar to MC.
|
||||||
|
|
||||||
|
You can find chest with different stuff like food, resources, ingots or even tools.
|
||||||
|
|
||||||
|
|
||||||
|
Remember that this mod is still beta!
|
||||||
|
|
||||||
|
|
||||||
|
Settings
|
||||||
|
--------
|
||||||
|
|
||||||
|
You can change the spawing of mines by adding/changing these values in minetest.conf
|
||||||
|
|
||||||
|
|
||||||
|
mines_deep_min = -64
|
||||||
|
^ at this deep mines are created
|
||||||
|
mines_deep_max = -380
|
||||||
|
^ up to this deep mines are created
|
||||||
|
mines_spawnfactor = 1.5
|
||||||
|
^ increase this value to generate more mines
|
1
depends.txt
Normal file
1
depends.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
default
|
255
init.lua
Normal file
255
init.lua
Normal file
@ -0,0 +1,255 @@
|
|||||||
|
local MINE_DEEP_MIN = tonumber(minetest.setting_get("mines_deep_min"))
|
||||||
|
local MINE_DEEP_MAX = tonumber(minetest.setting_get("mines_deep_max"))
|
||||||
|
local MINE_FACTOR = tonumber(minetest.setting_get("mines_spawnfactor"))
|
||||||
|
|
||||||
|
if not MINE_DEEP_MIN then
|
||||||
|
MINE_DEEP_MIN = -64
|
||||||
|
end
|
||||||
|
if not MINE_DEEP_MAX then
|
||||||
|
MINE_DEEP_MAX = -380
|
||||||
|
end
|
||||||
|
if not MINE_FACTOR then
|
||||||
|
MINE_FACTOR = 1.5
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("mines:dummy", {
|
||||||
|
description = "Air (you hacker you!)",
|
||||||
|
inventory_image = "unknown_node.png",
|
||||||
|
wield_image = "unknown_node.png",
|
||||||
|
drawtype = "airlike",
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
walkable = false,
|
||||||
|
pointable = false,
|
||||||
|
diggable = false,
|
||||||
|
buildable_to = true,
|
||||||
|
air_equivalent = true,
|
||||||
|
drop = "",
|
||||||
|
groups = {not_in_creative_inventory=1},
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
local ids = {
|
||||||
|
air = minetest.get_content_id("air"),
|
||||||
|
fence = minetest.get_content_id("default:fence_wood"),
|
||||||
|
wood = minetest.get_content_id("default:wood"),
|
||||||
|
dummy = minetest.get_content_id("mines:dummy")
|
||||||
|
}
|
||||||
|
|
||||||
|
local chest_stuff = {
|
||||||
|
{name="default:apple", max = 3},
|
||||||
|
{name="farming:bread", max = 3},
|
||||||
|
{name="default:steel_ingot", max = 2},
|
||||||
|
{name="default:gold_ingot", max = 2},
|
||||||
|
{name="default:diamond", max = 1},
|
||||||
|
{name="default:pick_steel", max = 1},
|
||||||
|
{name="default:pick_diamond", max = 1}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
local function rotate_torch(pos)
|
||||||
|
minetest.after(8, function()
|
||||||
|
local n = minetest.get_node(pos)
|
||||||
|
if n ~= nil then
|
||||||
|
if n.name == "mines:dummy" then
|
||||||
|
minetest.set_node(pos, {name="default:torch",param2=1})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function fill_chest(pos)
|
||||||
|
minetest.after(5, function()
|
||||||
|
local n = minetest.get_node(pos)
|
||||||
|
if n ~= nil then
|
||||||
|
if n.name == "mines:dummy" then
|
||||||
|
minetest.set_node(pos, {name="default:chest"})
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
--meta:set_string("formspec",default.chest_formspec)
|
||||||
|
--meta:set_string("infotext", "Chest")
|
||||||
|
local inv = meta:get_inventory()
|
||||||
|
inv:set_size("main", 8*4)
|
||||||
|
for i=0,2,1 do
|
||||||
|
local stuff = chest_stuff[math.random(1,#chest_stuff)]
|
||||||
|
local stack = {name=stuff.name, count = math.random(1,stuff.max)}
|
||||||
|
if not inv:contains_item("main", stack) then
|
||||||
|
inv:set_stack("main", math.random(1,32), stack)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function check_dir(dir,old_dir)
|
||||||
|
if old_dir == 1 and dir == 3 then
|
||||||
|
--n_switch = 2
|
||||||
|
return true
|
||||||
|
elseif old_dir == 3 and dir == 1 then
|
||||||
|
--n_switch = 4
|
||||||
|
return true
|
||||||
|
elseif old_dir == 2 and dir == 4 then
|
||||||
|
--n_switch = 1
|
||||||
|
return true
|
||||||
|
elseif old_dir == 4 and dir == 2 then
|
||||||
|
--n_switch = 3
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
local function make_mine(mpos,p2,p3, vm_data, vx_area,cnt)
|
||||||
|
local pos = {x=mpos.x,y=mpos.y,z=mpos.z}
|
||||||
|
for j=0,12,1 do
|
||||||
|
local switch = cnt+1
|
||||||
|
n_switch = math.random(1,4)
|
||||||
|
while check_dir(n_switch,switch) == true do
|
||||||
|
n_switch = math.random(1,4)
|
||||||
|
end
|
||||||
|
switch = n_switch
|
||||||
|
|
||||||
|
for i=0,20,1 do
|
||||||
|
local pillar = ids.air
|
||||||
|
local pillar_top = ids.air
|
||||||
|
if i==0 or i == 5 or i == 10 or i == 15 or i == 20 then
|
||||||
|
pillar = ids.fence
|
||||||
|
pillar_top = ids.wood
|
||||||
|
end
|
||||||
|
local x1
|
||||||
|
local x2
|
||||||
|
local x3
|
||||||
|
local x4
|
||||||
|
local z1
|
||||||
|
local z2
|
||||||
|
local z3
|
||||||
|
local z4
|
||||||
|
if switch == 1 then
|
||||||
|
x1 = pos.x+1
|
||||||
|
x2 = pos.x
|
||||||
|
x3 = pos.x-1
|
||||||
|
x4 = pos.x
|
||||||
|
x5 = pos.x+1
|
||||||
|
|
||||||
|
z1 = pos.z+i
|
||||||
|
z2 = pos.z+i
|
||||||
|
z3 = pos.z+i
|
||||||
|
z4 = pos.z+i-1
|
||||||
|
z5 = pos.z+i
|
||||||
|
elseif switch == 2 then
|
||||||
|
x1 = pos.x+i
|
||||||
|
x2 = pos.x+i
|
||||||
|
x3 = pos.x+i
|
||||||
|
x4 = pos.x+i-1
|
||||||
|
x5 = pos.x+i
|
||||||
|
|
||||||
|
z1 = pos.z+1
|
||||||
|
z2 = pos.z
|
||||||
|
z3 = pos.z-1
|
||||||
|
z4 = pos.z
|
||||||
|
z5 = pos.z+1
|
||||||
|
elseif switch == 3 then
|
||||||
|
x1 = pos.x+1
|
||||||
|
x2 = pos.x
|
||||||
|
x3 = pos.x-1
|
||||||
|
x4 = pos.x
|
||||||
|
x5 = pos.x+1
|
||||||
|
|
||||||
|
z1 = pos.z-i
|
||||||
|
z2 = pos.z-i
|
||||||
|
z3 = pos.z-i
|
||||||
|
z4 = pos.z-i-1
|
||||||
|
z5 = pos.z-i
|
||||||
|
else
|
||||||
|
x1 = pos.x-i
|
||||||
|
x2 = pos.x-i
|
||||||
|
x3 = pos.x-i
|
||||||
|
x4 = pos.x-i-1
|
||||||
|
x5 = pos.x-i
|
||||||
|
|
||||||
|
z1 = pos.z+1
|
||||||
|
z2 = pos.z
|
||||||
|
z3 = pos.z-1
|
||||||
|
z4 = pos.z
|
||||||
|
z5 = pos.z+1
|
||||||
|
end
|
||||||
|
vm_data[vx_area:indexp({x=x1, y=pos.y-1, z=z1})] = pillar
|
||||||
|
vm_data[vx_area:indexp({x=x2, y=pos.y-1, z=z2})] = ids.air
|
||||||
|
vm_data[vx_area:indexp({x=x3, y=pos.y-1, z=z3})] = pillar
|
||||||
|
|
||||||
|
vm_data[vx_area:indexp({x=x1, y=pos.y, z=z1})] = pillar
|
||||||
|
vm_data[vx_area:indexp({x=x2, y=pos.y, z=z2})] = ids.air
|
||||||
|
vm_data[vx_area:indexp({x=x3, y=pos.y, z=z3})] = pillar
|
||||||
|
|
||||||
|
vm_data[vx_area:indexp({x=x1, y=pos.y+1, z=z1})] = pillar_top
|
||||||
|
vm_data[vx_area:indexp({x=x2, y=pos.y+1, z=z2})] = pillar_top
|
||||||
|
vm_data[vx_area:indexp({x=x3, y=pos.y+1, z=z3})] = pillar_top
|
||||||
|
|
||||||
|
if math.random(0,6) == 3 then
|
||||||
|
vm_data[vx_area:indexp({x=x4, y=pos.y-1, z=z4})] = ids.dummy
|
||||||
|
rotate_torch({x=x4, y=pos.y-1, z=z4})
|
||||||
|
end
|
||||||
|
if math.random(0,60) == 13 then
|
||||||
|
local p = {x=x5, y=pos.y-1, z=z5}
|
||||||
|
if vm_data[vx_area:indexp(p)] ~= ids.fence then
|
||||||
|
vm_data[vx_area:indexp(p)] = ids.dummy
|
||||||
|
fill_chest(p)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if switch == 1 then
|
||||||
|
pos.z = pos.z+20
|
||||||
|
--pos.x = pos.x+step
|
||||||
|
elseif switch == 2 then
|
||||||
|
pos.x = pos.x+20
|
||||||
|
--pos.z = pos.z+step
|
||||||
|
elseif switch == 3 then
|
||||||
|
pos.z = pos.z-20
|
||||||
|
--pos.x = pos.x+step
|
||||||
|
elseif switch == 4 then
|
||||||
|
pos.x = pos.x-20
|
||||||
|
--pos.z = pos.z+step
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if cnt == 0 then
|
||||||
|
minetest.log("action", "Created mine at ("..mpos.x..","..mpos.y..","..mpos.z..")")
|
||||||
|
local out2 = make_mine(p2,p3,mpos,vm_data,vx_area,1)
|
||||||
|
local out3 = make_mine(p3,p2,mpos,out2,vx_area,2)
|
||||||
|
return out3
|
||||||
|
else
|
||||||
|
return vm_data
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function find_cave(min,max,vm_data, vx_area)
|
||||||
|
local out = nil
|
||||||
|
for i in vx_area:iterp(min, max) do
|
||||||
|
if vm_data[i] == ids.air then
|
||||||
|
local p = vx_area:position(i)
|
||||||
|
if p.y <= MINE_DEEP_MIN then out = p end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return out
|
||||||
|
end
|
||||||
|
|
||||||
|
local cnt = 0
|
||||||
|
minetest.register_on_generated(function(minp, maxp, seed)
|
||||||
|
if minp.y > MINE_DEEP_MIN or minp.y < MINE_DEEP_MAX then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
cnt = cnt+1
|
||||||
|
if cnt < 8/MINE_FACTOR then return end
|
||||||
|
cnt = 0
|
||||||
|
|
||||||
|
--if math.random(0,100) > 85 then return end
|
||||||
|
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
|
||||||
|
local data = vm:get_data()
|
||||||
|
local va = VoxelArea:new{ MinEdge = emin, MaxEdge = emax }
|
||||||
|
local mpos = find_cave(emin,emax,data,va)
|
||||||
|
if mpos == nil then return end
|
||||||
|
local mpos2 = {x=mpos.x+math.random(0,3),y=mpos.y-1,z=mpos.z}
|
||||||
|
local mpos3 = {x=mpos.x,y=mpos.y-2,z=mpos.z+math.random(0,3)}
|
||||||
|
data = make_mine(mpos,mpos2,mpos3, data, va, 0)
|
||||||
|
vm:set_data(data)
|
||||||
|
vm:calc_lighting(emin,emax)
|
||||||
|
vm:update_liquids()
|
||||||
|
vm:write_to_map()
|
||||||
|
end)
|
Loading…
Reference in New Issue
Block a user