forked from mtcontrib/awards
Add support for groups in triggers
This commit is contained in:
parent
21e1ce6675
commit
237525b518
@ -73,6 +73,10 @@ local trigger = awards.register_trigger(name, {
|
|||||||
get_key = function(self, def)
|
get_key = function(self, def)
|
||||||
return minetest.registered_aliases[def.trigger.node] or def.trigger.node
|
return minetest.registered_aliases[def.trigger.node] or def.trigger.node
|
||||||
end,
|
end,
|
||||||
|
|
||||||
|
-- "counted_key" only, true if the key is an item name. On notify(),
|
||||||
|
-- any watched groups will also be notified as `group:groupname` keys.
|
||||||
|
key_is_item = true,
|
||||||
})
|
})
|
||||||
```
|
```
|
||||||
|
|
||||||
|
27
api.lua
27
api.lua
@ -178,8 +178,14 @@ function awards.register_trigger(tname, tdef)
|
|||||||
awards["notify_" .. tname] = tdef.notify
|
awards["notify_" .. tname] = tdef.notify
|
||||||
|
|
||||||
elseif tdef.type == "counted_key" then
|
elseif tdef.type == "counted_key" then
|
||||||
|
if tdef.key_is_item then
|
||||||
|
tdef.watched_groups = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
-- On award register
|
||||||
local old_reg = tdef.on_register
|
local old_reg = tdef.on_register
|
||||||
function tdef:on_register(def)
|
function tdef:on_register(def)
|
||||||
|
-- Register trigger
|
||||||
local tmp = {
|
local tmp = {
|
||||||
award = def.name,
|
award = def.name,
|
||||||
key = tdef:get_key(def),
|
key = tdef:get_key(def),
|
||||||
@ -187,6 +193,12 @@ function awards.register_trigger(tname, tdef)
|
|||||||
}
|
}
|
||||||
tdef.register(tmp)
|
tdef.register(tmp)
|
||||||
|
|
||||||
|
-- If group, add it to watch list
|
||||||
|
if tdef.key_is_item and tmp.key and tmp.key:sub(1, 6) == "group:" then
|
||||||
|
tdef.watched_groups[tmp.key:sub(7, #tmp.key)] = true
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Called to get progress values and labels
|
||||||
function def.getProgress(_, data)
|
function def.getProgress(_, data)
|
||||||
local done
|
local done
|
||||||
data[tname] = data[tname] or {}
|
data[tname] = data[tname] or {}
|
||||||
@ -201,6 +213,7 @@ function awards.register_trigger(tname, tdef)
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Build description if none is specificed by the award
|
||||||
function def.getDefaultDescription(_)
|
function def.getDefaultDescription(_)
|
||||||
local n = def.trigger.target
|
local n = def.trigger.target
|
||||||
if tmp.key then
|
if tmp.key then
|
||||||
@ -213,6 +226,7 @@ function awards.register_trigger(tname, tdef)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Call on_register in trigger type definition
|
||||||
if old_reg then
|
if old_reg then
|
||||||
return old_reg(tdef, def)
|
return old_reg(tdef, def)
|
||||||
end
|
end
|
||||||
@ -221,6 +235,17 @@ function awards.register_trigger(tname, tdef)
|
|||||||
function tdef.notify(player, key, n)
|
function tdef.notify(player, key, n)
|
||||||
n = n or 1
|
n = n or 1
|
||||||
|
|
||||||
|
if tdef.key_is_item and key:sub(1, 6) ~= "group:" then
|
||||||
|
local itemdef = minetest.registered_items[key]
|
||||||
|
if itemdef then
|
||||||
|
for groupname, _ in pairs(itemdef.groups or {}) do
|
||||||
|
if tdef.watched_groups[groupname] then
|
||||||
|
tdef.notify(player, "group:" .. groupname, n)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
assert(player and player.is_player and player:is_player() and key)
|
assert(player and player.is_player and player:is_player() and key)
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
local data = awards.player(name)
|
local data = awards.player(name)
|
||||||
@ -229,7 +254,9 @@ function awards.register_trigger(tname, tdef)
|
|||||||
data[tname] = data[tname] or {}
|
data[tname] = data[tname] or {}
|
||||||
local currentVal = (data[tname][key] or 0) + n
|
local currentVal = (data[tname][key] or 0) + n
|
||||||
data[tname][key] = currentVal
|
data[tname][key] = currentVal
|
||||||
|
if key:sub(1, 6) ~= "group:" then
|
||||||
data[tname].__total = (data[tname].__total or 0) + n
|
data[tname].__total = (data[tname].__total or 0) + n
|
||||||
|
end
|
||||||
|
|
||||||
tdef:run_callbacks(player, data, function(entry)
|
tdef:run_callbacks(player, data, function(entry)
|
||||||
local current
|
local current
|
||||||
|
12
triggers.lua
12
triggers.lua
@ -64,7 +64,8 @@ awards.register_trigger("dig", {
|
|||||||
auto_description_total = { "Mine @1 block.", "Mine @1 blocks." },
|
auto_description_total = { "Mine @1 block.", "Mine @1 blocks." },
|
||||||
get_key = function(self, def)
|
get_key = function(self, def)
|
||||||
return minetest.registered_aliases[def.trigger.node] or def.trigger.node
|
return minetest.registered_aliases[def.trigger.node] or def.trigger.node
|
||||||
end
|
end,
|
||||||
|
key_is_item = true,
|
||||||
})
|
})
|
||||||
minetest.register_on_dignode(function(pos, node, player)
|
minetest.register_on_dignode(function(pos, node, player)
|
||||||
if not player or not pos or not node then
|
if not player or not pos or not node then
|
||||||
@ -84,7 +85,8 @@ awards.register_trigger("place", {
|
|||||||
auto_description_total = { "Place @1 block.", "Place @1 blocks." },
|
auto_description_total = { "Place @1 block.", "Place @1 blocks." },
|
||||||
get_key = function(self, def)
|
get_key = function(self, def)
|
||||||
return minetest.registered_aliases[def.trigger.node] or def.trigger.node
|
return minetest.registered_aliases[def.trigger.node] or def.trigger.node
|
||||||
end
|
end,
|
||||||
|
key_is_item = true,
|
||||||
})
|
})
|
||||||
minetest.register_on_placenode(function(pos, node, player)
|
minetest.register_on_placenode(function(pos, node, player)
|
||||||
if not player or not pos or not node then
|
if not player or not pos or not node then
|
||||||
@ -104,7 +106,8 @@ awards.register_trigger("craft", {
|
|||||||
auto_description_total = { "Craft @1 item", "Craft @1 items." },
|
auto_description_total = { "Craft @1 item", "Craft @1 items." },
|
||||||
get_key = function(self, def)
|
get_key = function(self, def)
|
||||||
return minetest.registered_aliases[def.trigger.item] or def.trigger.item
|
return minetest.registered_aliases[def.trigger.item] or def.trigger.item
|
||||||
end
|
end,
|
||||||
|
key_is_item = true,
|
||||||
})
|
})
|
||||||
minetest.register_on_craft(function(itemstack, player, old_craft_grid, craft_inv)
|
minetest.register_on_craft(function(itemstack, player, old_craft_grid, craft_inv)
|
||||||
if not player or itemstack:is_empty() then
|
if not player or itemstack:is_empty() then
|
||||||
@ -124,7 +127,8 @@ awards.register_trigger("eat", {
|
|||||||
auto_description_total = { "Eat @1 item", "Eat @1 items." },
|
auto_description_total = { "Eat @1 item", "Eat @1 items." },
|
||||||
get_key = function(self, def)
|
get_key = function(self, def)
|
||||||
return minetest.registered_aliases[def.trigger.item] or def.trigger.item
|
return minetest.registered_aliases[def.trigger.item] or def.trigger.item
|
||||||
end
|
end,
|
||||||
|
key_is_item = true,
|
||||||
})
|
})
|
||||||
minetest.register_on_item_eat(function(_, _, itemstack, player, _)
|
minetest.register_on_item_eat(function(_, _, itemstack, player, _)
|
||||||
if not player or itemstack:is_empty() then
|
if not player or itemstack:is_empty() then
|
||||||
|
Loading…
Reference in New Issue
Block a user