Most active commenters
  • (5)
  • necovek(4)
  • pdpi(3)
  • anyfoo(3)

←back to thread

311 points todsacerdoti | 64 comments | | HN request time: 1.062s | source | bottom
1. pdpi ◴[] No.46239164[source]
GNU's version of Yacc is called Bison. Pine Is Not Elm (even though that was never an official acronym). UNIX was UNICS which was a pun on MULTICS. I couldn't for the life of me tell you what dd stands for. nano is a copy of pico which was the "PIne COmposer". Postfix is a completely opaque portmanteau of post (as in mail) and "bug fix". C++ is "C incremented", and C is the successor of B, which is the successor of BCPL.

Developers haven't "lost the plot", we never had it in the first place.

Inversely, Clang, LLDB, jq, fzf, loc are modern projects perfectly in line with the author's notion of a good name. "mise-en-place" is the perfect metaphor for what mise does.

replies(16): >>46239266 #>>46239267 #>>46239293 #>>46239675 #>>46239818 #>>46239903 #>>46240006 #>>46240043 #>>46240475 #>>46240516 #>>46240745 #>>46240858 #>>46240981 #>>46240986 #>>46242271 #>>46242669 #
2. anyfoo ◴[] No.46239266[source]
> I couldn't for the life of me tell you what dd stands for.

Data(set) Definition. But that name does not make any sense whatsoever by itself in this context, neither for the tool (it hardly "defines" anything), nor for UNIX in general (there are no "datasets" in UNIX).

Instead, it's specifically a reference to the DD statement in the JCL, the job control language, of many of IBM's mainframe operating systems of yore (let's not get into the specifics of which ones, because that's a whole other can of complexity).

And even then the relation between the DD statement and the dd command in UNIX is rather tenuous. To simplify a lot, DD in JCL does something akin to "opening a file", or rather "describing to the system a file that will later be opened". The UNIX tool dd, on the other hand, was designed to be useful for exchanging files/datasets with mainframes. Of course, that's not at all what it is used for today, and possibly that was true even back then.

This also explains dd's weird syntax, which consists of specifying "key=value" or "key=flag1,flag2,..." parameters. That is entirely alien to UNIX, but is how the DD and other JCL (again, of the right kind) statements work.

replies(5): >>46240018 #>>46240367 #>>46240644 #>>46241335 #>>46241977 #
3. ekidd ◴[] No.46239267[source]
> I couldn't for the life of me tell you what dd stands for.

Traditionally, according to folklore? "Delete disk" or "destroy data". (Because it was commonly used to write raw disk blocks.)

replies(3): >>46239594 #>>46240961 #>>46243101 #
4. layer8 ◴[] No.46239293[source]
> what dd stands for

https://groups.google.com/d/msg/alt.folklore.computers/HAWoZ...

5. QuantumNomad_ ◴[] No.46239594[source]
Another, similar name it is sometimes jokingly referred to under is “destroyer of disks”.

https://web.archive.org/web/20081206105906/http://www.noah.o...

6. rikthevik ◴[] No.46239675[source]
https://en.wikipedia.org/wiki/Back_Orifice_2000 was pretty clear about what it did.

https://en.wikipedia.org/wiki/BitchX less so.

7. HPsquared ◴[] No.46239818[source]
Naming is a big part of programming, you'd expect software to have good descriptive names.
replies(5): >>46239863 #>>46239907 #>>46240940 #>>46241522 #>>46242293 #
8. Supermancho ◴[] No.46239863[source]
How do you discriminate between 2 different things that ostensibly have similar features, but do it in different ways without getting very large names? What if you modify software or just part of it to make it something distinctively new, should it keep the name or add to it? What if I revert that non-trivial feature and add a different non-trivial one. Now what is it?

I would hope the author realizes the core counterpoint when re-reading "We’re using Viper for configuration management, which feeds into Cobra for the CLI, and then Melody handles our WebSocket connections, Casbin manages permissions, all through Asynq for our job queue" - because the real names, are the roles the tools play. The implementation name is incidental and amorphous, since you can make wild changes to software, rendering the name without much utility beyond a project label. Project labels are necessarily opaque, for the same good reasons software is. The ideals are more important than the details. They are a conflux of interests and plans, not a market label. If market labels were fixed to functionality, the world would be worse off for obvious reasons of practicality and marketability. Ironically, Stallman is completely comfortable with PostgreSQL which is semantic context adjacent, charitably. It describes a small element of the project (a synthetic SQL syntax), not the project itself.

