60 lines
1.3 KiB
Markdown
60 lines
1.3 KiB
Markdown
|
# multistep
|
||
|
|
||
|
multistep is a Go library for building up complex actions using discrete,
|
||
|
individual "steps." These steps are strung together and run in sequence
|
||
|
to achieve a more complex goal. The runner handles cleanup, cancelling, etc.
|
||
|
if necessary.
|
||
|
|
||
|
## Basic Example
|
||
|
|
||
|
Make a step to perform some action. The step can access your "state",
|
||
|
which is passed between steps by the runner.
|
||
|
|
||
|
```go
|
||
|
type stepAdd struct{}
|
||
|
|
||
|
func (s *stepAdd) Run(state multistep.StateBag) multistep.StepAction {
|
||
|
// Read our value and assert that it is they type we want
|
||
|
value := state.Get("value").(int)
|
||
|
fmt.Printf("Value is %d\n", value)
|
||
|
|
||
|
// Store some state back
|
||
|
state.Put("value", value + 1)
|
||
|
return multistep.ActionContinue
|
||
|
}
|
||
|
|
||
|
func (s *stepAdd) Cleanup(multistep.StateBag) {
|
||
|
// This is called after all the steps have run or if the runner is
|
||
|
// cancelled so that cleanup can be performed.
|
||
|
}
|
||
|
```
|
||
|
|
||
|
Make a runner and call your array of Steps.
|
||
|
|
||
|
```go
|
||
|
func main() {
|
||
|
// Our "bag of state" that we read the value from
|
||
|
state := new(multistep.BasicStateBag)
|
||
|
state.Put("value", 0)
|
||
|
|
||
|
steps := []multistep.Step{
|
||
|
&stepAdd{},
|
||
|
&stepAdd{},
|
||
|
&stepAdd{},
|
||
|
}
|
||
|
|
||
|
runner := &multistep.BasicRunner{Steps: steps}
|
||
|
|
||
|
// Executes the steps
|
||
|
runner.Run(state)
|
||
|
}
|
||
|
```
|
||
|
|
||
|
This will produce:
|
||
|
|
||
|
```
|
||
|
Value is 0
|
||
|
Value is 1
|
||
|
Value is 2
|
||
|
```
|