-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | Multiline strings, interpolation and templating. -- -- This package adds quasiquoter for multiline strings, interpolation and -- simple templating. It can handle repetition templates which makes it -- Handy for outputting larger structures, such as latex tables or -- gnuplot files. @package Interpolation @version 0.2.2 module Data.String.Interpolation -- | Quasiquote str implements multiline strings with interpolation. -- Interpolating a value into the string is done by $<String -- expression>$ and interpolating anything with instance Show is -- $:<Show expression>$. Due to pretty deep limitations, the parser -- is not able to properly deduce associtivity of infix operators, so use -- lots and lots of parenthesis. -- -- Repetitive patterns can be made with # symbol: -- --
-- #<var> in <list>: <interpolated string> (|<interpolated string>)# ---- -- Where (|<interpolated string>) denotes optional separator for -- the elements. -- -- Multiline indentation is handled by aligning on smallest un-empty line -- after the first. Neither pattern matching nor nested #-patterns are -- supported. Normal '\\n' style escaping of special characters is -- intentionally not supported. Please use $endline$ or $n$ style -- instead. (Also, in this beta release $, and : symbols are not escaped -- in the interpolated expressions. -- -- As an example, let's plot set of vectors with gnuplot: -- --
-- plotVecs :: [(String,[Double])] -> String -- plotVecs vs = -- [$str| ## Plot multiple vectors -- plot #(n,_) in vs:- with lines lw 5 title $n$ |, # -- #d in map snd vs:$singleVec d$$endline$e$endline$# |] -- where -- singleVec n = [$str|#(e,i) in zip n [1..]: $:i$ $:e$|$endline$#|] ---- --
-- *Gnuplotter> plotVecs [(A,[1..5]),(B,[2..6])] -- # Plot multiple vectors -- plot - with lines lw 5 title A , - with lines lw 5 title B -- 1 1.0 -- 2 2.0 -- 3 3.0 -- 4 4.0 -- 5 5.0 -- -- e -- 1 2.0 -- 2 3.0 -- 3 4.0 -- 4 5.0 -- 5 6.0 -- -- e --str :: QuasiQuoter -- | End of the line endline :: String -- | Tab tab :: String instance Typeable StringBits instance Eq StringBits instance Ord StringBits instance Show StringBits instance Data StringBits