Source File
bool.go
Belonging Package
go.uber.org/atomic
// @generated Code generated by gen-atomicwrapper.// Copyright (c) 2020-2023 Uber Technologies, Inc.//// Permission is hereby granted, free of charge, to any person obtaining a copy// of this software and associated documentation files (the "Software"), to deal// in the Software without restriction, including without limitation the rights// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell// copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions://// The above copyright notice and this permission notice shall be included in// all copies or substantial portions of the Software.//// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN// THE SOFTWARE.package atomicimport ()// Bool is an atomic type-safe wrapper for bool values.type Bool struct {_ nocmp // disallow non-atomic comparisonv Uint32}var _zeroBool bool// NewBool creates a new Bool.func ( bool) *Bool {:= &Bool{}if != _zeroBool {.Store()}return}// Load atomically loads the wrapped bool.func ( *Bool) () bool {return truthy(.v.Load())}// Store atomically stores the passed bool.func ( *Bool) ( bool) {.v.Store(boolToInt())}// CAS is an atomic compare-and-swap for bool values.//// Deprecated: Use CompareAndSwap.func ( *Bool) (, bool) ( bool) {return .CompareAndSwap(, )}// CompareAndSwap is an atomic compare-and-swap for bool values.func ( *Bool) (, bool) ( bool) {return .v.CompareAndSwap(boolToInt(), boolToInt())}// Swap atomically stores the given bool and returns the old// value.func ( *Bool) ( bool) ( bool) {return truthy(.v.Swap(boolToInt()))}// MarshalJSON encodes the wrapped bool into JSON.func ( *Bool) () ([]byte, error) {return json.Marshal(.Load())}// UnmarshalJSON decodes a bool from JSON.func ( *Bool) ( []byte) error {var boolif := json.Unmarshal(, &); != nil {return}.Store()return nil}
![]() |
The pages are generated with Golds v0.6.7. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds. |