summaryrefslogtreecommitdiff
path: root/compiler/parser/Lexer.x
diff options
context:
space:
mode:
authorAlec Theriault <alec.theriault@gmail.com>2019-02-25 16:39:27 -0800
committerMarge Bot <ben+marge-bot@smart-cactus.org>2019-03-01 16:32:09 -0500
commitf37efb11b957a21f3048f7005a234f96350ff938 (patch)
tree806f2937aa38e50ec4e9f3ba1949a15a35b7ca21 /compiler/parser/Lexer.x
parentc26d299dc422f43b8c37da4b26da2067eedcbae8 (diff)
downloadhaskell-f37efb11b957a21f3048f7005a234f96350ff938.tar.gz
Lexer: turn some fatal errors into non-fatal ones
The following previously fatal lexer errors are now non-fatal: * errors about enabling `LambdaCase` * errors about enabling `NumericUnderscores` * errors about having valid characters in primitive strings See #16270
Diffstat (limited to 'compiler/parser/Lexer.x')
-rw-r--r--compiler/parser/Lexer.x42
1 files changed, 24 insertions, 18 deletions
diff --git a/compiler/parser/Lexer.x b/compiler/parser/Lexer.x
index 5fb48eba36..d77564e13a 100644
--- a/compiler/parser/Lexer.x
+++ b/compiler/parser/Lexer.x
@@ -1312,9 +1312,11 @@ varid span buf len =
keyword <- case lastTk of
Just ITlam -> do
lambdaCase <- getBit LambdaCaseBit
- if lambdaCase
- then return ITlcase
- else failMsgP "Illegal lambda-case (use -XLambdaCase)"
+ unless lambdaCase $ do
+ pState <- getPState
+ addError (RealSrcSpan (last_loc pState)) $ text
+ "Illegal lambda-case (use LambdaCase)"
+ return ITlcase
_ -> return ITcase
maybe_layout keyword
return $ L span keyword
@@ -1379,9 +1381,11 @@ tok_integral :: (SourceText -> Integer -> Token)
tok_integral itint transint transbuf translen (radix,char_to_int) span buf len = do
numericUnderscores <- getBit NumericUnderscoresBit -- #14473
let src = lexemeToString buf len
- if (not numericUnderscores) && ('_' `elem` src)
- then failMsgP "Use NumericUnderscores to allow underscores in integer literals"
- else return $ L span $ itint (SourceText src)
+ when ((not numericUnderscores) && ('_' `elem` src)) $ do
+ pState <- getPState
+ addError (RealSrcSpan (last_loc pState)) $ text
+ "Use NumericUnderscores to allow underscores in integer literals"
+ return $ L span $ itint (SourceText src)
$! transint $ parseUnsignedInteger
(offsetBytes transbuf buf) (subtract translen len) radix char_to_int
@@ -1419,9 +1423,11 @@ tok_frac :: Int -> (String -> Token) -> Action
tok_frac drop f span buf len = do
numericUnderscores <- getBit NumericUnderscoresBit -- #14473
let src = lexemeToString buf (len-drop)
- if (not numericUnderscores) && ('_' `elem` src)
- then failMsgP "Use NumericUnderscores to allow underscores in floating literals"
- else return (L span $! (f $! src))
+ when ((not numericUnderscores) && ('_' `elem` src)) $ do
+ pState <- getPState
+ addError (RealSrcSpan (last_loc pState)) $ text
+ "Use NumericUnderscores to allow underscores in floating literals"
+ return (L span $! (f $! src))
tok_float, tok_primfloat, tok_primdouble :: String -> Token
tok_float str = ITrational $! readFractionalLit str
@@ -1618,23 +1624,23 @@ lex_string s = do
Just ('"',i) -> do
setInput i
+ let s' = reverse s
magicHash <- getBit MagicHashBit
if magicHash
then do
i <- getInput
case alexGetChar' i of
Just ('#',i) -> do
- setInput i
- if any (> '\xFF') s
- then failMsgP "primitive string literal must contain only characters <= \'\\xFF\'"
- else let bs = unsafeMkByteString (reverse s)
- in return (ITprimstring (SourceText (reverse s)) bs)
+ setInput i
+ when (any (> '\xFF') s') $ do
+ pState <- getPState
+ addError (RealSrcSpan (last_loc pState)) $ text
+ "primitive string literal must contain only characters <= \'\\xFF\'"
+ return (ITprimstring (SourceText s') (unsafeMkByteString s'))
_other ->
- return (ITstring (SourceText (reverse s))
- (mkFastString (reverse s)))
+ return (ITstring (SourceText s') (mkFastString s'))
else
- return (ITstring (SourceText (reverse s))
- (mkFastString (reverse s)))
+ return (ITstring (SourceText s') (mkFastString s'))
Just ('\\',i)
| Just ('&',i) <- next -> do