/
events.go
90 lines (67 loc) · 1.51 KB
/
events.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
package common
import (
"reflect"
"sync"
)
type Event interface{}
type EventFunc func(Event)
type EventType reflect.Type
type EventManager struct {
mu sync.Mutex
listeners map[EventType][]*EventFunc
}
var (
Events = NewEventManager()
)
func NewEventManager() *EventManager {
return &EventManager{
listeners: make(map[EventType][]*EventFunc),
}
}
func (this *EventManager) AddListener(event interface{}, eventFunc EventFunc) *EventFunc {
this.mu.Lock()
defer this.mu.Unlock()
eventType := reflect.TypeOf(event)
DebugFunc()
if _, ok := this.listeners[eventType]; ok {
this.listeners[eventType] = append(this.listeners[eventType], &eventFunc)
} else {
this.listeners[eventType] = []*EventFunc{&eventFunc}
}
return &eventFunc
}
func (this *EventManager) RemoveListener(eventFunc *EventFunc) {
this.mu.Lock()
defer this.mu.Unlock()
DebugFunc()
for eventType, funcs := range this.listeners {
for i := range funcs {
if funcs[i] == eventFunc {
funcs = append(funcs[:i], funcs[i+1:]...)
break
}
}
if len(funcs) == 0 {
delete(this.listeners, eventType)
} else {
this.listeners[eventType] = funcs
}
}
}
func (this *EventManager) Emit(event interface{}, reverse bool) bool {
this.mu.Lock()
defer this.mu.Unlock()
b := false
eventType := reflect.TypeOf(event)
DebugFunc(eventType)
if funcs, ok := this.listeners[eventType]; ok {
if reverse {
funcs = ReverseSlice(funcs)
}
for _, receiver := range funcs {
(*receiver)(event)
b = true
}
}
return b
}