prig

Prig is for Processing Records In Go. Like AWK, but snobbish. (by benhoyt)

Prig Alternatives

Similar projects and alternatives to prig

  • go

    2,070 prig VS go

    The Go programming language

  • goimports

    [mirror] Go Tools (by golang)

  • 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.

    InfluxDB logo
  • FStar

    A Proof-oriented Programming Language

NOTE: The number of mentions on this list indicates mentions on common posts plus user suggested alternatives. Hence, a higher number means a better prig alternative or higher similarity.

prig reviews and mentions

Posts with mentions or reviews of prig. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-06-13.
  • I Don't Like Golang
    4 projects | news.ycombinator.com | 13 Jun 2022
    My thoughts on his points, from someone who really likes Go and has used it heavily on small and large projects (1M LoC):

    1. Probably a matter of taste, but I love this feature, just because of the lack of noisy public/private keywords everywhere that you see in Java et al. It also means you can tell from a usage (not just the definition) that something is exported, which is often useful.

    As far as renaming goes, either rename the definition and see where the compiler complains, or get your IDE to do it (I use GoLand, but good things are said about gopls).

    As for his example, the idiomatic way to write that is either just call it `usr` or `adminUser`, or use `user := &user{}` which is valid (if a little confusing).

    2. This is a feature: it allows you to define interfaces only where you need them (on the consumer side), and you define the interface with only the methods you actually need. This means that when you add a bunch of new methods on the implementation, you don't need to change all the consumers. Go interfaces are amazing.

    The downside he discusses almost never happens: it's surprising, but even in large projects I've never had structs accidentally implementing interfaces or a IsAdmin method being implemented with reversed polarity by accident.

    3. Definitely has its downsides. Tooling helps find unchecked errors. Though I've found the biggest downside to explicit errors is the verbosity. You do get used to it, and the explicitness is at least clear.

    4. There are a couple of "magical" things like this, but they're well known and documented, and simple to fix if you run into them. I love the fact I can just name a file foo_test.go and add TestFoo methods, and "go test" finds them automatically.

    5. I have not found this to be the case, and in the rare cases it does happen, the compiler tells you loudly and it's easy to fix.

    6. Yeah, this is a slight pain, but the semi-official "imports" package (golang.org/x/tools/imports) fixes it up, so you just run generated code through that (and it auto-formats the code as well). It's a couple of lines of code. See: https://github.com/benhoyt/prig/blob/2df1b65a2bdf34c10bb5e57...

    7. Yeah, I wouldn't mind a ternary operator. Easily misused, which is why they didn't add it, but it would be really nice used judiciously, rather than the 4-line if-else block.

    8. Fixed by sort.Slice, which avoids the need for Len and Swap (and even more so by the new generics "slices" package, coming soon). I guess this was added after the article was written?

    9. Fixed by "Go modules", which is really well designed and works well (though opinions differ).

    10. Fixed with generics being added in Go 1.18. And generic helpers like "slices" and "maps" packages coming soon.

    11. Yeah, slightly annoying for newbies, though as he mentioned, tooling tells you. I do like the control you (can) get over allocation and memory management with Go slices.

    As far as his summary goes (eg: the type system getting in your way for large programs), I have definitely not found that to be the case. The author doesn't like Go, and that's okay! I don't like Java. :-)

  • Difference in Script Speed
    1 project | /r/awk | 10 Jun 2022
    fwiw I remember ben hoyt making a awk2go thing, It was still in alpha though... he also had a go like language that took go and made it behave a lot like awk here it is... It's weird to switch to go but if you want things to run as fast as possible, You need all cores, I'd switch to either luajit (for single core CPUs) or go/rust. you can also try to parallelize with gnu parallel. and use mawk which is a JIT. that should be better.

Stats

Basic prig repo stats
2
64
0.0
almost 2 years ago

benhoyt/prig is an open source project licensed under MIT License which is an OSI approved license.

The primary programming language of prig is Go.


Sponsored
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com