本站源代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
1.7KB

  1. // Copyright 2015 go-swagger maintainers
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. // +build !go1.9
  15. package swag
  16. import (
  17. "sort"
  18. "sync"
  19. )
  20. // indexOfInitialisms is a thread-safe implementation of the sorted index of initialisms.
  21. // Before go1.9, this may be implemented with a mutex on the map.
  22. type indexOfInitialisms struct {
  23. getMutex *sync.Mutex
  24. index map[string]bool
  25. }
  26. func newIndexOfInitialisms() *indexOfInitialisms {
  27. return &indexOfInitialisms{
  28. getMutex: new(sync.Mutex),
  29. index: make(map[string]bool, 50),
  30. }
  31. }
  32. func (m *indexOfInitialisms) load(initial map[string]bool) *indexOfInitialisms {
  33. m.getMutex.Lock()
  34. defer m.getMutex.Unlock()
  35. for k, v := range initial {
  36. m.index[k] = v
  37. }
  38. return m
  39. }
  40. func (m *indexOfInitialisms) isInitialism(key string) bool {
  41. m.getMutex.Lock()
  42. defer m.getMutex.Unlock()
  43. _, ok := m.index[key]
  44. return ok
  45. }
  46. func (m *indexOfInitialisms) add(key string) *indexOfInitialisms {
  47. m.getMutex.Lock()
  48. defer m.getMutex.Unlock()
  49. m.index[key] = true
  50. return m
  51. }
  52. func (m *indexOfInitialisms) sorted() (result []string) {
  53. m.getMutex.Lock()
  54. defer m.getMutex.Unlock()
  55. for k := range m.index {
  56. result = append(result, k)
  57. }
  58. sort.Sort(sort.Reverse(byInitialism(result)))
  59. return
  60. }
上海开阖软件有限公司 沪ICP备12045867号-1