this post was submitted on 29 Oct 2024
59 points (92.8% liked)

Programming

17326 readers
217 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



founded 1 year ago
MODERATORS
top 19 comments
sorted by: hot top controversial new old
[–] SquiffSquiff@lemmy.world 15 points 6 days ago

Looks like it's too easy to delete. I click on the link and I get a not found exception

[–] Feathercrown@lemmy.world 6 points 5 days ago

Code that's easy to extend generally encourages creating related code that's easy to delete. These are very similar directives.

[–] jim@programming.dev 9 points 6 days ago

This is a classic piece, and I love the contradictions in the text. It encapsulates my feelings on good software and code that it almost becomes an art than a science.

[–] drspod@lemmy.ml 21 points 1 week ago* (last edited 1 week ago) (1 children)

“Every line of code is written without reason, maintained out of weakness, and deleted by chance” Jean-Paul Sartre’s Programming in ANSI C

Is this a joke ~~or an AI hallucination~~? I'm pretty sure Sartre never wrote about programming in ANSI C.

There is a book called "Programming in ANSI C" by E. Balagurusamy

I can only find other references to this quote from sites that are linking this article.

The article actually does date back to 2016 so it's not AI generated.

[–] drspod@lemmy.ml 45 points 1 week ago (1 children)

I should have tried a bit harder to search, the original quote by Sartre is:

"Every existing thing is born without reason, prolongs itself out of weakness, and dies by chance."

[–] Evotech@lemmy.world 3 points 5 days ago

Thanks for checking

[–] Lysergid@lemmy.ml 18 points 1 week ago (3 children)

TLDR;

My current project has mostly easy to delete code and not easy to extend. Why? Coz shit was copy-pasted 50 times. It’s not fun to work in this project.

[–] VoterFrog@lemmy.world 1 points 4 days ago

Eh, not really then. If you have some behavior in those 50 copy/pastes that needs to be deleted, you've got to delete it 50 times. That's not easier at all.

[–] Kache@lemm.ee 9 points 1 week ago* (last edited 1 week ago) (1 children)

I don't understand, if you've got easy to delete copy-pasted code, then delete it. It'll be a nice and cathartic exercise.

But sounds like what you're really talking about is code that isn't easy to delete.

[–] Lysergid@lemmy.ml 3 points 6 days ago (2 children)

I don’t understand too. Are you suggesting me to drop bunch of features in the product?

[–] tyler@programming.dev 5 points 5 days ago (1 children)

That means it’s not easy to delete. So your initial premise is wrong.

[–] Lysergid@lemmy.ml 5 points 5 days ago* (last edited 5 days ago)

No, that means you falling into author’s bait where they misuse term “delete”. Refactoring is not equal to deleting. One can be result of another. But the truth is that extendable code needs to be modular to be extendable. And modular code is easy to refactor. Author couldn’t not name it “Write code that is easy to refactor, not easy to extend” coz it’s even more dumb

[–] samus7070@programming.dev 3 points 6 days ago (1 children)

I think the responder means that duplicate code is usually easy to refactor into single methods. Typically I see copy pasted code that is changed just a little bit. However much of a duplicated function can be broken into smaller functions and the redundant code removed in favor of calling into the functions. Often what is left then becomes easier to reason about and refactor accordingly. I love the PRs that I make which delete more code than I add but still manage to add functionality. It doesn’t happen often but it’s fun when it does.

[–] Lysergid@lemmy.ml -3 points 5 days ago (1 children)

Right, but my initial comment was about article’s statement being wrong. Refactoring in the way you described will make code harder to delete which is bad according to the article.

[–] Evotech@lemmy.world 3 points 5 days ago (1 children)

Sounds like you read the first paragraph only

[–] Lysergid@lemmy.ml -2 points 5 days ago

No, title only

Same thing on my project. Thousands of lines across a few dozen files copied 100+ times. At that point there's almost no going back with everything diverging so long ago.

[–] FlorianSimon@sh.itjust.works 10 points 1 week ago

I'd go easy with the recommendation to couple components loosely. If you make things that belong together loosely coupled, you've created obfuscation, and added complexity to your codebase. Loose coupling makes sense, but not everywhere.

[–] lascapi@jlai.lu 3 points 1 week ago

Some though are interesting. 🤔