Files
lambda/pkg/set/set.go
M.V. Hutz d715d38e9e refactor: rename interpreter to runtime and use receiver methods
- Rename pkg/interpreter to pkg/runtime
- Move ReduceOnce to new pkg/normalorder package
- Convert standalone functions (Substitute, Rename, GetFree, IsFree)
  to receiver methods on concrete expression types
- Change Set from pointer receivers to value receivers
- Update all references from interpreter to runtime terminology

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-18 15:11:04 -05:00

58 lines
769 B
Go

package set
import "iter"
type Set[T comparable] map[T]bool
func (s Set[T]) Add(items ...T) {
for _, item := range items {
s[item] = true
}
}
func (s Set[T]) Has(item T) bool {
return s[item]
}
func (s Set[T]) Remove(items ...T) {
for _, item := range items {
delete(s, item)
}
}
func (s Set[T]) Merge(o Set[T]) {
for item := range o {
s.Add(item)
}
}
func (s Set[T]) ToList() []T {
list := []T{}
for item := range s {
list = append(list, item)
}
return list
}
func (s Set[T]) Items() iter.Seq[T] {
return func(yield func(T) bool) {
for item := range s {
if !yield(item) {
return
}
}
}
}
func New[T comparable](items ...T) Set[T] {
result := Set[T]{}
for _, item := range items {
result.Add(item)
}
return result
}