9. saghm ◴[] No.46239903[source]
In the same vein, my recollection is reading that the X windowing system is called X because it's the letter after "W", which was the original choice (because it's what the word "window" starts with), but it was already taken, so they went with X.
replies(1): >>46240008 #
10. mbesto ◴[] No.46239907[source]
"There are only two hard things in Computer Science: cache invalidation and naming things."
replies(2): >>46239928 #>>46239933 #
11. MrDarcy ◴[] No.46239928{3}[source]
And off by one errors.
12. casper14 ◴[] No.46239933{3}[source]
"And off by one errors"
13. abetusk ◴[] No.46240006[source]
GNU stands for "GNU's Not Unix".

Yacc stands for "Yet Another C Compiler".

Nano was originally TIP which stood for "TIP Isn't Pico" but was later changed to Nano so as not to conflict with another Unix utility called tip [0]. Presumably nano was chosen as the metric prefix next larger than pico.

Personally, I'd prefer choosing a random string of 3-8 letters for command line tools. At least that would be better than naming programs using generic names (Keep, Bamboo, Chef, Salt) which leads to all sorts of name collisions.

From the article:

> This would be career suicide in virtually any other technical field.

The mascot for an $8.8T dollar (supply side) software industry, larger than Google, Microsoft and Apple combined, is a cartoon penguin [1].

"never had it in the first place" is absolutely correct.

[0] https://en.wikipedia.org/wiki/GNU_nano

[1] https://www.hbs.edu/ris/Publication%20Files/24-038_51f8444f-...

replies(2): >>46240033 #>>46240563 #
14. anyfoo ◴[] No.46240008[source]
It looks like X was deliberately chosen to denote succession of W, not clashing with it:

    "The name X derives from the lineage of the system. At Stanford University, Paul Asente and Brian Reid had begun work on the W window system [3] as an alternative to VGTS [13, 221 for the V system [5]. [...] We acquired a UNIX-based version of W for the VSlOO (with synchronous communication over TCP[24] produced by Asente and Chris Kent at Digital’s Western Research Laboratory. [...] It was also clear that, although synchronous communication was perhaps acceptable in the V system (owing to very fast networking primitives), it was completely inadequate in most other operating environments. X is our “reaction” to W."
-- https://dl.acm.org/doi/pdf/10.1145/22949.24053
15. necovek ◴[] No.46240018[source]
Having come from the DOS world (or it could have been Norton utilities), I always thought it was more like DiskDupe (duplicate disks).

Funny how we never confirm our hypothesis that "checks out".

replies(1): >>46240083 #
16. Sniffnoy ◴[] No.46240033[source]
Yacc is Yet Another Compiler Compiler, not Yet Another C Compiler. It's useful for writing compilers, not for compiling C.
replies(2): >>46240108 #>>46241045 #
17. necovek ◴[] No.46240043[source]
Even GNU is a recursive acronym, Emacs a convoluted one... What's Perl, Python, Java... all about? Remember how JavaScript was named? Don't mention Go (go-lang) or Pascal... Git, Mercurial, CVS anyone?

I believe this makes much ado about nothing.

replies(4): >>46240449 #>>46241400 #>>46241676 #>>46243053 #
18. anyfoo ◴[] No.46240083{3}[source]
"disk dump" is another common (but wrong) guess.
replies(2): >>46240156 #>>46240841 #
19. abetusk ◴[] No.46240108{3}[source]
Yep, my mistake! And it makes a lot more sense.
20. softskunk ◴[] No.46240156{4}[source]
I always read it as “[disk|data] destroyer”, because that’s what it’ll do if you’re not careful.
replies(1): >>46240974 #
21. ◴[] No.46240367[source]
22. pdpi ◴[] No.46240449[source]
"Concurrent Versions/Versioning System" is a pretty reasonable one, though.
replies(1): >>46240591 #
23. PenguinCoder ◴[] No.46240475[source]
Pretty sure dd is disk destroyer
24. kazinator ◴[] No.46240516[source]
The only thing that's different between the era when Bison as named and now is the proliferation. There is vastly more shit in open source with the cute names. Back then, one person could keep all the cute names for everything related to C and Unix in their head.
replies(1): >>46241238 #
25. pdpi ◴[] No.46240563[source]
> "never had it in the first place" is absolutely correct.

