329
submitted 3 days ago* (last edited 3 days ago) by HiddenLayer555@lemmy.ml to c/programmer_humor@programming.dev

Made with KolourPaint and screenshots from Kate (with the GitHub theme).

you are viewing a single comment's thread
view the rest of the comments
[-] sus@programming.dev 19 points 2 days ago* (last edited 2 days ago)

So I think it's still probably unclear to people why "mix of keywords and identifiers" is bad: it means any new keyword could break backwards compatibility because someone could have already named a type the same thing as that new keyword.

This syntax puts type identifiers in the very prominent position of "generic fresh statement after semicolon or newline"

..though I've spent like 10 minutes thinking about this and now it's again not making sense to me. Isn't the very common plain "already_existing_variable = 5" also causing the same problem? We'd have to go back to cobol style "SET foo = 5" for everything to actually make it not an issue

[-] HiddenLayer555@lemmy.ml 1 points 1 day ago* (last edited 1 day ago)

any new keyword could break backwards compatibility

Wouldn't that happen anyway with variable and function names? Any type other than primitive/built in ones are usually camel case so lower case keywords are more likely to clash with single word variable and function names, unless you restrict the cases of those too or allow keyword overriding or something.

[-] sus@programming.dev 2 points 1 day ago* (last edited 1 day ago)

Yeah, it's in my edit I realized the same thing. I'm thinking it doesn't actually really make sense and the real reason is more "the specific way C does it causes a lot of problems so we're not poking syntax like that with a 10 foot pole" + "it makes writing the parser easier" + maybe a bit of "it makes grepping easier"

[-] HiddenLayer555@lemmy.ml 1 points 1 day ago* (last edited 1 day ago)

One thing that annoyed me about C# as a Java guy is that it really wants you to use camel case for function and property names, even private ones. I don't like it specifically because it's hard to differentiate between a function/property and a type.

But C# has quite a few keywords and seem to like adding them more than Java.

Maybe that's their way of ensuring keywords don't clash with stuff?

[-] AnotherPenguin@programming.dev 3 points 2 days ago

At least in C#, you can define variables with keyword names like this:

var @struct = "abc"

I think in Kotlin you can do the same, and even include spaces with backticks like val abstract class = "abc"

I'm not sure if other languages allow that, regardless it should be rarely used.

[-] pivot_root@lemmy.world 3 points 2 days ago

Swift also uses backticks and Rust has a dumb one in the form of r#thekeyword. Still much better than introducing a async as a new keyword in a minor version of a language and breaking a bunch of libraries.

[-] fayaz@lemmy.world 4 points 2 days ago
[-] piccolo@sh.itjust.works 3 points 2 days ago

Ah I was misunderstanding the problem. And learned something new about C#, seems in order to avoid breaking existing code they introduce "contextual keywords" var being added later, it is a contextual. You can create a class 'var' and the compiler will prefer it.

this post was submitted on 19 Jun 2025
329 points (90.4% liked)

Programmer Humor

24374 readers
987 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