mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 10:03:42 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			96 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
   Copyright 2020 The Compose Specification Authors.
 | 
						|
 | 
						|
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
   you may not use this file except in compliance with the License.
 | 
						|
   You may obtain a copy of the License at
 | 
						|
 | 
						|
       http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 | 
						|
   Unless required by applicable law or agreed to in writing, software
 | 
						|
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
   See the License for the specific language governing permissions and
 | 
						|
   limitations under the License.
 | 
						|
*/
 | 
						|
 | 
						|
package utils
 | 
						|
 | 
						|
type Set[T comparable] map[T]struct{}
 | 
						|
 | 
						|
func NewSet[T comparable](v ...T) Set[T] {
 | 
						|
	if len(v) == 0 {
 | 
						|
		return make(Set[T])
 | 
						|
	}
 | 
						|
 | 
						|
	out := make(Set[T], len(v))
 | 
						|
	for i := range v {
 | 
						|
		out.Add(v[i])
 | 
						|
	}
 | 
						|
	return out
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Has(v T) bool {
 | 
						|
	_, ok := s[v]
 | 
						|
	return ok
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Add(v T) {
 | 
						|
	s[v] = struct{}{}
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) AddAll(v ...T) {
 | 
						|
	for _, e := range v {
 | 
						|
		s[e] = struct{}{}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Remove(v T) bool {
 | 
						|
	_, ok := s[v]
 | 
						|
	if ok {
 | 
						|
		delete(s, v)
 | 
						|
	}
 | 
						|
	return ok
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Clear() {
 | 
						|
	for v := range s {
 | 
						|
		delete(s, v)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Elements() []T {
 | 
						|
	elements := make([]T, 0, len(s))
 | 
						|
	for v := range s {
 | 
						|
		elements = append(elements, v)
 | 
						|
	}
 | 
						|
	return elements
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) RemoveAll(elements ...T) {
 | 
						|
	for _, e := range elements {
 | 
						|
		s.Remove(e)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Diff(other Set[T]) Set[T] {
 | 
						|
	out := make(Set[T])
 | 
						|
	for k := range s {
 | 
						|
		if _, ok := other[k]; !ok {
 | 
						|
			out[k] = struct{}{}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return out
 | 
						|
}
 | 
						|
 | 
						|
func (s Set[T]) Union(other Set[T]) Set[T] {
 | 
						|
	out := make(Set[T])
 | 
						|
	for k := range s {
 | 
						|
		out[k] = struct{}{}
 | 
						|
	}
 | 
						|
	for k := range other {
 | 
						|
		out[k] = struct{}{}
 | 
						|
	}
 | 
						|
	return out
 | 
						|
}
 |