 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package zerokit helps with zero value related use-cases such as initialisation.
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Coalesce ¶
func Coalesce[T any](vs ...T) T
Coalesce will return the first non-zero value from the provided values.
Example ¶
package main
import (
	"go.llib.dev/frameless/pkg/zerokit"
)
func main() {
	_ = zerokit.Coalesce("", "", "42") // -> "42"
}
func Init ¶
func Init[T any, I initialiser[T]](ptr *T, init I) T
Init will initialise a zero value through its pointer (*T), If it's not set, it assigns a value to it based on the supplied initialiser. Init is safe to use concurrently, it has no race condition.
Example ¶
package main
import (
	"go.llib.dev/frameless/pkg/pointer"
	"go.llib.dev/frameless/pkg/zerokit"
)
func main() {
	type MyType struct {
		V *string
	}
	var mt MyType
	_ = zerokit.Init(&mt.V, func() *string {
		return pointer.Of("default value from a lambda")
	})
	_ = zerokit.Init(&mt.V, pointer.Of(pointer.Of("default value from a pointer")))
}
Types ¶
This section is empty.
 Click to show internal directories. 
   Click to hide internal directories.