Initial Bus implementation

This commit is contained in:
Ian Gulliver
2022-03-15 16:27:52 +00:00
parent eb60a6aacf
commit 88c24f1a40
5 changed files with 120 additions and 69 deletions

50
bus.go Normal file
View File

@@ -0,0 +1,50 @@
package main
import "sync"
type Bus struct {
mu sync.Mutex
chans map[string][]chan Object
}
func NewBus() *Bus {
return &Bus{
chans: map[string][]chan Object{},
}
}
func (b *Bus) Announce(obj Object) {
key := ObjectKey(obj)
b.mu.Lock()
defer b.mu.Unlock()
chans := b.chans[key]
newChans := []chan Object{}
for _, ch := range chans {
select {
case ch <- obj:
newChans = append(newChans, ch)
default:
close(ch)
}
}
if len(chans) != len(newChans) {
b.chans[key] = newChans
}
}
func (b *Bus) Subscribe(obj Object) chan Object {
key := ObjectKey(obj)
b.mu.Lock()
defer b.mu.Unlock()
ch := make(chan Object, 100)
b.chans[key] = append(b.chans[key], ch)
return ch
}

View File

@@ -21,4 +21,7 @@ func main() {
store.Read(in) store.Read(in)
fmt.Printf("%+v\n", in) fmt.Printf("%+v\n", in)
bus := NewBus()
bus.Announce(in)
} }

View File

@@ -1,5 +1,6 @@
package main package main
import "encoding/hex"
import "fmt" import "fmt"
type Object interface { type Object interface {
@@ -7,12 +8,10 @@ type Object interface {
GetId() string GetId() string
} }
func ObjectKey(obj Object) string { func ObjectSafeId(obj Object) string {
return fmt.Sprintf( return hex.EncodeToString([]byte(obj.GetId()))
"%d:%s:%d:%s", }
len(obj.GetType()),
obj.GetType(), func ObjectKey(obj Object) string {
len(obj.GetId()), return fmt.Sprintf("%s:%s", obj.GetType(), ObjectSafeId(obj))
obj.GetId(),
)
} }

View File

@@ -1,6 +1,5 @@
package main package main
import "encoding/hex"
import "encoding/json" import "encoding/json"
import "fmt" import "fmt"
import "os" import "os"
@@ -18,7 +17,7 @@ func NewStore(root string) *Store {
func (s *Store) Write(obj Object) error { func (s *Store) Write(obj Object) error {
dir := filepath.Join(s.root, obj.GetType()) dir := filepath.Join(s.root, obj.GetType())
filename := hex.EncodeToString([]byte(obj.GetId())) filename := ObjectSafeId(obj)
err := os.MkdirAll(dir, 0700) err := os.MkdirAll(dir, 0700)
if err != nil { if err != nil {
@@ -54,7 +53,7 @@ func (s *Store) Write(obj Object) error {
func (s *Store) Read(obj Object) error { func (s *Store) Read(obj Object) error {
dir := filepath.Join(s.root, obj.GetType()) dir := filepath.Join(s.root, obj.GetType())
filename := hex.EncodeToString([]byte(obj.GetId())) filename := ObjectSafeId(obj)
fh, err := os.Open(filepath.Join(dir, filename)) fh, err := os.Open(filepath.Join(dir, filename))
if err != nil { if err != nil {