summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn MacFarlane <fiddlosopher@gmail.com>2013-01-18 10:33:37 -0800
committerJohn MacFarlane <fiddlosopher@gmail.com>2013-01-18 10:33:37 -0800
commit8eab759a9c72e98b8e47d7c4b19d6aeb3e24cdcb (patch)
tree4920140f776294e25fefb7a6a2cddba49e045bd5
parent4aea26e8e1179a2feb1672256b1b9317d2c3baf8 (diff)
RTF writer: Added writeRTFWithEmbeddedImages.
* RTF writer: Export writeRTFWithEmbeddedImages instead of rtfEmbedImage. * Text.Pandoc: Use writeRTFWithEmbeddedImages for RTF. * Moved code for embedding images in RTF out of pandoc.hs.
m---------data/templates10
-rw-r--r--pandoc.hs12
-rw-r--r--src/Text/Pandoc.hs3
-rw-r--r--src/Text/Pandoc/Writers/RTF.hs9
-rw-r--r--tests/tables.rtf1
5 files changed, 18 insertions, 17 deletions
diff --git a/data/templates b/data/templates
-Subproject 25386101d5428eedca69089ab8e5373f0a079bf
+Subproject b49608bf92ad66f255cd3371da834ddb7bee521
diff --git a/pandoc.hs b/pandoc.hs
index 61499ad69..536e3566e 100644
--- a/pandoc.hs
+++ b/pandoc.hs
@@ -1062,10 +1062,6 @@ main = do
let doc0 = foldr ($) doc transforms
- doc1 <- if "rtf" `isPrefixOf` writerName'
- then bottomUpM rtfEmbedImage doc0
- else return doc0
-
let writeBinary :: B.ByteString -> IO ()
writeBinary = B.writeFile (UTF8.encodePath outputFile)
@@ -1075,15 +1071,15 @@ main = do
case getWriter writerName' of
Left e -> err 9 e
- Right (IOStringWriter f) -> f writerOptions doc1 >>= writerFn outputFile
- Right (IOByteStringWriter f) -> f writerOptions doc1 >>= writeBinary
+ Right (IOStringWriter f) -> f writerOptions doc0 >>= writerFn outputFile
+ Right (IOByteStringWriter f) -> f writerOptions doc0 >>= writeBinary
Right (PureStringWriter f)
| pdfOutput -> do
- res <- tex2pdf latexEngine $ f writerOptions doc1
+ res <- tex2pdf latexEngine $ f writerOptions doc0
case res of
Right pdf -> writeBinary pdf
Left err' -> err 43 $ UTF8.toStringLazy err'
- | otherwise -> selfcontain (f writerOptions doc1 ++
+ | otherwise -> selfcontain (f writerOptions doc0 ++
['\n' | not standalone'])
>>= writerFn outputFile . handleEntities
where htmlFormat = writerName' `elem`
diff --git a/src/Text/Pandoc.hs b/src/Text/Pandoc.hs
index be9c8f573..4301ad49a 100644
--- a/src/Text/Pandoc.hs
+++ b/src/Text/Pandoc.hs
@@ -103,7 +103,6 @@ module Text.Pandoc
-- * Miscellaneous
, getReader
, getWriter
- , rtfEmbedImage
, jsonFilter
, ToJsonFilter(..)
) where
@@ -243,7 +242,7 @@ writers = [
,("rst" , PureStringWriter writeRST)
,("mediawiki" , PureStringWriter writeMediaWiki)
,("textile" , PureStringWriter writeTextile)
- ,("rtf" , PureStringWriter writeRTF)
+ ,("rtf" , IOStringWriter writeRTFWithEmbeddedImages)
,("org" , PureStringWriter writeOrg)
,("asciidoc" , PureStringWriter writeAsciiDoc)
]
diff --git a/src/Text/Pandoc/Writers/RTF.hs b/src/Text/Pandoc/Writers/RTF.hs
index f2a271c1d..ca33cb0e9 100644
--- a/src/Text/Pandoc/Writers/RTF.hs
+++ b/src/Text/Pandoc/Writers/RTF.hs
@@ -27,12 +27,13 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Conversion of 'Pandoc' documents to RTF (rich text format).
-}
-module Text.Pandoc.Writers.RTF ( writeRTF, rtfEmbedImage ) where
+module Text.Pandoc.Writers.RTF ( writeRTF, writeRTFWithEmbeddedImages ) where
import Text.Pandoc.Definition
import Text.Pandoc.Options
import Text.Pandoc.Shared
import Text.Pandoc.Readers.TeXMath
import Text.Pandoc.Templates (renderTemplate)
+import Text.Pandoc.Generic (bottomUpM)
import Data.List ( isSuffixOf, intercalate )
import Data.Char ( ord, isDigit, toLower )
import System.FilePath ( takeExtension )
@@ -64,6 +65,12 @@ rtfEmbedImage x@(Image _ (src,_)) = do
else return x
rtfEmbedImage x = return x
+-- | Convert Pandoc to a string in rich text format, with
+-- images embedded as encoded binary data.
+writeRTFWithEmbeddedImages :: WriterOptions -> Pandoc -> IO String
+writeRTFWithEmbeddedImages options doc =
+ writeRTF options `fmap` bottomUpM rtfEmbedImage doc
+
-- | Convert Pandoc to a string in rich text format.
writeRTF :: WriterOptions -> Pandoc -> String
writeRTF options (Pandoc (Meta title authors date) blocks) =
diff --git a/tests/tables.rtf b/tests/tables.rtf
index e7c1e9f60..011724967 100644
--- a/tests/tables.rtf
+++ b/tests/tables.rtf
@@ -357,4 +357,3 @@
}
\intbl\row}
{\pard \ql \f0 \sa180 \li0 \fi0 \par}
-