From 6a19b62db6466f88132f5e41868336ff74ef969c Mon Sep 17 00:00:00 2001 From: obscuren Date: Thu, 17 Jul 2014 22:01:13 +0200 Subject: [PATCH] added chainSync event --- ethereum.go | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/ethereum.go b/ethereum.go index 2806dfd9d..f43d37be2 100644 --- a/ethereum.go +++ b/ethereum.go @@ -80,6 +80,8 @@ type Ethereum struct { keyManager *ethcrypto.KeyManager clientIdentity ethwire.ClientIdentity + + isUpToDate bool } func New(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager *ethcrypto.KeyManager, caps Caps, usePnp bool) (*Ethereum, error) { @@ -107,6 +109,7 @@ func New(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager nat: nat, keyManager: keyManager, clientIdentity: clientIdentity, + isUpToDate: true, } ethereum.reactor = ethutil.NewReactorEngine() @@ -371,6 +374,7 @@ func (s *Ethereum) Start(seed bool) { // Start the reaping processes go s.ReapDeadPeerHandler() + go s.update() if seed { s.Seed() @@ -510,3 +514,23 @@ out: ethlogger.Debugln("succesfully disestablished UPnP port mapping") } } + +func (self *Ethereum) update() { + upToDateTimer := time.NewTicker(1 * time.Second) + +out: + for { + select { + case <-upToDateTimer.C: + if self.IsUpToDate() && !self.isUpToDate { + self.reactor.Post("chainSync", false) + self.isUpToDate = true + } else if !self.IsUpToDate() && self.isUpToDate { + self.reactor.Post("chainSync", true) + self.isUpToDate = false + } + case <-self.quit: + break out + } + } +}