Use \enquote{..} for latex quotes if template uses csquotes package.

This provides better support for foreign language quoting.
Thanks to Andreas Wagner for the idea.
This commit is contained in:
John MacFarlane 2011-07-23 13:11:39 -07:00
parent 6424e7d02c
commit 81c403d2d1
2 changed files with 34 additions and 16 deletions

3
README
View file

@ -1390,6 +1390,9 @@ correct output, converting straight quotes to curly quotes, `---` and `--`
to Em-dashes, and `...` to ellipses. Nonbreaking spaces are inserted after to Em-dashes, and `...` to ellipses. Nonbreaking spaces are inserted after
certain abbreviations, such as "Mr." certain abbreviations, such as "Mr."
Note: if your LaTeX template uses the `csquotes` package, pandoc will
detect automatically this and use `\enquote{...}` for quoted text.
Inline formatting Inline formatting
----------------- -----------------

View file

@ -35,7 +35,8 @@ import Text.Pandoc.Shared
import Text.Pandoc.Templates import Text.Pandoc.Templates
import Text.Printf ( printf ) import Text.Printf ( printf )
import Network.URI ( isAbsoluteURI, unEscapeString ) import Network.URI ( isAbsoluteURI, unEscapeString )
import Data.List ( (\\), isSuffixOf, isPrefixOf, intercalate, intersperse ) import Data.List ( (\\), isSuffixOf, isInfixOf,
isPrefixOf, intercalate, intersperse )
import Data.Char ( toLower, isPunctuation ) import Data.Char ( toLower, isPunctuation )
import Control.Monad.State import Control.Monad.State
import Text.Pandoc.Pretty import Text.Pandoc.Pretty
@ -57,6 +58,7 @@ data WriterState =
, stGraphics :: Bool -- true if document contains images , stGraphics :: Bool -- true if document contains images
, stLHS :: Bool -- true if document has literate haskell code , stLHS :: Bool -- true if document has literate haskell code
, stBook :: Bool -- true if document uses book or memoir class , stBook :: Bool -- true if document uses book or memoir class
, stCsquotes :: Bool -- true if document uses csquotes
} }
-- | Convert Pandoc to LaTeX. -- | Convert Pandoc to LaTeX.
@ -68,7 +70,8 @@ writeLaTeX options document =
stVerbInNote = False, stEnumerate = False, stVerbInNote = False, stEnumerate = False,
stTable = False, stStrikeout = False, stSubscript = False, stTable = False, stStrikeout = False, stSubscript = False,
stUrl = False, stGraphics = False, stUrl = False, stGraphics = False,
stLHS = False, stBook = writerChapters options } stLHS = False, stBook = writerChapters options,
stCsquotes = False }
pandocToLaTeX :: WriterOptions -> Pandoc -> State WriterState String pandocToLaTeX :: WriterOptions -> Pandoc -> State WriterState String
pandocToLaTeX options (Pandoc (Meta title authors date) blocks) = do pandocToLaTeX options (Pandoc (Meta title authors date) blocks) = do
@ -78,6 +81,10 @@ pandocToLaTeX options (Pandoc (Meta title authors date) blocks) = do
"{report}" `isSuffixOf` x) "{report}" `isSuffixOf` x)
when (any usesBookClass (lines template)) $ when (any usesBookClass (lines template)) $
modify $ \s -> s{stBook = True} modify $ \s -> s{stBook = True}
-- check for \usepackage...{csquotes}; if present, we'll use
-- \enquote{...} for smart quotes:
when ("{csquotes}" `isInfixOf` template) $
modify $ \s -> s{stCsquotes = True}
opts <- liftM stOptions get opts <- liftM stOptions get
let colwidth = if writerWrapText opts let colwidth = if writerWrapText opts
then Just $ writerColumns opts then Just $ writerColumns opts
@ -380,22 +387,30 @@ inlineToLaTeX (Code _ str) = do
else return $ text $ "\\texttt{" ++ stringToLaTeX str ++ "}" else return $ text $ "\\texttt{" ++ stringToLaTeX str ++ "}"
inlineToLaTeX (Quoted SingleQuote lst) = do inlineToLaTeX (Quoted SingleQuote lst) = do
contents <- inlineListToLaTeX lst contents <- inlineListToLaTeX lst
let s1 = if (not (null lst)) && (isQuoted (head lst)) csquotes <- liftM stCsquotes get
then "\\," if csquotes
else empty then return $ "\\enquote" <> braces contents
let s2 = if (not (null lst)) && (isQuoted (last lst)) else do
then "\\," let s1 = if (not (null lst)) && (isQuoted (head lst))
else empty then "\\,"
return $ char '`' <> s1 <> contents <> s2 <> char '\'' else empty
let s2 = if (not (null lst)) && (isQuoted (last lst))
then "\\,"
else empty
return $ char '`' <> s1 <> contents <> s2 <> char '\''
inlineToLaTeX (Quoted DoubleQuote lst) = do inlineToLaTeX (Quoted DoubleQuote lst) = do
contents <- inlineListToLaTeX lst contents <- inlineListToLaTeX lst
let s1 = if (not (null lst)) && (isQuoted (head lst)) csquotes <- liftM stCsquotes get
then "\\," if csquotes
else empty then return $ "\\enquote" <> braces contents
let s2 = if (not (null lst)) && (isQuoted (last lst)) else do
then "\\," let s1 = if (not (null lst)) && (isQuoted (head lst))
else empty then "\\,"
return $ "``" <> s1 <> contents <> s2 <> "''" else empty
let s2 = if (not (null lst)) && (isQuoted (last lst))
then "\\,"
else empty
return $ "``" <> s1 <> contents <> s2 <> "''"
inlineToLaTeX Apostrophe = return $ char '\'' inlineToLaTeX Apostrophe = return $ char '\''
inlineToLaTeX EmDash = return "---" inlineToLaTeX EmDash = return "---"
inlineToLaTeX EnDash = return "--" inlineToLaTeX EnDash = return "--"