this post was submitted on 01 Sep 2023
331 points (96.1% liked)

Programming

16975 readers
1288 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 [email protected]



founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 45 points 1 year ago (6 children)

Tabs are better than spaces

[–] [email protected] 13 points 1 year ago (1 children)

Tabs are literally designed for aligned indentation, and they're configurable for clientside viewing. There is no excuse for spaces. I don't care if your goddang function arguments line up once they spill out onto another line. You've got deeper problems.

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

Tabs are designed for tabulation (hence the name), not indentation. The side effect is that a tab's length changes based on its position in a line, which is terrible for programming. If you use tabs in the Python REPL, it looks like this:

>>> def frobnicate_all(arr):
>>>     for item in arr:
>>>             frobnicate(item)
[–] [email protected] 1 points 1 year ago (1 children)

a tab’s length changes based on its position in a line

What does this even mean? A tab is a tab.

Tab's don't have multiple lengths inside a file, they all have the same length.

That's the point of tabs.

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

The horizontal tabulation character moves the cursor to the next column which is a multiple of the tabulation length. See the examples here: https://en.m.wikipedia.org/wiki/Tab_key

At least for me, it renders like this:

Screenshot of a part of the linked Wikipedia page

Clearly the whitespace produced by each tab character has a different length.

[–] [email protected] 1 points 1 year ago

The horizontal tabulation character moves the cursor to the next column which is a multiple of the tabulation length. See the examples here: https://en.m.wikipedia.org/wiki/Tab_key

Yes

Clearly the whitespace produced by each tab character has a different length.

No, each tab has the same size, the text rendered over the top of the tabs are not the same size.

Always remember the golden rule: Tabs for indentation, spaces for alignment.

[–] [email protected] 1 points 1 year ago (1 children)
[–] [email protected] 1 points 1 year ago (1 children)

A newline is the separator between lines, so the concept of length doesn't make sense for it.

[–] [email protected] 1 points 1 year ago (1 children)

Correct.

And a tab is the separator between stops.

[–] [email protected] 1 points 1 year ago (1 children)

Indeed. It's a separator, so using it for indentation doesn't make sense.

[–] [email protected] 1 points 1 year ago

Stops are indentation.

They're what you indent... to.

Tab goes to the next stop, the same way newline goes to the next line. Exactly the same way. If you write more text before the next line, the amount of whitespace shrinks. That doesn't mean the "length" of a newline changes. It always goes one line.

A tab always goes one stop.

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

Pressing tab and having the appropriate number of spaces added is objectively the only right answer.

[–] [email protected] 10 points 1 year ago

But you can set a tab width instead so any developer editing the code can adjust the indentation width to his liking, without changing the actual files contents and having to worry about setting the editor up to insert the right amount of spaces.

[–] [email protected] 6 points 1 year ago

Tabs for indentation, spaces for alignment

[–] [email protected] 3 points 1 year ago

I work in a massive project where they used both. Often in the same functions. Sometimes mixing 2 and 4 spaces aswell.

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

The real hot take: Spaces are better than tabs. Fight me

[–] [email protected] 1 points 1 year ago

Spaces ARE better than tabs.

[–] [email protected] 1 points 1 year ago (1 children)

Tabs could be a good idea if their default size in most environments (and often not configurable) wasn't 8, which is terribly big.

[–] [email protected] 1 points 1 year ago (1 children)

most environments

What environment are you using that have tabs set to 8?

[–] [email protected] 1 points 1 year ago (1 children)
  • Many terminal emulators (may or may not be configurable), including Termux for Android (not configurable)
  • GitHub (by default)
  • SourceHut (not configurable)
  • Vim/Neovim (by default)
  • HTML (by default, I think)

Honestly, I can't think of an environment that doesn't have 8-space tabs by default.

[–] [email protected] 1 points 1 year ago

Interesting...

Every IDE and editor (gui and tui) I've used has always come preconfigured with a tab-size of 4.

The only thing I've ever experienced having a tab-size of 8 was github, and I thought that was just a problem with a setting from github's size that I quickly set back to 4.

It seems that tui editors come with tab-sizes of 8 only when a config isn't provided, and every environment I've used where I've used a tui editor has always come with sensible configs (for things like config location, language recognition for syntax highlighting, etc...) including a tab-size of 4.