diff options
-rw-r--r-- | provider/templates/preamble.tex | 11 | ||||
-rw-r--r-- | src/Site.hs | 7 | ||||
-rw-r--r-- | src/Tex.hs | 10 |
3 files changed, 18 insertions, 10 deletions
diff --git a/provider/templates/preamble.tex b/provider/templates/preamble.tex index 0d76503..1f2c1e4 100644 --- a/provider/templates/preamble.tex +++ b/provider/templates/preamble.tex | |||
@@ -11,11 +11,12 @@ | |||
11 | \newcommand*{\ca}[1]{\ensuremath{\mathbf{#1}}} | 11 | \newcommand*{\ca}[1]{\ensuremath{\mathbf{#1}}} |
12 | \newcommand*{\idarr}[1]{\ensuremath{\mathrm{id}_{#1}}} | 12 | \newcommand*{\idarr}[1]{\ensuremath{\mathrm{id}_{#1}}} |
13 | 13 | ||
14 | \newcommand{\id}{\ensuremath{\mathrm{id}}} | 14 | \newcommand*{\id}{\ensuremath{\mathrm{id}}} |
15 | \renewcommand{\implies}{\ensuremath{\rightarrow}} | 15 | \renewcommand{\implies}{\ensuremath{\rightarrow}} |
16 | 16 | ||
17 | \newcommand{\N}{\ensuremath{\mathbb{N}}} | 17 | \newcommand*{\N}{\ensuremath{\mathbb{N}}} |
18 | \newcommand{\arr}[3]{\begin{tikzcd}[ampersand replacement=\&]{#1} \rar{#2} \& {#3}\end{tikzcd}} | 18 | \newcommand*{\arr}[3]{\begin{tikzcd}[ampersand replacement=\&]{#1} \rar{#2} \& {#3}\end{tikzcd}} |
19 | \renewcommand{\hom}[3]{\ensuremath{\mathrm{hom}_{#1} \left [ #2, #3 \right ]}} | 19 | \newcommand*{\Hom}[3]{\ensuremath{\mathrm{Hom}_{#1} \left [ #2, #3 \right ]}} |
20 | \newcommand*{\End}[2]{\ensuremath{\mathrm{End}_{#1} \left [ #2 \right ]}} | ||
20 | 21 | ||
21 | \newcommand{\powerset}{\raisebox{.15\baselineskip}{\Large\ensuremath{\wp}}} | 22 | \newcommand*{\powerset}{\raisebox{.15\baselineskip}{\Large\ensuremath{\wp}}} |
diff --git a/src/Site.hs b/src/Site.hs index d3ac76d..03b6e16 100644 --- a/src/Site.hs +++ b/src/Site.hs | |||
@@ -170,7 +170,7 @@ getTex pattern makeId = do | |||
170 | getTex' :: FilePath -> Rules [String] | 170 | getTex' :: FilePath -> Rules [String] |
171 | getTex' path = preprocess . fmap concat $ (\x -> [query extractTex, query extractTex'] <*> pure x) `liftM` readPandoc' path | 171 | getTex' path = preprocess . fmap concat $ (\x -> [query extractTex, query extractTex'] <*> pure x) `liftM` readPandoc' path |
172 | extractTex :: Inline -> [String] | 172 | extractTex :: Inline -> [String] |
173 | extractTex (Math _ str) = ["\\(" ++ str ++ "\\)"] | 173 | extractTex (Math _ str) = [wrapMath str] |
174 | extractTex (RawInline "latex" str) = [str] | 174 | extractTex (RawInline "latex" str) = [str] |
175 | extractTex _ = [] | 175 | extractTex _ = [] |
176 | extractTex' :: Block -> [String] | 176 | extractTex' :: Block -> [String] |
@@ -181,6 +181,9 @@ getTex pattern makeId = do | |||
181 | mergeGroups' :: [([Identifier], String)] -> ([Identifier], String) | 181 | mergeGroups' :: [([Identifier], String)] -> ([Identifier], String) |
182 | mergeGroups' xs@((_, str):_) = (concatMap fst xs, str) | 182 | mergeGroups' xs@((_, str):_) = (concatMap fst xs, str) |
183 | 183 | ||
184 | wrapMath :: String -> String | ||
185 | wrapMath str = "\\(" ++ str ++ "\\)" | ||
186 | |||
184 | readPandoc' :: FilePath -> IO Pandoc | 187 | readPandoc' :: FilePath -> IO Pandoc |
185 | readPandoc' path = readFile path >>= either fail return . result' | 188 | readPandoc' path = readFile path >>= either fail return . result' |
186 | where | 189 | where |
@@ -211,7 +214,7 @@ texTransform :: Pandoc -> Compiler Pandoc | |||
211 | texTransform = walkM texTransformInline <=< walkM texTransformBlock | 214 | texTransform = walkM texTransformInline <=< walkM texTransformBlock |
212 | where | 215 | where |
213 | texTransformInline :: Inline -> Compiler Inline | 216 | texTransformInline :: Inline -> Compiler Inline |
214 | texTransformInline (Math mathType tex) = (\html -> Span ("", [classOf mathType], []) [RawInline "html" html]) <$> texTransform' ("\\(" ++ tex ++ "\\)") | 217 | texTransformInline (Math mathType tex) = (\html -> Span ("", [classOf mathType], []) [RawInline "html" html]) <$> texTransform' (wrapMath tex) |
215 | texTransformInline (RawInline "latex" tex) = (\html -> Span ("", [], []) [RawInline "html" html]) <$> texTransform' tex | 218 | texTransformInline (RawInline "latex" tex) = (\html -> Span ("", [], []) [RawInline "html" html]) <$> texTransform' tex |
216 | texTransformInline x = return x | 219 | texTransformInline x = return x |
217 | texTransformBlock :: Block -> Compiler Block | 220 | texTransformBlock :: Block -> Compiler Block |
@@ -2,10 +2,10 @@ module Tex | |||
2 | ( compileTex | 2 | ( compileTex |
3 | ) where | 3 | ) where |
4 | 4 | ||
5 | import System.IO (stdout, stderr, hPutStrLn, writeFile, readFile) | 5 | import System.IO (stdout, stderr, hPutStrLn, writeFile, readFile, hClose) |
6 | import System.IO.Temp (withSystemTempDirectory) | 6 | import System.IO.Temp (withSystemTempDirectory, openTempFile) |
7 | import System.Process (callProcess, readProcessWithExitCode) | 7 | import System.Process (callProcess, readProcessWithExitCode) |
8 | import System.Directory (copyFile, getCurrentDirectory, setCurrentDirectory) | 8 | import System.Directory (copyFile, getCurrentDirectory, setCurrentDirectory, getTemporaryDirectory) |
9 | import System.FilePath (takeFileName, FilePath(..), (</>)) | 9 | import System.FilePath (takeFileName, FilePath(..), (</>)) |
10 | import System.Exit (ExitCode(..)) | 10 | import System.Exit (ExitCode(..)) |
11 | 11 | ||
@@ -50,6 +50,10 @@ compileTex' input tmpDir = do | |||
50 | when (exitCode /= ExitSuccess) $ do | 50 | when (exitCode /= ExitSuccess) $ do |
51 | hPutStrLn stdout out | 51 | hPutStrLn stdout out |
52 | hPutStrLn stderr err | 52 | hPutStrLn stderr err |
53 | (srcF, srcH) <- flip openTempFile "source.tex" =<< getTemporaryDirectory | ||
54 | hPutStrLn srcH input | ||
55 | hClose srcH | ||
56 | hPutStrLn stdout $ "Tex source saved to " ++ srcF | ||
53 | throwIO exitCode | 57 | throwIO exitCode |
54 | (\x -> return $!! (x, extractAlignment err)) =<< (readFile $ tmpDir </> "image.svg") | 58 | (\x -> return $!! (x, extractAlignment err)) =<< (readFile $ tmpDir </> "image.svg") |
55 | where | 59 | where |