Skip to content

Commit

Permalink
add args to Transition
Browse files Browse the repository at this point in the history
  • Loading branch information
okhowang committed Apr 29, 2024
1 parent 2a5b0eb commit 640ab36
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 10 deletions.
17 changes: 9 additions & 8 deletions statemachine.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ type Transition struct {
Source State
Destination State
Trigger Trigger
Arguments []interface{}

isInitial bool
}
Expand Down Expand Up @@ -344,27 +345,27 @@ func (sm *StateMachine) internalFireOne(ctx context.Context, trigger Trigger, ar
case *ignoredTriggerBehaviour:
// ignored
case *reentryTriggerBehaviour:
transition := Transition{Source: source, Destination: t.Destination, Trigger: trigger}
transition := Transition{Source: source, Destination: t.Destination, Trigger: trigger, Arguments: args}
err = sm.handleReentryTrigger(ctx, representativeState, transition, args...)
case *dynamicTriggerBehaviour:
var destination any
destination, err = t.Destination(ctx, args...)
if err == nil {
transition := Transition{Source: source, Destination: destination, Trigger: trigger}
transition := Transition{Source: source, Destination: destination, Trigger: trigger, Arguments: args}
err = sm.handleTransitioningTrigger(ctx, representativeState, transition, args...)
}
case *transitioningTriggerBehaviour:
if source == t.Destination {
// If a trigger was found on a superstate that would cause unintended reentry, don't trigger.
break
}
transition := Transition{Source: source, Destination: t.Destination, Trigger: trigger}
transition := Transition{Source: source, Destination: t.Destination, Trigger: trigger, Arguments: args}
err = sm.handleTransitioningTrigger(ctx, representativeState, transition, args...)
case *internalTriggerBehaviour:
var sr *stateRepresentation
sr, err = sm.currentState(ctx)
if err == nil {
transition := Transition{Source: source, Destination: source, Trigger: trigger}
transition := Transition{Source: source, Destination: source, Trigger: trigger, Arguments: args}
err = sr.InternalAction(ctx, transition, args...)
}
}
Expand All @@ -377,7 +378,7 @@ func (sm *StateMachine) handleReentryTrigger(ctx context.Context, sr *stateRepre
}
newSr := sm.stateRepresentation(transition.Destination)
if !transition.IsReentry() {
transition = Transition{Source: transition.Destination, Destination: transition.Destination, Trigger: transition.Trigger}
transition = Transition{Source: transition.Destination, Destination: transition.Destination, Trigger: transition.Trigger, Arguments: args}
if err := newSr.Exit(ctx, transition, args...); err != nil {
return err
}
Expand Down Expand Up @@ -413,7 +414,7 @@ func (sm *StateMachine) handleTransitioningTrigger(ctx context.Context, sr *stat
return err
}
}
callEvents(sm.onTransitionedEvents, ctx, Transition{transition.Source, rep.State, transition.Trigger, false})
callEvents(sm.onTransitionedEvents, ctx, Transition{transition.Source, rep.State, transition.Trigger, args, false})
return nil
}

Expand All @@ -437,9 +438,9 @@ func (sm *StateMachine) enterState(ctx context.Context, sr *stateRepresentation,
if !isValidForInitialState {
panic(fmt.Sprintf("stateless: The target (%v) for the initial transition is not a substate.", sr.InitialTransitionTarget))
}
initialTranslation := Transition{Source: transition.Source, Destination: sr.InitialTransitionTarget, Trigger: transition.Trigger, isInitial: true}
initialTranslation := Transition{Source: transition.Source, Destination: sr.InitialTransitionTarget, Trigger: transition.Trigger, isInitial: true, Arguments: args}
sr = sm.stateRepresentation(sr.InitialTransitionTarget)
callEvents(sm.onTransitioningEvents, ctx, Transition{transition.Destination, initialTranslation.Destination, transition.Trigger, false})
callEvents(sm.onTransitioningEvents, ctx, Transition{transition.Destination, initialTranslation.Destination, transition.Trigger, args, false})
sr, err = sm.enterState(ctx, sr, initialTranslation, args...)
}
return sr, err
Expand Down
4 changes: 2 additions & 2 deletions statemachine_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ func TestTransition_IsReentry(t *testing.T) {
t *Transition
want bool
}{
{"TransitionIsNotChange", &Transition{"1", "1", "0", false}, true},
{"TransitionIsChange", &Transition{"1", "2", "0", false}, false},
{"TransitionIsNotChange", &Transition{"1", "1", "0", nil, false}, true},
{"TransitionIsChange", &Transition{"1", "2", "0", nil, false}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
Expand Down

0 comments on commit 640ab36

Please sign in to comment.