mirror of
https://github.com/diamondburned/arikawa.git
synced 2025-01-06 20:16:59 +00:00
Updated heartbeat behavior
This commit is contained in:
parent
8ce6e94990
commit
7f06d88d0f
|
@ -4,6 +4,7 @@ import (
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
|
"github.com/diamondburned/arikawa/bot"
|
||||||
"github.com/diamondburned/arikawa/gateway"
|
"github.com/diamondburned/arikawa/gateway"
|
||||||
"github.com/diamondburned/arikawa/session"
|
"github.com/diamondburned/arikawa/session"
|
||||||
)
|
)
|
||||||
|
@ -38,8 +39,6 @@ func main() {
|
||||||
|
|
||||||
log.Println("Started as", u.Username)
|
log.Println("Started as", u.Username)
|
||||||
|
|
||||||
// Wait is optional.
|
// Block until SIGINT. Optional.
|
||||||
if err := s.Wait(); err != nil {
|
bot.Wait()
|
||||||
log.Fatalln("Fatal error:", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ import (
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
|
"github.com/diamondburned/arikawa/bot"
|
||||||
"github.com/diamondburned/arikawa/gateway"
|
"github.com/diamondburned/arikawa/gateway"
|
||||||
"github.com/diamondburned/arikawa/handler"
|
"github.com/diamondburned/arikawa/handler"
|
||||||
"github.com/diamondburned/arikawa/state"
|
"github.com/diamondburned/arikawa/state"
|
||||||
|
@ -48,8 +49,6 @@ func main() {
|
||||||
|
|
||||||
log.Println("Started as", u.Username)
|
log.Println("Started as", u.Username)
|
||||||
|
|
||||||
// Wait is optional.
|
// Block until SIGINT. Optional.
|
||||||
if err := s.Wait(); err != nil {
|
bot.Wait()
|
||||||
log.Fatalln("Fatal error:", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,10 @@ type Pacemaker struct {
|
||||||
|
|
||||||
// LastBeat logs the received heartbeats, with the newest one
|
// LastBeat logs the received heartbeats, with the newest one
|
||||||
// first.
|
// first.
|
||||||
LastBeat [2]time.Time
|
// LastBeat [2]time.Time
|
||||||
|
|
||||||
|
SentBeat time.Time
|
||||||
|
EchoBeat time.Time
|
||||||
|
|
||||||
// Any callback that returns an error will stop the pacer.
|
// Any callback that returns an error will stop the pacer.
|
||||||
Pace func() error
|
Pace func() error
|
||||||
|
@ -26,16 +29,25 @@ type Pacemaker struct {
|
||||||
|
|
||||||
func (p *Pacemaker) Echo() {
|
func (p *Pacemaker) Echo() {
|
||||||
// Swap our received heartbeats
|
// Swap our received heartbeats
|
||||||
p.LastBeat[0], p.LastBeat[1] = time.Now(), p.LastBeat[0]
|
// p.LastBeat[0], p.LastBeat[1] = time.Now(), p.LastBeat[0]
|
||||||
|
p.EchoBeat = time.Now()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Dead, if true, will have Pace return an ErrDead.
|
// Dead, if true, will have Pace return an ErrDead.
|
||||||
func (p *Pacemaker) Dead() bool {
|
func (p *Pacemaker) Dead() bool {
|
||||||
|
/* Deprecated
|
||||||
if p.LastBeat[0].IsZero() || p.LastBeat[1].IsZero() {
|
if p.LastBeat[0].IsZero() || p.LastBeat[1].IsZero() {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
return p.LastBeat[0].Sub(p.LastBeat[1]) > p.Heartrate*2
|
return p.LastBeat[0].Sub(p.LastBeat[1]) > p.Heartrate*2
|
||||||
|
*/
|
||||||
|
|
||||||
|
if p.EchoBeat.IsZero() || p.SentBeat.IsZero() {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
return p.SentBeat.Sub(p.EchoBeat) > p.Heartrate*2
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Pacemaker) Stop() {
|
func (p *Pacemaker) Stop() {
|
||||||
|
@ -69,6 +81,9 @@ func (p *Pacemaker) start(stop chan struct{}) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Paced, save
|
||||||
|
p.SentBeat = time.Now()
|
||||||
|
|
||||||
if p.Dead() {
|
if p.Dead() {
|
||||||
if err := p.OnDead(); err != nil {
|
if err := p.OnDead(); err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
|
@ -91,10 +91,6 @@ func (s *Session) startHandler(stop <-chan struct{}) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Session) Wait() error {
|
|
||||||
return s.gateway.Wait()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *Session) Close() error {
|
func (s *Session) Close() error {
|
||||||
// Stop the event handler
|
// Stop the event handler
|
||||||
if s.hstop != nil {
|
if s.hstop != nil {
|
||||||
|
|
Loading…
Reference in a new issue