this post was submitted on 27 Mar 2025
230 points (97.9% liked)

Programmer Humor

22155 readers
2457 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
 

AltIndiana Jones swapping out an artifact for a fake one meme template with the text "existing code" on the real artifact, "new commit" on the fake one, and "linter" on the pedestal / trap

top 16 comments
sorted by: hot top controversial new old
[–] [email protected] 4 points 5 days ago

The linter runs automatically on every commit and blocks merges if it fails. Try again

[–] [email protected] 5 points 6 days ago* (last edited 6 days ago)

Trial:

and error:

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

Why linter? I hope your CI has more than just linting turned on

[–] [email protected] 2 points 6 days ago (2 children)

The idea for the meme came to me regarding contributing to a project for the first time. It's not like I will push trash code, but if I accidentally didn't add exactly two newlines between something and it starts complaining...

[–] [email protected] 9 points 6 days ago (1 children)

If there's a linter with such opinionated rules there should also be a pre-commit hook that auto-formats accordingly.

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

Or on save even. Slow pre commit hooks suckkkk

[–] [email protected] 1 points 4 days ago (1 children)

That's up to each individual developer's own setup. But hooks are a way to ensure uniformity since they apply to all commits.

[–] [email protected] 1 points 4 days ago* (last edited 4 days ago)

Why would it be on each dev to setup?

Your repo can, and should, include workspace settings for major editors that provide a uniform experience for anyone onboarded to the platform.

I agree that precommit hooks are good for uniformity. But slow pre commit hooks are frustrating, they are also often turned off. Your CI will always be the last gatekeeper for linting/formatting rules regardless.

Making precommit hooks slower means more devs disable them, which is the opposite of what you want. Save them for simple, read, checks and validations that can run in < 1s for even huge changesets.

[–] [email protected] 1 points 4 days ago* (last edited 4 days ago)

That's not a linting problem that's a formatting problem.

That project should have automatic formatting on save setup.

Linters are not necessarily formatters they're solving two different problems and are becoming increasingly separated in their toolset.

[–] [email protected] 2 points 6 days ago

for me, it’s rather the tests in the pipelines rather than linting, which happens while I’m writing code

[–] [email protected] 23 points 1 week ago (3 children)

I used to have my vim set up to trim excess whitespace on write.

I had no idea how many errant diff's that would generate, I had to turn it off.

[–] [email protected] 2 points 6 days ago (1 children)

i have prettier auto formatting on save (but also use vim auto format)

[–] [email protected] 2 points 6 days ago

I’ve been trying to pair down my extensions, so I’ve been using ale’s fixers to do formatting.

I’m not a huge fan though, I’ll probably go back to vim auto format.

[–] [email protected] 15 points 1 week ago (1 children)

The right balance on this is to set it up to only trim whitespace on lines that you have edited, and only on-save.

Emacs has ws-butler for that behavior: https://github.com/lewang/ws-butler

[–] [email protected] 2 points 6 days ago

That History section is exactly what happened to me

I’ll have to see if there’s a nvim equivalent, or if I can make my own

[–] [email protected] 4 points 1 week ago

Yeah, you generally just want the same auto-stuff done as would be enforced in CI anyway.

… all the other stuff you could fix but wind up just ignoring because your team ignores it will just glare at you until you sneak it in somehow