There is a small but turbulent shitstorm on Lobste.rs about Go: https://lobste.rs/s/cclrkn/were_multiple_return_values_go_s_biggest

and the key quote, perhaps, is this:

I’m always amazed how Ken Thompson, Rob Pike and Robert Griesemer, with a combined 100+ years experience with PLT and about a dozen languages, are treated as total idiots by people whose greatest hits are building a web app once.

There is how I think about it.

Back at the late 90s, when suddenly, out of fucking nowhere we have got Internet, FreeBSD and Linux and that Apache httpd, everything seemed to be just as an endless WOW!!! Something new and amazing almost every day.

I still remember the “unreal” feeling of seeing an IRC client on a SCO UNIX 3.2 terminal “connected to the whole world”. I have seen that Zyxel modem which served the whole region as an IP uplink to Finland. I have seen things you perople would not belive.

And, yes, at that time the actual experience of having been able to say cc a.c && ./a.out was amazing too.

Then I remember having endless complications of compiling that PHP 2.0 as a DSO module into Apache http server and of running some crappy code, Drupal or something.

That PHP thing allowed me to write a lame ad-hook web-reporting system to then small retailer Lenta C&C at which I worked as UNIX and Informix admin. It was a glorious time.

Again, the WOW-factor, the novelty and the sudden ability to do something which has never been done before overshadowed everything else and all other concerns (It is an urban legend how crappy SCO UNIX was compared to literally anything. Yes, I ran DEC OSF/1 and AIX too).

Then suddenly I have read this:

https://eev.ee/blog/2012/04/09/php-a-fractal-of-bad-design/

back then it wasn’t formatted this silly and was less politically correctly worded.

This was my sudden realization that as a sysadmin who can code, I know and understand literally nothing about the languages I use. Since then I have studied, some, here, there.

Now look. When C has been released it was exactly the same situation, literally.

Suddenly, people got something that allow them to do things they have never done before, most notably – port crappy code between different machines (with various degree of success).

Campuses got UNIX installations for students, and, of course, email, irc, vi, Emacs and what not, literally everything has been written in C.

Just exactly the same as it were with PHP, almost no one realized how crappy the language actually is – they just keep hacking up stuff, without much awareness, until, perhaps, the Morris virus came out.

The C ABI became what it is today – “the way things are”. Zero-terminated strings and NULLs became “the standard” and the compatibility with C became a necessity (hi, Bjarne).

Again, using 0 as a special address and a special character was a very clever, and even “obvious” hack, especially given that in the non-bullshit discrete math the positive numbers start at 1 (these old guys all were math-literate).

Another reason was the historic stupidity of assuming an (not the) Empty Set to be an apriory member of any other Set, so, again, 0 seemed to be OK.

And, of course, the god-like Common Lisp guys used NIL correctly (yes!) – “T is not NIL” so, CAR of NIL is NIL and so on.

It requires a much deeper knowledge to realize that no member of a set should be special (there is a principle of such that behind it, which makes all the elements equivalent in principle, including singleton sets and the empty set).

Math guys with an abstract algebra and theorem proving background (ML) got this exactly right.

But see, the C hacks with 0 are so clever. They resulted in a clever language standard idioms (just as in Common Lisp, but worse). C was a bunch of clever hacks at all levels (syntax, semantics, idioms), just like PHP was for a total newbie.

One more time – to say that the inventors of C and UNIX were PL gurus is bullshit. You could say the same about the authors of PHP or Javascript. They were ambitious and enthusiastic and obviously smart, but nowhere near being PL gurus like Barbara Liskov (with her CLU) or the late Ada guys.

My own metaphor was that back then C was a thin layer of common imperative idioms for a very thin layer of bad (not proper ADTs), leaky, abstractions – a surgical gloves, through which one can still touch the hardware. PHP 2.0 of its time.

As for Go, well, it has been aimed as a in principle minimal PROCEDURAL IMPERATIVE language “done right”, according to what is right in the procedural and imperative mindset, damaged by the hacky and clever Bell Labs and its C (and the early hacky C++) history.

Okay, enough. “The Worse Is Better” is out there.

So, Go is very-very opinionated and it came from its own sect. As a sect it is perfectly fine and cool and clever. They had their own world view and a set of principles to follow, just like any other sectarians do.

Ignoring literally everything good and true within the ML-family sects was “natural” and even “obvious” thing to do, just like Hindu ignores Muslims and so on.

To say that Go is any good except that being a realization of a certain rigid set of principles, is an insult to intelligence.

There are less rigid languages (Ocaml, Scala 3) which evolved way better idioms, subtle better semantics, and way more balanced overall feel. They are just a better art.

And yes, I am autistic enough to appreciate how they would return a two values instead of one (on the stack) but not a pair or any other “unnecessary, redundant” abstraction. This is an obsession of “doing the right thing” (again, according to their world view) closest to hardware.

I myself absolutely love truly high-level ML, OCaml, Matlab or Scala and I see how adding to them “a low level imperative DSL with lots of traditional curly braces” would make a good language. Think of “unsafe” as a DSL with all the cool C syntactic hacks and tricks but without preprocessor and other stuff.