diff options
author | Rubenwardy <anjayward@gmail.com> | 2013-02-23 12:02:02 +0000 |
---|---|---|
committer | Rubenwardy <anjayward@gmail.com> | 2013-02-23 12:02:02 +0000 |
commit | 96f692215eb4f937587a0721d8580820cbbef4ce (patch) | |
tree | ccdd53842f3d63eb9bcdb7f0979758448333f8f8 /triggers.lua | |
parent | 0b4ac32bfb1b20426c818865edbab47f851eeab9 (diff) |
table based triggers
Diffstat (limited to 'triggers.lua')
-rw-r--r-- | triggers.lua | 54 |
1 files changed, 51 insertions, 3 deletions
diff --git a/triggers.lua b/triggers.lua index 2ce81de..03d7703 100644 --- a/triggers.lua +++ b/triggers.lua @@ -47,7 +47,31 @@ minetest.register_on_dignode(function(pos, oldnode, digger) local data=player_data[playern] for i=1,# awards.onDig do - local res=awards.onDig[i](player,data) + local res=nil + + if type(awards.onDig[i]) == "function" then + -- run the function + print(i.." is a function") + res=awards.onDig[i](player,data) + elseif type(awards.onDig[i]) == "table" then + -- handle table here + print(i.." is a table") + if not awards.onDig[i]['node'] or not awards.onDig[i]['target'] or not awards.onDig[i]['award'] then + -- table running failed! + else + -- run the table + local tnodedug = string.split(awards.onDig[i]['node'], ":") + + local tmod=tnodedug[1] + local titem=tnodedug[2] + + if tmod==nil or titem==nil or not data['count'][tmod] or not data['count'][tmod][titem] then + -- table running failed! + elseif data['count'][tmod][titem] > awards.onDig[i]['target']-1 then + res=awards.onDig[i]['award'] + end + end + end if res~=nil then awards.give_achievement(playern,res) @@ -91,7 +115,31 @@ minetest.register_on_placenode(function(pos, newnode, placer) local data=player_data[playern] for i=1,# awards.onPlace do - local res=awards.onPlace[i](player,data) + local res=nil + + if type(awards.onPlace[i]) == "function" then + -- run the function + print(i.." is a function") + res=awards.onPlace[i](player,data) + elseif type(awards.onPlace[i]) == "table" then + -- handle table here + print(i.." is a table") + if not awards.onPlace[i]['node'] or not awards.onPlace[i]['target'] or not awards.onPlace[i]['award'] then + -- table running failed! + else + -- run the table + local tnodedug = string.split(awards.onPlace[i]['node'], ":") + + local tmod=tnodedug[1] + local titem=tnodedug[2] + + if tmod==nil or titem==nil or not data['place'][tmod] or not data['place'][tmod][titem] then + -- table running failed! + elseif data['place'][tmod][titem] > awards.onPlace[i]['target']-1 then + res=awards.onPlace[i]['award'] + end + end + end if res~=nil then awards.give_achievement(playern,res) @@ -102,7 +150,7 @@ end) minetest.register_on_newplayer(function(player) minetest.chat_send_player(player:get_player_name(),"[Awards] Registering you now...") - + --Player data root player_data[player:get_player_name()]={} player_data[player:get_player_name()]['name']=player:get_player_name() |