210
top 29 comments
sorted by: hot top controversial new old
[-] lelgenio@lemmy.ml 47 points 2 weeks ago
[🌽].pop() == 🍿
[-] tetris11@lemmy.ml 27 points 2 weeks ago* (last edited 2 weeks ago)
"🚴".push() = "🚲🀸"
[-] BaumGeist@lemmy.ml 39 points 2 weeks ago
"☹️".reverse() == "☹️"
[-] hydroptic@sopuli.xyz 14 points 2 weeks ago
[-] BaumGeist@lemmy.ml 11 points 2 weeks ago

Look closer at the beauty mark, I flipped the emoji

[-] Boomkop3@reddthat.com 5 points 2 weeks ago* (last edited 2 weeks ago)

wasn't it
πŸ™
.
r
e
v
e
r
s
e
()

[-] AllNewTypeFace@leminal.space 29 points 2 weeks ago

Then β€œb” backwards would have to be β€œd”

[-] hydroptic@sopuli.xyz 28 points 2 weeks ago

"E".reverse() == "βˆƒ"

[-] socsa@piefed.social 24 points 2 weeks ago

Be the operator overload you wish to see in the world

[-] deathmetal27@lemmy.world 22 points 2 weeks ago

":-)".reverse() == ")-:"

Close enough

[-] CanadaPlus@lemmy.sdf.org 15 points 2 weeks ago* (last edited 2 weeks ago)

Also, it should turn an error into an empty but successful call. /s

[-] hydroptic@sopuli.xyz 12 points 2 weeks ago

Calling reverse() on a function should return its inverse

[-] tetris11@lemmy.ml 6 points 2 weeks ago
isprime.reverse(True)
// outputs 19 billion prime numbers. Checkmate, atheists.
[-] CanadaPlus@lemmy.sdf.org 2 points 2 weeks ago

It's a just a joke, but I feel like that actually says something pretty profound about duck typing, and how computable it actually is.

[-] tetris11@lemmy.ml 12 points 2 weeks ago
"🐈".concat() = "😼"
[-] RiceMunk@sopuli.xyz 11 points 2 weeks ago* (last edited 2 weeks ago)

but

"πŸ™‚".reverse() == "πŸ™ƒ"

[-] skullgiver@popplesburger.hilciferous.nl 11 points 2 weeks ago* (last edited 2 weeks ago)

The npm package flip-text is the closest that I know of:

const flip = require('flip-text');

const str = "dobo";
const flippedStr = flip(str);

console.log(flippedStr); // Output: "qoqo"

However, with great libraries like is-thirteen I'm sure JavaScript will some day gain a proper flipping library.

[-] 418teapot@lemmy.world 7 points 2 weeks ago* (last edited 2 weeks ago)

Best I can do is

"\ude41πŸ™‚".split("").reverse().join("")

returns "\ude42πŸ™"

[-] MultipleAnimals@sopuli.xyz 7 points 2 weeks ago

JavaScript taking notes

[-] Boomkop3@reddthat.com 3 points 2 weeks ago

You could implement that on a chat, but I wouldn't do that on a string

[-] hydroptic@sopuli.xyz 1 points 2 weeks ago

Where's your sense of adventure?!

[-] TCB13@lemmy.world 2 points 2 weeks ago

Today I found out that this is valid JS:

const someString = "test string";
console.log(someString.toString());

I dint know many OO languages that don't have a useless toString on string types. It mostly seems to be a result of using a generic string-able type that's implemented to add toString() in a standardised way.

Calling toString on a string is practically a no-op anyway.

[-] hydroptic@sopuli.xyz 4 points 2 weeks ago* (last edited 2 weeks ago)

I dint know many OO languages that don’t have a useless toString on string types.

Well, that's just going to be one of those "it is what it is" things in an OO language if your base class has a toString()-equivalent. Sure, it's probably useless for a string, but if everything's an object and inherits from some top-level Object class with a toString() method, then you're going to get a toString() method in strings too. You're going to get a toString() in everything; in JS even functions have a toString() (the output of which depends on the implementation):

In a dynamically typed language, if you know that everything can be turned into a string with toString() (or the like), then you can just call that method on any value you have and not have to worry about whether it'll hurl at runtime because eg. Strings don't have a toString because it'd technically be useless.

Same is true for JavaScript's namesake, Java; Object has a toString method, so everything but primitives (int, long, etc.) must have a toString method (and primitives sort of have one too in a roundabout way).

I think JavaScript's toString also serves another function, namely to have some form of fallback when doing operations on what should be incompatible types. [] + "", for instance; JavaScript will call toString() to do type conversion when the nearest matching type is a String.

[-] TCB13@lemmy.world 1 points 2 weeks ago

I dint know many OO languages that don’t have a useless toString on string types

Okay, fair enough. Guess I never found about it because I never had to do it... JS also allows for "test string".toString() directly, not sure how it goes in other languages.

[-] skullgiver@popplesburger.hilciferous.nl 4 points 2 weeks ago* (last edited 2 weeks ago)

Java would be "test string".toString(). C# has "test string".ToString(). Python has str("test string") (as str() is Python's toString equivalent). Rust has String::from("test string").to_string().

That's just from the top of my head. I'm sure there's more.

Edit: actually, I think Rust's to_string() may not be entirely useless, I think it may be used as a consuming placeholder for clone()? Not sure how that would be useful, but it's not a complete no-op at least.

[-] tmat256@lemmings.world 2 points 2 weeks ago

It's also incredibly useful as a failsafe in a helper method where you need the argument to be a string but someone might pass in something that is sort of a string. Lets you be a little more flexible in how your method gets called

[-] hydroptic@sopuli.xyz 11 points 2 weeks ago* (last edited 2 weeks ago)

Everything that's an Object is going to either inherit Object.prototype.toString() (mdn) or provide its own implementation. Like I said in another comment, even functions have a toString() because they're also objects.

A String is an Object, so it's going to have a toString() method. It doesn't inherit Object's implementation, but provides one that's sort of a no-op / identity function but not quite.

So, the thing is that when you say const someString = "test string", you're not actually creating a new String object instance and assigning it to someString, you're creating a string (lowercase s!) primitive and assigning it to someString:

Compare this with creating a new String("bla"):

In Javascript, primitives don't actually have any properties or methods, so when you call someString.toString() (or call any other method or access any property on someString), what happens is that someString is coerced into a String instance, and then toString() is called on that. Essentially it's like going new String(someString).toString().

Now, what String.prototype.toString() (mdn) does is it returns the underlying string primitive and not the String instance itself:

Why? Fuckin beats me, I honestly can't remember what the point of returning the primitive instead of the String instance is because I haven't been elbow-deep in Javascript in years, but regardless this is what String's toString() does. Probably has something to do with coercion logic.

this post was submitted on 27 Aug 2024
210 points (94.1% liked)

Programmer Humor

32024 readers
553 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS