event

package
v0.0.1-unstable Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 21, 2019 License: GPL-3.0 Imports: 4 Imported by: 0

Documentation

Index

Constants

View Source
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 Clear

func Clear()

Clear .

func GetTypeByCode

func GetTypeByCode(typecode int) reflect.Type

GetTypeByCode return Type by typecode

func InitRounter

func InitRounter()

func ReplyEvent

func ReplyEvent(e *Event, typecode int, data interface{})

ReplyEvent is equivalent to `SendTo(e.To, e.From, typecode, data)`

func SendEvent

func SendEvent(e *Event) (nsent int)

SendEvent send event

func SendEvents

func SendEvents(es []*Event) (nsent int)

SendEvents .

func SendTo

func SendTo(from, to Station, typecode int, data interface{}) int

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 Event

type Event struct {
	From     Station
	To       Station
	Typecode int
	Data     interface{}
}

Event is including normal event and p2p event

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

func (f *Feed) Send(value interface{}) (nsent int)

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

type ProtoAdaptor interface {
	SendOut(*Event) error
}

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

type Station interface {
	Name() string
	IsRemote() bool
	IsBroadcast() bool
	Data() interface{}
}

func GetStationByName

func GetStationByName(name string) Station

GetStationByName retrun Station by Station's name

func NewBroadcastStation

func NewBroadcastStation(name string, data interface{}) Station

func NewLocalStation

func NewLocalStation(name string, data interface{}) Station

func NewRemoteStation

func NewRemoteStation(name string, data interface{}) Station

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.

func Subscribe

func Subscribe(station Station, channel chan *Event, typecode int, data interface{}) Subscription

Subscribe .

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL