safe_bool_react.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. // package safe_bool_react -- потокобезопасный булевый признак с реакцией на своё изменение
  2. package safe_bool_react
  3. import (
  4. "fmt"
  5. "os"
  6. "strings"
  7. "sync"
  8. . "gitp78su.ipnodns.ru/svi/kern/kc/helpers"
  9. . "gitp78su.ipnodns.ru/svi/kern/krn/ktypes"
  10. )
  11. // safeBoolReact -- потокобезопасный булевый признак с реакцией на своё изменение
  12. type safeBoolReact struct {
  13. sync.RWMutex
  14. dict map[string]func(bool) // Словарь обратных вызовов
  15. val bool
  16. }
  17. // NewSafeBoolReact -- возвращает новый потокобезопасный булевый признак с реакцией на своё изменение
  18. func NewSafeBoolReact() ISafeBoolReact {
  19. sf := &safeBoolReact{
  20. dict: map[string]func(bool){},
  21. }
  22. return sf
  23. }
  24. // NewSafeBoolReactFromStr -- возвращает новое потокобезоппсное булево с реакцией из строки
  25. func NewSafeBoolReactFromStr(strVal string) Result[ISafeBoolReact] {
  26. sf := NewSafeBoolReact()
  27. res := sf.FromStr(strVal)
  28. if res.IsErr() {
  29. err := fmt.Errorf("NewSafeBoolReactFromStr(): in parse str(%v), err=\n\t%w", strVal, res.Err())
  30. return NewErr[ISafeBoolReact](err)
  31. }
  32. return NewOk(sf)
  33. }
  34. // NewSafeBoolGetenv -- возвращает новое потокобезоппсное целое с реакцией из окружения
  35. func NewSafeBoolGetenv(env string) Result[ISafeBoolReact] {
  36. sf := NewSafeBoolReact()
  37. res := sf.Getenv(env)
  38. if res.IsErr() {
  39. err := fmt.Errorf("NewSafeBoolGetenv(): in parse env(%v), err=\n\t%w", env, res.Err())
  40. return NewErr[ISafeBoolReact](err)
  41. }
  42. return NewOk(sf)
  43. }
  44. // Delete -- удаляет функцию обратного вызова из наблюдения
  45. func (sf *safeBoolReact) Delete(key string) {
  46. sf.Lock()
  47. defer sf.Unlock()
  48. delete(sf.dict, key)
  49. }
  50. // Add -- добавляет функцию обратного вызова
  51. func (sf *safeBoolReact) Add(key string, fn func(bool)) {
  52. sf.Lock()
  53. defer sf.Unlock()
  54. Hassert(key != "", "safeBoolReact.Add(): key is empty")
  55. _, isOk := sf.dict[key]
  56. Hassert(!isOk, "safeBoolReact.Add(): key already exists")
  57. sf.dict[key] = fn
  58. }
  59. // Get -- возвращает хранимый булевый признак
  60. func (sf *safeBoolReact) Get() bool {
  61. sf.RLock()
  62. defer sf.RUnlock()
  63. return sf.val
  64. }
  65. // Set -- устанавливает булевый признак
  66. func (sf *safeBoolReact) Set() {
  67. sf.Lock()
  68. defer sf.Unlock()
  69. sf.val = true
  70. for _, fn := range sf.dict {
  71. fn(true)
  72. }
  73. }
  74. // Reset -- сбрасывает булевый признак
  75. func (sf *safeBoolReact) Reset() {
  76. sf.Lock()
  77. defer sf.Unlock()
  78. sf.val = false
  79. for _, fn := range sf.dict {
  80. fn(false)
  81. }
  82. }
  83. // FromStr -- получает число из строки
  84. func (sf *safeBoolReact) FromStr(strVal string) Result[bool] {
  85. strVal = strings.ToLower(strVal)
  86. sf.Lock()
  87. defer sf.Unlock()
  88. switch strVal {
  89. case "true":
  90. sf.val = true
  91. case "false":
  92. sf.val = false
  93. default:
  94. return NewErr[bool](fmt.Errorf("safeBoolReact.FromStr(): val(%v) bad", strVal))
  95. }
  96. return NewOk(sf.val)
  97. }
  98. // Getenv -- получает значение из окружения
  99. func (sf *safeBoolReact) Getenv(env string) Result[bool] {
  100. strVal := os.Getenv(env)
  101. res := sf.FromStr(strVal)
  102. if res.IsErr() {
  103. err := fmt.Errorf("safeBoolReact.Getenv(): from env %v, err=\n\t%w", env, res.Err())
  104. return NewErr[bool](err)
  105. }
  106. return res
  107. }