fat xmas scaffold commit

This commit is contained in:
cora 2020-12-27 05:07:44 +01:00
parent 00e605c0f9
commit 88c2c9449f
3 changed files with 103 additions and 19 deletions

View File

@ -4,6 +4,34 @@ local category = "Scaffold"
scaffold = {} scaffold = {}
scaffold.registered_scaffolds = {} scaffold.registered_scaffolds = {}
scaffold.lockdir = false
scaffold.locky = false
local storage=minetest.get_mod_storage()
local wason = {}
local function get_locks()
scaffold.lockdir = storage:get_string('lockdir')
scaffold.locky = storage:get_string('locky')
if scaffold.lockdir or scaffold.locky then return true end
return false
end
local function set_locks()
storage:set_string('lockdir', scaffold.lockdir)
storage:set_string('locky', scaffold.locky)
end
local function del_locks()
storage:set_string('lockdir','')
storage:set_string('locky','')
end
if get_locks() then
if scaffold.lockdir then wason.scaffold_lockyaw = true end
if scaffold.locky then wason.scaffold_locky = true end
end
function scaffold.register_scaffold(func) function scaffold.register_scaffold(func)
table.insert(scaffold.registered_scaffolds, func) table.insert(scaffold.registered_scaffolds, func)
@ -23,6 +51,9 @@ function scaffold.template(setting, func, offset)
local lp = minetest.localplayer:get_pos() local lp = minetest.localplayer:get_pos()
local tgt = vector.round(vector.add(lp, offset)) local tgt = vector.round(vector.add(lp, offset))
func(tgt) func(tgt)
if not wason[setting] then wason[setting] = true end
elseif wason[setting] then
wason[setting] = false
end end
end end
end end
@ -61,6 +92,7 @@ function scaffold.find_any_swap(items)
end end
function scaffold.in_list(val, list) function scaffold.in_list(val, list)
if type(list) ~= "table" then return false end
for i, v in ipairs(list) do for i, v in ipairs(list) do
if v == val then if v == val then
return true return true
@ -118,6 +150,18 @@ dofile(mpath .. "/autofarm.lua")
dofile(mpath .. "/railscaffold.lua") dofile(mpath .. "/railscaffold.lua")
scaffold.register_template_scaffold("LockYaw", "scaffold_lockyaw", function(pos)
if not wason.scaffold_lockyaw then scaffold.lockdir=turtle.getdir() end
if scaffold.lockdir then turtle.setdir(scaffold.lockdir) end
end)
scaffold.register_template_scaffold("LockY", "scaffold_locky", function(pos)
local lp=minetest.localplayer:get_pos()
if not wason.scaffold_locky then scaffold.locky = lp.y end
if scaffold.locky and lp.y ~= scaffold.locky then
minetest.localplayer:set_pos(vector.add(lp,{x=0,y=scaffold.locky,z=0}))
end
end)
scaffold.register_template_scaffold("CheckScaffold", "scaffold_check", function(pos) scaffold.register_template_scaffold("CheckScaffold", "scaffold_check", function(pos)
scaffold.place_if_able(pos) scaffold.place_if_able(pos)
end) end)
@ -169,7 +213,7 @@ if turtle then
end end
end end
if pl then if pl then
local lpos=turtle.dircoord(0,2,0) local lpos=turtle.dircoord(0,3,0)
local nd=minetest.get_node_or_nil(lpos) local nd=minetest.get_node_or_nil(lpos)
if nd and nd.name ~= 'mcl_ocean:sea_lantern' then if nd and nd.name ~= 'mcl_ocean:sea_lantern' then
scaffold.dig(lpos) scaffold.dig(lpos)
@ -200,6 +244,7 @@ end
if nlist then if nlist then
scaffold.register_template_scaffold("RandomScaff", "scaffold_rnd", function(below) scaffold.register_template_scaffold("RandomScaff", "scaffold_rnd", function(below)
if true then return false end
local n = minetest.get_node_or_nil(below) local n = minetest.get_node_or_nil(below)
-- n == nil is ignore -- n == nil is ignore
if n and not scaffold.in_list(n.name, nlist.get('randomscaffold')) then if n and not scaffold.in_list(n.name, nlist.get('randomscaffold')) then

View File

@ -10,12 +10,16 @@ local rails = {
} }
local tunnelmaterial = { local tunnelmaterial = {
'mcl_core:glass_light_blue',
'mcl_core:cobble', 'mcl_core:cobble',
'mcl_nether:netherrack',
'mcl_core:dirt',
'mcl_core:andesite', 'mcl_core:andesite',
'mcl_core:diorite', 'mcl_core:diorite',
'mcl_core:granite', 'mcl_core:granite'
'mcl_core:dirt'
} }
local setdir=false;
minetest.register_cheat("RailT",'Scaffold','scaffold_railtunnel') minetest.register_cheat("RailT",'Scaffold','scaffold_railtunnel')
local function checknode(pos) local function checknode(pos)
local node = minetest.get_node_or_nil(pos) local node = minetest.get_node_or_nil(pos)
@ -26,24 +30,46 @@ end
scaffold.register_template_scaffold("RailScaffold", "scaffold_rails", function(below) scaffold.register_template_scaffold("RailScaffold", "scaffold_rails", function(below)
local lp = vector.round(minetest.localplayer:get_pos()) local lp = vector.round(minetest.localplayer:get_pos())
local fpos1=turtle.dircoord(1,1,0) local fpos1=turtle.dircoord(1,2,0)
local fpos2=turtle.dircoord(1,0,0) local fpos2=turtle.dircoord(1,1,0)
local fpos3=turtle.dircoord(1,-1,0) local fpos3=turtle.dircoord(1,0,0)
local fpos4=turtle.dircoord(2,1,0)
local fpos5=turtle.dircoord(2,0,0)
local fpos6=turtle.dircoord(2,-1,0)
if checknode(fpos2) then scaffold.dig(fpos2) end
if checknode(fpos3) then scaffold.dig(fpos3) end
if checknode(fpos1) then scaffold.dig(fpos1) end if checknode(fpos1) then scaffold.dig(fpos1) end
if checknode(fpos3) then scaffold.dig(fpos3) end
if checknode(fpos2) then scaffold.dig(fpos2) end
local lp=minetest.localplayer:get_pos()
local pos1=vector.add(lp,{x=-2,y=0,z=-2})
local pos2=vector.add(lp,{x=2,y=4,z=2})
local liquids={'mcl_core:lava_source','mcl_core:water_source','mcl_core:lava_flowing','mcl_core:water_flowing'}
local liquids={'mcl_core:lava_source','mcl_core:water_source'}
local bn,cnt=minetest.find_nodes_in_area(pos1,pos2,liquids,false)
for kk,vv in pairs(bn) do
minetest.switch_to_item("mcl_nether:netherrack")
minetest.place_node(vv)
end
minetest.after("0.1",function() minetest.after("0.1",function()
if scaffold.place_if_needed(ground, below) then local frpos=turtle.dircoord(1,1,0)
scaffold.place_if_needed(rails, lp) local fgpos=turtle.dircoord(1,0,0)
end local it = core.find_item("mesecons_torch:redstoneblock")
if not it then minetest.settings:set_bool('continuous_forward',false) end
scaffold.place_if_needed(ground, below)
scaffold.place_if_needed(rails, lp)
scaffold.place_if_needed(ground, fgpos)
scaffold.place_if_needed(rails, frpos)
end) end)
if minetest.settings:get_bool('scaffold_railtunnel') then if minetest.settings:get_bool('scaffold_railtunnel') then
scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,2,0)) scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,3,0))
scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,0,1)) scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,2,1))
scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,1,1)) scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,1,1))
scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,0,-1)) scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,2,-1))
scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,1,-1)) scaffold.place_if_needed(tunnelmaterial, turtle.dircoord(0,1,-1))
end end
end) end)

