diff options
author | John MacFarlane <fiddlosopher@gmail.com> | 2012-04-03 18:49:05 -0700 |
---|---|---|
committer | John MacFarlane <fiddlosopher@gmail.com> | 2012-04-03 18:49:05 -0700 |
commit | f25dcacedf693b9a573607051db3a0dcacdf5165 (patch) | |
tree | dc0cc8ddd3e6081ce71e804f47b0f4c9c84aa5ec | |
parent | 0afd33e4c51ca1f19d041d1504bc35600b2786e6 (diff) | |
download | pandoc-f25dcacedf693b9a573607051db3a0dcacdf5165.tar.gz |
LaTeX writer: don't use eurosym package unless document has a €.
-rw-r--r-- | src/Text/Pandoc/Writers/LaTeX.hs | 28 | ||||
m--------- | templates | 10 | ||||
-rw-r--r-- | tests/lhs-test.latex | 1 | ||||
-rw-r--r-- | tests/lhs-test.latex+lhs | 1 | ||||
-rw-r--r-- | tests/writer.latex | 1 |
5 files changed, 22 insertions, 19 deletions
diff --git a/src/Text/Pandoc/Writers/LaTeX.hs b/src/Text/Pandoc/Writers/LaTeX.hs index 9536a3c87..3bef597dc 100644 --- a/src/Text/Pandoc/Writers/LaTeX.hs +++ b/src/Text/Pandoc/Writers/LaTeX.hs @@ -65,6 +65,7 @@ data WriterState = , stHighlighting :: Bool -- true if document has highlighted code , stIncremental :: Bool -- true if beamer lists should be displayed bit by bit , stInternalLinks :: [String] -- list of internal link targets + , stUsesEuro :: Bool -- true if euro symbol used } -- | Convert Pandoc to LaTeX. @@ -79,7 +80,7 @@ writeLaTeX options document = stLHS = False, stBook = writerChapters options, stCsquotes = False, stHighlighting = False, stIncremental = writerIncremental options, - stInternalLinks = [] } + stInternalLinks = [], stUsesEuro = False } pandocToLaTeX :: WriterOptions -> Pandoc -> State WriterState String pandocToLaTeX options (Pandoc (Meta title authors date) blocks) = do @@ -153,6 +154,7 @@ pandocToLaTeX options (Pandoc (Meta title authors date) blocks) = do [ ("lhs", "yes") | stLHS st ] ++ [ ("graphics", "yes") | stGraphics st ] ++ [ ("book-class", "yes") | stBook st] ++ + [ ("euro", "yes") | stUsesEuro st] ++ [ ("listings", "yes") | writerListings options || stLHS st ] ++ [ ("beamer", "yes") | writerBeamer options ] ++ [ ("mainlang", maybe "" (reverse . takeWhile (/=',') . reverse) @@ -173,10 +175,15 @@ elementToLaTeX opts (Sec level _ id' title' elements) = do return $ vcat (header' : innerContents) -- escape things as needed for LaTeX -stringToLaTeX :: Bool -> String -> String -stringToLaTeX _ [] = "" -stringToLaTeX isUrl (x:xs) = - case x of +stringToLaTeX :: Bool -> String -> State WriterState String +stringToLaTeX _ [] = return "" +stringToLaTeX isUrl (x:xs) = do + rest <- stringToLaTeX isUrl xs + when (x == '€') $ + modify $ \st -> st{ stUsesEuro = True } + return $ + case x of + '€' -> "\\euro{}" ++ rest '{' -> "\\{" ++ rest '}' -> "\\}" ++ rest '$' -> "\\$" ++ rest @@ -190,7 +197,6 @@ stringToLaTeX isUrl (x:xs) = '~' | not isUrl -> "\\textasciitilde{}" ++ rest '^' -> "\\^{}" ++ rest '\\' -> "\\textbackslash{}" ++ rest - '€' -> "\\euro{}" ++ rest '|' -> "\\textbar{}" ++ rest '<' -> "\\textless{}" ++ rest '>' -> "\\textgreater{}" ++ rest @@ -205,7 +211,6 @@ stringToLaTeX isUrl (x:xs) = '\x2014' -> "---" ++ rest '\x2013' -> "--" ++ rest _ -> x : rest - where rest = stringToLaTeX isUrl xs -- | Puts contents into LaTeX command. inCmd :: String -> Doc -> Doc @@ -529,8 +534,8 @@ inlineToLaTeX (Code (_,classes,_) str) = do Nothing -> rawCode Just h -> modify (\st -> st{ stHighlighting = True }) >> return (text h) - rawCode = return - $ text $ "\\texttt{" ++ stringToLaTeX False str ++ "}" + rawCode = liftM (text . (\s -> "\\texttt{" ++ s ++ "}")) + $ stringToLaTeX False str inlineToLaTeX (Quoted SingleQuote lst) = do contents <- inlineListToLaTeX lst csquotes <- liftM stCsquotes get @@ -557,7 +562,7 @@ inlineToLaTeX (Quoted DoubleQuote lst) = do then "\\," else empty return $ "``" <> s1 <> contents <> s2 <> "''" -inlineToLaTeX (Str str) = return $ text $ stringToLaTeX False str +inlineToLaTeX (Str str) = liftM text $ stringToLaTeX False str inlineToLaTeX (Math InlineMath str) = return $ char '$' <> text str <> char '$' inlineToLaTeX (Math DisplayMath str) = return $ "\\[" <> text str <> "\\]" inlineToLaTeX (RawInline "latex" str) = return $ text str @@ -571,7 +576,8 @@ inlineToLaTeX (Link txt (src, _)) = do modify $ \s -> s{ stUrl = True } return $ text $ "\\url{" ++ x ++ "}" _ -> do contents <- inlineListToLaTeX txt - return $ text ("\\href{" ++ stringToLaTeX True src ++ "}{") <> + src' <- stringToLaTeX True src + return $ text ("\\href{" ++ src' ++ "}{") <> contents <> char '}' inlineToLaTeX (Image _ (source, _)) = do modify $ \s -> s{ stGraphics = True } diff --git a/templates b/templates -Subproject fe86fad75cce01c977a17c70ec6eece82c7e2da +Subproject 8e7c61c3074f98b7d41634575715d897510fc1b diff --git a/tests/lhs-test.latex b/tests/lhs-test.latex index 7fca818bd..307139499 100644 --- a/tests/lhs-test.latex +++ b/tests/lhs-test.latex @@ -12,7 +12,6 @@ \newcommand{\euro}{€} \else \usepackage[utf8]{inputenc} - \usepackage{eurosym} \fi \fi \usepackage{color} diff --git a/tests/lhs-test.latex+lhs b/tests/lhs-test.latex+lhs index 76ee4d7ce..cda150107 100644 --- a/tests/lhs-test.latex+lhs +++ b/tests/lhs-test.latex+lhs @@ -12,7 +12,6 @@ \newcommand{\euro}{€} \else \usepackage[utf8]{inputenc} - \usepackage{eurosym} \fi \fi \usepackage{listings} diff --git a/tests/writer.latex b/tests/writer.latex index c56611047..0600efa1e 100644 --- a/tests/writer.latex +++ b/tests/writer.latex @@ -12,7 +12,6 @@ \newcommand{\euro}{€} \else \usepackage[utf8]{inputenc} - \usepackage{eurosym} \fi \fi \usepackage{fancyvrb} |