Move the event emitter and lifecycle events from the engine into the reducer, making the reducer the single point of orchestration for reduction. This eliminates the engine package entirely. - Add events.go to pkg/reducer with Start, Step, and Stop events. - Extend Reducer interface to embed Emitter and add Expression() method. - Update NormalOrderReducer to embed BaseEmitter and emit lifecycle events. - Update all plugins to attach to Reducer instead of Engine. - Remove internal/engine package. - Add Off() method to BaseEmitter to complete Emitter interface. - Fix Emitter.On signature to use generic type E instead of string.
32 lines
753 B
Go
32 lines
753 B
Go
// Package "explanation" provides an observer to gather the reasoning during the
|
|
// reduction, and present a thorough explanation to the user for each step.
|
|
package plugins
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"git.maximhutz.com/max/lambda/pkg/reducer"
|
|
)
|
|
|
|
// Track the reductions made by a reduction process.
|
|
type Explanation struct {
|
|
reducer reducer.Reducer
|
|
}
|
|
|
|
// Attaches a new explanation tracker to a reducer.
|
|
func NewExplanation(r reducer.Reducer) *Explanation {
|
|
plugin := &Explanation{reducer: r}
|
|
r.On(reducer.StartEvent, plugin.Start)
|
|
r.On(reducer.StepEvent, plugin.Step)
|
|
|
|
return plugin
|
|
}
|
|
|
|
func (t *Explanation) Start() {
|
|
fmt.Println(t.reducer.Expression().String())
|
|
}
|
|
|
|
func (t *Explanation) Step() {
|
|
fmt.Println(" =", t.reducer.Expression().String())
|
|
}
|