Documentation ¶
Index ¶
- Constants
- func AdaptorRegister(adaptor ProtoAdaptor)
- func Clear()
- func GetTypeByCode(typecode int) reflect.Type
- func InitRounter()
- func ReplyEvent(e *Event, typecode int, data interface{})
- func SendEvent(e *Event) (nsent int)
- func SendEvents(es []*Event) (nsent int)
- func SendTo(from, to Station, typecode int, data interface{}) int
- func StationRegister(station Station)
- func StationUnregister(station Station)
- type BaseStation
- type BroadcastStation
- type Event
- type Feed
- type LocalStation
- type ProtoAdaptor
- type RemoteStation
- type Router
- type Station
- type Subscription
Constants ¶
const ( RouterTestInt int = iota // 0 RouterTestInt64 // 1 RouterTestString // 2 P2pNewPeer // 3 P2pDelPeer // 4 P2pDisconectPeer // 5 DownloaderGetStatus // 6 DownloaderStatusMsg // 7 DownloaderGetBlockHashMsg // 8 DownloaderGetBlockHeadersMsg // 9 DownloaderGetBlockBodiesMsg // 10 BlockHeadersMsg // 11 BlockBodiesMsg // 12 BlockHashMsg // 13 NewBlockHashesMsg // 14 TxMsg // 15 ChainEv // 16 ChainSideEv // 17 ChainHeadEv // 18 LogsEv // 19 TxEv // 20 NewMinedEv EndSize )
Type enumerator
Variables ¶
This section is empty.
Functions ¶
func AdaptorRegister ¶
func AdaptorRegister(adaptor ProtoAdaptor)
AdaptorRegister register P2P interface to Router
func GetTypeByCode ¶
GetTypeByCode return Type by typecode
func InitRounter ¶
func InitRounter()
func ReplyEvent ¶
ReplyEvent is equivalent to `SendTo(e.To, e.From, typecode, data)`
func SendTo ¶
SendTo is equivalent to SendEvent(&Event{From: from, To: to, Type: typecode, Data: data})
func StationRegister ¶
func StationRegister(station Station)
StationRegister register 'Station' to Router
func StationUnregister ¶
func StationUnregister(station Station)
StationUnregister unregister 'Station'
Types ¶
type BaseStation ¶
type BaseStation struct {
// contains filtered or unexported fields
}
func (*BaseStation) Data ¶
func (bs *BaseStation) Data() interface{}
func (*BaseStation) Name ¶
func (bs *BaseStation) Name() string
type BroadcastStation ¶
type BroadcastStation struct {
BaseStation
}
func (*BroadcastStation) IsBroadcast ¶
func (*BroadcastStation) IsBroadcast() bool
func (*BroadcastStation) IsRemote ¶
func (*BroadcastStation) IsRemote() bool
type Feed ¶
type Feed struct {
// contains filtered or unexported fields
}
Feed implements one-to-many subscriptions where the carrier of events is a channel. Values sent to a Feed are delivered to all subscribed channels simultaneously.
Feeds can only be used with a single type. The type is determined by the first Send or Subscribe operation. Subsequent calls to these methods panic if the type does not match.
The zero value is ready to use.
func (*Feed) Send ¶
Send delivers to all subscribed channels simultaneously. It returns the number of subscribers that the value was sent to.
func (*Feed) Subscribe ¶
func (f *Feed) Subscribe(channel interface{}) Subscription
Subscribe adds a channel to the feed. Future sends will be delivered on the channel until the subscription is canceled. All channels added must have the same element type.
The channel should have ample buffer space to avoid blocking other subscribers. Slow subscribers are not dropped.
type LocalStation ¶
type LocalStation struct {
BaseStation
}
func (*LocalStation) IsBroadcast ¶
func (*LocalStation) IsBroadcast() bool
func (*LocalStation) IsRemote ¶
func (*LocalStation) IsRemote() bool
type ProtoAdaptor ¶
ProtoAdaptor used to send out event
type RemoteStation ¶
type RemoteStation struct {
BaseStation
}
func (*RemoteStation) IsBroadcast ¶
func (*RemoteStation) IsBroadcast() bool
func (*RemoteStation) IsRemote ¶
func (*RemoteStation) IsRemote() bool
type Router ¶
type Router struct {
// contains filtered or unexported fields
}
Router Router all events
type Station ¶
func GetStationByName ¶
GetStationByName retrun Station by Station's name
func NewBroadcastStation ¶
func NewLocalStation ¶
func NewRemoteStation ¶
type Subscription ¶
type Subscription interface { Err() <-chan error // returns the error channel Unsubscribe() // cancels sending of events, closing the error channel }
Subscription represents a stream of events. The carrier of the events is typically a channel, but isn't part of the interface.
Subscriptions can fail while established. Failures are reported through an error channel. It receives a value if there is an issue with the subscription (e.g. the network connection delivering the events has been closed). Only one value will ever be sent.
The error channel is closed when the subscription ends successfully (i.e. when the source of events is closed). It is also closed when Unsubscribe is called.
The Unsubscribe method cancels the sending of events. You must call Unsubscribe in all cases to ensure that resources related to the subscription are released. It can be called any number of times.