summaryrefslogtreecommitdiff
path: root/soundbox/streaming.go
diff options
context:
space:
mode:
authorxegineering <me@xegineering.eu>2024-11-28 22:44:28 +0100
committerxegineering <me@xegineering.eu>2024-11-28 22:44:28 +0100
commit99031596efbcf004188217d2a9e53ac5ce33b511 (patch)
tree34425218468652238956029371ba3ad123f7a389 /soundbox/streaming.go
parentbb84332ef7ca114f0c608bbea7f11451f010a831 (diff)
downloadsoundbox-go-99031596efbcf004188217d2a9e53ac5ce33b511.tar
soundbox-go-99031596efbcf004188217d2a9e53ac5ce33b511.tar.zst
soundbox-go-99031596efbcf004188217d2a9e53ac5ce33b511.zip
Replace custom code by io package functions
This makes use of two functions from this package: - io.Copy() - io.MultiWriter() `io.Copy()` is used to move the data from whatever reader is provided. `io.Multiwriter()` solves the issue that we need to stream to multiple network connections at the same time (one for each soundbox).
Diffstat (limited to 'soundbox/streaming.go')
-rw-r--r--soundbox/streaming.go27
1 files changed, 8 insertions, 19 deletions
diff --git a/soundbox/streaming.go b/soundbox/streaming.go
index 2686f47..1a2d89e 100644
--- a/soundbox/streaming.go
+++ b/soundbox/streaming.go
@@ -2,7 +2,6 @@ package soundbox
import (
"context"
- "errors"
"io"
"net"
"time"
@@ -27,24 +26,14 @@ func streamContext(ctx context.Context, r io.Reader, targets []net.HardwareAddr)
}
}()
- for {
- buffer := make([]byte, bufferSize)
- i, readErr := r.Read(buffer)
- for _, conn := range conns {
- conn.SetDeadline(time.Now().Add(writeTimeout))
- _, writeErr := conn.Write(buffer[:i])
- if writeErr != nil {
- return writeErr
- }
- }
- if readErr != nil {
- if errors.Is(readErr, io.EOF) {
- break
- } else {
- return readErr
- }
- }
+ writers := make([]io.Writer, 0)
+ for _, conn := range conns {
+ writers = append(writers, conn)
}
- return nil
+ mw := io.MultiWriter(writers...)
+
+ _, err := io.Copy(mw, r)
+
+ return err
}