To be clear: I didn't mean to imply this is a bad thing.

GNU's Not Unix, Pine Is Not Elm, TIP Isn't Pico all share one important characteristic — their audience is expected to know what Unix, Elm, Pico are, and saying "X is not Y" implies "X is specifically, deliberately an alternative to Y, in the same style as Y".

If you know what GNU and YACC are, you probably don't need to be told twice that "Bison" is GNU's YACC implementation — the pun makes it instantly memorable.

One of my personal favourites is Ubuntu's version naming scheme. The "alliterative animal" form is highly memorable, and gives you two different words to latch on to, either of which is enough to uniquely identify a version. The fact they're alphabetical also makes it easy to check which version is newer (Letter collisions happen on a 13-year cycle, which makes it highly unlikely to be a source of confusion).

replies(1): >>46242273 #
26. necovek ◴[] No.46240591{3}[source]
Then Gimp is also a great name, right? GNU-is-not-Unix Image Manipulation Program: immediatelly obvious what it does as soon as you learn what the acronym stands for.

Or Gtk even: Gnu-is-not-Unix Image Manipulation Program ToolKit (later changed to refer to Gnome instead of Gimp I believe).

replies(1): >>46242929 #
27. f33d5173 ◴[] No.46240644[source]
I had remembered it was "convert and copy", but cc was already taken by the c compiler so they shifted it down a letter. That might have been apocryphal.
replies(1): >>46241805 #
28. bsder ◴[] No.46240745[source]
There are two hard problems in computer science: caching things, naming things and off-by-one errors.
29. Kevin-Xi ◴[] No.46240841{4}[source]
One explanation that left a deep impression on me is[1]:

  it stands for 'Copy and Convert' and was renamed to `dd` only because `cc` was reserved for the C compiler!
[1]: https://unix.stackexchange.com/a/6835/192313
replies(1): >>46241388 #
30. bruce511 ◴[] No.46240858[source]
The article even refers to AWK as being the initials of the authors. And posits this as "reasonable"?

Naming is hard, not least because "a million" new projects are spawned every day. And if you're going down a path of "rule the world" (even in a niche like infrastructure) you start by getting a .com domain, so choices are limited.

Plus the name has to be unique enough to Google.

31. selcuka ◴[] No.46240940[source]
> you'd expect software to have good descriptive names

Like Microsoft Word?

32. sweetjuly ◴[] No.46240961[source]
I always assumed part of the "data destroyer" folklore was from people flipping if/of by accident and destroying their data :)
replies(2): >>46240993 #>>46242578 #
33. jaredhallen ◴[] No.46240974{5}[source]
You know, this is true. And I've read any number of "you should never use dd, use this instead" articles over the years. But man, do I love me some dd.
replies(1): >>46242087 #
34. jaredhallen ◴[] No.46240981[source]
dd = (D)oes what it says it (D)oes
replies(1): >>46240989 #
35. Groxx ◴[] No.46240986[source]
This, plus it's less obtuse than drug naming, and about on par with any other random product on the market.

Which is not to claim the general market is full of good names - clearly it is not. But I don't think it's below par at any point in its existence.

36. ◴[] No.46240989[source]
37. opan ◴[] No.46240993{3}[source]
I thought the more common mistake with dd was picking the wrong disk to write to (especially when using /dev/sdc type naming instead of /dev/disk/by-id/whatever naming). Flipping source/dest and overwriting data is a problem I associate with the tar command.
38. spauldo ◴[] No.46241045{3}[source]
Especially since, IIRC, it actually predates C.
39. Suppafly ◴[] No.46241238[source]
>The only thing that's different between the era when Bison as named and now is the proliferation. There is vastly more shit in open source with the cute names.

I personally think that's a pretty good idea for coming up with better names instead of cute names now.

