summaryrefslogtreecommitdiff
path: root/Build
diff options
context:
space:
mode:
Diffstat (limited to 'Build')
-rw-r--r--Build/EvilSplicer.hs159
1 files changed, 80 insertions, 79 deletions
diff --git a/Build/EvilSplicer.hs b/Build/EvilSplicer.hs
index 47402b522..b5eb5173d 100644
--- a/Build/EvilSplicer.hs
+++ b/Build/EvilSplicer.hs
@@ -34,13 +34,14 @@ import Text.Parsec
import Text.Parsec.String
import Control.Applicative ((<$>))
import Data.Either
-import Data.List
+import Data.List hiding (find)
import Data.String.Utils
import Data.Char
import System.Environment
import System.FilePath
import System.Directory
import Control.Monad
+import Prelude hiding (log)
import Utility.Monad
import Utility.Misc
@@ -85,27 +86,27 @@ coordsParser = (try singleline <|> try weird <|> multiline) <?> "Coords"
where
singleline = do
line <- number
- char ':'
+ void $ char ':'
startcol <- number
- char '-'
+ void $ char '-'
endcol <- number
return $ (Coord line startcol, Coord line endcol)
weird = do
line <- number
- char ':'
+ void $ char ':'
col <- number
return $ (Coord line col, Coord line col)
multiline = do
start <- fromparens
- char '-'
+ void $ char '-'
end <- fromparens
return $ (start, end)
fromparens = between (char '(') (char ')') $ do
line <- number
- char ','
+ void $ char ','
col <- number
return $ Coord line col
@@ -121,19 +122,19 @@ indentedLine = indent >> restOfLine
spliceParser :: Parser Splice
spliceParser = do
file <- many1 (noneOf ":\n")
- char ':'
+ void $ char ':'
(start, end) <- coordsParser
- string ": Splicing "
+ void $ string ": Splicing "
splicetype <- tosplicetype
<$> (string "expression" <|> string "declarations")
- newline
+ void newline
getthline <- expressionextractor
expression <- unlines <$> many1 getthline
- indent
- string "======>"
- newline
+ void indent
+ void $ string "======>"
+ void newline
getcodeline <- expressionextractor
realcoords <- try (Right <$> getrealcoords file) <|> (Left <$> getcodeline)
@@ -157,7 +158,7 @@ spliceParser = do
expressionextractor = do
i <- lookAhead indent
return $ try $ do
- string i
+ void $ string i
restOfLine
{- When splicing declarations, GHC will output a splice
@@ -165,9 +166,9 @@ spliceParser = do
- the first line will give the actual coordinates of the
- line that was spliced. -}
getrealcoords file = do
- indent
- string file
- char ':'
+ void indent
+ void $ string file
+ void $ char ':'
char '\n' `after` coordsParser
{- Extracts the splices, ignoring the rest of the compiler output. -}
@@ -196,6 +197,7 @@ splicesExtractor = rights <$> many extract
- starts with "import "
-}
applySplices :: FilePath -> Maybe String -> [Splice] -> IO ()
+applySplices _ _ [] = noop
applySplices destdir imports splices@(first:_) = do
let f = splicedFile first
let dest = (destdir </> f)
@@ -237,10 +239,10 @@ expandDeclarationSplice s lls = concat [before, [splice], end]
{- Expression splices are expanded within their line. -}
expandExpressionSplice :: Splice -> [String] -> [String]
-expandExpressionSplice s lls = concat [before, spliced:padding, end]
+expandExpressionSplice sp lls = concat [before, spliced:padding, end]
where
- cs = spliceStart s
- ce = spliceEnd s
+ cs = spliceStart sp
+ ce = spliceEnd sp
(before, rest) = splitAt (coordLine cs - 1) lls
(oldlines, end) = splitAt (1 + coordLine (offsetCoord ce cs)) rest
@@ -251,7 +253,7 @@ expandExpressionSplice s lls = concat [before, spliced:padding, end]
_ -> ([], [], [])
spliced = concat
[ joinsplice $ deqqstart $ take (coordColumn cs - 1) splicestart
- , addindent (findindent splicestart) (mangleCode $ splicedCode s)
+ , addindent (findindent splicestart) (mangleCode $ splicedCode sp)
, deqqend $ drop (coordColumn ce) spliceend
]
@@ -260,7 +262,7 @@ expandExpressionSplice s lls = concat [before, spliced:padding, end]
{- splicing leaves $() quasiquote behind; remove it -}
deqqstart s = case reverse s of
- ('(':'$':rest) -> reverse rest
+ ('(':'$':restq) -> reverse restq
_ -> s
deqqend (')':s) = s
deqqend s = s
@@ -331,27 +333,27 @@ mangleCode = flip_colon
-- skip lambdas inside tuples or parens
prefix <- noneOf "(, \n"
preindent <- many1 $ oneOf " \n"
- string "\\ "
+ void $ string "\\ "
lambdaparams <- restofline
continuedlambdaparams <- many $ try $ do
- indent <- many1 $ char ' '
+ indent1 <- many1 $ char ' '
p <- satisfy isLetter
aram <- many $ satisfy isAlphaNum <|> oneOf "_"
- newline
- return $ indent ++ p:aram ++ "\n"
- indent <- many1 $ char ' '
- string "-> "
+ void newline
+ return $ indent1 ++ p:aram ++ "\n"
+ indent1 <- many1 $ char ' '
+ void $ string "-> "
firstline <- restofline
lambdalines <- many $ try $ do
- string indent
- char ' '
+ void $ string indent1
+ void $ char ' '
l <- restofline
- return $ indent ++ " " ++ l
+ return $ indent1 ++ " " ++ l
return $ concat
[ prefix:preindent
, "(\\ " ++ lambdaparams ++ "\n"
, concat continuedlambdaparams
- , indent ++ "-> "
+ , indent1 ++ "-> "
, lambdaparens $ intercalate "\n" (firstline:lambdalines)
, ")\n"
]
@@ -376,27 +378,27 @@ mangleCode = flip_colon
- layer of parens even when a lambda seems to be in parent.
-}
lambdaparenhack = parsecAndReplace $ do
- indent <- many1 $ char ' '
+ indent1 <- many1 $ char ' '
staticr <- string "StaticR"
- newline
- string indent
+ void newline
+ void $ string indent1
yesod_dispatch_env <- restofline
- string indent
+ void $ string indent1
lambdaprefix <- string "(\\ "
l1 <- restofline
- string indent
+ void $ string indent1
lambdaarrow <- string " ->"
l2 <- restofline
l3 <- if '{' `elem` l2 && '}' `elem` l2
then return ""
else do
- string indent
+ void $ string indent1
restofline
return $ unlines
- [ indent ++ staticr
- , indent ++ yesod_dispatch_env
- , indent ++ "(" ++ lambdaprefix ++ l1
- , indent ++ lambdaarrow ++ l2 ++ l3 ++ ")"
+ [ indent1 ++ staticr
+ , indent1 ++ yesod_dispatch_env
+ , indent1 ++ "(" ++ lambdaprefix ++ l1
+ , indent1 ++ lambdaarrow ++ l2 ++ l3 ++ ")"
]
restofline = manyTill (noneOf "\n") newline
@@ -408,9 +410,9 @@ mangleCode = flip_colon
- To work around what is likely a GHC bug, just collapse
- multiline strings. -}
collapse_multiline_strings = parsecAndReplace $ do
- string "\\\n"
- many1 $ oneOf " \t"
- string "\\"
+ void $ string "\\\n"
+ void $ many1 $ oneOf " \t"
+ void $ string "\\"
return "\\n"
{- GHC outputs splices using explicit braces rather than layout.
@@ -439,8 +441,8 @@ mangleCode = flip_colon
- all whitespace up until it.
-}
case_layout = parsecAndReplace $ do
- newline
- indent <- many1 $ char ' '
+ void newline
+ indent1 <- many1 $ char ' '
prefix <- manyTill (noneOf "\n") (try (string "-> "))
if length prefix > 10
then unexpected "too long a prefix"
@@ -448,24 +450,24 @@ mangleCode = flip_colon
then unexpected "lambda expression"
else if null prefix
then unexpected "second line of lambda"
- else return $ "\n" ++ indent ++ "; " ++ prefix ++ " -> "
+ else return $ "\n" ++ indent1 ++ "; " ++ prefix ++ " -> "
{- Sometimes cases themselves span multiple lines:
-
- Nothing
- -> foo
-}
case_layout_multiline = parsecAndReplace $ do
- newline
- indent <- many1 $ char ' '
+ void newline
+ indent1 <- many1 $ char ' '
firstline <- restofline
- string indent
+ void $ string indent1
indent2 <- many1 $ char ' '
- string "-> "
+ void $ string "-> "
if "\\ " `isInfixOf` firstline
then unexpected "lambda expression"
- else return $ "\n" ++ indent ++ "; " ++ firstline ++ "\n"
- ++ indent ++ indent2 ++ "-> "
+ else return $ "\n" ++ indent1 ++ "; " ++ firstline ++ "\n"
+ ++ indent1 ++ indent2 ++ "-> "
{- (foo, \ -> bar) is not valid haskell, GHC.
- Change to (foo, bar)
@@ -497,11 +499,11 @@ mangleCode = flip_colon
- signature is easily inferred, so is just removed.
-}
remove_unnecessary_type_signatures = parsecAndReplace $ do
- string " ::"
- newline
- many1 $ char ' '
- string "Text.Css.Block Text.Css.Resolved"
- newline
+ void $ string " ::"
+ void newline
+ void $ many1 $ char ' '
+ void $ string "Text.Css.Block Text.Css.Resolved"
+ void newline
return ""
{- GHC may add full package and version qualifications for
@@ -520,15 +522,14 @@ mangleCode = flip_colon
qualifiedSymbol :: Parser String
qualifiedSymbol = do
- s <- token
- char ':'
+ s <- hstoken
+ void $ char ':'
if length s < 5
then unexpected "too short to be a namespace"
- else do
- token
+ else hstoken
- token :: Parser String
- token = do
+ hstoken :: Parser String
+ hstoken = do
t <- satisfy isLetter
oken <- many $ satisfy isAlphaNum <|> oneOf "-.'"
return $ t:oken
@@ -561,25 +562,25 @@ mangleCode = flip_colon
-}
yesod_url_render_hack :: String -> String
yesod_url_render_hack = parsecAndReplace $ do
- string "(toHtml"
- whitespace
- string "(\\"
- whitespace
- wtf <- token
- whitespace
- string "->"
- whitespace
- renderer <- token
- whitespace
- string wtf
- whitespace
+ void $ string "(toHtml"
+ void whitespace
+ void $ string "(\\"
+ void whitespace
+ wtf <- hstoken
+ void whitespace
+ void $ string "->"
+ void whitespace
+ renderer <- hstoken
+ void whitespace
+ void $ string wtf
+ void whitespace
return $ "(toHtml (flip " ++ renderer ++ " "
where
whitespace :: Parser String
whitespace = many $ oneOf " \t\r\n"
- token :: Parser String
- token = many1 $ satisfy isAlphaNum <|> oneOf "_"
+ hstoken :: Parser String
+ hstoken = many1 $ satisfy isAlphaNum <|> oneOf "_"
{- Use exported symbol. -}
text_builder_hack :: String -> String
@@ -591,7 +592,7 @@ text_builder_hack = replace "Data.Text.Lazy.Builder.Internal.fromText" "Data.Tex
- Rather slow, but crazy powerful. -}
parsecAndReplace :: Parser String -> String -> String
parsecAndReplace p s = case parse find "" s of
- Left e -> s
+ Left _e -> s
Right l -> concatMap (either return id) l
where
find :: Parser [Either Char String]