mirror of
https://github.com/fluencelabs/tendermint
synced 2025-05-29 14:11:21 +00:00
update comment [ci skip] [circleci skip]
This commit is contained in:
parent
c46ffe39a8
commit
dec518eb06
81
service.go
81
service.go
@ -1,42 +1,3 @@
|
|||||||
/*
|
|
||||||
|
|
||||||
Classical-inheritance-style service declarations.
|
|
||||||
Services can be started, then stopped, then optionally restarted.
|
|
||||||
Users can override the OnStart/OnStop methods.
|
|
||||||
By default, these methods are guaranteed to be called at most once.
|
|
||||||
A call to Reset will panic, unless OnReset is overwritten, allowing OnStart/OnStop to be called again.
|
|
||||||
Caller must ensure that Start() and Stop() are not called concurrently.
|
|
||||||
It is ok to call Stop() without calling Start() first.
|
|
||||||
Services cannot be re-started unless OnReset is overwritten to allow it.
|
|
||||||
|
|
||||||
Typical usage:
|
|
||||||
|
|
||||||
type FooService struct {
|
|
||||||
BaseService
|
|
||||||
// private fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewFooService() *FooService {
|
|
||||||
fs := &FooService{
|
|
||||||
// init
|
|
||||||
}
|
|
||||||
fs.BaseService = *NewBaseService(log, "FooService", fs)
|
|
||||||
return fs
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *FooService) OnStart() error {
|
|
||||||
fs.BaseService.OnStart() // Always call the overridden method.
|
|
||||||
// initialize private fields
|
|
||||||
// start subroutines, etc.
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *FooService) OnStop() error {
|
|
||||||
fs.BaseService.OnStop() // Always call the overridden method.
|
|
||||||
// close/destroy private fields
|
|
||||||
// stop subroutines, etc.
|
|
||||||
}
|
|
||||||
|
|
||||||
*/
|
|
||||||
package common
|
package common
|
||||||
|
|
||||||
import (
|
import (
|
||||||
@ -60,6 +21,48 @@ type Service interface {
|
|||||||
String() string
|
String() string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
Classical-inheritance-style service declarations. Services can be started, then
|
||||||
|
stopped, then optionally restarted.
|
||||||
|
|
||||||
|
Users can override the OnStart/OnStop methods. In the absence of errors, these
|
||||||
|
methods are guaranteed to be called at most once. If OnStart returns an error,
|
||||||
|
service won't be marked as started, so the user can call Start again.
|
||||||
|
|
||||||
|
A call to Reset will panic, unless OnReset is overwritten, allowing
|
||||||
|
OnStart/OnStop to be called again.
|
||||||
|
|
||||||
|
The caller must ensure that Start and Stop are not called concurrently.
|
||||||
|
|
||||||
|
It is ok to call Stop without calling Start first.
|
||||||
|
|
||||||
|
Typical usage:
|
||||||
|
|
||||||
|
type FooService struct {
|
||||||
|
BaseService
|
||||||
|
// private fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewFooService() *FooService {
|
||||||
|
fs := &FooService{
|
||||||
|
// init
|
||||||
|
}
|
||||||
|
fs.BaseService = *NewBaseService(log, "FooService", fs)
|
||||||
|
return fs
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fs *FooService) OnStart() error {
|
||||||
|
fs.BaseService.OnStart() // Always call the overridden method.
|
||||||
|
// initialize private fields
|
||||||
|
// start subroutines, etc.
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fs *FooService) OnStop() error {
|
||||||
|
fs.BaseService.OnStop() // Always call the overridden method.
|
||||||
|
// close/destroy private fields
|
||||||
|
// stop subroutines, etc.
|
||||||
|
}
|
||||||
|
*/
|
||||||
type BaseService struct {
|
type BaseService struct {
|
||||||
log log15.Logger
|
log log15.Logger
|
||||||
name string
|
name string
|
||||||
|
Loading…
x
Reference in New Issue
Block a user