diff options
author | ANAND <ClobberXD@gmail.com> | 2019-04-28 15:12:20 +0530 |
---|---|---|
committer | sfan5 <sfan5@live.de> | 2019-05-04 12:56:19 +0200 |
commit | 72feab081c336d2d71d300131d30e71694b485f3 (patch) | |
tree | e3c202863ab57011831de81fec82d14b65c85acb | |
parent | 96f250ed8f5b019904bb67c427fe5c1babf0f4df (diff) | |
download | minetest-72feab081c336d2d71d300131d30e71694b485f3.tar.gz minetest-72feab081c336d2d71d300131d30e71694b485f3.tar.bz2 minetest-72feab081c336d2d71d300131d30e71694b485f3.zip |
builtin/../register.lua: Abort make_wrap_deregistration if param is invalid
-rw-r--r-- | builtin/game/register.lua | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/builtin/game/register.lua b/builtin/game/register.lua index 3edab0471..d111e5c27 100644 --- a/builtin/game/register.lua +++ b/builtin/game/register.lua @@ -514,11 +514,17 @@ local function make_registration_wrap(reg_fn_name, clear_fn_name) end local function make_wrap_deregistration(reg_fn, clear_fn, list) - local unregister = function (unregistered_key) + local unregister = function (key) + if type(key) ~= "string" then + error("key is not a string", 2) + end + if not list[key] then + error("Attempt to unregister non-existent element - '" .. key .. "'", 2) + end local temporary_list = table.copy(list) clear_fn() for k,v in pairs(temporary_list) do - if unregistered_key ~= k then + if key ~= k then reg_fn(v) end end @@ -564,7 +570,8 @@ core.registered_biomes = make_registration_wrap("register_biome", "cle core.registered_ores = make_registration_wrap("register_ore", "clear_registered_ores") core.registered_decorations = make_registration_wrap("register_decoration", "clear_registered_decorations") -core.unregister_biome = make_wrap_deregistration(core.register_biome, core.clear_registered_biomes, core.registered_biomes) +core.unregister_biome = make_wrap_deregistration(core.register_biome, + core.clear_registered_biomes, core.registered_biomes) core.registered_on_chat_messages, core.register_on_chat_message = make_registration() core.registered_globalsteps, core.register_globalstep = make_registration() |