diff options
Diffstat (limited to 'compiler/GHC/Parser.y')
| -rw-r--r-- | compiler/GHC/Parser.y | 19 | 
1 files changed, 12 insertions, 7 deletions
| diff --git a/compiler/GHC/Parser.y b/compiler/GHC/Parser.y index c93ce8ff4c..5d8a9c2c9d 100644 --- a/compiler/GHC/Parser.y +++ b/compiler/GHC/Parser.y @@ -92,7 +92,8 @@ import GHC.Parser.Annotation  import GHC.Parser.Errors.Types  import GHC.Parser.Errors.Ppr () -import GHC.Builtin.Types ( unitTyCon, unitDataCon, tupleTyCon, tupleDataCon, nilDataCon, +import GHC.Builtin.Types ( unitTyCon, unitDataCon, sumTyCon, +                           tupleTyCon, tupleDataCon, nilDataCon,                             unboxedUnitTyCon, unboxedUnitDataCon,                             listTyCon_RDR, consDataCon_RDR, eqTyCon_RDR) @@ -3043,11 +3044,13 @@ tup_exprs :: { forall b. DisambECP b => PV (SumOrTuple b) }                        ; return (Tuple (cos ++ $2)) } }             | texp bars   { unECP $1 >>= \ $1 -> return $ -                            (Sum 1  (snd $2 + 1) $1 [] (fst $2)) } +                            (Sum 1  (snd $2 + 1) $1 [] (map (EpaSpan . realSrcSpan) $ fst $2)) }             | bars texp bars0                  { unECP $2 >>= \ $2 -> return $ -                  (Sum (snd $1 + 1) (snd $1 + snd $3 + 1) $2 (fst $1) (fst $3)) } +                  (Sum (snd $1 + 1) (snd $1 + snd $3 + 1) $2 +                    (map (EpaSpan . realSrcSpan) $ fst $1) +                    (map (EpaSpan . realSrcSpan) $ fst $3)) }  -- Always starts with commas; always follows an expr  commas_tup_tail :: { forall b. DisambECP b => PV (SrcSpan,[Either (EpAnn EpaLocation) (LocatedA b)]) } @@ -3571,6 +3574,8 @@ ntgtycon :: { LocatedN RdrName }  -- A "general" qualified tycon, excluding unit          | '(#' commas '#)'      {% amsrn (sLL $1 $> $ getRdrName (tupleTyCon Unboxed                                                          (snd $2 + 1)))                                         (NameAnnCommas NameParensHash (glAA $1) (map (EpaSpan . realSrcSpan) (fst $2)) (glAA $3) []) } +        | '(#' bars '#)'        {% amsrn (sLL $1 $> $ getRdrName (sumTyCon (snd $2 + 1))) +                                       (NameAnnBars NameParensHash (glAA $1) (map (EpaSpan . realSrcSpan) (fst $2)) (glAA $3) []) }          | '(' '->' ')'          {% amsrn (sLL $1 $> $ getRdrName unrestrictedFunTyCon)                                         (NameAnn NameParens (glAA $1) (glAA $2) (glAA $3) []) }          | '[' ']'               {% amsrn (sLL $1 $> $ listTyCon_RDR) @@ -3862,13 +3867,13 @@ commas :: { ([SrcSpan],Int) }   -- One or more commas          : commas ','             { ((fst $1)++[gl $2],snd $1 + 1) }          | ','                    { ([gl $1],1) } -bars0 :: { ([EpaLocation],Int) }     -- Zero or more bars +bars0 :: { ([SrcSpan],Int) }     -- Zero or more bars          : bars                   { $1 }          |                        { ([], 0) } -bars :: { ([EpaLocation],Int) }     -- One or more bars -        : bars '|'               { ((fst $1)++[glAA $2],snd $1 + 1) } -        | '|'                    { ([glAA $1],1) } +bars :: { ([SrcSpan],Int) }     -- One or more bars +        : bars '|'               { ((fst $1)++[gl $2],snd $1 + 1) } +        | '|'                    { ([gl $1],1) }  {  happyError :: P a | 
