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 ( "github.com/adamluzsi/frameless/pkg/zerokit" ) func main() { _ = zerokit.Coalesce("", "", "42") // -> "42" }
Output:
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 ( "github.com/adamluzsi/frameless/pkg/pointer" "github.com/adamluzsi/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"))) }
Output:
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.