summaryrefslogtreecommitdiff
path: root/builtin/game/register.lua
diff options
context:
space:
mode:
authorkwolekr <kwolekr@minetest.net>2015-01-13 12:26:13 -0500
committerkwolekr <kwolekr@minetest.net>2015-01-13 12:36:05 -0500
commita4a6cc8eb1197648bce9bec1f0a1aa6aa4b787b7 (patch)
tree23f99eb94ac5b9747983a78bb2d1572c5808872d /builtin/game/register.lua
parent0fd1ee03808ee8121e7b65e5c7c9ba19599d185e (diff)
downloadminetest-a4a6cc8eb1197648bce9bec1f0a1aa6aa4b787b7.tar.gz
minetest-a4a6cc8eb1197648bce9bec1f0a1aa6aa4b787b7.tar.bz2
minetest-a4a6cc8eb1197648bce9bec1f0a1aa6aa4b787b7.zip
builtin: Unify register wrapper functions and wrap clear_registered_* functions too
Diffstat (limited to 'builtin/game/register.lua')
-rw-r--r--builtin/game/register.lua39
1 files changed, 23 insertions, 16 deletions
diff --git a/builtin/game/register.lua b/builtin/game/register.lua
index c0c579a25..f286113ec 100644
--- a/builtin/game/register.lua
+++ b/builtin/game/register.lua
@@ -368,13 +368,6 @@ end
-- Callback registration
--
-local register_biome_raw = core.register_biome
-core.registered_biomes = {}
-function core.register_biome(biome)
- core.registered_biomes[biome.name] = biome
- register_biome_raw(biome)
-end
-
local function make_registration()
local t = {}
local registerfunc = function(func) table.insert(t, func) end
@@ -387,20 +380,34 @@ local function make_registration_reverse()
return t, registerfunc
end
-local function make_registration_wrap(name)
+local function make_registration_wrap(reg_fn_name, clear_fn_name)
local list = {}
- local full_name = "register_"..name
- local orig_func = core[full_name]
- core[full_name] = function(def)
- table.insert(list, def)
- orig_func(def)
+
+ local orig_reg_fn = core[reg_fn_name]
+ core[reg_fn_name] = function(def)
+ local retval = orig_reg_fn(def)
+ if retval ~= nil then
+ if def.name ~= nil then
+ list[def.name] = def
+ else
+ list[retval] = def
+ end
+ end
+ return retval
end
+
+ local orig_clear_fn = core[clear_fn_name]
+ core[clear_fn_name] = function()
+ list = {}
+ return orig_clear_fn()
+ end
+
return list
end
-
-core.registered_ores = make_registration_wrap("ore")
-core.registered_decorations = make_registration_wrap("decoration")
+core.registered_biomes = make_registration_wrap("register_biome", "clear_registered_biomes")
+core.registered_ores = make_registration_wrap("register_ore", "clear_registered_ores")
+core.registered_decorations = make_registration_wrap("register_decoration", "clear_registered_decorations")
core.registered_on_chat_messages, core.register_on_chat_message = make_registration()
core.registered_globalsteps, core.register_globalstep = make_registration()