/* Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments Copyright (C) ITsysCOM GmbH This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see */ package utils // NewStringSet returns a new StringSet func NewStringSet(dataSlice []string) (s *StringSet) { s = &StringSet{data: make(map[string]struct{})} s.AddSlice(dataSlice) return s } // StringSet will manage data within a set type StringSet struct { data map[string]struct{} } // Add adds a key in set func (s *StringSet) Add(val string) { s.data[val] = struct{}{} } // Remove removes a key from set func (s *StringSet) Remove(val string) { delete(s.data, val) } // Has returns if the key is in set func (s *StringSet) Has(val string) bool { _, has := s.data[val] return has } // AddSlice adds all the element of a slice func (s *StringSet) AddSlice(dataSlice []string) { for _, val := range dataSlice { s.Add(val) } } // AsSlice returns the keys as string slice func (s *StringSet) AsSlice() []string { result := make([]string, len(s.data)) i := 0 for k := range s.data { result[i] = k i++ } return result } // Data exports the internal map, so we can benefit for example of key iteration func (s *StringSet) Data() map[string]struct{} { return s.data } // Size returns the size of the set func (s *StringSet) Size() int { if s == nil || s.data == nil { return 0 } return len(s.data) } // Intersect removes all key s2 do not have func (s *StringSet) Intersect(s2 *StringSet) { for k := range s.data { if !s2.Has(k) { s.Remove(k) } } }