9 Commits

Author SHA1 Message Date
2907b3dd0c update to version 4.1
fixed:
* text is saved if user exit formspec by pressign esc
* everybody was allowed to edit the locked arrow sign
* uninitialized global variable
* tidy up code
2015-03-13 15:02:54 +01:00
73bf457a8c Merged in Jat15/dependstxt-edited-online-with-bitbucket-1423246322583 (pull request #6)
Fix craft (group) with modpack homedecor
2015-02-06 19:37:06 +01:00
ad28a5b7f6 Fix craft (group) with modpack homedecor 2015-02-06 18:12:47 +00:00
e403d916d2 fixed selection box 2014-08-13 19:48:11 +02:00
03579c3912 Merged in dev (pull request #5)
Merging Dev in Master
2014-08-13 19:39:16 +02:00
f963f894ca merged dev into master pull request #5 by Jat15 2014-08-13 19:31:35 +02:00
d252588de1 fixed not working in version 0.4.10 2014-07-20 08:22:02 +02:00
7f84a95d1e Merged in Jat15/arrow_signs/correction (pull request #3)
Minetest.env: deprecated.
2014-01-05 22:01:19 +01:00
Jat
de70260127 Minetest.env: deprecated. 2014-01-05 17:08:59 +01:00
3 changed files with 42 additions and 41 deletions

View File

@ -1,2 +1,3 @@
default default
signs_lib?
locks? locks?

View File

@ -1,4 +1,5 @@
--more_signs by addi --arrow_signs by addi
--thanks to Jat15 for the new place and rotate-system.
--Code and Textures are under the CC by-sa 3.0 licence --Code and Textures are under the CC by-sa 3.0 licence
--see: http://creativecommons.org/licenses/by-sa/3.0/ --see: http://creativecommons.org/licenses/by-sa/3.0/
@ -8,7 +9,7 @@ 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) arrow_signs.on_place = function(itemstack, placer, pointed_thing)
local posabove = pointed_thing.above local posabove = pointed_thing.above
local posunder = pointed_thing.under local posunder = pointed_thing.under
@ -103,20 +104,20 @@ arrow_signs_on_place = function(itemstack, placer, pointed_thing)
end end
function arrow_signs:savetext(pos, formname, fields, sender) arrow_signs.savetext = function(pos, formname, fields, sender)
if fields.text then
if not minetest.get_player_privs(sender:get_player_name())["interact"] then if not minetest.get_player_privs(sender:get_player_name())["interact"] then
minetest.chat_send_player(sender:get_player_name(), "error: you don't have permission to edit the sign. you need the interact priv") minetest.chat_send_player(sender:get_player_name(), "error: you don't have permission to edit the sign. you need the interact priv")
return return
end end
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
fields.text = fields.text or "" fields.text = fields.text or ""
print((sender:get_player_name() or "").." wrote \""..fields.text.. minetest.log("action", (sender:get_player_name() or "").." wrote \""..fields.text..
"\" to sign at "..minetest.pos_to_string(pos)) "\" to sign at "..minetest.pos_to_string(pos));
meta:set_string("text", fields.text) meta:set_string("text", fields.text)
text = arrow_signs:create_lines(fields.text) local text = arrow_signs.create_lines(fields.text)
meta:set_string("infotext", '"'..text..'"') meta:set_string("infotext", '"'..text..'"')
i=0 local i=0
for wort in text:gfind("\n") do for wort in text:gfind("\n") do
i=i+1 i=i+1
end end
@ -125,8 +126,10 @@ end
end end
return true return true
end end
end
function arrow_signs:create_lines(text) --this function creates the linebreaks
arrow_signs.create_lines = function(text)
text = text:gsub("/", "\"\n\"") text = text:gsub("/", "\"\n\"")
text = text:gsub("|", "\"\n\"") text = text:gsub("|", "\"\n\"")
return text return text
@ -152,10 +155,7 @@ minetest.register_node("arrow_signs:wall", {
selection_box = { selection_box = {
type = "fixed", type = "fixed",
fixed = { fixed = {
{ 0.25, -0.25, 0.5, -0.25, 0.5, 0.47}, { 0.30, -0.5, 0.5, -0.30, 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"}, 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"},
@ -166,16 +166,14 @@ minetest.register_node("arrow_signs:wall", {
walkable = false, walkable = false,
groups = {choppy=2,dig_immediate=2,sign=1}, groups = {choppy=2,dig_immediate=2,sign=1},
sounds = default.node_sound_defaults(), sounds = default.node_sound_defaults(),
on_place = arrow_signs_on_place, 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)
meta:set_string("formspec", arrow_signs.formspec) meta:set_string("formspec", arrow_signs.formspec)
meta:set_string("infotext", "\"\"") meta:set_string("infotext", [[""]])
end,
on_receive_fields = function(pos, formname, fields, sender)
arrow_signs:savetext(pos, formname, fields, sender)
end, end,
on_receive_fields = arrow_signs.savetext,
}) })
--Recipes --Recipes

View File

@ -14,10 +14,7 @@ minetest.register_node("arrow_signs:shared_locked", {
selection_box = { selection_box = {
type = "fixed", type = "fixed",
fixed = { fixed = {
{ 0.25, -0.25, 0.5, -0.25, 0.5, 0.47}, { 0.30, -0.5, 0.5, -0.30, 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"}, 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"},
@ -29,14 +26,16 @@ minetest.register_node("arrow_signs:shared_locked", {
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_place = function(itemstack, placer, pointed_thing)
arrow_signs.on_place(itemstack, placer, pointed_thing);
locks:lock_set_owner( pointed_thing.above, placer, "Shared locked sign" );
end,
on_construct = function(pos) on_construct = function(pos)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
-- prepare the lock of the sign -- prepare the lock of the sign
locks:lock_init( pos, locks:lock_init( pos,
"size[8,4]".. "size[8,4]"..
"field[0.3,0.6;6,0.7;text;Text:;]".. "field[0.3,0.6;6,0.7;text;Text:;${text}]"..
"field[0.3,3.6;6,0.7;locks_sent_lock_command;Locked sign. Type /help for help:;]".. "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]" ); "button_exit[6.3,3.2;1.7,0.7;locks_sent_input;Proceed]" );
end, end,
@ -57,18 +56,21 @@ minetest.register_node("arrow_signs:shared_locked", {
and ( not(fields.locks_sent_lock_command) and ( not(fields.locks_sent_lock_command)
or fields.locks_sent_lock_command=="") or fields.locks_sent_lock_command=="")
and locks:lock_allow_use( pos, sender )) then and locks:lock_allow_use( pos, sender )) then
--then save the text to the sign meta
--print("Sign at "..minetest.pos_to_string(pos).." got "..dump(fields)) --print("Sign at "..minetest.pos_to_string(pos).." got "..dump(fields))
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
fields.text = fields.text or ""; fields.text = fields.text or "";
print((sender:get_player_name() or "").." wrote \""..fields.text.. minetest.log("action", (sender:get_player_name() or "").." wrote \""..fields.text..
"\" to sign at "..minetest.pos_to_string(pos)); "\" to sign at "..minetest.pos_to_string(pos));
meta:set_string("text", fields.text.." ["..sender:get_player_name().."]"); meta:set_string("text", fields.text);
meta:set_string("infotext", '"'..fields.text..'"'.." ["..sender:get_player_name().."]"); local text = arrow_signs.create_lines(fields.text)
meta:set_string("infotext", '"'..text..'"'.." ["..sender:get_player_name().."]");
-- a command for the lock? -- a command for the lock?
else else
arrow_signs:savetext( pos, formname, fields, sender ); --do nothing, because user does not have the right to change the sign
--a warning message is also printed by the locks mod
--arrow_signs.savetext( pos, formname, fields, sender );
end end
end, end,