From 8abe08d6d43b77fe05f3b942a28b0f1a987753bd Mon Sep 17 00:00:00 2001 From: John MacFarlane Date: Sat, 28 Jan 2012 11:41:26 -0800 Subject: [PATCH] Made `beamer` an output format, removed `pdf` as output format. Removed `--beamer` option; instead, use `beamer` as output format. There is no longer a `pdf` output format; instead, pandoc tries to produce a pdf if the output file has a `.pdf` extension. (The output format can be latex -- the default for pdf output, latex+lhs, or beamer.) This seems more consistent with the way pandoc currently works (e.g. we have an `html5` output format, not an `--html5` option). --- README | 88 ++++++++++++++++-------------------- src/Text/Pandoc.hs | 2 + src/Text/Pandoc/Templates.hs | 2 +- src/pandoc.hs | 60 ++++++++++++------------ 4 files changed, 74 insertions(+), 78 deletions(-) diff --git a/README b/README index de0a2124c..23b43d2c0 100644 --- a/README +++ b/README @@ -14,11 +14,11 @@ Pandoc is a [Haskell] library for converting from one markup format to another, and a command-line tool that uses this library. It can read [markdown] and (subsets of) [Textile], [reStructuredText], [HTML], and [LaTeX]; and it can write plain text, [markdown], [reStructuredText], -[XHTML], [HTML 5], [LaTeX], [ConTeXt], [RTF], [DocBook XML], -[OpenDocument XML], [ODT], [Word docx], [GNU Texinfo], [MediaWiki markup], [EPUB], -[Textile], [groff man] pages, [Emacs Org-Mode], [AsciiDoc], and [Slidy], -[DZSlides], or [S5] HTML slide shows. It can also produce [PDF] output -on systems where LaTeX is installed. +[XHTML], [HTML 5], [LaTeX] (including [beamer] slide shows), +[ConTeXt], [RTF], [DocBook XML], [OpenDocument XML], [ODT], [Word docx], [GNU +Texinfo], [MediaWiki markup], [EPUB], [Textile], [groff man] pages, [Emacs +Org-Mode], [AsciiDoc], and [Slidy], [DZSlides], or [S5] HTML slide shows. It +can also produce [PDF] output on systems where LaTeX is installed. Pandoc's enhanced version of markdown includes syntax for footnotes, tables, flexible ordered lists, definition lists, delimited code blocks, @@ -42,7 +42,7 @@ If no *input-file* is specified, input is read from *stdin*. Otherwise, the *input-files* are concatenated (with a blank line between each) and used as input. Output goes to *stdout* by default (though output to *stdout* is disabled for the `odt`, `docx`, -`pdf`, and `epub` output formats). For output to a file, use the +and `epub` output formats). For output to a file, use the `-o` option: pandoc -o output.html input.txt @@ -91,23 +91,25 @@ should pipe input and output through `iconv`: iconv -t utf-8 input.txt | pandoc | iconv -f utf-8 -`markdown2pdf` +Creating a PDF -------------- Earlier versions of pandoc came with a program, `markdown2pdf`, that used pandoc and pdflatex to produce a PDF. This is no longer needed, -since `pandoc` now has a `pdf` output format, and there is no reason -to limit input to markdown. Note that whereas `markdown2pdf` would -create an ouput file based on the input file name, `pandoc` requires -that you specify the output filename explicitly. So, +since `pandoc` can now produce `pdf` output itself. To produce a PDF, simply +specify an output file with a `.pdf` extension. Pandoc will create a latex +file and use pdflatex (or another engine, see `--latex-engine`) to convert it +to PDF: - pandoc input.txt -o input.pdf --latex-engine=xelatex + pandoc test.txt -o test.pdf -does the same thing - - markdown2pdf --xetex input.txt - -used to do. +Production of a PDF requires that a LaTeX engine be installed (see +`--latex-engine`, below), and assumes that the following LaTeX packages are +available: `amssymb`, `amsmath`, `ifxetex`, `ifluatex`, `listings` (if the +`--listings` option is used), `fancyvrb`, `enumerate`, `ctable`, `url`, +`graphicx`, `hyperref`, `ulem`, `babel` (if the `lang` variable is set), +`fontspec` (if `xelatex` or `lualatex` is used as the LaTeX engine), `xltxtra` +and `xunicode` (if `xelatex` is used). `hsmarkdown` ------------ @@ -144,32 +146,24 @@ General options : Specify output format. *FORMAT* can be `native` (native Haskell), `json` (JSON version of native AST), `plain` (plain text), `markdown` (markdown), `rst` (reStructuredText), `html` (XHTML 1), - `html5` (HTML 5), `latex` (LaTeX), `context` (ConTeXt), - `man` (groff man), `mediawiki` (MediaWiki markup), `textile` - (Textile), `org` (Emacs Org-Mode), `texinfo` (GNU Texinfo), `docbook` - (DocBook XML), `opendocument` (OpenDocument XML), `odt` (OpenOffice text - document), `docx` (Word docx), `epub` (EPUB book), `asciidoc` (AsciiDoc), - `slidy` (Slidy HTML and javascript slide show), `dzslides` (HTML5 + - javascript slide show), `s5` (S5 HTML and javascript slide show), - `rtf` (rich text format), or `pdf` (PDF). Note that `odt` and `epub` output - will not be directed to *stdout*; an output filename must be specified - using the `-o/--output` option. If `+lhs` is appended to `markdown`, `rst`, - `latex`, `html`, or `html5`, the output will be rendered as literate Haskell - source: see [Literate Haskell support](#literate-haskell-support), below. - - Production of `pdf` output requires that a LaTeX engine be installed - (see `--latex-engine`, below), and assumes that the following LaTeX - packages are available: `amssymb`, `amsmath`, `ifxetex`, `ifluatex`, - `listings` (if the `--listings` option is used), `fancyvrb`, - `enumerate`, `ctable`, `url`, `graphicx`, `hyperref`, `ulem`, - `babel` (if the `lang` variable is set), `fontspec` (if `xelatex` - or `lualatex` is used as the LaTeX engine), `xltxtra` and - `xunicode` (if `xelatex` is used). + `html5` (HTML 5), `latex` (LaTeX), `beamer` (LaTeX beamer slide show), + `context` (ConTeXt), `man` (groff man), `mediawiki` (MediaWiki markup), + `textile` (Textile), `org` (Emacs Org-Mode), `texinfo` (GNU Texinfo), + `docbook` (DocBook XML), `opendocument` (OpenDocument XML), `odt` + (OpenOffice text document), `docx` (Word docx), `epub` (EPUB book), + `asciidoc` (AsciiDoc), `slidy` (Slidy HTML and javascript slide show), + `dzslides` (HTML5 + javascript slide show), `s5` (S5 HTML and javascript + slide show), or `rtf` (rich text format). Note that `odt` and `epub` + output will not be directed to *stdout*; an output filename must + be specified using the `-o/--output` option. If `+lhs` is appended + to `markdown`, `rst`, `latex`, `html`, or `html5`, the output will + be rendered as literate Haskell source: see [Literate Haskell + support](#literate-haskell-support), below. `-o` *FILE*, `--output=`*FILE* : Write output to *FILE* instead of *stdout*. If *FILE* is `-`, output will go to *stdout*. (Exception: if the output - format is `odt`, `docx`, `pdf`, or `epub`, output to stdout is disabled.) + format is `odt`, `docx`, or `epub`, output to stdout is disabled.) `--data-dir=`*DIRECTORY* : Specify the user data directory to search for pandoc data files. @@ -248,7 +242,8 @@ General writer options `-s`, `--standalone` : Produce output with an appropriate header and footer (e.g. a - standalone HTML, LaTeX, or RTF file, not a fragment). + standalone HTML, LaTeX, or RTF file, not a fragment). This option + is set automatically for `pdf`, `epub`, `docx`, and `odt` output. `--template=`*FILE* : Use *FILE* as a custom template for the generated document. Implies @@ -359,10 +354,6 @@ Options affecting specific writers `--listings` : Use listings package for LaTeX code blocks -`--beamer` -: Produce LaTeX output for the `beamer` document class. - This has an effect only for `latex` or `pdf` output. - `-i`, `--incremental` : Make list items in slide shows display incrementally (one by one). The default is for lists to be displayed all at once. @@ -1979,8 +1970,7 @@ Producing slide shows with Pandoc You can use Pandoc to produce an HTML + javascript slide presentation that can be viewed via a web browser. There are three ways to do this, using [S5], [DZSlides], or [Slidy]. You can also produce a PDF slide -show using [LaTeX beamer]: just use the `--beamer` option with `pdf` -output. +show using LaTeX [beamer]. Here's the markdown source for a simple slide show, `habits.txt`: @@ -2030,7 +2020,7 @@ for Slidy, for DZSlides, or - pandoc --beamer habits.txt -o habits.pdf + pandoc -t beamer habits.txt -o habits.pdf for beamer. @@ -2110,7 +2100,7 @@ be modified there. To style beamer slides, you can specify a beamer "theme" or "colortheme" using the `-V` option: - pandoc --beamer habits.txt -V theme:Warsaw -o habits.pdf + pandoc -t beamer habits.txt -V theme:Warsaw -o habits.pdf Literate Haskell support ======================== @@ -2177,7 +2167,7 @@ Christopher Sawicki, Kelsey Hightower. [HTML 5]: http://www.w3.org/TR/html5/ [XHTML]: http://www.w3.org/TR/xhtml1/ [LaTeX]: http://www.latex-project.org/ -[LaTeX beamer]: http://www.tex.ac.uk/CTAN/macros/latex/contrib/beamer +[beamer]: http://www.tex.ac.uk/CTAN/macros/latex/contrib/beamer [ConTeXt]: http://www.pragma-ade.nl/ [RTF]: http://en.wikipedia.org/wiki/Rich_Text_Format [DocBook XML]: http://www.docbook.org/ diff --git a/src/Text/Pandoc.hs b/src/Text/Pandoc.hs index 1eab57fcb..878f0e0dd 100644 --- a/src/Text/Pandoc.hs +++ b/src/Text/Pandoc.hs @@ -190,6 +190,8 @@ writers = [("native" , writeNative) ,("latex" , writeLaTeX) ,("latex+lhs" , \o -> writeLaTeX o{ writerLiterateHaskell = True }) + ,("beamer" , \o -> + writeLaTeX o{ writerBeamer = True }) ,("context" , writeConTeXt) ,("texinfo" , writeTexinfo) ,("man" , writeMan) diff --git a/src/Text/Pandoc/Templates.hs b/src/Text/Pandoc/Templates.hs index ca2776ffc..73aba4de4 100644 --- a/src/Text/Pandoc/Templates.hs +++ b/src/Text/Pandoc/Templates.hs @@ -85,7 +85,7 @@ getDefaultTemplate _ "native" = return $ Right "" getDefaultTemplate _ "json" = return $ Right "" getDefaultTemplate _ "docx" = return $ Right "" getDefaultTemplate user "odt" = getDefaultTemplate user "opendocument" -getDefaultTemplate user "pdf" = getDefaultTemplate user "latex" +getDefaultTemplate user "beamer" = getDefaultTemplate user "latex" getDefaultTemplate user "epub" = getDefaultTemplate user "html" getDefaultTemplate user writer = do let format = takeWhile (/='+') writer -- strip off "+lhs" if present diff --git a/src/pandoc.hs b/src/pandoc.hs index ecebe18f6..c159d61f7 100644 --- a/src/pandoc.hs +++ b/src/pandoc.hs @@ -83,7 +83,7 @@ wrapWords indent c = wrap' (c - indent) (c - indent) else ", " ++ x ++ wrap' cols (remaining - (length x + 2)) xs nonTextFormats :: [String] -nonTextFormats = ["odt","docx","epub","pdf"] +nonTextFormats = ["odt","docx","epub"] -- | Data structure for command line options. data Opt = Opt @@ -130,7 +130,6 @@ data Opt = Opt , optAbbrevsFile :: Maybe FilePath , optListings :: Bool -- ^ Use listings package for code blocks , optLaTeXEngine :: String -- ^ Program to use for latex -> pdf - , optBeamer :: Bool -- ^ Produce latex output for beamer class , optSlideLevel :: Maybe Int -- ^ Header level that creates slides , optSetextHeaders :: Bool -- ^ Use atx headers for markdown level 1-2 } @@ -181,7 +180,6 @@ defaultOpts = Opt , optAbbrevsFile = Nothing , optListings = False , optLaTeXEngine = "pdflatex" - , optBeamer = False , optSlideLevel = Nothing , optSetextHeaders = True } @@ -436,11 +434,6 @@ options = (\opt -> return opt { optListings = True })) "" -- "Use listings package for LaTeX code blocks" - , Option "" ["beamer"] - (NoArg - (\opt -> return opt { optBeamer = True })) - "" -- "Produce latex output for beamer class" - , Option "i" ["incremental"] (NoArg (\opt -> return opt { optIncremental = True })) @@ -732,7 +725,7 @@ defaultWriterName x = ".epub" -> "epub" ".org" -> "org" ".asciidoc" -> "asciidoc" - ".pdf" -> "pdf" + ".pdf" -> "latex" ['.',y] | y `elem` ['1'..'9'] -> "man" _ -> "html" @@ -815,7 +808,6 @@ main = do , optCiteMethod = citeMethod , optListings = listings , optLaTeXEngine = latexEngine - , optBeamer = beamer , optSlideLevel = slideLevel , optSetextHeaders = setextHeaders } = opts @@ -845,7 +837,13 @@ main = do then defaultWriterName outputFile else writerName - when (writerName' == "pdf") $ do + let pdfOutput = map toLower (takeExtension outputFile) == ".pdf" + + when pdfOutput $ do + -- make sure writer is latex or beamer + unless (writerName' == "latex" || writerName' == "beamer" || + writerName' == "latex+lhs") $ + err 47 $ "cannot produce pdf output with " ++ writerName' ++ " writer" -- check for latex program mbLatex <- findExecutable latexEngine case mbLatex of @@ -858,7 +856,7 @@ main = do Just r -> return r Nothing -> err 7 ("Unknown reader: " ++ readerName') - let standalone' = standalone || (`elem` nonTextFormats) writerName' + let standalone' = standalone || writerName' `elem` nonTextFormats || pdfOutput templ <- case templatePath of _ | not standalone' -> return "" @@ -925,13 +923,13 @@ main = do stateStandalone = standalone', stateCitations = map CSL.refId refs, stateSmart = smart || writerName' `elem` - ["latex", "context", "latex+lhs", "pdf"], + ["latex", "context", "latex+lhs", "beamer"], stateOldDashes = oldDashes, stateColumns = columns, stateStrict = strict, stateIndentedCodeClasses = codeBlockClasses, stateApplyMacros = writerName' `notElem` - ["latex", "latex+lhs", "pdf"] } + ["latex", "latex+lhs", "beamer"] } let writerOptions = defaultWriterOptions { writerStandalone = standalone', @@ -965,7 +963,7 @@ main = do slideVariant == DZSlides, writerChapters = chapters, writerListings = listings, - writerBeamer = beamer, + writerBeamer = writerName' == "beamer", writerSlideLevel = slideLevel, writerHighlight = highlight, writerHighlightStyle = highlightStyle, @@ -1013,24 +1011,30 @@ main = do processBiblio cslfile' cslabbrevs refs doc1 else return doc1 + let writeBinary :: B.ByteString -> IO () + writeBinary = B.writeFile (encodeString outputFile) + + let writerFn :: FilePath -> String -> IO () + writerFn "-" = UTF8.putStr + writerFn f = UTF8.writeFile f + case lookup writerName' writers of - Nothing | writerName' == "epub" -> - writeEPUB epubStylesheet writerOptions doc2 >>= writeBinary - | writerName' == "odt" -> - writeODT referenceODT writerOptions doc2 >>= writeBinary - | writerName' == "docx" -> - writeDocx referenceDocx writerOptions doc2 >>= writeBinary - | writerName' == "pdf" -> - do res <- tex2pdf latexEngine $ writeLaTeX writerOptions doc2 + Nothing + | writerName' == "epub" -> + writeEPUB epubStylesheet writerOptions doc2 >>= writeBinary + | writerName' == "odt" -> + writeODT referenceODT writerOptions doc2 >>= writeBinary + | writerName' == "docx" -> + writeDocx referenceDocx writerOptions doc2 >>= writeBinary + | otherwise -> err 9 ("Unknown writer: " ++ writerName') + Just _ + | pdfOutput -> do + res <- tex2pdf latexEngine $ writeLaTeX writerOptions doc2 case res of Right pdf -> writeBinary pdf Left err' -> err 43 $ toString err' - | otherwise -> err 9 ("Unknown writer: " ++ writerName') - where writeBinary = B.writeFile (encodeString outputFile) Just r -> writerFn outputFile =<< postProcess result - where writerFn "-" = UTF8.putStr - writerFn f = UTF8.writeFile f - result = r writerOptions doc2 ++ ['\n' | not standalone'] + where result = r writerOptions doc2 ++ ['\n' | not standalone'] htmlFormats = ["html","html+lhs","s5","slidy","dzslides"] postProcess = if selfContained && writerName' `elem` htmlFormats then makeSelfContained datadir