Documentation ¶
Index ¶
- func MergePublications(recoveredPubs []*protocol.Publication, bufferedPubs []*protocol.Publication, ...) ([]*protocol.Publication, bool)
- func PackUint64(seq, gen uint32) uint64
- func UnpackUint64(val uint64) (uint32, uint32)
- type PubSubSync
- func (c *PubSubSync) LockBuffer(channel string)
- func (c *PubSubSync) ReadBuffered(channel string) []*protocol.Publication
- func (c *PubSubSync) StartBuffering(channel string)
- func (c *PubSubSync) StopBuffering(channel string)
- func (c *PubSubSync) SyncPublication(channel string, pub *protocol.Publication, syncedFn func())
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func MergePublications ¶
func MergePublications(recoveredPubs []*protocol.Publication, bufferedPubs []*protocol.Publication, isLegacyOrder bool) ([]*protocol.Publication, bool)
MergePublications allows to merge recovered pubs with buffered pubs collected during extracting recovered so result is ordered and with duplicates removed.
Types ¶
type PubSubSync ¶
type PubSubSync struct {
// contains filtered or unexported fields
}
PubSubSync wraps logic to synchronize recovery with PUB/SUB.
func (*PubSubSync) ReadBuffered ¶
func (c *PubSubSync) ReadBuffered(channel string) []*protocol.Publication
ReadBuffered ...
func (*PubSubSync) StartBuffering ¶
func (c *PubSubSync) StartBuffering(channel string)
StartBuffering ...
func (*PubSubSync) StopBuffering ¶
func (c *PubSubSync) StopBuffering(channel string)
StopBuffering ...
func (*PubSubSync) SyncPublication ¶
func (c *PubSubSync) SyncPublication(channel string, pub *protocol.Publication, syncedFn func())
SyncPublication ...
Click to show internal directories.
Click to hide internal directories.