Add a few more hardcoded fixities
parent
a90550f62d
commit
5ee0733f96
|
@ -193,143 +193,143 @@ remSuperfluousParens outerFixity = \case
|
||||||
|
|
||||||
hardcodedFixity :: Bool -> String -> Maybe Fixity
|
hardcodedFixity :: Bool -> String -> Maybe Fixity
|
||||||
hardcodedFixity allowUnqualify = \case
|
hardcodedFixity allowUnqualify = \case
|
||||||
"." -> Just $ Fixity NoSourceText 9 InfixR
|
"." -> Just $ Fixity NoSourceText 9 InfixR
|
||||||
"!!" -> Just $ Fixity NoSourceText 9 InfixL
|
"!!" -> Just $ Fixity NoSourceText 9 InfixL
|
||||||
"**" -> Just $ Fixity NoSourceText 8 InfixR
|
"**" -> Just $ Fixity NoSourceText 8 InfixR
|
||||||
"^" -> Just $ Fixity NoSourceText 8 InfixR
|
"^" -> Just $ Fixity NoSourceText 8 InfixR
|
||||||
"^^" -> Just $ Fixity NoSourceText 8 InfixR
|
"^^" -> Just $ Fixity NoSourceText 8 InfixR
|
||||||
"*" -> Just $ Fixity NoSourceText 7 InfixL
|
"*" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"/" -> Just $ Fixity NoSourceText 7 InfixL
|
"/" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"`quot`" -> Just $ Fixity NoSourceText 7 InfixL
|
"`quot`" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"`rem`" -> Just $ Fixity NoSourceText 7 InfixL
|
"`rem`" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"`div`" -> Just $ Fixity NoSourceText 7 InfixL
|
"`div`" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"`mod`" -> Just $ Fixity NoSourceText 7 InfixL
|
"`mod`" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"+" -> Just $ Fixity NoSourceText 6 InfixL
|
"+" -> Just $ Fixity NoSourceText 6 InfixL
|
||||||
"-" -> Just $ Fixity NoSourceText 6 InfixL
|
"-" -> Just $ Fixity NoSourceText 6 InfixL
|
||||||
":" -> Just $ Fixity NoSourceText 5 InfixR
|
":" -> Just $ Fixity NoSourceText 5 InfixR
|
||||||
"==" -> Just $ Fixity NoSourceText 4 InfixN
|
"==" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
"/=" -> Just $ Fixity NoSourceText 4 InfixN
|
"/=" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
"<" -> Just $ Fixity NoSourceText 4 InfixN
|
"<" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
"<=" -> Just $ Fixity NoSourceText 4 InfixN
|
"<=" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
">" -> Just $ Fixity NoSourceText 4 InfixN
|
">" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
">=" -> Just $ Fixity NoSourceText 4 InfixN
|
">=" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
"&&" -> Just $ Fixity NoSourceText 3 InfixR
|
"&&" -> Just $ Fixity NoSourceText 3 InfixR
|
||||||
"||" -> Just $ Fixity NoSourceText 2 InfixR
|
"||" -> Just $ Fixity NoSourceText 2 InfixR
|
||||||
">>=" -> Just $ Fixity NoSourceText 1 InfixL
|
">>=" -> Just $ Fixity NoSourceText 1 InfixL
|
||||||
">>" -> Just $ Fixity NoSourceText 1 InfixL
|
">>" -> Just $ Fixity NoSourceText 1 InfixL
|
||||||
"=<<" -> Just $ Fixity NoSourceText 1 InfixR
|
"=<<" -> Just $ Fixity NoSourceText 1 InfixR
|
||||||
"$" -> Just $ Fixity NoSourceText 0 InfixR
|
"$" -> Just $ Fixity NoSourceText 0 InfixR
|
||||||
"`seq`" -> Just $ Fixity NoSourceText 0 InfixR
|
"`seq`" -> Just $ Fixity NoSourceText 0 InfixR
|
||||||
"$!" -> Just $ Fixity NoSourceText 0 InfixR
|
"$!" -> Just $ Fixity NoSourceText 0 InfixR
|
||||||
"!" -> Just $ Fixity NoSourceText 9 InfixL
|
"!" -> Just $ Fixity NoSourceText 9 InfixL
|
||||||
"//" -> Just $ Fixity NoSourceText 9 InfixL
|
"//" -> Just $ Fixity NoSourceText 9 InfixL
|
||||||
"<>" -> Just $ Fixity NoSourceText 6 InfixR
|
"<>" -> Just $ Fixity NoSourceText 6 InfixR
|
||||||
"<+>" -> Just $ Fixity NoSourceText 5 InfixR
|
"<+>" -> Just $ Fixity NoSourceText 5 InfixR
|
||||||
"<$" -> Just $ Fixity NoSourceText 4 InfixL
|
"<$" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"$>" -> Just $ Fixity NoSourceText 4 InfixL
|
"$>" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"<$>" -> Just $ Fixity NoSourceText 4 InfixL
|
"<$>" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"<&>" -> Just $ Fixity NoSourceText 1 InfixL
|
"<&>" -> Just $ Fixity NoSourceText 1 InfixL
|
||||||
"&" -> Just $ Fixity NoSourceText 1 InfixL
|
"&" -> Just $ Fixity NoSourceText 1 InfixL
|
||||||
"<*>" -> Just $ Fixity NoSourceText 4 InfixL
|
"<*>" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"<**>" -> Just $ Fixity NoSourceText 4 InfixL
|
"<**>" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"*>" -> Just $ Fixity NoSourceText 4 InfixL
|
"*>" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"<*" -> Just $ Fixity NoSourceText 4 InfixL
|
"<*" -> Just $ Fixity NoSourceText 4 InfixL
|
||||||
"`elem`" -> Just $ Fixity NoSourceText 4 InfixN
|
"`elem`" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
"`notElem`" -> Just $ Fixity NoSourceText 4 InfixN
|
"`notElem`" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
"++" -> Just $ Fixity NoSourceText 5 InfixR
|
"++" -> Just $ Fixity NoSourceText 5 InfixR
|
||||||
"%" -> Just $ Fixity NoSourceText 7 InfixL
|
"%" -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
"<|>" -> Just $ Fixity NoSourceText 3 InfixL
|
"<|>" -> Just $ Fixity NoSourceText 3 InfixL
|
||||||
".&." -> Just $ Fixity NoSourceText 7 InfixL
|
".&." -> Just $ Fixity NoSourceText 7 InfixL
|
||||||
".|." -> Just $ Fixity NoSourceText 5 InfixL
|
".|." -> Just $ Fixity NoSourceText 5 InfixL
|
||||||
"`xor`" -> Just $ Fixity NoSourceText 6 InfixL
|
"`xor`" -> Just $ Fixity NoSourceText 6 InfixL
|
||||||
"`shift`" -> Just $ Fixity NoSourceText 8 InfixL
|
"`shift`" -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"`rotate`" -> Just $ Fixity NoSourceText 8 InfixL
|
"`rotate`" -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"`shiftL`" -> Just $ Fixity NoSourceText 8 InfixL
|
"`shiftL`" -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"`shiftR`" -> Just $ Fixity NoSourceText 8 InfixL
|
"`shiftR`" -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"`rotateL`" -> Just $ Fixity NoSourceText 8 InfixL
|
"`rotateL`" -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"`rotateR`" -> Just $ Fixity NoSourceText 8 InfixL
|
"`rotateR`" -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"+#" -> Just $ Fixity NoSourceText 6 InfixL
|
"+#" -> Just $ Fixity NoSourceText 6 InfixL
|
||||||
".^." -> Just $ Fixity NoSourceText 6 InfixL
|
".^." -> Just $ Fixity NoSourceText 6 InfixL
|
||||||
".>>." -> Just $ Fixity NoSourceText 8 InfixL
|
".>>." -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
".<<." -> Just $ Fixity NoSourceText 8 InfixL
|
".<<." -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"!>>." -> Just $ Fixity NoSourceText 8 InfixL
|
"!>>." -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
"!<<." -> Just $ Fixity NoSourceText 8 InfixL
|
"!<<." -> Just $ Fixity NoSourceText 8 InfixL
|
||||||
">=>" -> Just $ Fixity NoSourceText 1 InfixR
|
">=>" -> Just $ Fixity NoSourceText 1 InfixR
|
||||||
"<=<" -> Just $ Fixity NoSourceText 1 InfixR
|
"<=<" -> Just $ Fixity NoSourceText 1 InfixR
|
||||||
"&&&" -> Just $ Fixity NoSourceText 3 InfixR
|
"&&&" -> Just $ Fixity NoSourceText 3 InfixR
|
||||||
"<$!>" -> fixity InfixL 4
|
"<$!>" -> fixity InfixL 4
|
||||||
|
|
||||||
"~" -> fixity InfixN 4
|
"~" -> fixity InfixN 4
|
||||||
"~~" -> fixity InfixN 4
|
"~~" -> fixity InfixN 4
|
||||||
":~:" -> Just $ Fixity NoSourceText 4 InfixN
|
":~:" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
":~~:" -> Just $ Fixity NoSourceText 4 InfixN
|
":~~:" -> Just $ Fixity NoSourceText 4 InfixN
|
||||||
":+:" -> fixity InfixR 5
|
":+:" -> fixity InfixR 5
|
||||||
":*:" -> fixity InfixR 6
|
":*:" -> fixity InfixR 6
|
||||||
":.:" -> fixity InfixR 7
|
":.:" -> fixity InfixR 7
|
||||||
":|" -> fixity InfixR 5
|
":|" -> fixity InfixR 5
|
||||||
|
|
||||||
-- non-base from random sources.
|
-- non-base from random sources.
|
||||||
"<|" -> Just $ Fixity NoSourceText 5 InfixR
|
"<|" -> Just $ Fixity NoSourceText 5 InfixR
|
||||||
"|>" -> Just $ Fixity NoSourceText 5 InfixL
|
"|>" -> Just $ Fixity NoSourceText 5 InfixL
|
||||||
"><" -> Just $ Fixity NoSourceText 5 InfixR
|
"><" -> Just $ Fixity NoSourceText 5 InfixR
|
||||||
"$+$" -> Just $ Fixity NoSourceText 5 InfixL
|
"$+$" -> Just $ Fixity NoSourceText 5 InfixL
|
||||||
"\\\\" -> Just $ Fixity NoSourceText 5 InfixN
|
"\\\\" -> Just $ Fixity NoSourceText 5 InfixN
|
||||||
".>" -> Just $ Fixity NoSourceText 9 InfixL
|
".>" -> Just $ Fixity NoSourceText 9 InfixL
|
||||||
":?" -> Just $ Fixity NoSourceText 7 InfixN
|
":?" -> Just $ Fixity NoSourceText 7 InfixN
|
||||||
":-" -> Just $ Fixity NoSourceText 9 InfixR
|
":-" -> Just $ Fixity NoSourceText 9 InfixR
|
||||||
".:" -> Just $ Fixity NoSourceText 9 InfixR
|
".:" -> Just $ Fixity NoSourceText 9 InfixR
|
||||||
"$!!" -> fixity InfixR 0
|
"$!!" -> fixity InfixR 0
|
||||||
"<$!!>" -> fixity InfixL 4
|
"<$!!>" -> fixity InfixL 4
|
||||||
|
|
||||||
-- lens, not complete!
|
-- lens, not complete!
|
||||||
"<|" -> fixity InfixR 5
|
"<|" -> fixity InfixR 5
|
||||||
"|>" -> fixity InfixL 5
|
"|>" -> fixity InfixL 5
|
||||||
"%~" -> fixity InfixR 4
|
"%~" -> fixity InfixR 4
|
||||||
".~" -> fixity InfixR 4
|
".~" -> fixity InfixR 4
|
||||||
"?~" -> fixity InfixR 4
|
"?~" -> fixity InfixR 4
|
||||||
"<.~" -> fixity InfixR 4
|
"<.~" -> fixity InfixR 4
|
||||||
"<?~" -> fixity InfixR 4
|
"<?~" -> fixity InfixR 4
|
||||||
"+~" -> fixity InfixR 4
|
"+~" -> fixity InfixR 4
|
||||||
"*~" -> fixity InfixR 4
|
"*~" -> fixity InfixR 4
|
||||||
"-~" -> fixity InfixR 4
|
"-~" -> fixity InfixR 4
|
||||||
"//~" -> fixity InfixR 4
|
"//~" -> fixity InfixR 4
|
||||||
"^~" -> fixity InfixR 4
|
"^~" -> fixity InfixR 4
|
||||||
"^^~" -> fixity InfixR 4
|
"^^~" -> fixity InfixR 4
|
||||||
"**~" -> fixity InfixR 4
|
"**~" -> fixity InfixR 4
|
||||||
"||~" -> fixity InfixR 4
|
"||~" -> fixity InfixR 4
|
||||||
"&&~" -> fixity InfixR 4
|
"&&~" -> fixity InfixR 4
|
||||||
".=" -> fixity InfixN 4
|
".=" -> fixity InfixN 4
|
||||||
"%=" -> fixity InfixN 4
|
"%=" -> fixity InfixN 4
|
||||||
"?=" -> fixity InfixN 4
|
"?=" -> fixity InfixN 4
|
||||||
"+=" -> fixity InfixN 4
|
"+=" -> fixity InfixN 4
|
||||||
"-=" -> fixity InfixN 4
|
"-=" -> fixity InfixN 4
|
||||||
"*=" -> fixity InfixN 4
|
"*=" -> fixity InfixN 4
|
||||||
"//=" -> fixity InfixN 4
|
"//=" -> fixity InfixN 4
|
||||||
"^=" -> fixity InfixN 4
|
"^=" -> fixity InfixN 4
|
||||||
"^^=" -> fixity InfixN 4
|
"^^=" -> fixity InfixN 4
|
||||||
"**=" -> fixity InfixN 4
|
"**=" -> fixity InfixN 4
|
||||||
"&&=" -> fixity InfixN 4
|
"&&=" -> fixity InfixN 4
|
||||||
"||=" -> fixity InfixN 4
|
"||=" -> fixity InfixN 4
|
||||||
"<~" -> fixity InfixR 2
|
"<~" -> fixity InfixR 2
|
||||||
"<.=" -> fixity InfixN 4
|
"<.=" -> fixity InfixN 4
|
||||||
"<?=" -> fixity InfixN 4
|
"<?=" -> fixity InfixN 4
|
||||||
"<>~" -> fixity InfixR 4
|
"<>~" -> fixity InfixR 4
|
||||||
"<>=" -> fixity InfixN 4
|
"<>=" -> fixity InfixN 4
|
||||||
"^.." -> fixity InfixL 8
|
"^.." -> fixity InfixL 8
|
||||||
"^?" -> fixity InfixL 8
|
"^?" -> fixity InfixL 8
|
||||||
"^?!" -> fixity InfixL 8
|
"^?!" -> fixity InfixL 8
|
||||||
"^@.." -> fixity InfixL 8
|
"^@.." -> fixity InfixL 8
|
||||||
"^@?" -> fixity InfixL 8
|
"^@?" -> fixity InfixL 8
|
||||||
"^@?!" -> fixity InfixL 8
|
"^@?!" -> fixity InfixL 8
|
||||||
"^." -> fixity InfixL 8
|
"^." -> fixity InfixL 8
|
||||||
"^@." -> fixity InfixL 8
|
"^@." -> fixity InfixL 8
|
||||||
"<." -> fixity InfixR 9
|
"<." -> fixity InfixR 9
|
||||||
".>" -> fixity InfixR 9
|
".>" -> fixity InfixR 9
|
||||||
"<.>" -> fixity InfixR 9
|
"<.>" -> fixity InfixR 9
|
||||||
"@@~" -> fixity InfixR 4
|
"@@~" -> fixity InfixR 4
|
||||||
"@@=" -> fixity InfixR 4
|
"@@=" -> fixity InfixR 4
|
||||||
"&~" -> fixity InfixL 1
|
"&~" -> fixity InfixL 1
|
||||||
"??" -> fixity InfixL 1
|
"??" -> fixity InfixL 1
|
||||||
|
|
||||||
|
|
||||||
-- certain other operators
|
-- certain other operators
|
||||||
|
@ -343,50 +343,62 @@ hardcodedFixity allowUnqualify = \case
|
||||||
-- ".*?" -> fixity _ _
|
-- ".*?" -> fixity _ _
|
||||||
-- ".+." -> fixity _ _
|
-- ".+." -> fixity _ _
|
||||||
-- ".-." -> fixity _ _
|
-- ".-." -> fixity _ _
|
||||||
".&." -> fixity InfixR 1
|
".&." -> fixity InfixR 1
|
||||||
".&&." -> fixity InfixR 1
|
".&&." -> fixity InfixR 1
|
||||||
".||." -> fixity InfixR 1
|
".||." -> fixity InfixR 1
|
||||||
"==>" -> fixity InfixR 0
|
"==>" -> fixity InfixR 0
|
||||||
"=/=" -> fixity InfixN 4
|
"=/=" -> fixity InfixN 4
|
||||||
"===" -> fixity InfixN 4
|
"===" -> fixity InfixN 4
|
||||||
".:!" -> fixity InfixL 9
|
".:!" -> fixity InfixL 9
|
||||||
".:?" -> fixity InfixL 9
|
".:?" -> fixity InfixL 9
|
||||||
-- ".:>" -> fixity _ _
|
-- ".:>" -> fixity _ _
|
||||||
-- ".:>?" -> fixity _ _
|
-- ".:>?" -> fixity _ _
|
||||||
"<.>" -> fixity InfixR 7
|
"<.>" -> fixity InfixR 7
|
||||||
"</>" -> fixity InfixR 5
|
"</>" -> fixity InfixR 5
|
||||||
"<?>" -> fixity InfixL 9
|
"<?>" -> fixity InfixL 9
|
||||||
-- "~" -> fixity _ _
|
-- "~" -> fixity _ _
|
||||||
"===" -> fixity InfixN 4
|
"===" -> fixity InfixN 4
|
||||||
"!?" -> fixity InfixL 9
|
"!?" -> fixity InfixL 9
|
||||||
"%==" -> fixity InfixN 3
|
"%==" -> fixity InfixN 3
|
||||||
".*" -> fixity InfixR 8
|
".*" -> fixity InfixR 8
|
||||||
".**" -> fixity InfixR 8
|
".**" -> fixity InfixR 8
|
||||||
".***" -> fixity InfixR 8
|
".***" -> fixity InfixR 8
|
||||||
":?-" -> fixity InfixN 1
|
":?-" -> fixity InfixN 1
|
||||||
"::-" -> fixity InfixN 0
|
"::-" -> fixity InfixN 0
|
||||||
"&!" -> fixity InfixL 1
|
"&!" -> fixity InfixL 1
|
||||||
|
|
||||||
-- quickcheck (-state-machine)
|
-- quickcheck (-state-machine)
|
||||||
":&&" -> fixity InfixL 9
|
":&&" -> fixity InfixL 9
|
||||||
":||" -> fixity InfixL 9
|
":||" -> fixity InfixL 9
|
||||||
":&&:" -> fixity InfixL 9
|
":&&:" -> fixity InfixL 9
|
||||||
":=>" -> fixity InfixL 9
|
":=>" -> fixity InfixL 9
|
||||||
":==" -> fixity InfixL 9
|
":==" -> fixity InfixL 9
|
||||||
":/=" -> fixity InfixL 9
|
":/=" -> fixity InfixL 9
|
||||||
":<" -> fixity InfixL 9
|
":<" -> fixity InfixL 9
|
||||||
":<=" -> fixity InfixL 9
|
":<=" -> fixity InfixL 9
|
||||||
":>" -> fixity InfixL 9
|
":>" -> fixity InfixL 9
|
||||||
":>=" -> fixity InfixL 9
|
":>=" -> fixity InfixL 9
|
||||||
":->" -> fixity InfixL 9
|
":->" -> fixity InfixL 9
|
||||||
|
".==" -> fixity InfixN 5
|
||||||
|
"./" -> fixity InfixN 5
|
||||||
|
".<" -> fixity InfixN 5
|
||||||
|
".<=" -> fixity InfixN 5
|
||||||
|
".>" -> fixity InfixN 5
|
||||||
|
".>=" -> fixity InfixN 5
|
||||||
|
"`member`" -> fixity InfixN 8
|
||||||
|
"`notMember`" -> fixity InfixN 8
|
||||||
|
".//" -> fixity InfixL 4
|
||||||
|
".&&" -> fixity InfixR 3
|
||||||
|
".||" -> fixity InfixR 2
|
||||||
|
".=>" -> fixity InfixR 1
|
||||||
|
|
||||||
-- servant
|
-- servant
|
||||||
":>" -> fixity InfixR 4
|
":>" -> fixity InfixR 4
|
||||||
":<|>" -> fixity InfixR 3
|
":<|>" -> fixity InfixR 3
|
||||||
":-" -> fixity InfixL 0
|
":-" -> fixity InfixL 0
|
||||||
|
|
||||||
-- postgresql-simple
|
-- postgresql-simple
|
||||||
":." -> fixity InfixR 3 -- this has wildly different fixities in different libraries
|
":." -> fixity InfixR 3 -- this has wildly different fixities in different libraries
|
||||||
|
|
||||||
-- ?
|
-- ?
|
||||||
-- ":-:" -> fixity _ _
|
-- ":-:" -> fixity _ _
|
||||||
|
@ -399,7 +411,7 @@ hardcodedFixity allowUnqualify = \case
|
||||||
-- ":>:" -> fixity _ _
|
-- ":>:" -> fixity _ _
|
||||||
-- ":>=:" -> fixity _ _
|
-- ":>=:" -> fixity _ _
|
||||||
|
|
||||||
str -> case (Safe.headMay str, Safe.lastMay str) of
|
str -> case (Safe.headMay str, Safe.lastMay str) of
|
||||||
(Just '\'', _) -> hardcodedFixity False (drop 1 str)
|
(Just '\'', _) -> hardcodedFixity False (drop 1 str)
|
||||||
(Just '`', Just '`') -> Just $ Fixity NoSourceText 9 InfixL
|
(Just '`', Just '`') -> Just $ Fixity NoSourceText 9 InfixL
|
||||||
(Just c, _) | Data.Char.isAlpha c && allowUnqualify -> hardcodedFixity False
|
(Just c, _) | Data.Char.isAlpha c && allowUnqualify -> hardcodedFixity False
|
||||||
|
|
Loading…
Reference in New Issue