Charles Iliya Krempeaux d6b2890eaa | ||
---|---|---|
LICENSE | ||
README.md | ||
go.mod | ||
go.sum | ||
map.go | ||
map_test.go | ||
optional.go | ||
optional_filter_test.go | ||
optional_get_test.go | ||
optional_gostring_test.go | ||
optional_marshaljson.go | ||
optional_marshaljson_bool_test.go | ||
optional_marshaljson_int_test.go | ||
optional_marshaljson_string_test.go | ||
optional_unmarshaljson.go | ||
optional_unmarshaljson_bool_test.go | ||
optional_unmarshaljson_int_test.go | ||
optional_unmarshaljson_string_test.go | ||
optional_whennothing_test.go | ||
optional_whensomething_test.go | ||
then.go | ||
then_test.go |
README.md
go-opt
Package opt implements an optional-type, for the Go programming language.
In other programming languages, an optional-type might be know as: a option-type, or a maybe-type.
Documention
Online documentation, which includes examples, can be found at: http://godoc.org/sourcecode.social/reiver/go-opt
Examples
Here is an example optional-type that can hold a string:
import "sourcecode.social/reiver/go-opt"
//
var op opt.Optional[string] // the default value is nothing.
// ...
if opt.Nothing[string]() == op {
fmt.Println("nothing")
}
// ...
op = opt.Something("Hello world! 👾")
// ...
switch op {
case op.Nothing[string]():
//@TODO
case op.Something("apple"):
//@TODO
case op.Something("banana"):
//@TODO
case op.Something("cherry"):
//@TODO
default:
//@TODO
}
// ...
value, found := op.Get()
if found {
fmt.Println("VALUE:", value)
} else {
fmt.Println("nothing")
}