49 lines
1.3 KiB
Haskell
49 lines
1.3 KiB
Haskell
|
{-# LANGUAGE TemplateHaskell #-}
|
||
|
|
||
|
-- | QuasiQuoter for non-interpolated strings, texts and bytestrings.
|
||
|
--
|
||
|
-- The "s" quoter contains a multi-line string with no interpolation at all,
|
||
|
-- except that the leading newline is trimmed and carriage returns stripped.
|
||
|
--
|
||
|
-- @
|
||
|
-- {-\# LANGUAGE QuasiQuotes #-}
|
||
|
-- import Data.Text (Text)
|
||
|
-- import Data.String.QQ
|
||
|
-- foo :: Text -- "String", "ByteString" etc also works
|
||
|
-- foo = [s|
|
||
|
-- Well here is a
|
||
|
-- multi-line string!
|
||
|
-- |]
|
||
|
-- @
|
||
|
--
|
||
|
-- Any instance of the IsString type is permitted.
|
||
|
--
|
||
|
-- (For GHC versions 6, write "[$s||]" instead of "[s||]".)
|
||
|
--
|
||
|
module GHCup.Utils.String.QQ
|
||
|
( s
|
||
|
)
|
||
|
where
|
||
|
|
||
|
|
||
|
import Data.Char
|
||
|
import GHC.Exts ( IsString(..) )
|
||
|
import Language.Haskell.TH.Quote
|
||
|
|
||
|
-- | QuasiQuoter for a non-interpolating ASCII IsString literal.
|
||
|
-- The pattern portion is undefined.
|
||
|
s :: QuasiQuoter
|
||
|
s = QuasiQuoter
|
||
|
(\s' -> case and $ fmap isAscii s' of
|
||
|
True -> (\a -> [|fromString a|]) . trimLeadingNewline . removeCRs $ s'
|
||
|
False -> fail "Not ascii"
|
||
|
)
|
||
|
(error "Cannot use q as a pattern")
|
||
|
(error "Cannot use q as a type")
|
||
|
(error "Cannot use q as a dec")
|
||
|
where
|
||
|
removeCRs = filter (/= '\r')
|
||
|
trimLeadingNewline ('\n' : xs) = xs
|
||
|
trimLeadingNewline xs = xs
|
||
|
|