40. isoprophlex ◴[] No.46241335[source]
I just remember it as "Da Disk", early 2000's nu metal lyrics-style, because it does mad things to da disk, yo.
replies(1): >>46241531 #
41. usefulcat ◴[] No.46241388{5}[source]
Reminds me of IBM => HAL, just the other direction
replies(1): >>46242536 #
42. usefulcat ◴[] No.46241400[source]
Perl stands for “practical extraction and report language”
replies(1): >>46241961 #
43. tempest_ ◴[] No.46241522[source]
eh, in 2025 SEO ( Whatever the jargon is for LLM) is as important or perhaps more important so that you can search and find documentation and issues etc
44. ◴[] No.46241531{3}[source]
45. xxs ◴[] No.46241676[source]
Java is easy - named after the coffee beans of the coffee they used to drink...

CVS (noticed already mentioned by a sibling comment) is just an abbreviation.

Python - well Monty Python

replies(2): >>46241910 #>>46242111 #
46. classified ◴[] No.46241805{3}[source]
Same here. But I also seem to remember claims that this isn't true…
replies(1): >>46241962 #
47. necovek ◴[] No.46241910{3}[source]
Yes, I am simply highlighting that programmers have not used descriptive names consistently... well, ever (reinforcing the point the GP made).

The entire premise of the OP is simply wrong.

48. nineteen999 ◴[] No.46241961{3}[source]
Also "pathlogically eclectic rubbish lister".
49. f1shy ◴[] No.46241962{4}[source]
I had it learned as "data duplicator" or something like that... seems also bogus.
replies(1): >>46242621 #
50. richardc323 ◴[] No.46241977[source]
Ha, for the last 30 years I have been convinced it was Disk Direct.
51. georgefrowny ◴[] No.46242087{6}[source]
dd is the software equivalent of removing the riving knife from a table saw.

Then again, I get very paranoid when I write software that has to delete arbitrary files recursively. One bad string gets in there and it's a very bad day.

52. eloisant ◴[] No.46242111{3}[source]
Java was originally called Oak but its creator because he could see an oak from his office, but marketing people at Sun thought Java would be more catchy. Yes it's named after coffee beans, but it has no relation whatsoever to the language or the way it was created, it's just a marketing name.
replies(1): >>46242868 #
53. port11 ◴[] No.46242271[source]
I agree we never had it in the first place, and that it ultimately doesn't add up to much. It seems like just a familiarity problem.

If I'm diagnosing something at 2AM, I don't care whether my database queries were written with Zapatos or PG-ORM, even if the latter is clearer. As long as you use the tools, you know what they do.

54. swiftcoder ◴[] No.46242273{3}[source]
> their audience is expected to know what Unix, Elm, Pico are

Of course, the context for these references are all kind of anchored in the 90s. Someone first discovering Bison in the year of our lord 2025 is unlikely to have the foggiest clue what YACC was...

55. swiftcoder ◴[] No.46242293[source]
I think this runs into the intersection of the "code is art" and "code is a tool" crowds. I like to name my API methods with a little whimsy too...
replies(1): >>46242613 #
56. bmacho ◴[] No.46242536{6}[source]
APL -> BQN where the author remembered the alphabet wrong : https://chat.stackexchange.com/transcript/message/54753804#5...
57. ◴[] No.46242578{3}[source]
58. rahoulb ◴[] No.46242613{3}[source]
I remember writing a function to convert a string from snake case to camel case and calling it `humpify`. And another that would take a string and locate the constant with that name called `constantinople`.

But then, this is ruby and it's known for its unusual naming. Plus both also had sensible/boring aliases and they were for internal use only.

59. ◴[] No.46242621{5}[source]
60. Y_Y ◴[] No.46242669[source]
I feel obliged to point out that C++ is C postincremented, that is to say it has the same value as C, but after you read it C gets incremented. The metaphor is flawless.
61. yard2010 ◴[] No.46242868{4}[source]
Imagine a parallel world in which Java is called Oak and it's actually nice from inception, not just like nice after decades.
62. zem ◴[] No.46242929{4}[source]
and gdk was, delightfully enough, the gnu's not unix image manipulation program toolkit drawing kit
63. delaminator ◴[] No.46243053[source]
The 2000s Plan9 community asserts "Gnu is Not Useful" as the correct expansion.
64. hoherd ◴[] No.46243101[source]
I always thought it was "disk dump"