View File

@ -130,6 +130,7 @@ end
function turtle.relcoord(x, y, z) function turtle.relcoord(x, y, z)
local pos = minetest.localplayer:get_pos() local pos = minetest.localplayer:get_pos()
if pos.y > -5000 then pos.y=pos.y-1 end
return turtle.cadd(pos, turtle.optcoord(x, y, z)) return turtle.cadd(pos, turtle.optcoord(x, y, z))
end end
@ -149,6 +150,17 @@ function turtle.getdir() --
return "west" return "west"
end end
end end
function turtle.setdir(dir) --
if dir == "north" then
minetest.localplayer:set_yaw(0)
elseif dir == "south" then
minetest.localplayer:set_yaw(180)
elseif dir == "east" then
minetest.localplayer:set_yaw(270)
elseif dir == "west" then
minetest.localplayer:set_yaw(90)
end
end
function turtle.dircoord(f, y, r) function turtle.dircoord(f, y, r)
local dir=turtle.getdir() local dir=turtle.getdir()
@ -156,16 +168,17 @@ function turtle.dircoord(f, y, r)
local f = coord.x local f = coord.x
local y = coord.y local y = coord.y
local r = coord.z local r = coord.z
local lp=minetest.localplayer:get_pos()
if dir == "north" then -- north if dir == "north" then
return turtle.relcoord(r, y, f) return turtle.relcoord(r, y, f)
elseif dir == "south" then -- south elseif dir == "south" then
return turtle.relcoord(-r, y, -f) return turtle.relcoord(-r, y, -f)
elseif dir == "east" then -- east elseif dir == "east" then
return turtle.relcoord(f, y, -r) return turtle.relcoord(f, y, -r)
elseif dir== "west" then -- west elseif dir== "west" then
return turtle.relcoord(-f, y, r) return turtle.relcoord(-f, y, r)
end end
return turtle.relcoord(0, 0, 0) return turtle.relcoord(0, 0, 0)
end end