DEV Community

Cover image for The Case for Comma-Leading Lists
Lewis Lloyd
Lewis Lloyd

Posted on

The Case for Comma-Leading Lists

Introduction

Comma-leading lists are an objectively better presentation style.

They make logical sense; the next value on the list is dependant on the comma, and so, they should be kept together.

The style may look alien at first, but give it a test drive and you'll be surprised at how quickly it starts to look normal.

For now, let's have a look at the benefits.


Justification

1. No Merge Conflicts

When adding a new value to a list with trailing commas, you're making 2 additions and 1 deletion.

Comma-Trailing List Diff

This will give you a merge conflict just because someone else adds a value on a different branch.

By using the comma-leading style, you make 1 addition and 0 deletions.

Comma-Leading List Diff

These commits play ball with each other, without needing any conflict resolution.

"Ah, but I've used a dangling comma," you say? Allow me to continue.

2. Dangling Commas Bad

It's true that using a trailing comma after the final value will prevent conflicts, but it's dumb for two reasons.

1. Language Inconsistency

SQL doesn't support them.

Comma-Leading JSON

The JSON standard and Pre-ES5 JavaScript don't support them.

Comma-Leading JSON

It's better to stick to a style that works across more languages, especially for a multi-lingual codebase.

2. Redundant Logic

There's not a second element. It's unnecessary context, so why justify it?

And, if an interpreter ever decides to stick a None in there, good luck.

3. Better Presentation

Separating Context

With the comma-leading style, the logic stays on the left, and the data stays on the right.

This makes it quicker and easier to scan when looking through code.

Better Presentation

It will also allow you to quickly identify logic errors, such as missing commas.

Leaking Globals

Saving Whitespace

When you indent after the opening bracket, you're adding extra columns of whitespace on the left-hand side.

Placing the commas on the left keeps the code neat and narrow. Neat!


Summary

Comma-leading lists are easier for source control, more compatible across languages, and much faster to read since they keep data separate from the list's logic.

Do the world a favour and switch to a better standard of data structure.

animals = [ "ant"
          , "bat"
          , "cat"
          , "dog"
          ]
Enter fullscreen mode Exit fullscreen mode

What's not to love? πŸ˜‰


Hey, guys! Thank you for reading. I hope that you enjoyed this.

Keep up to date with me:

Catch you around!

Latest comments (24)

Collapse
 
appomsk profile image
Andrey

Write a shopping list in this style and give it to someone more ordinary than Haskell programmers... You will be surprised.

It's just disgusting.

Collapse
 
tdotholla profile image
Kiel

no way to get this in an eslint/prettier config to apply automatically?

Collapse
 
jwwwwwww profile image
jwwwwwww

No way the code look awful

Collapse
 
guneyozsan profile image
Guney Ozsan

I wonder the probability of encountering such a merge conflict versus the amount of code you will write (and read) in a not-so-human-readable way. The complexity introduced doesn't justify its use case.

Collapse
 
johnnycricket profile image
John Vorwald

I hadn't encountered comma first until recently in some old code. Drove me crazy and I couldn't figure out why someone would do that. This explanation makes a lot of sense.

Collapse
 
youpiwaza profile image
max

Thought it was a creepy trolls, but it's arguably logic.

Nice one, I'll go into it

Collapse
 
moopet profile image
Ben Sinclair

I understand why people are looking at leading commas, but they're a hack to get things to work better with VCS. And you know what? That shouldn't impact how you use the language.

Collapse
 
adam_cyclones profile image
Adam Crockett πŸŒ€

Indeed, just resolve the conflict and move on.

Collapse
 
djsullenbarger profile image
David Sullenbarger • Edited

I write SQL this way - in a SQL editor (like SQL Tools) and in my code (mostly Visual Studio). You can comment out individual items from your select and not break anything if you structure it right.

I didn't read the post so if that's what he said then I completely agree :-)

Collapse
 
dzefo profile image
Dzefo

I refuse to do this. Even though I really should

Collapse
 
adam_cyclones profile image
Adam Crockett πŸŒ€

I read it, I saw maybe a thin benefit. But I just can't do it. It make me want to cry.