mattermost-community-enterp.../vendor/github.com/sagikazarmark/locafero/internal/queue/eager.go
Claude ec1f89217a Merge: Complete Mattermost Server with Community Enterprise
Full Mattermost server source with integrated Community Enterprise features.
Includes vendor directory for offline/air-gapped builds.

Structure:
- enterprise-impl/: Enterprise feature implementations
- enterprise-community/: Init files that register implementations
- enterprise/: Bridge imports (community_imports.go)
- vendor/: All dependencies for offline builds

Build (online):
  go build ./cmd/mattermost

Build (offline/air-gapped):
  go build -mod=vendor ./cmd/mattermost

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-17 23:59:07 +09:00

54 lines
811 B
Go

package queue
import "sync"
// NewEager creates a new eager queue.
func NewEager[T any]() Queue[T] {
return &Eager[T]{}
}
// Eager is a queue that processes items eagerly.
type Eager[T any] struct {
results []T
error error
mu sync.Mutex
}
// Add implements the [Queue] interface.
func (p *Eager[T]) Add(fn func() (T, error)) {
p.mu.Lock()
defer p.mu.Unlock()
// Return early if there's an error
if p.error != nil {
return
}
result, err := fn()
if err != nil {
p.error = err
return
}
p.results = append(p.results, result)
}
// Wait implements the [Queue] interface.
func (p *Eager[T]) Wait() ([]T, error) {
p.mu.Lock()
defer p.mu.Unlock()
if p.error != nil {
return nil, p.error
}
results := p.results
// Reset results for reuse
p.results = nil
return results, nil
}