diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/Site.hs | 7 | ||||
-rw-r--r-- | src/Tex.hs | 10 |
2 files changed, 12 insertions, 5 deletions
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 |