2020-10-16 14:55:18 +03:00
# HLint configuration file
# https://github.com/ndmitchell/hlint
##########################
# This file contains a template configuration file, which is typically
# placed as .hlint.yaml in the root of your project
# Specify additional command line arguments
#
# - arguments: [--color, --cpp-simple, -XQuasiQuotes]
- arguments : -XQuasiQuotes
# Control which extensions/flags/modules/functions can be used
#
# - extensions:
# - default: false # all extension are banned by default
# - name: [PatternGuards, ViewPatterns] # only these listed extensions can be used
# - {name: CPP, within: CrossPlatform} # CPP can only be used in a given module
#
# - flags:
# - {name: -w, within: []} # -w is allowed nowhere
#
# - modules:
# - {name: [Data.Set, Data.HashSet], as: Set} # if you import Data.Set qualified, it must be as 'Set'
# - {name: Control.Arrow, within: []} # Certain modules are banned entirely
#
# - functions:
# - {name: unsafePerformIO, within: []} # unsafePerformIO can only appear in no modules
2022-06-08 19:35:44 +03:00
- functions :
- name : "Test.Hspec.focus"
within : [ ]
message : "Specs with focusing should only be used during development"
- name : "Test.Hspec.fit"
within : [ ]
message : "Specs with focusing should only be used during development"
- name : "Test.Hspec.fspecify"
within : [ ]
message : "Specs with focusing should only be used during development"
- name : "Test.Hspec.fdescribe"
within : [ ]
message : "Specs with focusing should only be used during development"
- name : "Test.Hspec.fcontext"
within : [ ]
message : "Specs with focusing should only be used during development"
2020-10-16 14:55:18 +03:00
# Add custom hints for this project
#
# Will suggest replacing "wibbleMany [myvar]" with "wibbleOne myvar"
# - error: {lhs: "wibbleMany [x]", rhs: wibbleOne x}
# Turn on hints that are off by default
#
# Ban "module X(module X) where", to require a real export list
# - warn: {name: Use explicit module export list}
#
# Replace a $ b $ c with a . b $ c
# - group: {name: dollar, enabled: true}
#
# Generalise map to fmap, ++ to <>
# - group: {name: generalise, enabled: true}
# Ignore some builtin hints
# - ignore: {name: Use let}
# - ignore: {name: Use const, within: SpecialModule} # Only within certain modules
- ignore : {name : Reduce duplication}
- ignore : {name : Redundant $}
- ignore : {name : Redundant bracket}
- ignore : {name : Use fmap}
- ignore : {name : Use first}
- ignore : {name : Use if}
- ignore : {name : Redundant <$>}
- ignore : {name : Use ++}
- ignore : {name : Use const}
- ignore : {name : Eta reduce}
- ignore : {name : Redundant multi-way if}
- ignore : {name : Use newtype instead of data}
- ignore : {name : Use bimap}
2022-06-21 14:11:08 +03:00
- ignore : {name : Use fromRight}
2020-10-16 14:55:18 +03:00
- ignore : {name : Use $>}
2022-03-19 03:30:01 +03:00
- ignore : {name : Use <$>}
2020-10-16 14:55:18 +03:00
- ignore : {name : "Use ?~" }
- ignore : {name : Use <=<}
- ignore : {name : Use sequenceA}
- ignore : {name : Use camelCase}
- ignore : {name : Redundant return}
2021-02-23 20:37:27 +03:00
- ignore : {name: Use <$>, within : [ Hasura.RQL.DDL.Metadata, Hasura.Backends.MSSQL.Types.Instances]}
2020-10-28 19:40:33 +03:00
- ignore : {name: Functor law, within : Hasura.Server.AuthSpec}
2022-04-01 18:41:07 +03:00
- ignore : {name : Use underscore} # suggests to format port numbers
2022-06-26 01:08:01 +03:00
# These three need to be disabled under 'simplified subsumption' unfortunately.
# If we want to use -XDeepSubsumption these can be reenabled and lints fixed
# See: https://github.com/mpickering/ghc-proposals/blob/deep-subsumption/proposals/0000-deep-subsumption.rst
- ignore : {name : Avoid lambda}
- ignore : {name : Redundant lambda}
- ignore : {name : Avoid lambda using `infix`}
2020-10-16 14:55:18 +03:00
# Define some custom infix operators
# - fixity: infixr 3 ~^#^~
# To generate a suitable file for HLint do:
# $ hlint --default > .hlint.yaml
2020-10-28 19:40:33 +03:00
- group :
name : hasura-prelude
enabled : true
imports :
- package base
rules :
2022-07-01 13:49:31 +03:00
- error : {lhs : "a == []" , rhs : "null a" }
- error : {lhs : "a /= []" , rhs : "not (null a)" }
- error : {lhs : "maybe b return a" , rhs : "onNothing a b" }
- error : {lhs : "maybe b pure a" , rhs : "onNothing a b" }
- error : {lhs : "maybe (return ()) b a" , rhs : "onJust a b" }
- error : {lhs : "maybe (pure ()) b a" , rhs : "onJust a b" }
- error : {lhs : "either b return a" , rhs : "onLeft a b" }
- error : {lhs : "either b pure a" , rhs : "onLeft a b" }
- error : {lhs : "maybe (f x) f" , rhs : "f . fromMaybe x" }
- error : {lhs : "maybe (f x) f" , rhs : "f . fromMaybe x" }
- error : {lhs : "either (f . g) (f . h)" , rhs : "f . either g h" }
- error : {lhs : "either (f . g) (f . h)" , rhs : "f . either g h" }
- error : {lhs : "onNothing x (return y)" , rhs : "return (fromMaybe y x)" }
- error : {lhs : "onNothing x (pure y)" , rhs : "pure (fromMaybe y x)" }
- error : {lhs : "onLeft x (return . f)" , rhs : "return (either f id x)" }
- error : {lhs : "onLeft x (pure . f)" , rhs : "pure (either f id x)" }
- error : {lhs : "case x of {Right a -> pure a; Left c -> d}" , rhs : "onLeft x (\\ c -> d)" }
- error : {lhs : "case x of {Left c -> d; Right a -> pure a}" , rhs : "onLeft x (\\ c -> d)" }
- error : {lhs : "case x of {Right a -> return a; Left c -> d}" , rhs : "onLeft x (\\ c -> d)" }
- error : {lhs : "case x of {Left c -> d; Right a -> return a}" , rhs : "onLeft x (\\ c -> d)" }
- error : {lhs : "case x of {Nothing -> a; Just b -> pure b}" , rhs : "onNothing x a" }
- error : {lhs : "case x of {Just b -> pure b; Nothing -> a}" , rhs : "onNothing x a" }
- error : {lhs : "case x of {Nothing -> a; Just b -> return b}" , rhs : "onNothing x a" }
- error : {lhs : "case x of {Just b -> return b; Nothing -> a}" , rhs : "onNothing x a" }
- error : {lhs : "if x then pure (); else y" , rhs : "unless x y" }
- error : {lhs : "if x then return (); else y" , rhs : "unless x y" }
- error : {lhs : "if x then y; else pure ()" , rhs : "when x y" }
- error : {lhs : "if x then y; else return ()" , rhs : "when x y" }
- error : {lhs : "unless (not x)" , rhs : "when x" }
- error : {lhs : "when (not x)" , rhs : "unless x" }
2022-05-27 16:33:38 +03:00
- suggest : {lhs : "not x && not y" , rhs : "not (x || y)" }
- suggest : {lhs : "not x || not y" , rhs : "not (x && y)" }
2022-07-01 13:49:31 +03:00
- error : {lhs : "Data.Text.pack (Prelude.show x)" , rhs : "Hasura.Prelude.tshow x" }
- error : {lhs : "map f xs == map f ys" , rhs : "liftEq ((==) `on` f)" , note : "This is liable to be faster" }
2022-02-24 21:55:23 +03:00
- suggest : {lhs : "fmap f xs == fmap f ys" , rhs : "liftEq ((==) `on` f)" , note : "This is liable to be faster" }
2020-12-20 09:52:43 +03:00
# mapKeys:
2022-07-01 13:49:31 +03:00
- error : {lhs : "Data.HashMap.Strict.Extended.fromList . map (first f) . Data.HashMap.Strict.Extended.toList" , rhs : "mapKeys f" }
- error : {lhs : "Data.HashMap.Strict.fromList . map (first f) . Data.HashMap.Strict.toList" , rhs : "mapKeys f" }
- error : {lhs : "Data.HashMap.Strict.Extended.fromList $ map (first f) $ Data.HashMap.Strict.Extended.toList x" , rhs : "mapKeys f x" }
- error : {lhs : "Data.HashMap.Strict.fromList $ map (first f) $ Data.HashMap.Strict.toList x" , rhs : "mapKeys f x" }
2021-01-19 16:37:43 +03:00
# MaybeT
2022-07-01 13:49:31 +03:00
- error : {lhs : "MaybeT (pure x)" , rhs : "hoistMaybe x" }
- error : {lhs : "MaybeT (return x)" , rhs : "hoistMaybe x" }
- error : {lhs : "MaybeT (pure Nothing)" , rhs : "Control.Applicative.empty" }
- error : {lhs : "MaybeT (return Nothing)" , rhs : "Control.Applicative.empty" }
2022-03-03 23:12:09 +03:00
# catMaybes
2022-07-01 13:49:31 +03:00
- error : {lhs : "Data.HashMap.Strict.mapMaybe id" , rhs : "Data.HashMap.Strict.Extended.catMaybes" }
- error : {lhs : "Data.HashMap.Strict.Extended.mapMaybe id" , rhs : "Data.HashMap.Strict.Extended.catMaybes" }
- error : {lhs : "Data.HashMap.Strict.InsOrd.mapMaybe id" , rhs : "Data.HashMap.Strict.InsOrd.Extended.catMaybes" }
- error : {lhs : "Data.HashMap.Strict.InsOrd.Extended.mapMaybe id" , rhs : "Data.HashMap.Strict.InsOrd.Extended.catMaybes" }
- error : {lhs : "Data.IntMap.Strict.mapMaybe id" , rhs : "Data.HashMap.Strict.Extended.catMaybes" }
- error : {lhs : "Data.IntMap.Strict.Extended.mapMaybe id" , rhs : "Data.HashMap.Strict.Extended.catMaybes" }
2020-10-28 19:40:33 +03:00
- group :
name : data-text-extended
enabled : true
imports :
- package base
rules :
2022-07-01 13:49:31 +03:00
- error : {lhs : "Data.Text.intercalate \", \" x" , rhs : "commaSeparated x" , note : "From Data.Text.Extended" }
- error : {lhs : "Data.Text.Extended.intercalate \", \" x" , rhs : "commaSeparated x" }
2022-01-19 08:25:54 +03:00
- group :
name : mssql-transaction
enabled : true
imports :
- package base
rules :
2022-07-01 13:49:31 +03:00
- error : {lhs : "Database.MSSQL.runTxE id tx pool" , rhs : "Database.MSSQL.runTx tx pool" }
- error : {lhs : "Database.MSSQL.unitQueryE id q" , rhs : "Database.MSSQL.unitQuery q" }
- error : {lhs : "Database.MSSQL.singleRowQueryE id tx pool" , rhs : "Database.MSSQL.singleRowQuery tx pool" }
- error : {lhs : "Database.MSSQL.multiRowQueryE id tx pool" , rhs : "Database.MSSQL.multiRowQuery tx pool" }
2022-01-27 18:12:38 +03:00
- group :
name : unsafe
enabled : true
imports :
- package base
rules :
2022-07-18 20:01:05 +03:00
- error : {lhs : "Language.GraphQL.Draft.Syntax.unsafeMkName" , rhs : "Language.GraphQL.Draft.Syntax.mkName" , note : "avoid unsafeMkName if possible" }
2022-06-30 12:55:06 +03:00
- error : {lhs : "Control.Concurrent.threadDelay" , rhs : "Control.Concurrent.Extended.sleep" , note : "Please use `sleep` instead (and read the docs!)" }
- suggest : {lhs : "Control.Concurrent.Async.Lifted.Safe.async" , rhs : "Control.Concurrent.Async.Lifted.Safe.withAsync" , note : "Please use 'Control.Control.Concurrent.Async.Lifted.Safe.withAsync' or our 'forkImmortal' instead for more robust threading." }
- suggest : {lhs : "Control.Concurrent.forkIO" , rhs : "Control.Concurrent.Async.Lifted.Safe.withAsync" , note : "Please use 'Control.Control.Concurrent.Async.Lifted.Safe.withAsync' or our 'forkImmortal' instead for more robust threading." }