tmhedberg/here
Haskell here docs & interpolated strings via quasiquotation
{ "createdAt": "2013-02-23T11:15:34Z", "defaultBranch": "master", "description": "Haskell here docs & interpolated strings via quasiquotation", "fullName": "tmhedberg/here", "homepage": "", "language": "Haskell", "name": "here", "pushedAt": "2025-01-13T17:54:33Z", "stargazersCount": 57, "topics": [], "updatedAt": "2025-01-13T17:54:37Z", "url": "https://github.com/tmhedberg/here"}here is a package that adds support for multi-line string literals (a.k.a. “here docs”) and string interpolation to Haskell via GHC’s QuasiQuotes extension.
The quoted expressions behave like string literals in the source code; that is, they produce values of type String, or, with the OverloadedStrings language extension enabled, values of type IsString a => a.
The package includes six quasiquoters:
here: Strips leading and trailing whitespace. This allows you to add a line break after the opening quote bracket, which looks nicer.hereLit: Quotes the here doc literally, with no whitespace strippinghereFile: Quotes a file’s contents as a here doci: LikehereLit, but with the ability to interpolate the values of antiquoted Haskell expressions (bracketed by${and})iTrim: Likei, but trimming leading and trailing whitespace as withheretemplate: Applies string interpolation to a file, as a simple template engine
Example
Section titled “Example”{-# LANGUAGE QuasiQuotes #-}
import Data.Charimport Data.String.Here
main = do let foo = "foo" putStrLn [i|"foo", when capitalized, is ${map toUpper foo}!|] putStrLn [here|Hello world,
I am a multiline here doc!|]Output
Section titled “Output”"foo", when capitalized, is FOO!Hello world,
I am a multiline here doc!