mirror of
https://github.com/pyrollo/display_modpack.git
synced 2025-01-24 23:50:18 +01:00
Alternate optional parsing mechanism
This commit is contained in:
parent
89fc7f863d
commit
ccd4840c42
@ -22,6 +22,14 @@ boards = {}
|
|||||||
boards.name = minetest.get_current_modname()
|
boards.name = minetest.get_current_modname()
|
||||||
boards.path = minetest.get_modpath(boards.name)
|
boards.path = minetest.get_modpath(boards.name)
|
||||||
|
|
||||||
|
-- Load support for utfparse
|
||||||
|
local UParse
|
||||||
|
if minetest.global_exists("utfparse") then
|
||||||
|
UParse = function(...) return utfparse.parse(...) end
|
||||||
|
else
|
||||||
|
UParse = function(...) return ... end
|
||||||
|
end
|
||||||
|
|
||||||
-- Load support for intllib.
|
-- Load support for intllib.
|
||||||
local S, NS = dofile(boards.path.."/intllib.lua")
|
local S, NS = dofile(boards.path.."/intllib.lua")
|
||||||
boards.intllib = S
|
boards.intllib = S
|
||||||
@ -43,7 +51,7 @@ end
|
|||||||
local function on_receive_fields(pos, formname, fields, player)
|
local function on_receive_fields(pos, formname, fields, player)
|
||||||
if fields then
|
if fields then
|
||||||
if fields.ok or fields.key_enter then
|
if fields.ok or fields.key_enter then
|
||||||
signs_api.set_display_text(pos, fields.display_text, fields.font)
|
signs_api.set_display_text(pos, UParse(fields.display_text), fields.font)
|
||||||
end
|
end
|
||||||
if fields.wipe then
|
if fields.wipe then
|
||||||
signs_api.set_display_text(pos, "", fields.font)
|
signs_api.set_display_text(pos, "", fields.font)
|
||||||
|
@ -26,6 +26,15 @@ signs.path = minetest.get_modpath(signs.name)
|
|||||||
local S, NS = dofile(signs.path.."/intllib.lua")
|
local S, NS = dofile(signs.path.."/intllib.lua")
|
||||||
signs.intllib = S
|
signs.intllib = S
|
||||||
|
|
||||||
|
-- Load support for utfparse
|
||||||
|
local UParse
|
||||||
|
if minetest.global_exists("utfparse") then
|
||||||
|
UParse = function(...) return utfparse.parse(...) end
|
||||||
|
else
|
||||||
|
UParse = function(...) return ... end
|
||||||
|
end
|
||||||
|
signs.utfparse = UParse
|
||||||
|
|
||||||
dofile(signs.path.."/common.lua")
|
dofile(signs.path.."/common.lua")
|
||||||
dofile(signs.path.."/nodes.lua")
|
dofile(signs.path.."/nodes.lua")
|
||||||
dofile(signs.path.."/crafts.lua")
|
dofile(signs.path.."/crafts.lua")
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
name=signs
|
name=signs
|
||||||
description=Basic signs and posters with text display using signs_api
|
description=Basic signs and posters with text display using signs_api
|
||||||
depends=default,dye,signs_api
|
depends=default,dye,signs_api
|
||||||
optional_depends=intllib
|
optional_depends=intllib,utfparse
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
along with signs. If not, see <http://www.gnu.org/licenses/>.
|
along with signs. If not, see <http://www.gnu.org/licenses/>.
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
|
local UParse = signs.utfparse
|
||||||
local S = signs.intllib
|
local S = signs.intllib
|
||||||
local F = function(...) return minetest.formspec_escape(S(...)) end
|
local F = function(...) return minetest.formspec_escape(S(...)) end
|
||||||
|
|
||||||
@ -91,9 +92,9 @@ local function on_receive_fields_poster(pos, formname, fields, player)
|
|||||||
if formname == node.name.."@"..minetest.pos_to_string(pos)..":edit"
|
if formname == node.name.."@"..minetest.pos_to_string(pos)..":edit"
|
||||||
then
|
then
|
||||||
if (fields.write or fields.font or fields.key_enter) then
|
if (fields.write or fields.font or fields.key_enter) then
|
||||||
meta:set_string("display_text", fields.display_text)
|
meta:set_string("display_text", UParse(fields.display_text))
|
||||||
meta:set_string("text", fields.text)
|
meta:set_string("text", UParse(fields.text))
|
||||||
meta:set_string("infotext", "\""..fields.display_text
|
meta:set_string("infotext", "\""..UParse(fields.display_text)
|
||||||
.."\"\n"..S("(right-click to read more text)"))
|
.."\"\n"..S("(right-click to read more text)"))
|
||||||
display_api.update_entities(pos)
|
display_api.update_entities(pos)
|
||||||
end
|
end
|
||||||
|
@ -22,6 +22,15 @@ signs_api = {}
|
|||||||
signs_api.name = minetest.get_current_modname()
|
signs_api.name = minetest.get_current_modname()
|
||||||
signs_api.path = minetest.get_modpath(signs_api.name)
|
signs_api.path = minetest.get_modpath(signs_api.name)
|
||||||
|
|
||||||
|
-- Load support for utfparse
|
||||||
|
local UParse
|
||||||
|
if minetest.global_exists("utfparse") then
|
||||||
|
UParse = function(...) return utfparse.parse(...) end
|
||||||
|
else
|
||||||
|
UParse = function(...) return ... end
|
||||||
|
end
|
||||||
|
signs_api.utfparse = UParse
|
||||||
|
|
||||||
-- Load support for intllib.
|
-- Load support for intllib.
|
||||||
local S, NS = dofile(signs_api.path.."/intllib.lua")
|
local S, NS = dofile(signs_api.path.."/intllib.lua")
|
||||||
signs_api.intllib = S
|
signs_api.intllib = S
|
||||||
@ -77,10 +86,10 @@ end
|
|||||||
function signs_api.on_receive_fields(pos, formname, fields, player)
|
function signs_api.on_receive_fields(pos, formname, fields, player)
|
||||||
if not minetest.is_protected(pos, player:get_player_name()) then
|
if not minetest.is_protected(pos, player:get_player_name()) then
|
||||||
if fields and (fields.ok or fields.key_enter) then
|
if fields and (fields.ok or fields.key_enter) then
|
||||||
signs_api.set_display_text(pos, fields.display_text)
|
signs_api.set_display_text(pos, UParse(fields.display_text))
|
||||||
end
|
end
|
||||||
if fields and (fields.font) then
|
if fields and (fields.font) then
|
||||||
signs_api.set_display_text(pos, fields.display_text)
|
signs_api.set_display_text(pos, UParse(fields.display_text))
|
||||||
font_api.show_font_list(player, pos)
|
font_api.show_font_list(player, pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
name=signs_api
|
name=signs_api
|
||||||
description=A library providing various helper functions for registereing signs with text display
|
description=A library providing various helper functions for registereing signs with text display
|
||||||
depends=default,display_api,font_api
|
depends=default,display_api,font_api
|
||||||
optional_depends=intllib
|
optional_depends=intllib,utfparse
|
||||||
|
@ -25,6 +25,14 @@ steles.path = minetest.get_modpath(steles.name)
|
|||||||
-- Load support for intllib.
|
-- Load support for intllib.
|
||||||
local S, NS = dofile(steles.path.."/intllib.lua")
|
local S, NS = dofile(steles.path.."/intllib.lua")
|
||||||
steles.intllib = S
|
steles.intllib = S
|
||||||
|
-- Load support for utfparse
|
||||||
|
local UParse
|
||||||
|
if minetest.global_exists("utfparse") then
|
||||||
|
UParse = function(...) return utfparse.parse(...) end
|
||||||
|
else
|
||||||
|
UParse = function(...) return ... end
|
||||||
|
end
|
||||||
|
steles.utfparse = UParse
|
||||||
|
|
||||||
dofile(steles.path.."/config.lua")
|
dofile(steles.path.."/config.lua")
|
||||||
dofile(steles.path.."/nodes.lua")
|
dofile(steles.path.."/nodes.lua")
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
name=steles
|
name=steles
|
||||||
description=Stone steles with text display on them
|
description=Stone steles with text display on them
|
||||||
depends=default,display_api,font_api
|
depends=default,display_api,font_api
|
||||||
optional_depends=intllib,technic
|
optional_depends=intllib,technic,utfparse
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
along with steles. If not, see <http://www.gnu.org/licenses/>.
|
along with steles. If not, see <http://www.gnu.org/licenses/>.
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
|
local UParse = steles.utfparse
|
||||||
local S = steles.intllib
|
local S = steles.intllib
|
||||||
local F = function(...) return minetest.formspec_escape(S(...)) end
|
local F = function(...) return minetest.formspec_escape(S(...)) end
|
||||||
|
|
||||||
@ -79,8 +80,8 @@ for i, material in ipairs(steles.materials) do
|
|||||||
if not minetest.is_protected(pos, player:get_player_name()) then
|
if not minetest.is_protected(pos, player:get_player_name()) then
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if fields.ok or fields.font then
|
if fields.ok or fields.font then
|
||||||
meta:set_string("display_text", fields.display_text)
|
meta:set_string("display_text", UParse(fields.display_text))
|
||||||
meta:set_string("infotext", "\""..fields.display_text.."\"")
|
meta:set_string("infotext", "\""..UParse(fields.display_text).."\"")
|
||||||
display_api.update_entities(pos)
|
display_api.update_entities(pos)
|
||||||
end
|
end
|
||||||
if fields.font then
|
if fields.font then
|
||||||
|
Loading…
Reference in New Issue
Block a user