|
|
@@ -11,13 +11,16 @@ type Msg interface{}
|
|
|
type Bus interface {
|
|
|
Dispatch(msg Msg) error
|
|
|
Publish(msg Msg) error
|
|
|
+
|
|
|
AddHandler(handler HandlerFunc)
|
|
|
AddEventListener(handler HandlerFunc)
|
|
|
+ AddWildcardListener(handler HandlerFunc)
|
|
|
}
|
|
|
|
|
|
type InProcBus struct {
|
|
|
- handlers map[string]HandlerFunc
|
|
|
- listeners map[string][]HandlerFunc
|
|
|
+ handlers map[string]HandlerFunc
|
|
|
+ listeners map[string][]HandlerFunc
|
|
|
+ wildcardListeners []HandlerFunc
|
|
|
}
|
|
|
|
|
|
// temp stuff, not sure how to handle bus instance, and init yet
|
|
|
@@ -27,6 +30,7 @@ func New() Bus {
|
|
|
bus := &InProcBus{}
|
|
|
bus.handlers = make(map[string]HandlerFunc)
|
|
|
bus.listeners = make(map[string][]HandlerFunc)
|
|
|
+ bus.wildcardListeners = make([]HandlerFunc, 0)
|
|
|
return bus
|
|
|
}
|
|
|
|
|
|
@@ -52,16 +56,20 @@ func (b *InProcBus) Dispatch(msg Msg) error {
|
|
|
|
|
|
func (b *InProcBus) Publish(msg Msg) error {
|
|
|
var msgName = reflect.TypeOf(msg).Elem().Name()
|
|
|
-
|
|
|
var listeners = b.listeners[msgName]
|
|
|
- if len(listeners) == 0 {
|
|
|
- return nil
|
|
|
- }
|
|
|
|
|
|
var params = make([]reflect.Value, 1)
|
|
|
params[0] = reflect.ValueOf(msg)
|
|
|
|
|
|
- for listenerHandler := range listeners {
|
|
|
+ for _, listenerHandler := range listeners {
|
|
|
+ ret := reflect.ValueOf(listenerHandler).Call(params)
|
|
|
+ err := ret[0].Interface()
|
|
|
+ if err != nil {
|
|
|
+ return err.(error)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for _, listenerHandler := range b.wildcardListeners {
|
|
|
ret := reflect.ValueOf(listenerHandler).Call(params)
|
|
|
err := ret[0].Interface()
|
|
|
if err != nil {
|
|
|
@@ -72,6 +80,10 @@ func (b *InProcBus) Publish(msg Msg) error {
|
|
|
return nil
|
|
|
}
|
|
|
|
|
|
+func (b *InProcBus) AddWildcardListener(handler HandlerFunc) {
|
|
|
+ b.wildcardListeners = append(b.wildcardListeners, handler)
|
|
|
+}
|
|
|
+
|
|
|
func (b *InProcBus) AddHandler(handler HandlerFunc) {
|
|
|
handlerType := reflect.TypeOf(handler)
|
|
|
queryTypeName := handlerType.In(0).Elem().Name()
|
|
|
@@ -81,12 +93,11 @@ func (b *InProcBus) AddHandler(handler HandlerFunc) {
|
|
|
func (b *InProcBus) AddEventListener(handler HandlerFunc) {
|
|
|
handlerType := reflect.TypeOf(handler)
|
|
|
eventName := handlerType.In(0).Elem().Name()
|
|
|
- list, exists := b.listeners[eventName]
|
|
|
+ _, exists := b.listeners[eventName]
|
|
|
if !exists {
|
|
|
- list = make([]HandlerFunc, 0)
|
|
|
- b.listeners[eventName] = list
|
|
|
+ b.listeners[eventName] = make([]HandlerFunc, 0)
|
|
|
}
|
|
|
- list = append(list, handler)
|
|
|
+ b.listeners[eventName] = append(b.listeners[eventName], handler)
|
|
|
}
|
|
|
|
|
|
// Package level functions
|
|
|
@@ -99,6 +110,14 @@ func AddEventListener(handler HandlerFunc) {
|
|
|
globalBus.AddEventListener(handler)
|
|
|
}
|
|
|
|
|
|
+func AddWildcardListener(handler HandlerFunc) {
|
|
|
+ globalBus.AddWildcardListener(handler)
|
|
|
+}
|
|
|
+
|
|
|
func Dispatch(msg Msg) error {
|
|
|
return globalBus.Dispatch(msg)
|
|
|
}
|
|
|
+
|
|
|
+func Publish(msg Msg) error {
|
|
|
+ return globalBus.Publish(msg)
|
|
|
+}
|