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