1
0
This repository has been archived on 2023-12-27. You can view files and clone it, but cannot push or open issues or pull requests.
beginning-go/vendor/github.com/clockworksoul/smudge/events.go
Tony Grosinger a1e0fb3b7e
Add smudge dependency to vendor
Smudge provides an implementation of the gossip protocol that will be
used for communicating with other chat client implementations.

Retrieved at: d39c17654b
2017-10-19 19:44:45 -07:00

82 lines
2.6 KiB
Go

/*
Copyright 2016 The Smudge Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package smudge
import "sync"
var broadcastListeners = struct {
sync.RWMutex
s []BroadcastListener
}{s: make([]BroadcastListener, 0, 16)}
var statusListeners = struct {
sync.RWMutex
s []StatusListener
}{s: make([]StatusListener, 0, 16)}
// BroadcastListener is the interface that must be implemented to take advantage
// of the cluster member status update notification functionality provided by
// the AddBroadcastListener() function.
type BroadcastListener interface {
// The OnChange() function is called whenever the node is notified of any
// change in the status of a cluster member.
OnBroadcast(broadcast *Broadcast)
}
// AddBroadcastListener allows the submission of a BroadcastListener implementation
// whose OnChange() function will be called whenever the node is notified of any
// change in the status of a cluster member.
func AddBroadcastListener(listener BroadcastListener) {
broadcastListeners.Lock()
broadcastListeners.s = append(broadcastListeners.s, listener)
broadcastListeners.Unlock()
}
func doBroadcastUpdate(broadcast *Broadcast) {
broadcastListeners.RLock()
for _, sl := range broadcastListeners.s {
sl.OnBroadcast(broadcast)
}
broadcastListeners.RUnlock()
}
// StatusListener is the interface that must be implemented to take advantage
// of the cluster member status update notification functionality provided by
// the AddStatusListener() function.
type StatusListener interface {
// The OnChange() function is called whenever the node is notified of any
// change in the status of a cluster member.
OnChange(node *Node, status NodeStatus)
}
// AddStatusListener allows the submission of a StatusListener implementation
// whose OnChange() function will be called whenever the node is notified of any
// change in the status of a cluster member.
func AddStatusListener(listener StatusListener) {
statusListeners.Lock()
statusListeners.s = append(statusListeners.s, listener)
statusListeners.Unlock()
}
func doStatusUpdate(node *Node, status NodeStatus) {
statusListeners.RLock()
for _, sl := range statusListeners.s {
sl.OnChange(node, status)
}
statusListeners.RUnlock()
}