Safe Haskell | None |
---|---|
Language | Haskell2010 |
NeatInterpolation provides a quasiquoter for producing strings with a simple interpolation of input values. It removes the excessive indentation from the input and accurately manages the indentation of all lines of interpolated variables. But enough words, the code shows it better.
Consider the following declaration:
{-# LANGUAGE QuasiQuotes #-} import NeatInterpolation import Data.Text (Text) f :: Text -> Text -> Text f a b = [text| function(){ function(){ $a } return $b } |]
Executing the following:
main = T.putStrLn $ f "1" "2"
will produce this (notice the reduced indentation compared to how it was declared):
function(){ function(){ 1 } return 2 }
Now let's test it with multiline string parameters:
main = T.putStrLn $ f "{\n indented line\n indented line\n}" "{\n indented line\n indented line\n}"
We get
function(){ function(){ { indented line indented line } } return { indented line indented line } }
See how it neatly preserved the indentation levels of lines the variable placeholders were at?
If you need to separate variable placeholder from the following text to prevent treating the rest of line as variable name, use escaped variable:
f name = [text|this_could_be_${name}_long_identifier|]
So
f "one" == "this_could_be_one_long_identifier"
If you want to write something that looks like a variable but should be
inserted as-is, escape it with another $
:
f word = [text|$$my ${word} $${string}|]
results in
f "funny" == "$my funny ${string}|]
Synopsis
- text :: QuasiQuoter
Documentation
text :: QuasiQuoter Source #
The quasiquoter.