http urls monitor.

post_go19.go 1.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. // +build go1.9
  2. package swag
  3. import (
  4. "sort"
  5. "sync"
  6. )
  7. // indexOfInitialisms is a thread-safe implementation of the sorted index of initialisms.
  8. // Since go1.9, this may be implemented with sync.Map.
  9. type indexOfInitialisms struct {
  10. sortMutex *sync.Mutex
  11. index *sync.Map
  12. }
  13. func newIndexOfInitialisms() *indexOfInitialisms {
  14. return &indexOfInitialisms{
  15. sortMutex: new(sync.Mutex),
  16. index: new(sync.Map),
  17. }
  18. }
  19. func (m *indexOfInitialisms) load(initial map[string]bool) *indexOfInitialisms {
  20. m.sortMutex.Lock()
  21. defer m.sortMutex.Unlock()
  22. for k, v := range initial {
  23. m.index.Store(k, v)
  24. }
  25. return m
  26. }
  27. func (m *indexOfInitialisms) isInitialism(key string) bool {
  28. _, ok := m.index.Load(key)
  29. return ok
  30. }
  31. func (m *indexOfInitialisms) add(key string) *indexOfInitialisms {
  32. m.index.Store(key, true)
  33. return m
  34. }
  35. func (m *indexOfInitialisms) sorted() (result []string) {
  36. m.sortMutex.Lock()
  37. defer m.sortMutex.Unlock()
  38. m.index.Range(func(key, value interface{}) bool {
  39. k := key.(string)
  40. result = append(result, k)
  41. return true
  42. })
  43. sort.Sort(sort.Reverse(byLength(result)))
  44. return
  45. }