Introduction

I’ve started working on a children’s book called ``m00n’’ (about which, more on another day) and am using the R bookdown package. This package creates a variety of formats, including pdf and epub.

As explained at [1], Epub format is used quite widely for electronic publishing, and works with a lot of readers (apparently, not including kindle, but I’ve not tested that yet). The fact that R bookdown uses epub is good enough to convince me that it’s a useful format, kindle notwithstanding.

In building the book, I saw the output (I added back-slashes to indicate line continuation)

/usr/local/bin/pandoc \
+RTS -K512m -RTS \
m00n.utf8.md \
--to epub3 \
--from markdown+autolink_bare_uris+tex_math_single_backslash \
--output m00n.epub \
--number-sections \
--filter /usr/local/bin/pandoc-citeproc

Although I have not looked in detail at the pandoc documentation, I think I can make some educated guesses as to what is going on:

So, let’s try making our own epub file. First, create a file named a.md containing

Hi kids.

1. This is a test.
2. Just a test.

Oh, isn’t $\pi$ a sweetie-pie.

Second, run pandoc with

pandoc a.md --o=epub3 --output=a.epub --metadata title=‘test’

where the title part is to prevent an error. (The error suggested how to solve the problem. There is also something called pagetitle that seems related.)

And that’s it. You’ll have a file a.epub that you can read on a variety of devices. And it ought to render well on all of them, adjusting to screen size and geometry. It has nice navigation features for going between pages, etc. This will all be familiar to people who read books this way.

References and resources

  1. epub wikipedia page

  2. Jekyll source code for this blog entry: 2020-01-31-pandoc-epub.Rmd

This website is written in Jekyll, and the source is available on GitHub.