diff options
| author | Sam Anthony <sam@samanthony.xyz> | 2024-11-26 15:08:44 -0500 |
|---|---|---|
| committer | Sam Anthony <sam@samanthony.xyz> | 2024-11-26 15:08:44 -0500 |
| commit | d40dee9b7b5327b30e6bcf770dfda14a2e6fed02 (patch) | |
| tree | 039f57306b5bb716a0c282126e29380727933f1f /server/record.go | |
| parent | 5f24b031fa0b10e1cf8fbc7345daa223908e1872 (diff) | |
| download | soen422-d40dee9b7b5327b30e6bcf770dfda14a2e6fed02.zip | |
server: limit number of samples kept in memory
Diffstat (limited to 'server/record.go')
| -rw-r--r-- | server/record.go | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/server/record.go b/server/record.go index 9051146..c2f38eb 100644 --- a/server/record.go +++ b/server/record.go @@ -15,13 +15,15 @@ type entry[T any] struct { v T } -func newRecord[T any]() Record[T] { +// Create a record with the specified capacity. +// If the capacity is exceeded, old entires will be discarded and new ones kept. +func newRecord[T any](capacity int) Record[T] { put := make(chan T) get := make(chan chan T) getRecent := make(chan chan T) go func() { - var entries []entry[T] + entries := make([]entry[T], 0, capacity) for { select { @@ -30,6 +32,9 @@ func newRecord[T any]() Record[T] { return } entries = append(entries, entry[T]{time.Now(), v}) + if len(entries) > capacity { + entries = entries[1:] + } case c, ok := <-get: if !ok { return |