haskell-symbol-search-cheatsheet
haskell-symbol-search-cheatsheet copied to clipboard
Haskell/GHC symbol search cheatsheet

Haskell/GHC symbol search cheatsheet
Several features of Haskell/GHC have low googleability.
Because some of them are composed of symbols :)
This page is a reference collection to support search of them.
If you want to search for function symbols like ., $, >>=, <*>, ..., you can use the following search engines:
Happy Haskelling!
! : "strictness flag"
[ Haskell 2010 Language Report ]
data Vec = Vec !Int
! : "bang pattern"
[ GHC User's Guide ]
f1 !x =
# : "MagicHash"
[ GHC User's Guide ]
data Int = I# Int#
# : "OverloadedLabels"
[ GHC User's Guide ]
example = #x (Point 1 2)
# : C pre-processor's directive
[ GHC User's Guide ]
#include "MachDeps.h"
# : hsc2hs command's operator
[ GHC User's Guide ]
flag = #const VER_MAJORVERSION
$( ) : Template Haskell’s splice syntax
[ GHC User's Guide ]
two = $(add1 1)
$$( ) : Typed Template Haskell’s splice syntax
[ GHC User's Guide ]
two = $$(add1 1)
%1 -> : "Linear types"
[ GHC User's Guide ]
f :: a %1 -> a
' : an identifier consists of a letter followed by zero or more letters, digits, underscores, and single quotes
[ Haskell 2010 Language Report ]
xs' = f ys
' : promoted constructors are prefixed by a tick '
[ GHC User's Guide ]
type * = TYPE 'LiftedRep
' '' : Template Haskell’s quotation syntax
[ GHC User's Guide ]
makeLenses ''FooBar
() : "unit type"
[ Haskell 2010 Language Report ] [ Haskell 2010 Language Report ]
main :: IO ()
() : "unit expression"
[ Haskell 2010 Language Report ] [ Haskell 2010 Language Report ]
return ()
( ) : "section" - a convenient syntax for partial application
[ Haskell 2010 Language Report ]
add1 = (1+)
(,) : the constructor for a tuple
[ Haskell 2010 Language Report ]
f x y = liftM2 (,) x y
(, xxx) : "TupleSections"
[ GHC User's Guide ]
f xs = fmap (, True) xs
(# #) : "unboxed tuple"
[ GHC User's Guide ]
f x y = (# x+1, y-1 #)
(# | | #) : "unboxed sum"
[ GHC User's Guide ]
f :: (# Int | Bool | Char #) -> Int
f (# x | | #) = 1
f (# | True | #) = 2
f _ = 3
(..) : export all of its names
[ Haskell 2010 Language Report ]
module GHC.Arr (
Ix(..),
(..) : import all of its names
[ Haskell 2010 Language Report ]
import GHC.Types (Bool(..))
* : the kind of ordinary types (synonym for Type and TYPE `LiftedRep)
[ Haskell 2010 Language Report ] [ GHC User's Guide ] [ GHC User's Guide ]
ghci> :kind Int
Int :: *
-> : case expression
[ Haskell 2010 Language Report ]
f x = case x of
Nothing -> False
Just _ -> True
-> : "view pattern"
[ GHC User's Guide ]
size (view -> Unit) = 1
size (view -> Arrow t1 t2) = size t1 + size t2
-> : "function type"
[ Haskell 2010 Language Report ]
id :: a -> a
. : module names are a dot-separated sequence
[ Haskell 2010 Language Report ]
import Data.Maybe
import qualified Text.Read.Lex as L
lexP = lift L.lex
. : "OverloadedRecordDot"
[ GHC User's Guide ]
getResult c = c.result
getResults = map (.result)
. : "OverloadedRecordUpdate" (experimental)
[ GHC User's Guide ]
setYearTaken c y = c{taken.year = y}
. : universal quantification
[ GHC User's Guide ]
f :: forall a. a -> [a]
: : "list constructor" (cons)
[ Haskell 2010 Language Report ] [ Haskell 2010 Language Report ] [ Haskell 2010 Language Report ]
f x xs = x:xs
: : an operator symbol starting with a colon is a constructor
[ Haskell 2010 Language Report ]
data NonEmpty a = a :| [a]
:: : "type signature"
[ Haskell 2010 Language Report ]
id :: a -> a
id x = x
:: : "expression type-signature" (type annotation)
[ Haskell 2010 Language Report ]
x = fromIntegral (maxBound::Int)
; : semicolon in layout rule
[ Haskell 2010 Language Report ]
f x = let a = 1; b = 2
g y = exp2
in exp1
<- : lambda-bound in do expression
[ Haskell 2010 Language Report ]
f = do
x <- getLine
putStrLn x
<- : "pattern guard"
[ Haskell 2010 Language Report ]
f x
| Just y <- g x =
=> : context (type class constraint)
[ Haskell 2010 Language Report ]
subtract :: (Num a) => a -> a -> a
subtract x y = y - x
? : "ImplicitParams"
[ GHC User's Guide ]
sort :: (?cmp :: a -> a -> Bool) => [a] -> [a]
sort = sortBy ?cmp
@ : "as pattern"
[ Haskell 2010 Language Report ]
f s@(x:xs) =
@ : "type application"
[ GHC User's Guide ]
f = read @Int
[] : "empty list" (nil)
[ Haskell 2010 Language Report ] [ Haskell 2010 Language Report ]
null [] = True
null _ = False
[ .. ] : "arithmetic sequence"
[ Haskell 2010 Language Report ]
xs = [1..10]
[ | <- ] : "list comprehension"
[ Haskell 2010 Language Report ]
xs = [x^2 | x <- [1..10]]
[| |], [e| |], [d| |], [t| |], [p| |] : Template Haskell’s quotation syntax (expression, declaration, type, and pattern)
[ GHC User's Guide ]
add1 x = [| x + 1 |]
[varid| |] : Template Haskell’s quasi-quotation syntax
[ GHC User's Guide ]
greet name = [interpolate| Hello, #name! |]
[|| ||] : Typed Template Haskell’s quotation syntax
[ GHC User's Guide ]
add1 x = [|| x + 1 ||]
_ : "wildcard pattern"
[ Haskell 2010 Language Report ]
f Red =
f Blue =
f _ =
_ : unused identifiers beginning with underscore
[ GHC User's Guide ] [ Haskell 2010 Language Report ]
_w = True -- No warning: _w starts with an underscore
_ : "typed hole" (expression level)
[ GHC User's Guide ]
sum xs = foldr _ 0 xs
_ : "type wildcard" (type level)
[ GHC User's Guide ]
not' :: Bool -> _
not' x = not x
_ : "extra-constraints wildcard"
[ GHC User's Guide ]
arbitCs :: _ => a -> String
_ : "NumericUnderscores"
[ GHC User's Guide ]
million = 1_000_000
\ -> : "lambda abstraction"
[ Haskell 2010 Language Report ]
add1 = \x -> x + 1
\case -> : "LambdaCase"
[ GHC User's Guide ]
f = \case
Red -> 2
Blue -> 1
_ -> 0
` ` : "infix notation" - an identifier enclosed in grave accents
[ Haskell 2010 Language Report ]
div10 x = x `div` 10
{ } : brace in layout rule
[ Haskell 2010 Language Report ]
f x = case x of {Nothing -> False; Just _ -> True}
{ } : "record syntax" (datatypes with field labels)
[ Haskell 2010 Language Report ]
data MyPoint = Point { x :: Int, y :: Int }
{..} : "record wildcard"
[ GHC User's Guide ]
f Vec{..} =
{-# #-} : "compiler pragma"
[ Haskell 2010 Language Report ] [ GHC User's Guide ] [ GHC User's Guide ]
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE GADTs #-}
{-# INLINE fmap #-}
| : "boolean guard" (guard)
[ Haskell 2010 Language Report ]
clip255 x
| x > 255 = 255
| otherwise = x
| : "MultiWayIf"
[ GHC User's Guide ]
if | x == ":q" -> quit
| isError x -> errorExit x
| otherwise -> execCommand x
| : algebraic datatype declaration
[ Haskell 2010 Language Report ]
data Maybe a = Nothing | Just a
| : "functional dependency"
[ GHC User's Guide ]
class Foo a b c | a b -> c where
~ : "irrefutable pattern"
[ Haskell 2010 Language Report ]
f1 ~(as,bs) =
~ : lazy pattern when Strict is enabled
[ GHC User's Guide ]
{-# LANGUAGE Strict #-}
f ~x =
~ : laziness flag
[ GHC User's Guide ]
data T = C ~a
~ : "equality constraint"
[ GHC User's Guide ]
class (F a ~ b) => C a b where