2014-07-03 14:39:46 -06:00
|
|
|
--scripts/modtools/interaction-trigger.lua
|
2014-07-03 04:02:39 -06:00
|
|
|
--author expwnent
|
|
|
|
--triggers scripts when a unit does a unit interaction on another
|
|
|
|
|
|
|
|
local eventful = require 'plugins.eventful'
|
|
|
|
local utils = require 'utils'
|
|
|
|
|
|
|
|
attackStrTriggers = attackStrTriggers or {}
|
|
|
|
defendStrTriggers = defendStrTriggers or {}
|
|
|
|
|
2014-07-03 14:39:46 -06:00
|
|
|
eventful.enableEvent(eventful.eventType.INTERACTION,1) --cheap, so every tick is fine
|
|
|
|
eventful.enableEvent(eventful.eventType.UNLOAD,1)
|
|
|
|
|
|
|
|
eventful.onUnload.interactionTrigger = function()
|
|
|
|
attackStrTriggers = {}
|
|
|
|
defendStrTriggers = {}
|
|
|
|
end
|
|
|
|
|
2014-07-03 04:02:39 -06:00
|
|
|
local function processTrigger(args)
|
|
|
|
local command = {}
|
|
|
|
for _,arg in ipairs(args.command) do
|
|
|
|
if arg == '\\ATTACK_VERB' then
|
|
|
|
table.insert(command,args.attackVerb)
|
|
|
|
elseif arg == '\\DEFEND_VERB' then
|
|
|
|
table.insert(command,args.defendVerb)
|
|
|
|
elseif arg == '\\ATTACKER_ID' then
|
|
|
|
table.insert(command,args.attackerId)
|
|
|
|
elseif arg == '\\DEFENDER_ID' then
|
|
|
|
table.insert(command,args.defenderId)
|
|
|
|
elseif arg == '\\ATTACK_REPORT' then
|
|
|
|
table.insert(command,args.attackReport)
|
|
|
|
elseif arg == '\\DEFEND_REPORT' then
|
|
|
|
table.insert(command,args.defendReport)
|
|
|
|
elseif string.sub(arg,1,1) == '\\' then
|
|
|
|
table.insert(command,string.sub(arg,2))
|
|
|
|
else
|
|
|
|
table.insert(command,arg)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
dfhack.run_command(table.unpack(command))
|
|
|
|
end
|
|
|
|
|
|
|
|
eventful.onInteraction.interactionTrigger = function(attackVerb, defendVerb, attacker, defender, attackReport, defendReport)
|
|
|
|
local extras = {}
|
|
|
|
extras.attackVerb = attackVerb
|
|
|
|
extras.defendVerb = defendVerb
|
|
|
|
extras.attackReport = attackReport
|
|
|
|
extras.defendReport = defendReport
|
|
|
|
extras.attackerId = attacker
|
|
|
|
extras.defenderId = defender
|
|
|
|
local suppressAttack = false
|
|
|
|
local suppressDefend = false
|
|
|
|
for _,trigger in ipairs(attackStrTriggers[attackVerb] or {}) do
|
|
|
|
suppressAttack = suppressAttack or trigger.suppressAttack
|
|
|
|
suppressDefend = suppressDefend or trigger.suppressDefend
|
|
|
|
utils.fillTable(trigger,extras)
|
|
|
|
processTrigger(trigger)
|
|
|
|
utils.unfillTable(trigger,extras)
|
|
|
|
end
|
|
|
|
for _,trigger in ipairs(defendStrTriggers[defendVerb] or {}) do
|
|
|
|
suppressAttack = suppressAttack or trigger.suppressAttack
|
|
|
|
suppressDefend = suppressDefend or trigger.suppressDefend
|
|
|
|
utils.fillTable(trigger,extras)
|
|
|
|
processTrigger(trigger)
|
|
|
|
utils.unfillTable(trigger,extras)
|
|
|
|
end
|
|
|
|
|
|
|
|
local eraseReport = function(unit,report)
|
|
|
|
for i,v in ipairs(unit.reports.log.Combat) do
|
|
|
|
if v == report then
|
|
|
|
unit.reports.log.Combat:erase(i)
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if suppressAttack or suppressDefend then
|
|
|
|
attacker = df.unit.find(tonumber(attacker))
|
|
|
|
defender = df.unit.find(tonumber(defender))
|
|
|
|
end
|
|
|
|
if suppressAttack then
|
|
|
|
eraseReport(attacker,attackReport)
|
|
|
|
eraseReport(defender,attackReport)
|
|
|
|
end
|
|
|
|
if suppressDefend then
|
|
|
|
eraseReport(attacker,defendReport)
|
|
|
|
eraseReport(defender,defendReport)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
----------------------------------------------------
|
|
|
|
--argument processing
|
|
|
|
|
|
|
|
validArgs = validArgs or utils.invert({
|
|
|
|
'clear',
|
|
|
|
'help',
|
|
|
|
'onAttackStr',
|
|
|
|
'onDefendStr',
|
|
|
|
'command',
|
|
|
|
'suppressAttack',
|
|
|
|
'suppressDefend',
|
|
|
|
})
|
|
|
|
|
|
|
|
local args = utils.processArgs({...}, validArgs)
|
|
|
|
|
2014-07-03 14:39:46 -06:00
|
|
|
if args.help then
|
|
|
|
print([[scripts/modtools/interaction-trigger.lua
|
|
|
|
arguments:
|
|
|
|
-help
|
|
|
|
print this help message
|
|
|
|
-clear
|
|
|
|
unregisters all triggers
|
|
|
|
-onAttackStr str
|
|
|
|
trigger the command when the attack verb is "str"
|
|
|
|
-onDefendStr str
|
|
|
|
trigger the command when the defend verb is "str"
|
|
|
|
-suppressAttack
|
|
|
|
delete the attack announcement from the combat logs
|
|
|
|
-suppressDefend
|
|
|
|
delete the defend announcement from the combat logs
|
2014-07-03 14:50:35 -06:00
|
|
|
-command [ commandStrs ]
|
|
|
|
specify the command to be executed
|
|
|
|
commandStrs
|
|
|
|
\\ATTACK_VERB
|
|
|
|
\\DEFEND_VERB
|
|
|
|
\\ATTACKER_ID
|
|
|
|
\\DEFENDER_ID
|
|
|
|
\\ATTACK_REPORT
|
|
|
|
\\DEFEND_REPORT
|
|
|
|
\\anything -> anything
|
|
|
|
anything -> anything
|
2014-07-03 14:39:46 -06:00
|
|
|
]])
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
2014-07-03 04:02:39 -06:00
|
|
|
if args.clear then
|
|
|
|
attackStrTriggers = {}
|
|
|
|
defendStrTriggers = {}
|
|
|
|
end
|
|
|
|
|
|
|
|
if not args.command then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
if args.onAttackStr then
|
|
|
|
if not attackStrTriggers[args.onAttackStr] then
|
|
|
|
attackStrTriggers[args.onAttackStr] = {}
|
|
|
|
end
|
|
|
|
table.insert(attackStrTriggers[args.onAttackStr], args)
|
|
|
|
end
|
|
|
|
|
|
|
|
if args.onDefendStr then
|
|
|
|
if not defendStrTriggers[args.onDefendStr] then
|
|
|
|
defendStrTriggers[args.onDefendStr] = {}
|
|
|
|
end
|
|
|
|
table.insert(defendStrTriggers[args.onDefendStr], args)
|
|
|
|
end
|
|
|
|
|