| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- // package safe_bool -- потокобезопасный булевый признак.
- package safe_bool
- import (
- "fmt"
- "os"
- "strings"
- "sync"
- mL0 "gitp78su.ipnodns.ru/svi/kern/v4/lev0"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev0/etypes/ebool"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kspec"
- mKs "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kspec"
- )
- // safeBool -- потокобезопасный булевый признак.
- type safeBool struct {
- sync.RWMutex
- val bool
- }
- // NewSafeBool -- возвращает новый потокобезопасный булевый признак.
- func NewSafeBool(val bool) mKs.ISafeBool {
- sf := &safeBool{
- val: val,
- }
- return sf
- }
- // NewSafeBoolFromStr -- возвращает новое потокобезопасное булево из строки.
- func NewSafeBoolFromStr(strVal string) mL0.IResult[mKs.ISafeBool] {
- sf := NewSafeBool(false)
- res := sf.FromStr(strVal)
- if res.IsErr() {
- err := fmt.Errorf("NewSafeBoolFromStr(): in parse str(%v), err=\n\t%w", strVal, res.Err())
- return mL0.NewErr[mKs.ISafeBool](err)
- }
- return mL0.NewOk(sf)
- }
- // NewSafeBoolGetenv -- возвращает новое потокобезопасное целое из окружения.
- func NewSafeBoolGetenv(env string) mL0.IResult[mKs.ISafeBool] {
- sf := NewSafeBool(false)
- res := sf.Getenv(env)
- if res.IsErr() {
- err := fmt.Errorf("NewSafeBoolGetenv(): in parse env(%v), err=\n\t%w", env, res.Err())
- return mL0.NewErr[mKs.ISafeBool](err)
- }
- return mL0.NewOk(sf)
- }
- // Get -- возвращает хранимый булевый признак.
- func (sf *safeBool) Get() bool {
- sf.RLock()
- defer sf.RUnlock()
- return sf.val
- }
- // Set -- устанавливает булевый признак.
- func (sf *safeBool) Set() {
- sf.Lock()
- defer sf.Unlock()
- sf.val = true
- }
- // Reset -- сбрасывает булевый признак.
- func (sf *safeBool) Reset() {
- sf.Lock()
- defer sf.Unlock()
- sf.val = false
- }
- // FromStr -- получает число из строки.
- func (sf *safeBool) FromStr(strVal string) mL0.IResult[kspec.EBool] {
- strVal = strings.ToLower(strVal)
- sf.Lock()
- defer sf.Unlock()
- switch strVal {
- case "true":
- sf.val = true
- case "false":
- sf.val = false
- default:
- return mL0.NewErr[kspec.EBool](fmt.Errorf("safeBool.FromStr(): val(%v) bad", strVal))
- }
- return mL0.NewOk(ebool.NewEBool(sf.val))
- }
- // Getenv -- получает значение из окружения.
- func (sf *safeBool) Getenv(env string) mL0.IResult[kspec.EBool] {
- strVal := os.Getenv(env)
- res := sf.FromStr(strVal)
- if res.IsErr() {
- err := fmt.Errorf("safeBool.Getenv(): from env %v, err=\n\t%w", env, res.Err())
- return mL0.NewErr[kspec.EBool](err)
- }
- return res
- }
|