2019-08-03 09:19:32 +02:00
|
|
|
package v2
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
2019-08-08 16:56:39 +02:00
|
|
|
|
|
|
|
"github.com/tendermint/tendermint/libs/log"
|
2019-08-03 09:19:32 +02:00
|
|
|
)
|
|
|
|
|
2019-08-08 15:53:02 +02:00
|
|
|
type timeCheck struct {
|
|
|
|
}
|
|
|
|
|
2019-08-03 09:19:32 +02:00
|
|
|
func schedulerHandle(event Event) (Events, error) {
|
|
|
|
switch event.(type) {
|
|
|
|
case timeCheck:
|
|
|
|
fmt.Println("scheduler handle timeCheck")
|
2019-08-08 15:53:02 +02:00
|
|
|
case Event:
|
2019-08-03 09:19:32 +02:00
|
|
|
fmt.Println("scheduler handle testEvent")
|
|
|
|
}
|
|
|
|
return Events{}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func processorHandle(event Event) (Events, error) {
|
|
|
|
switch event.(type) {
|
|
|
|
case timeCheck:
|
|
|
|
fmt.Println("processor handle timeCheck")
|
2019-08-08 15:53:02 +02:00
|
|
|
case Event:
|
|
|
|
fmt.Println("processor handle event")
|
2019-08-03 09:19:32 +02:00
|
|
|
}
|
|
|
|
return Events{}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type Reactor struct {
|
|
|
|
demuxer *demuxer
|
|
|
|
scheduler *Routine
|
|
|
|
processor *Routine
|
|
|
|
tickerStopped chan struct{}
|
|
|
|
}
|
|
|
|
|
2019-08-08 17:42:46 +02:00
|
|
|
// nolint:unused
|
2019-08-08 16:56:39 +02:00
|
|
|
func (r *Reactor) setLogger(logger log.Logger) {
|
|
|
|
r.scheduler.setLogger(logger)
|
|
|
|
r.processor.setLogger(logger)
|
|
|
|
r.demuxer.setLogger(logger)
|
|
|
|
}
|
|
|
|
|
2019-08-03 09:19:32 +02:00
|
|
|
func (r *Reactor) Start() {
|
2019-08-06 13:27:15 +02:00
|
|
|
r.scheduler = newRoutine("scheduler", schedulerHandle)
|
|
|
|
r.processor = newRoutine("processor", processorHandle)
|
2019-08-03 09:19:32 +02:00
|
|
|
r.demuxer = newDemuxer(r.scheduler, r.processor)
|
|
|
|
r.tickerStopped = make(chan struct{})
|
|
|
|
|
2019-08-08 15:12:11 +02:00
|
|
|
go r.scheduler.start()
|
|
|
|
go r.processor.start()
|
|
|
|
go r.demuxer.start()
|
2019-08-03 09:19:32 +02:00
|
|
|
|
2019-08-08 17:42:46 +02:00
|
|
|
<-r.scheduler.ready()
|
|
|
|
<-r.processor.ready()
|
|
|
|
<-r.demuxer.ready()
|
2019-08-06 13:27:15 +02:00
|
|
|
|
2019-08-03 09:19:32 +02:00
|
|
|
go func() {
|
|
|
|
ticker := time.NewTicker(1 * time.Second)
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-ticker.C:
|
2019-08-08 15:12:11 +02:00
|
|
|
r.demuxer.trySend(timeCheck{})
|
2019-08-03 09:19:32 +02:00
|
|
|
case <-r.tickerStopped:
|
|
|
|
fmt.Println("ticker stopped")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Reactor) Wait() {
|
|
|
|
fmt.Println("completed routines")
|
|
|
|
r.Stop()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Reactor) Stop() {
|
|
|
|
fmt.Println("reactor stopping")
|
|
|
|
|
|
|
|
r.tickerStopped <- struct{}{}
|
|
|
|
r.demuxer.stop()
|
|
|
|
r.scheduler.stop()
|
|
|
|
r.processor.stop()
|
|
|
|
// todo: accumulator
|
|
|
|
// todo: io
|
|
|
|
|
|
|
|
fmt.Println("reactor stopped")
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Reactor) Receive(event Event) {
|
|
|
|
fmt.Println("receive event")
|
2019-08-08 15:12:11 +02:00
|
|
|
sent := r.demuxer.trySend(event)
|
2019-08-03 09:19:32 +02:00
|
|
|
if !sent {
|
2019-08-06 13:27:15 +02:00
|
|
|
fmt.Println("demuxer is full")
|
2019-08-03 09:19:32 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Reactor) AddPeer() {
|
|
|
|
// TODO: add peer event and send to demuxer
|
|
|
|
}
|