From bae0306fc1368d460886d76df3b6c32ffe3332f5 Mon Sep 17 00:00:00 2001 From: Chris Martin Date: Mon, 26 Feb 2024 12:18:28 -0700 Subject: [PATCH] Do not prefix record field names (#89) --- haskell-best-practices.md | 27 +++++++++++++++++++++++++++ haskell-style.md | 3 +++ 2 files changed, 30 insertions(+) diff --git a/haskell-best-practices.md b/haskell-best-practices.md index ab4ef15..2988a52 100644 --- a/haskell-best-practices.md +++ b/haskell-best-practices.md @@ -109,6 +109,33 @@ been maintained for that as things have evolved. - [What I Wish I Knew When Learning Haskell](http://dev.stephendiehl.com/hask/) - [Haskell For Web Developers](http://www.stephendiehl.com/posts/haskell_web.html) +## Do not prefix record fields + +There was once a time when record field names needed to be unique, and so it was +conventional to prefix them with a constructor name: + +```haskell +data StudentAssignmentReport = + StudentAssignmentReport + { studentAssignmentReportId :: UUID + , studentAssignmentReportGrade :: Percentage + , studentAssignmentReportTitle :: Text + } +``` + +Thanks to `NoFieldSelectors`, `DuplicateRecordFields`, and `OverloadedRecordDot`, +it does not matter whether a record field has the same name as anything else, and +so the prefixed field style is no longer useful. Such names should be shortened: + +```haskell +data StudentAssignmentReport = + StudentAssignmentReport + { id :: UUID + , grade :: Percentage + , title :: Text + } +``` + ## Existentials Why / when you want to use them: diff --git a/haskell-style.md b/haskell-style.md index 16957d5..2bc37b0 100644 --- a/haskell-style.md +++ b/haskell-style.md @@ -244,11 +244,14 @@ Sort your exports, unless the order matters in your desired Haddock output. - DeriveAnyClass - DerivingStrategies - DerivingVia + - DuplicateRecordFields - GADTs - LambdaCase + - NoFieldSelectors - NoImplicitPrelude - NoMonomorphismRestriction - NoPostfixOperators + - OverloadedRecordDot - OverloadedStrings - QuasiQuotes - TypeFamilies