forked from Bastion/Bastion
Merge pull request 'main' (#1) from Bastion/Bastion:main into main
Reviewed-on: CiscOH/Bastion#1main
commit
72c4c8b87b
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,87 @@ |
|||||||
|
-- Create a sequencer class that takes a table of actions and executes them in order |
||||||
|
|
||||||
|
---@class Sequencer |
||||||
|
local Sequencer = {} |
||||||
|
Sequencer.__index = Sequencer |
||||||
|
|
||||||
|
-- Constructor |
||||||
|
---@param actions table |
||||||
|
---@return Sequencer |
||||||
|
function Sequencer:New(actions, resetCondition) |
||||||
|
local self = setmetatable({}, Sequencer) |
||||||
|
|
||||||
|
self.actions = actions |
||||||
|
self.index = 1 |
||||||
|
|
||||||
|
self.resetCondition = resetCondition |
||||||
|
|
||||||
|
return self |
||||||
|
end |
||||||
|
|
||||||
|
-- Should we reset the sequencer |
||||||
|
---@return boolean |
||||||
|
function Sequencer:ShouldReset() |
||||||
|
if self.resetCondition then |
||||||
|
return self.resetCondition() |
||||||
|
end |
||||||
|
|
||||||
|
return false |
||||||
|
end |
||||||
|
|
||||||
|
-- Should we abort the sequencer |
||||||
|
---@return boolean |
||||||
|
function Sequencer:ShouldAbort() |
||||||
|
if self.abortCondition then |
||||||
|
return self.abortCondition() |
||||||
|
end |
||||||
|
|
||||||
|
return false |
||||||
|
end |
||||||
|
|
||||||
|
-- Execute the next action in the sequence if it doesn't return true we need to try it again |
||||||
|
---@return boolean |
||||||
|
function Sequencer:Next() |
||||||
|
if self:Finished() then |
||||||
|
print("Its finished?") |
||||||
|
return false |
||||||
|
end |
||||||
|
|
||||||
|
local action = self.actions[self.index] |
||||||
|
print("Attempting action: " .. self.index .. "") |
||||||
|
if action(self) then |
||||||
|
self.index = self.index + 1 |
||||||
|
return true |
||||||
|
end |
||||||
|
|
||||||
|
return false |
||||||
|
end |
||||||
|
|
||||||
|
-- Reset the sequencer |
||||||
|
---@return nil |
||||||
|
function Sequencer:Reset() |
||||||
|
self.index = 1 |
||||||
|
end |
||||||
|
|
||||||
|
function Sequencer:Execute() |
||||||
|
if self:Next() then |
||||||
|
return true |
||||||
|
end |
||||||
|
|
||||||
|
return false |
||||||
|
end |
||||||
|
|
||||||
|
function Sequencer:Finished() |
||||||
|
return self.index > #self.actions |
||||||
|
end |
||||||
|
|
||||||
|
function Sequencer:Abort() |
||||||
|
self.index = #self.actions + 1 |
||||||
|
end |
||||||
|
|
||||||
|
-- tostring |
||||||
|
---@return string |
||||||
|
function Sequencer:__tostring() |
||||||
|
return "Bastion.__Sequencer" |
||||||
|
end |
||||||
|
|
||||||
|
return Sequencer |
Loading…
Reference in new issue