2013-01-23 08:47:43 -08:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
2012-06-01 10:50:22 -07:00
|
|
|
module Tests.Writers.LaTeX (tests) where
|
|
|
|
|
|
|
|
import Test.Framework
|
|
|
|
import Text.Pandoc.Builder
|
|
|
|
import Text.Pandoc
|
|
|
|
import Tests.Helpers
|
|
|
|
import Tests.Arbitrary()
|
|
|
|
|
|
|
|
latex :: (ToString a, ToPandoc a) => a -> String
|
2014-06-20 10:24:30 -07:00
|
|
|
latex = writeLaTeX def{ writerHighlight = True } . toPandoc
|
2012-06-01 10:50:22 -07:00
|
|
|
|
2013-08-22 20:15:36 +02:00
|
|
|
latexListing :: (ToString a, ToPandoc a) => a -> String
|
|
|
|
latexListing = writeLaTeX def{ writerListings = True } . toPandoc
|
|
|
|
|
2012-06-01 10:50:22 -07:00
|
|
|
{-
|
|
|
|
"my test" =: X =?> Y
|
|
|
|
|
|
|
|
is shorthand for
|
|
|
|
|
|
|
|
test latex "my test" $ X =?> Y
|
|
|
|
|
|
|
|
which is in turn shorthand for
|
|
|
|
|
|
|
|
test latex "my test" (X,Y)
|
|
|
|
-}
|
|
|
|
|
|
|
|
infix 4 =:
|
|
|
|
(=:) :: (ToString a, ToPandoc a)
|
|
|
|
=> String -> (a, String) -> Test
|
|
|
|
(=:) = test latex
|
|
|
|
|
|
|
|
tests :: [Test]
|
|
|
|
tests = [ testGroup "code blocks"
|
|
|
|
[ "in footnotes" =: note (para "hi" <> codeBlock "hi") =?>
|
|
|
|
"\\footnote{hi\n\n\\begin{Verbatim}\nhi\n\\end{Verbatim}\n}"
|
2013-08-22 20:15:36 +02:00
|
|
|
, test latexListing "identifier" $ codeBlockWith ("id",[],[]) "hi" =?>
|
|
|
|
("\\begin{lstlisting}[label=id]\nhi\n\\end{lstlisting}" :: String)
|
|
|
|
, test latexListing "no identifier" $ codeBlock "hi" =?>
|
|
|
|
("\\begin{lstlisting}\nhi\n\\end{lstlisting}" :: String)
|
2012-06-01 10:50:22 -07:00
|
|
|
]
|
2013-10-21 17:33:42 -07:00
|
|
|
, testGroup "definition lists"
|
|
|
|
[ "with internal link" =: definitionList [(link "#go" "" (str "testing"),
|
|
|
|
[plain (text "hi there")])] =?>
|
|
|
|
"\\begin{description}\n\\itemsep1pt\\parskip0pt\\parsep0pt\n\\item[{\\hyperref[go]{testing}}]\nhi there\n\\end{description}"
|
|
|
|
]
|
2013-01-12 10:21:19 -08:00
|
|
|
, testGroup "math"
|
|
|
|
[ "escape |" =: para (math "\\sigma|_{\\{x\\}}") =?>
|
2013-06-26 20:54:31 -07:00
|
|
|
"$\\sigma|_{\\{x\\}}$"
|
2013-01-12 10:21:19 -08:00
|
|
|
]
|
2013-08-16 13:02:55 -07:00
|
|
|
, testGroup "headers"
|
|
|
|
[ "unnumbered header" =:
|
|
|
|
headerWith ("foo",["unnumbered"],[]) 1
|
|
|
|
(text "Header 1" <> note (plain $ text "note")) =?>
|
|
|
|
"\\section*{Header 1\\footnote{note}}\\label{foo}\n\\addcontentsline{toc}{section}{Header 1}\n"
|
|
|
|
]
|
2014-06-20 10:24:30 -07:00
|
|
|
, testGroup "inline code"
|
|
|
|
[ "struck out and highlighted" =:
|
|
|
|
strikeout (codeWith ("",["haskell"],[]) "foo" <> space
|
|
|
|
<> str "bar") =?>
|
|
|
|
"\\sout{\\mbox{\\VERB|\\NormalTok{foo}|} bar}"
|
|
|
|
, "struck out and not highlighted" =:
|
|
|
|
strikeout (code "foo" <> space
|
|
|
|
<> str "bar") =?>
|
|
|
|
"\\sout{\\texttt{foo} bar}"
|
2014-06-23 12:51:10 -07:00
|
|
|
, "single quotes" =:
|
|
|
|
code "dog's" =?> "\\texttt{dog\\textquotesingle{}s}"
|
2014-06-20 10:24:30 -07:00
|
|
|
]
|
2012-06-01 10:50:22 -07:00
|
|
|
]
|