You are viewing a single thread.
View all comments View context
1 point

I think the reason that people still talk about it is that there isn’t a compelling reason on either side. There is just a series of slight benefits and drawbacks. Tabs are slightly better on braille readers, spaces are easier for consistency (when tools don’t respect .editorconfig), blah blah blah. No one is being entirely excluded due to either option being used, so it’s really a personal/team style decision.

permalink
report
parent
reply
2 points

Tabs are better than just for blind users.

Most users want an indentation size of 4 so for the rest of this comment we’ll just call that one the default size.

Tabs

Tabs at default/any size

  • Blind people don’t care about the tab size, just that there’s tabs.
  • Keyboard users don’t care about the tab size, just that there’s tabs (because it’s only one key to change indentation levels).
  • Manual formatters don’t care about tab size, just that there’s tabs (because you can’t mess anything up inside the tab itself, but you can with space indentation)

Tabs at larger than default size

  • Verbose language (e.g. FactoryFactoryFactory) users tend to care about tab size and put the tab size up to 8 to make it easier to read. These users tend to use tabs because it’s fewer keys.
  • Zen mode users (AKA visual overload users) tend to use larger tab sizes

Tabs at smaller than default size

  • Users with poorer vision who increase the size of the code while trying to fit as much on the display as possible

Tabs at variable sizes

  • Users who move their code between a laptop display and a larger display
  • Users who use terminal splitting / tiling window managers (as a code viewport becomes more squashed, the indentation adjusts to fit the same amount of code in the viewport)

Spaces

Spaced indentation at smaller than default size

  • Users are unaware of reasons why to use tabs
  • Users coding in C99 on an 80 character wide shell

Spaced indentation at default size

  • Working on a project or using a style guide created by developers who originally coded in C99 on an 80 character wide shell

Mixed Indentations

permalink
report
parent
reply
1 point
*

Spaces don’t require additional key presses, you press tab and it puts in X spaces. No one should be using the spacebar except for when you need to precisely align things. Arguably, no one should be pressing the tab key either, as most IDEs can automatically indent for you, and it doesn’t requires tabs or spaces.

Annecdotally, tabs don’t display nicely on some braille devices (saw someone mention this on the prettier tabs discussion while researching yesterday). This may come down to the specific device they use, or it could be entirely false, but all the arguments for tabs/spaces a11y have been anecdotal.

These are all reasons to prefer tabs, but none are reasons to require tabs. And hence, teams will make their own decisions based on what annoys/suits them most.

https://blog.jetbrains.com/dotnet/2022/08/11/virtual-formatter-in-resharper-2022-2/ https://github.com/prettier/prettier/issues/7475#issuecomment-668544890 - pro tabs

https://github.com/prettier/prettier/issues/7475#issuecomment-1169470712 - pro spaces, with some arguments for tabs

https://github.com/prettier/prettier/issues/7475#issuecomment-1169934190 - claims to be blind, no preference either way

Unfortunately I can’t find the tab display complaint, but it was anecdotal anyway. No one on the internet would lie…

permalink
report
parent
reply

Programming Polls

!polls@programming.dev

Create post

Welcome to the programming polls community! This is a place where you can run polls related to programming

For questions not related to being a poll theres communities such as !no_stupid_questions@programming.dev instead and for trivia theres !trivia@programming.dev

As lemmy doesnt have a built in poll system if you want to run a multiple choice poll you can just make each option its own reply and people can vote by upvoting

Community stats

  • 1

    Monthly active users

  • 8

    Posts

  • 61

    Comments

Community moderators