this post was submitted on 23 Jun 2024
727 points (96.5% liked)

Programmer Humor

19877 readers
327 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 53 points 6 months ago (3 children)

Sure. But in a sane language doing something totally nonsensical like that is an error, and in a statically typed language it’s a compiler error. It doesn’t just silently do weird shit.

[–] [email protected] 14 points 6 months ago

Agreed! Unfortunately these maddening behaviors were kind of set in stone several decades ago, and it has been (correctly) decided "Don't break the web", these weird quirks are kept in modern interpreters/compilers.

It's actually quite interesting to read through the logic to follow when implementing an interpreter:

https://262.ecma-international.org/13.0/#sec-object.prototype.tostring

[–] [email protected] 4 points 6 months ago* (last edited 6 months ago) (1 children)

a sane language

JavaScript

Pick one.

[–] [email protected] 1 points 6 months ago* (last edited 6 months ago)

I thought it was clear I was saying JavaScript is not a sane language for this very reason

[–] [email protected] 1 points 6 months ago (3 children)

What's a sane, dynamically typed language?

[–] [email protected] 3 points 6 months ago

I was trying to make a point without starting a flamewar that was beside the point. Personally I’d never choose a dynamically typed language for a production system. That being said, Python and Ruby complain if you try to add an array, dict/hashmap, string, or number to another (of a different type) so they’re certainly more sane than JavaScript.

[–] [email protected] 1 points 6 months ago
[–] Lime66 1 points 5 months ago

Any of them which are still strongly typed. Just because a language doesn't check for type errors before runtime doesn't mean it won't check at all