diff options
author | Vladislav Zavialov <vlad.z.4096@gmail.com> | 2019-05-02 07:42:16 +0300 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2019-05-05 10:39:24 -0400 |
commit | ead3f835e24338fb3df3ebdec3e86f9364df7c9c (patch) | |
tree | ed2cf60147ab36711391191cb4308cd5e0615650 /compiler/parser/RdrHsSyn.hs | |
parent | 615b4be66341edb513785d3511e71803c45da90f (diff) | |
download | haskell-ead3f835e24338fb3df3ebdec3e86f9364df7c9c.tar.gz |
'warnSpaceAfterBang' only in patterns (#16619)
Diffstat (limited to 'compiler/parser/RdrHsSyn.hs')
-rw-r--r-- | compiler/parser/RdrHsSyn.hs | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/compiler/parser/RdrHsSyn.hs b/compiler/parser/RdrHsSyn.hs index 8d15cb317b..7c457f83d1 100644 --- a/compiler/parser/RdrHsSyn.hs +++ b/compiler/parser/RdrHsSyn.hs @@ -1847,20 +1847,16 @@ ecpFromCmd a = ECP (ecpFromCmd' a) -- | Disambiguate infix operators. -- See Note [Ambiguous syntactic categories] class DisambInfixOp b where - checkIfBang :: b -> Bool mkHsVarOpPV :: Located RdrName -> PV (Located b) mkHsConOpPV :: Located RdrName -> PV (Located b) mkHsInfixHolePV :: SrcSpan -> PV (Located b) instance p ~ GhcPs => DisambInfixOp (HsExpr p) where - checkIfBang (HsVar _ (unLoc -> op)) = isBangRdr op - checkIfBang _ = False mkHsVarOpPV v = return $ cL (getLoc v) (HsVar noExt v) mkHsConOpPV v = return $ cL (getLoc v) (HsVar noExt v) mkHsInfixHolePV l = return $ cL l hsHoleExpr instance DisambInfixOp RdrName where - checkIfBang = isBangRdr mkHsConOpPV (dL->L l v) = return $ cL l v mkHsVarOpPV (dL->L l v) = return $ cL l v mkHsInfixHolePV l = @@ -2132,7 +2128,9 @@ instance p ~ GhcPs => DisambECP (PatBuilder p) where mkHsLetPV l _ _ = addFatalError l $ text "(let ... in ...)-syntax in pattern" type InfixOp (PatBuilder p) = RdrName superInfixOp m = m - mkHsOpAppPV l p1 op p2 = return $ cL l $ PatBuilderOpApp p1 op p2 + mkHsOpAppPV l p1 op p2 = do + warnSpaceAfterBang op (getLoc p2) + return $ cL l $ PatBuilderOpApp p1 op p2 mkHsCasePV l _ _ = addFatalError l $ text "(case ... of ...)-syntax in pattern" type FunArg (PatBuilder p) = PatBuilder p superFunArg m = m @@ -2193,6 +2191,19 @@ mkPatRec (unLoc -> PatBuilderVar c) (HsRecFields fs dd) mkPatRec p _ = addFatalError (getLoc p) $ text "Not a record constructor:" <+> ppr p +-- | Warn about missing space after bang +warnSpaceAfterBang :: Located RdrName -> SrcSpan -> PV () +warnSpaceAfterBang (dL->L opLoc op) argLoc = do + bang_on <- getBit BangPatBit + when (not bang_on && noSpace && isBangRdr op) $ + addWarning Opt_WarnSpaceAfterBang span msg + where + span = combineSrcSpans opLoc argLoc + noSpace = srcSpanEnd opLoc == srcSpanStart argLoc + msg = text "Did you forget to enable BangPatterns?" $$ + text "If you mean to bind (!) then perhaps you want" $$ + text "to add a space after the bang for clarity." + {- Note [Ambiguous syntactic categories] ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |