commit 22e18d03a2dfd34f059ce73499fae84c5c890b3f Author: Wuzzy Date: Thu Oct 9 16:53:53 2014 +0200 Import mines 0.3 by BlockMen diff --git a/README.txt b/README.txt new file mode 100644 index 0000000..b65e4c1 --- /dev/null +++ b/README.txt @@ -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 \ No newline at end of file diff --git a/depends.txt b/depends.txt new file mode 100644 index 0000000..331d858 --- /dev/null +++ b/depends.txt @@ -0,0 +1 @@ +default \ No newline at end of file diff --git a/init.lua b/init.lua new file mode 100644 index 0000000..968167e --- /dev/null +++ b/init.lua @@ -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)