go-sumtype VS exhaustive

Compare go-sumtype vs exhaustive and see what are their differences.

go-sumtype

A simple utility for running exhaustiveness checks on Go "sum types." (by BurntSushi)

exhaustive

Check exhaustiveness of switch statements of enum-like constants in Go source code. (by nishanths)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
go-sumtype exhaustive
11 11
403 276
- -
0.0 5.9
about 1 year ago 1 day ago
Go Go
The Unlicense BSD 2-clause "Simplified" License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

go-sumtype

Posts with mentions or reviews of go-sumtype. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-03-13.
  • Small sum types in Golang
    1 project | dev.to | 21 Jun 2023
    I find this implementation to be quite minimal and less clumsy than alternatives. Sure, you don't get nice exhaustive pattern matching. Also, type inference gets in the way when instantiating UserKey (though you can wrap it in constructor functions). But expressing your intent using types still makes your code much more convenient and easier to understand.
  • Switching from C++ to Rust
    7 projects | news.ycombinator.com | 13 Mar 2023
    The call out to sum types is something I feel. I've been using Rust daily for almost 10 years now, and sum types are absolutely still one of the things I love most about it. It's easily one of the things I miss the most in other languages. I'm usually a proponent of "using languages as they're intended," but I missed exhaustiveness checking so much that I ported a version of it to Go[1] as a sort of lint.

    [1]: https://github.com/BurntSushi/go-sumtype

  • Rusty enums in Go
    5 projects | /r/golang | 16 Feb 2023
    A Google search for golang sum types currently shows my project as a second hit: https://github.com/BurntSushi/go-sumtype
  • Carbon Language: An experimental successor to C++
    11 projects | /r/rust | 19 Jul 2022
    I've been writing Go and Rust nearly daily for about a decade now (Go is more than a decade, Rust is about 8 years). You are not going to teach me anything about the pros and cons of either language in a reddit comment. I do not need to be taught about the "iota mess" when I've written tooling for exhaustiveness checking in Go.
  • a go linter to check switch statements for default
    3 projects | /r/golang | 25 May 2022
    https://github.com/BurntSushi/go-sumtype forces exhaustive type switches for interfaces specifically annotated to need that.
  • Go: Making state explicit using the type system
    2 projects | dev.to | 15 May 2022
    We can fix these two problems by relying on static analyzers such as go-sumtypes
  • Hacking sum types with Go generics
    2 projects | /r/golang | 14 Mar 2022
    See also https://github.com/BurntSushi/go-sumtype
  • What I'd like to see in Go 2.0
    11 projects | news.ycombinator.com | 4 Feb 2022
  • Upcoming Features in Go 1.18
    3 projects | news.ycombinator.com | 9 Nov 2021
    go-sumtype[0] has completeness checking for sealed interfaces.

    [0] https://github.com/BurntSushi/go-sumtype

  • I want enum more than generics
    2 projects | /r/golang | 13 Jan 2021
    Pretty easy to achieve outside of the compiler: https://github.com/BurntSushi/go-sumtype

exhaustive

Posts with mentions or reviews of exhaustive. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-09-29.
  • Compile-time safety for enumerations in Go
    3 projects | news.ycombinator.com | 29 Sep 2023
    This is an analyzer that will catch this: https://github.com/nishanths/exhaustive

    I believe it's in golangci-lint.

  • Tools besides Go for a newbie
    36 projects | /r/golang | 26 Mar 2023
    I agree linters in general are quite useful for Go though. The default suite from golangci-lint is quite good. I would also recommend enabling exhaustive if you're working with a codebase that uses "enums" (full disclosure, I contributed a bit to that project).
  • What “sucks” about Golang?
    17 projects | /r/golang | 10 Mar 2023
    there’s a linter for exhaustive matching: https://github.com/nishanths/exhaustive
  • Rusty enums in Go
    5 projects | /r/golang | 16 Feb 2023
    I tried to find that linter and found this: exhaustive
  • Supporting the Use of Rust in the Chromium Project
    11 projects | /r/rust | 13 Jan 2023
    And in Go you'd use a linter, like this one.
  • Blog on enums in Go: benchmarks; issues; assembly
    2 projects | /r/golang | 16 Nov 2022
    this is AST go vet analyzer that performs just that: https://github.com/nishanths/exhaustive (too bad it can not do struct based enums..)
  • Rust Is Hard, Or: The Misery of Mainstream Programming
    15 projects | news.ycombinator.com | 2 Jun 2022
    >> the main thing missing from Go is ADT's. After using these in Rust and Swift, a programming language doesn't really feel complete without them

    What are the differences between an ADT (plus pattern matching i’d reckon?) in Rust/Swift vs the equiv in Go (tagged interfaces + switch statement)?

    One has exhaustive matching at compile time, the other has a default clause (non exhaustive matching), although there’s an important nub here with respect to developer experience; it would be idiomatic in Go to use static analysis tooling (e.g. Rob Pike is on record saying that various checks - inc this one - don’t belong in the compiler and should live in go vet). I’ve been playing with Go in a side project and using golint-ci which invokes https://github.com/nishanths/exhaustive - net result, in both go and rust, i get a red line of text annotated at the switch in vscode if i miss a case.

    Taking a step back, there isn’t a problem you can solve with one that you can’t solve with the other, or is there?

    To take a step further back, why incomplete?

  • Why are enums not a thing in Go?
    5 projects | /r/golang | 22 May 2022
    Use a linter.
  • 1.18 is released
    6 projects | /r/golang | 15 Mar 2022
    For an exhaustive linter, were you referring to this? It looks pretty nice. If it's possible to check this with static analysis, is it something that could be in the compiler itself in the future?
  • Go Replaces Interface{} with 'Any'
    10 projects | news.ycombinator.com | 14 Dec 2021
    https://github.com/nishanths/exhaustive

    here, have fun. You’re gonna write some tests, make new types to satisfy interfaces for testing, and then wind up with branches for your test paths in your live code, but go for it, I guess. You know everything! I am but a simple blubbite, too dim, too dim to get it.

What are some alternatives?

When comparing go-sumtype and exhaustive you can also consider the following projects:

go101 - An up-to-date (unofficial) knowledge base for Go programming self learning

golangci-lint - Fast linters Runner for Go

enumer - A Go tool to auto generate methods for your enums

reposurgeon

go - The Go programming language

Ionide-vim - F# Vim plugin based on FsAutoComplete and LSP protocol

hylo - The Hylo programming language

go-optional - A library that provides Go Generics friendly "optional" features.

crubit

ionide-vscode-fsharp - VS Code plugin for F# development

mo - 🦄 Monads and popular FP abstractions, powered by Go 1.18+ Generics (Option, Result, Either...)

enumcheck - Allows to mark Go enum types as exhaustive.