this post was submitted on 14 Nov 2024
72 points (98.6% liked)
Programmer Humor
32557 readers
630 users here now
Post funny things about programming here! (Or just rant about your favourite programming language.)
Rules:
- Posts must be relevant to programming, programmers, or computer science.
- No NSFW content.
- Jokes must be in good taste. No hate speech, bigotry, etc.
founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
Factory factory...n is literally just creating an OOP closure for when your language doesn't support first class functions, closures and/or currying.
Also metaprogramming and abstraction is literally the only way to actually manage and deal with the capriciousness of your stakeholders.
It's not simple, because it's literally not that simple. It's Conway's Law. That's what being a programmer in the industry is. I run a platform team, and I get paid because I can organize and deal with technical risk and contingency better than anyone else at my company. You bet your ass I do metaprogramming.
Also my product itself is a factory factory factory. Users create processes to author content, author content, and that content is delivered to other users. All in the same system. Managing complexity is extremely important if you want to work on interesting things.
I've had this exact conversation with a programmer who was retiring. He was complaining that I ask too much because I told him that he needed a more generic way to represent the logic that encodes how our end-users traverse the content that our authoring users create and manage. He literally said something to the effect of the above quote to me, but as complaining contempt.
The business explicitly doesn't want to spend money crafting individual code bases and products and unique logic. Our system lives and dies by our ability to service our internal clients and meet their needs in a dynamic manner. We need manage each factory layer carefully because very often different clients want two different things at two different times, and so each decision needs to be encoded in a way that allows us to make future platform changes without having to sell the business on refactors.
Sure you'll run into people who overuse things when it could be simpler from the business perspective. But the reality is that most programmers in the industry have never stepped foot into a well run shop. Most programmers in the industry haven't actually launched a product tip to tail.
It's very easy to criticize patterns when you don't actually have to use them, you've never seen them being used properly, and you don't know how and when to implement them.
You don't know how many times I've had to explain what two phase migration means and how to do them across multiple dependency links in the chain.
Sounds sooooo second class to me. I only deal with first class languages so I can enjoy my curry with a satisfying closure ๐ฉ ๐
So like Racket/Scheme and like maybe Ruby?