merged dev into master pull request #5 by Jat15
314
init.lua
@ -5,7 +5,103 @@
|
|||||||
|
|
||||||
|
|
||||||
arrow_signs={}
|
arrow_signs={}
|
||||||
|
|
||||||
arrow_signs.formspec = "field[text;Sign text:;${text}]";
|
arrow_signs.formspec = "field[text;Sign text:;${text}]";
|
||||||
|
|
||||||
|
arrow_signs_on_place = function(itemstack, placer, pointed_thing)
|
||||||
|
|
||||||
|
local posabove = pointed_thing.above
|
||||||
|
local posunder = pointed_thing.under
|
||||||
|
local vector = placer:get_look_dir()
|
||||||
|
local place = true
|
||||||
|
|
||||||
|
if posabove.y>posunder.y then
|
||||||
|
if(vector.z>0.5 and vector.z<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 10})
|
||||||
|
elseif (vector.x>0.5 and vector.x<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 19})
|
||||||
|
elseif(-0.5>vector.z and -1<=vector.z) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 4})
|
||||||
|
elseif (-0.5>vector.x and -1<=vector.x) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 13})
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
elseif posabove.y<posunder.y then
|
||||||
|
if(vector.z>0.5 and vector.z<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 8})
|
||||||
|
elseif (vector.x>0.5 and vector.x<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 17})
|
||||||
|
elseif(-0.5>vector.z and -1<=vector.z) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 6})
|
||||||
|
elseif (-0.5>vector.x and -1<=vector.x) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 15})
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
elseif posabove.z>posunder.z then
|
||||||
|
if(vector.y>0.75 and vector.y<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 22})
|
||||||
|
elseif (vector.y>=-1 and vector.y<-0.75) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 2})
|
||||||
|
elseif (vector.x>=0 and vector.x<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 18})
|
||||||
|
elseif (vector.x<0 and vector.x>=-1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 14})
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
elseif posabove.z<posunder.z then
|
||||||
|
if(vector.y>0.75 and vector.y<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 20})
|
||||||
|
elseif (vector.y>=-1 and vector.y<-0.75) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 0})
|
||||||
|
elseif (vector.x>=0 and vector.x<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 16})
|
||||||
|
elseif (vector.x<0 and vector.x>=-1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 12})
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
elseif posabove.x>posunder.x then
|
||||||
|
if(vector.y>0.75 and vector.y<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 21})
|
||||||
|
elseif (vector.y>=-1 and vector.y<-0.75) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 3})
|
||||||
|
elseif (vector.z>=0 and vector.z<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 11})
|
||||||
|
elseif (vector.z<0 and vector.z>=-1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 7})
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
elseif posabove.x<posunder.x then
|
||||||
|
if(vector.y>0.75 and vector.y<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 23})
|
||||||
|
elseif (vector.y>=-1 and vector.y<-0.75) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 1})
|
||||||
|
elseif (vector.z>=0 and vector.z<=1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 9})
|
||||||
|
elseif (vector.z<0 and vector.z>=-1) then
|
||||||
|
minetest.add_node(posabove,{name = itemstack:get_name(), param2 = 5})
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
else
|
||||||
|
place = false
|
||||||
|
end
|
||||||
|
|
||||||
|
if not(place) then
|
||||||
|
minetest.rotate_node(itemstack, placer, pointed_thing)
|
||||||
|
else
|
||||||
|
itemstack:take_item()
|
||||||
|
end
|
||||||
|
|
||||||
|
return itemstack
|
||||||
|
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
function arrow_signs:savetext(pos, formname, fields, sender)
|
function arrow_signs:savetext(pos, formname, fields, sender)
|
||||||
|
|
||||||
if not minetest.get_player_privs(sender:get_player_name())["interact"] then
|
if not minetest.get_player_privs(sender:get_player_name())["interact"] then
|
||||||
@ -39,63 +135,37 @@ minetest.override_item("default:sign_wall", {
|
|||||||
groups = {choppy=2,dig_immediate=2,attached_node=1,sign=1},
|
groups = {choppy=2,dig_immediate=2,attached_node=1,sign=1},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
--Sign arrow
|
||||||
|
minetest.register_node("arrow_signs:wall", {
|
||||||
|
description = "Arrow signs",
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
--Sign right
|
fixed = {
|
||||||
minetest.register_node("arrow_signs:wall_right", {
|
{ 0.25, -0.25, 0.5, -0.25, 0.5, 0.47},
|
||||||
description = "Sign right",
|
{ 0.1875, -0.3125, 0.5, -0.1875, -0.25, 0.47},
|
||||||
drawtype = "signlike",
|
{ 0.125, -0.3125, 0.5, -0.125, -0.375, 0.47},
|
||||||
tiles = {"arrow_sign_right.png"},
|
{ 0.0625, -0.375, 0.5, -0.0625, -0.437, 0.47}
|
||||||
inventory_image = "arrow_sign_right.png",
|
}
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ 0.25, -0.25, 0.5, -0.25, 0.5, 0.47},
|
||||||
|
{ 0.1875, -0.3125, 0.5, -0.1875, -0.25, 0.47},
|
||||||
|
{ 0.125, -0.3125, 0.5, -0.125, -0.375, 0.47},
|
||||||
|
{ 0.0625, -0.375, 0.5, -0.0625, -0.437, 0.47}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
tiles = {"arrow_sign_border_left.png","arrow_sign_border_right.png","arrow_sign_border_up.png","arrow_sign_border_down.png","arrow_sign.png","arrow_sign.png"},
|
||||||
|
inventory_image = "arrow_sign.png",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "wallmounted",
|
paramtype2 = "facedir",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
selection_box = {
|
groups = {choppy=2,dig_immediate=2,sign=1},
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,attached_node=1,sign=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
sounds = default.node_sound_defaults(),
|
|
||||||
on_construct = function(pos)
|
|
||||||
--local n = minetest.get_node(pos)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
meta:set_string("formspec", arrow_signs.formspec)
|
|
||||||
meta:set_string("infotext", "\"\"")
|
|
||||||
end,
|
|
||||||
on_receive_fields = function(pos, formname, fields, sender)
|
|
||||||
arrow_signs:savetext(pos, formname, fields, sender)
|
|
||||||
end,
|
|
||||||
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
-- sign left
|
|
||||||
minetest.register_node("arrow_signs:wall_left", {
|
|
||||||
description = "Sign left",
|
|
||||||
drawtype = "signlike",
|
|
||||||
tiles = {"arrow_sign_left.png"},
|
|
||||||
inventory_image = "arrow_sign_left.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "wallmounted",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,attached_node=1,sign=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
sounds = default.node_sound_defaults(),
|
sounds = default.node_sound_defaults(),
|
||||||
|
on_place = arrow_signs_on_place,
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
--local n = minetest.get_node(pos)
|
--local n = minetest.get_node(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
@ -107,128 +177,44 @@ minetest.register_node("arrow_signs:wall_left", {
|
|||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
--Recipes
|
||||||
--Sign up
|
|
||||||
minetest.register_node("arrow_signs:wall_up", {
|
|
||||||
description = "Sign up",
|
|
||||||
drawtype = "signlike",
|
|
||||||
tiles = {"arrow_sign_up.png"},
|
|
||||||
inventory_image = "arrow_sign_up.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "wallmounted",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,attached_node=1,sign=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
sounds = default.node_sound_defaults(),
|
|
||||||
on_construct = function(pos)
|
|
||||||
--local n = minetest.get_node(pos)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
meta:set_string("formspec", arrow_signs.formspec)
|
|
||||||
meta:set_string("infotext", "\"\"")
|
|
||||||
end,
|
|
||||||
on_receive_fields = function(pos, formname, fields, sender)
|
|
||||||
arrow_signs:savetext(pos, formname, fields, sender)
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
--Sign down
|
|
||||||
minetest.register_node("arrow_signs:wall_down", {
|
|
||||||
description = "Sign down",
|
|
||||||
drawtype = "signlike",
|
|
||||||
tiles = {"arrow_sign_down.png"},
|
|
||||||
inventory_image = "arrow_sign_down.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "wallmounted",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,attached_node=1,sign=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
sounds = default.node_sound_defaults(),
|
|
||||||
on_construct = function(pos)
|
|
||||||
--local n = minetest.get_node(pos)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
meta:set_string("formspec", arrow_signs.formspec)
|
|
||||||
meta:set_string("infotext", "\"\"")
|
|
||||||
end,
|
|
||||||
on_receive_fields = function(pos, formname, fields, sender)
|
|
||||||
arrow_signs:savetext(pos, formname, fields, sender)
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--recipes
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'arrow_signs:wall_right 1',
|
type = 'shapeless',
|
||||||
recipe = {
|
output = 'arrow_signs:wall',
|
||||||
{'', '', ''},
|
recipe = {'group:sign', 'default:stick'},
|
||||||
{'', 'group:sign', 'default:stick'},
|
|
||||||
{'', '', ''},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
minetest.register_craft({
|
|
||||||
output = 'arrow_signs:wall_left 1',
|
|
||||||
recipe = {
|
|
||||||
{'', '', ''},
|
|
||||||
{'default:stick', 'group:sign', ''},
|
|
||||||
{'', '', ''},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
minetest.register_craft({
|
|
||||||
output = 'arrow_signs:wall_up 1',
|
|
||||||
recipe = {
|
|
||||||
{'', 'default:stick', ''},
|
|
||||||
{'', 'group:sign', ''},
|
|
||||||
{'', '', ''},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
minetest.register_craft({
|
|
||||||
output = 'arrow_signs:wall_down 1',
|
|
||||||
recipe = {
|
|
||||||
{'', '', ''},
|
|
||||||
{'', 'group:sign', ''},
|
|
||||||
{'', 'default:stick', ''},
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:sign_wall',
|
output = 'default:sign_wall',
|
||||||
recipe = {
|
recipe = {
|
||||||
|
|
||||||
{'group:sign'},
|
{'group:sign'},
|
||||||
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_alias("more_signs:wall_right", "arrow_signs:wall_right")
|
--Redefinition
|
||||||
minetest.register_alias("sign_right", "arrow_signs:wall_right")
|
minetest.register_abm({
|
||||||
|
nodenames = {"arrow_signs:wall_right", "arrow_signs:wall_left", "arrow_signs:wall_up", "arrow_signs:wall_down",
|
||||||
minetest.register_alias("more_signs:wall_left", "arrow_signs:wall_left")
|
"more_signs:wall_right","more_signs:wall_left","more_signs:wall_up" ,"more_signs:wall_down"
|
||||||
minetest.register_alias("sign_left", "arrow_signs:wall_left")
|
},
|
||||||
|
interval = 1,
|
||||||
minetest.register_alias("more_signs:wall_up", "arrow_signs:wall_up")
|
chance = 1,
|
||||||
minetest.register_alias("sign_up", "arrow_signs:wall_up")
|
action = function(pos, node)
|
||||||
|
local convert_facedir={
|
||||||
minetest.register_alias("more_signs:wall_down", "arrow_signs:wall_down")
|
["arrow_signs:wall_right"] = {6,4,5,11,16,14},
|
||||||
minetest.register_alias("sign_down", "arrow_signs:wall_down")
|
["arrow_signs:wall_left"] = {8,10,9,7,12,18},
|
||||||
|
["arrow_signs:wall_up"] = {15,19,23,21,20,22},
|
||||||
|
["arrow_signs:wall_down"] = {17,13,1,3,0,2},
|
||||||
|
-- For old mod
|
||||||
|
["more_signs:wall_right"] = {6,4,5,11,16,14},
|
||||||
|
["more_signs:wall_left"] = {8,10,9,7,12,18},
|
||||||
|
["more_signs:wall_up"] = {15,19,23,21,20,22},
|
||||||
|
["more_signs:wall_down"] = {17,13,1,3,0,2},
|
||||||
|
}
|
||||||
|
minetest.swap_node(pos, {name="arrow_signs:wall",param2=convert_facedir[node.name][node.param2+1]})
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
--Locked sign
|
||||||
if locks then
|
if locks then
|
||||||
local MODPATH = minetest.get_modpath("arrow_signs");
|
local MODPATH = minetest.get_modpath("arrow_signs");
|
||||||
dofile(MODPATH.."/shared_locked.lua")
|
dofile(MODPATH.."/shared_locked.lua")
|
||||||
|
@ -1,208 +1,35 @@
|
|||||||
-- a sign
|
-- a sign
|
||||||
minetest.register_node("arrow_signs:shared_locked_right", {
|
minetest.register_node("arrow_signs:shared_locked", {
|
||||||
description = "Shared locked sign right",
|
description = "Shared locked sign",
|
||||||
drawtype = "signlike",
|
drawtype = "nodebox",
|
||||||
tiles = {"arrow_sign_right.png"},
|
node_box = {
|
||||||
inventory_image = "arrow_sign_right.png",
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ 0.25, -0.25, 0.5, -0.25, 0.5, 0.47},
|
||||||
|
{ 0.1875, -0.3125, 0.5, -0.1875, -0.25, 0.47},
|
||||||
|
{ 0.125, -0.3125, 0.5, -0.125, -0.375, 0.47},
|
||||||
|
{ 0.0625, -0.375, 0.5, -0.0625, -0.437, 0.47}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ 0.25, -0.25, 0.5, -0.25, 0.5, 0.47},
|
||||||
|
{ 0.1875, -0.3125, 0.5, -0.1875, -0.25, 0.47},
|
||||||
|
{ 0.125, -0.3125, 0.5, -0.125, -0.375, 0.47},
|
||||||
|
{ 0.0625, -0.375, 0.5, -0.0625, -0.437, 0.47}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
tiles = {"arrow_sign_border_left.png","arrow_sign_border_right.png","arrow_sign_border_up.png","arrow_sign_border_down.png","arrow_sign.png","arrow_sign.png"},
|
||||||
|
inventory_image = "arrow_sign.png",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "wallmounted",
|
paramtype2 = "facedir",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,sign_locked=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
|
|
||||||
|
|
||||||
on_construct = function(pos)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
-- prepare the lock of the sign
|
|
||||||
locks:lock_init( pos,
|
|
||||||
"size[8,4]"..
|
|
||||||
"field[0.3,0.6;6,0.7;text;Text:;]"..
|
|
||||||
"field[0.3,3.6;6,0.7;locks_sent_lock_command;Locked sign. Type /help for help:;]"..
|
|
||||||
"button_exit[6.3,3.2;1.7,0.7;locks_sent_input;Proceed]" );
|
|
||||||
end,
|
|
||||||
|
|
||||||
after_place_node = function(pos, placer)
|
|
||||||
locks:lock_set_owner( pos, placer, "Shared locked sign" );
|
|
||||||
end,
|
|
||||||
|
|
||||||
|
|
||||||
can_dig = function(pos,player)
|
|
||||||
return locks:lock_allow_dig( pos, player );
|
|
||||||
end,
|
|
||||||
|
|
||||||
on_receive_fields = function(pos, formname, fields, sender)
|
|
||||||
|
|
||||||
-- if the user already has the right to use this and did input text
|
|
||||||
if( fields.text
|
|
||||||
and ( not(fields.locks_sent_lock_command)
|
|
||||||
or fields.locks_sent_lock_command=="")
|
|
||||||
and locks:lock_allow_use( pos, sender )) then
|
|
||||||
|
|
||||||
--print("Sign at "..minetest.pos_to_string(pos).." got "..dump(fields))
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
fields.text = fields.text or "";
|
|
||||||
print((sender:get_player_name() or "").." wrote \""..fields.text..
|
|
||||||
"\" to sign at "..minetest.pos_to_string(pos));
|
|
||||||
meta:set_string("text", fields.text.." ["..sender:get_player_name().."]");
|
|
||||||
meta:set_string("infotext", '"'..fields.text..'"'.." ["..sender:get_player_name().."]");
|
|
||||||
|
|
||||||
-- a command for the lock?
|
|
||||||
else
|
|
||||||
arrow_signs:savetext( pos, formname, fields, sender );
|
|
||||||
end
|
|
||||||
|
|
||||||
end,
|
|
||||||
});
|
|
||||||
--left
|
|
||||||
minetest.register_node("arrow_signs:shared_locked_left", {
|
|
||||||
description = "Shared locked sign left",
|
|
||||||
drawtype = "signlike",
|
|
||||||
tiles = {"arrow_sign_left.png"},
|
|
||||||
inventory_image = "arrow_sign_left.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "wallmounted",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,sign_locked=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
|
|
||||||
|
|
||||||
on_construct = function(pos)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
-- prepare the lock of the sign
|
|
||||||
locks:lock_init( pos,
|
|
||||||
"size[8,4]"..
|
|
||||||
"field[0.3,0.6;6,0.7;text;Text:;]"..
|
|
||||||
"field[0.3,3.6;6,0.7;locks_sent_lock_command;Locked sign. Type /help for help:;]"..
|
|
||||||
"button_exit[6.3,3.2;1.7,0.7;locks_sent_input;Proceed]" );
|
|
||||||
end,
|
|
||||||
|
|
||||||
after_place_node = function(pos, placer)
|
|
||||||
locks:lock_set_owner( pos, placer, "Shared locked sign" );
|
|
||||||
end,
|
|
||||||
|
|
||||||
|
|
||||||
can_dig = function(pos,player)
|
|
||||||
return locks:lock_allow_dig( pos, player );
|
|
||||||
end,
|
|
||||||
|
|
||||||
on_receive_fields = function(pos, formname, fields, sender)
|
|
||||||
|
|
||||||
-- if the user already has the right to use this and did input text
|
|
||||||
if( fields.text
|
|
||||||
and ( not(fields.locks_sent_lock_command)
|
|
||||||
or fields.locks_sent_lock_command=="")
|
|
||||||
and locks:lock_allow_use( pos, sender )) then
|
|
||||||
|
|
||||||
--print("Sign at "..minetest.pos_to_string(pos).." got "..dump(fields))
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
fields.text = fields.text or "";
|
|
||||||
print((sender:get_player_name() or "").." wrote \""..fields.text..
|
|
||||||
"\" to sign at "..minetest.pos_to_string(pos));
|
|
||||||
meta:set_string("text", fields.text.." ["..sender:get_player_name().."]");
|
|
||||||
meta:set_string("infotext", '"'..fields.text..'"'.." ["..sender:get_player_name().."]");
|
|
||||||
|
|
||||||
-- a command for the lock?
|
|
||||||
else
|
|
||||||
arrow_signs:savetext( pos, formname, fields, sender );
|
|
||||||
end
|
|
||||||
|
|
||||||
end,
|
|
||||||
});
|
|
||||||
--up
|
|
||||||
minetest.register_node("arrow_signs:shared_locked_up", {
|
|
||||||
description = "Shared locked sign up",
|
|
||||||
drawtype = "signlike",
|
|
||||||
tiles = {"arrow_sign_up.png"},
|
|
||||||
inventory_image = "arrow_sign_up.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "wallmounted",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,sign_locked=1},
|
|
||||||
legacy_wallmounted = true,
|
|
||||||
|
|
||||||
|
|
||||||
on_construct = function(pos)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
-- prepare the lock of the sign
|
|
||||||
locks:lock_init( pos,
|
|
||||||
"size[8,4]"..
|
|
||||||
"field[0.3,0.6;6,0.7;text;Text:;]"..
|
|
||||||
"field[0.3,3.6;6,0.7;locks_sent_lock_command;Locked sign. Type /help for help:;]"..
|
|
||||||
"button_exit[6.3,3.2;1.7,0.7;locks_sent_input;Proceed]" );
|
|
||||||
end,
|
|
||||||
|
|
||||||
after_place_node = function(pos, placer)
|
|
||||||
locks:lock_set_owner( pos, placer, "Shared locked sign" );
|
|
||||||
end,
|
|
||||||
|
|
||||||
|
|
||||||
can_dig = function(pos,player)
|
|
||||||
return locks:lock_allow_dig( pos, player );
|
|
||||||
end,
|
|
||||||
|
|
||||||
on_receive_fields = function(pos, formname, fields, sender)
|
|
||||||
|
|
||||||
-- if the user already has the right to use this and did input text
|
|
||||||
if( fields.text
|
|
||||||
and ( not(fields.locks_sent_lock_command)
|
|
||||||
or fields.locks_sent_lock_command=="")
|
|
||||||
and locks:lock_allow_use( pos, sender )) then
|
|
||||||
|
|
||||||
--print("Sign at "..minetest.pos_to_string(pos).." got "..dump(fields))
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
fields.text = fields.text or "";
|
|
||||||
print((sender:get_player_name() or "").." wrote \""..fields.text..
|
|
||||||
"\" to sign at "..minetest.pos_to_string(pos));
|
|
||||||
meta:set_string("text", fields.text.." ["..sender:get_player_name().."]");
|
|
||||||
meta:set_string("infotext", '"'..fields.text..'"'.." ["..sender:get_player_name().."]");
|
|
||||||
|
|
||||||
-- a command for the lock?
|
|
||||||
else
|
|
||||||
arrow_signs:savetext( pos, formname, fields, sender );
|
|
||||||
end
|
|
||||||
|
|
||||||
end,
|
|
||||||
});
|
|
||||||
--down
|
|
||||||
minetest.register_node("arrow_signs:shared_locked_down", {
|
|
||||||
description = "Shared locked sign down",
|
|
||||||
drawtype = "signlike",
|
|
||||||
tiles = {"arrow_sign_down.png"},
|
|
||||||
inventory_image = "arrow_sign_down.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "wallmounted",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "wallmounted",
|
|
||||||
--wall_top = <default>
|
|
||||||
--wall_bottom = <default>
|
|
||||||
--wall_side = <default>
|
|
||||||
},
|
|
||||||
groups = {choppy=2,dig_immediate=2,sign_locked=1},
|
groups = {choppy=2,dig_immediate=2,sign_locked=1},
|
||||||
legacy_wallmounted = true,
|
legacy_wallmounted = true,
|
||||||
|
|
||||||
|
on_place = arrow_signs_on_place,
|
||||||
|
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
@ -248,37 +75,23 @@ minetest.register_node("arrow_signs:shared_locked_right", {
|
|||||||
});
|
});
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'arrow_signs:shared_locked_right',
|
type = 'shapeless',
|
||||||
recipe = {
|
output = 'arrow_signs:shared_locked',
|
||||||
{ 'arrow_signs:wall_right', 'locks:lock', '' },
|
recipe = {'arrow_signs:wall', 'locks:lock'},
|
||||||
},
|
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
--Redefinition
|
||||||
output = 'arrow_signs:shared_locked_left',
|
minetest.register_abm({
|
||||||
recipe = {
|
nodenames = {"arrow_signs:shared_locked_right", "'arrow_signs:shared_locked_left", "arrow_signs:shared_locked_up", "arrow_signs:shared_locked_down"},
|
||||||
{ 'arrow_signs:wall_left', 'locks:lock', '' },
|
interval = 1,
|
||||||
},
|
chance = 1,
|
||||||
})
|
action = function(pos, node)
|
||||||
|
local convert_facedir={
|
||||||
minetest.register_craft({
|
["arrow_signs:shared_locked_right"]={6,4,5,11,16,14},
|
||||||
output = 'arrow_signs:shared_locked_up',
|
["arrow_signs:shared_locked_left"]={8,10,9,7,12,18},
|
||||||
recipe = {
|
["arrow_signs:shared_locked_up"]={15,19,23,21,20,22},
|
||||||
{ 'arrow_signs:wall_up', 'locks:lock', '' },
|
["arrow_signs:shared_locked_down"]={17,13,1,3,0,2}
|
||||||
},
|
}
|
||||||
})
|
minetest.swap_node(pos, {name="arrow_signs:shared_locked",param2=convert_facedir[node.name][node.param2-1]})
|
||||||
|
end,
|
||||||
minetest.register_craft({
|
|
||||||
output = 'arrow_signs:shared_locked_down',
|
|
||||||
recipe = {
|
|
||||||
{ 'arrow_signs:wall_down', 'locks:lock', '' },
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = 'arrow_signs:shared_locked_right',
|
|
||||||
recipe = {
|
|
||||||
{ 'group:', 'locks:lock', '' },
|
|
||||||
},
|
|
||||||
})
|
})
|
Before Width: | Height: | Size: 676 B After Width: | Height: | Size: 676 B |
BIN
textures/arrow_sign_border_down.png
Normal file
After Width: | Height: | Size: 262 B |
BIN
textures/arrow_sign_border_left.png
Normal file
After Width: | Height: | Size: 236 B |
BIN
textures/arrow_sign_border_right.png
Normal file
After Width: | Height: | Size: 215 B |
BIN
textures/arrow_sign_border_up.png
Normal file
After Width: | Height: | Size: 260 B |
Before Width: | Height: | Size: 658 B |
Before Width: | Height: | Size: 666 B |
Before Width: | Height: | Size: 691 B |