summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2013-04-13 18:08:32 -0400
committerGravatar Joey Hess <joey@kitenet.net>2013-04-13 18:09:20 -0400
commit71e5010c34d63a9b27af86108474c5e2d9b1758f (patch)
tree1728d5764a6dcb58f9e6b387c669690cd5473f27
parent7b094951cae4406797611e1163032f0da8291e07 (diff)
better splice joining
-rw-r--r--Build/EvilSplicer.hs25
1 files changed, 18 insertions, 7 deletions
diff --git a/Build/EvilSplicer.hs b/Build/EvilSplicer.hs
index 0936e78eb..216b818d5 100644
--- a/Build/EvilSplicer.hs
+++ b/Build/EvilSplicer.hs
@@ -201,16 +201,10 @@ expandSplice s lls = concat [before, new:splicerest, end]
l:r -> (expandtabs l, take (length r) (repeat []))
_ -> ([], [])
new = concat
- [ beforesplice
+ [ joinsplice $ deqqstart $ take (coordColumn cs - 1) splicestart
, addindent (findindent splicestart) (mangleCode $ splicedCode s)
, deqqend $ drop (coordColumn ce) splicestart
]
- where
- beforesplice =
- let s = deqqstart $ take (coordColumn cs - 1) splicestart
- in if all isSpace s
- then ""
- else s ++ " $ "
{- coordinates assume tabs are expanded to 8 spaces -}
expandtabs = replace "\t" (take 8 $ repeat ' ')
@@ -222,6 +216,23 @@ expandSplice s lls = concat [before, new:splicerest, end]
deqqend (')':s) = s
deqqend s = s
+ {- Prepare the code that comes just before the splice so
+ - the splice will combine with it appropriately. -}
+ joinsplice s
+ -- all indentation? Skip it, we'll use the splice's indentation
+ | all isSpace s = ""
+ -- function definition needs no preparation
+ -- ie: foo = $(splice)
+ | "=" `isSuffixOf` s' = s
+ -- already have a $ to set off the splice
+ -- ie: foo $ $(splice)
+ | "$" `isSuffixOf` s' = s
+ -- need to add a $ to set off the splice
+ -- ie: bar $(splice)
+ | otherwise = s ++ " $ "
+ where
+ s' = filter (not . isSpace) s
+
findindent = length . takeWhile isSpace
addindent n = unlines . map (i ++) . lines
where