CHANGES IN bookdown VERSION 0.44
CRAN release: 2025-08-21
Figure numbering is now correctly working in HTML with Pandoc 3, when Markdown syntax is used to include images (thanks, @N0rbert, #1467).
Removed the CSS property
-webkit-touch-callout: none;fromgitbook(thanks, @AlbertLei, #1500).
CHANGES IN bookdown VERSION 0.43
CRAN release: 2025-04-15
- Support
split_byfor section level higher than2(i.e.,##sections) ingitbook(thanks, @katrinabrock #1490, @lcougnaud #1346 #1347).
CHANGES IN bookdown VERSION 0.42
CRAN release: 2025-01-07
New option in
gitbook’s font settings menu to control line spacing (thanks, @hayden-MB, #1479).New configuration setting
include_mdto control whether the input search includes.mdsource files in addition to.Rmd(thanks, @katrinabrock #1483, @kylelundstedt #956).
CHANGES IN bookdown VERSION 0.41
CRAN release: 2024-10-15
- New
mathjax-configoption forbs4_bookandgitbookto control MathJax config string (thanks, @bwu62, #1472). The option can be set either in the YAML metadata or as a variable inpandoc_args. Currently tested and supported settings:- If empty, defaults to original
TeX-MML-AM_CHTMLwhich renders all equations in common HTML. - If set to
TeX-AMS-MML_HTMLorMMLrenders equations in HTML + CSS (which may look nicer for some equations). - If set to
TeX-MML-AM_SVGrenders equations in SVG.
- If empty, defaults to original
- Fixed the bug that
render_book()fails due tofile.rename()being unable to rename files across different disk volumes (thanks, @Giqles @katrinabrock, #804).
CHANGES IN bookdown VERSION 0.39
CRAN release: 2024-04-15
- Fixed a bug that
bs4_book()errors on generating document description. The error occured when the beggining of the document is a very long sentence without spaces (> 197 characters), which typically happens in CJK languages (thanks, @atusy, #1463).
CHANGES IN bookdown VERSION 0.37
CRAN release: 2023-12-01
Custom config files passed to the
config_fileargument ofrender_book()are no longer temporarily renamed to_bookdown.yml(thanks, @debruine, #1307).Do not move all
_filesdirectories temporarily to the_bookdown_filesdirectory when callingrender_book()(thanks, @steeleb, #1307).
CHANGES IN bookdown VERSION 0.36
CRAN release: 2023-10-16
Fix an issue with parsing resources from raw HTML code (thanks, @lennylin, https://community.rstudio.com/t/bookdown-image-with-a-weblink/172542)
R 4.3.x would error if multiple files are passed to
render_book()without anoutput_formatspecified (thanks, @slodge-work, #1442).
CHANGES IN bookdown VERSION 0.35
CRAN release: 2023-08-09
- Search configuration in
bs4_book()will now return more results as Field-Length Norm is now ignored. This means the length of the search fields do not matter anymore in the scoring. Previous configuration was ignoring some search results being considered with a too low score (thanks, @jtbayly, #1431).
CHANGES IN bookdown VERSION 0.34
CRAN release: 2023-05-09
Fix an issue with CSL using hanging indent style in
gitbook()(thanks, @pablobernabeu, #1422).Fix cross referencing of figures and tables in
epub_book()format by correctly adding an anchor id at the caption level (thanks, @muschellij2, #766, @tstratopoulos, @jasonmosborne, #1399, @N0rbert, rstudio/bookdown-demo#42).Adapt an
epub_book()internal command-line argument passed to Pandoc for changes from version 3.0 and above (#1425).Fix an issue with Pandoc 2.19 not rendering math by default in
epub3format (#1417).
CHANGES IN bookdown VERSION 0.32
CRAN release: 2023-01-17
The defunct
kindlegen()has been removed from this package.Theorem and Proof environments are now supported again in HTML slide format
slidy_presentation2()(thanks, @urx449, #1398).
CHANGES IN bookdown VERSION 0.30
CRAN release: 2022-11-09
Support specific markdown content like list or code chunk inside Theorem and Proof special environments (#1371).
Fix regression about special usage of bookdown project not using
index.Rmdas main file. It is recommended to useindex.Rmdin all projects, but workflow has been improved for other cases (thanks, @otoomet, #1349).
CHANGES IN bookdown VERSION 0.29
CRAN release: 2022-09-12
The argument
code_foldingworks for thegitbook()output format now (thanks, @atusy, #1368).Setting
toc_depthortoc_floatinbs4_book()will now throw an error liketocto make it clear that TOC is not an opt-out choice and can’t be customize (thanks, @karlmay88, #1377).
CHANGES IN bookdown VERSION 0.27
CRAN release: 2022-06-14
Fix
fence_theorems()so thatoutputis not ignored anymore. With previous version, whenoutputwas different thanNULL, the result was written toinput, ignoringoutputvalue. From now on, setinputandoutputto the same file if you want to overwrite (thanks, @Scinawa, #1342).Tweak
bs4_book()default CSS for better support of python chunk highlighting (thanks, @briandk, #1333).Fix an issue with guessing output format when no
output_formatis provided inrender_book()for files in armd_subdirfolder (thanks, @shivam7898, #1331).Fix the issue of the invisible
gitbooktoolbar on iPad (thanks, @mpereira-dev, #60).
CHANGES IN bookdown VERSION 0.26
CRAN release: 2022-04-15
Fix issues with TOC in
gitbook()and Pandoc 2.18 (thanks, @avraam-inside, #1326, #1329).Fix an issue with per-format
rmd_filesconfig when nooutput_formatwas provided inrender_book()(thanks, @ellessenne, #1323).Added support for theorem/proof environments back for Word/EPUB/ODT output (thanks, @N0rbert, #1313).
kindlegen()is defunct now.
CHANGES IN bookdown VERSION 0.25
CRAN release: 2022-03-16
NEW FEATURES
Set option
bookdown.theorem.enabled = FALSEto opt-out bookdown special Theorem and Proof environment syntax.options(bookdown.theorem.enabled = FALSE)must be called before the function to render the book, e.g in a project’s.Rprofile. This can be useful for advanced users who only want PDF output and needs to handle themselves the environment using LaTeX directly, or Custom Blocks syntax without bookdown interfering (thanks, @finkelshtein, #1285).bs4_book()gains afootnotes_inlineargument. Set toFALSEto opt-out the default behavior of moving footnotes inline to show on hover (thanks, @Pindar777, #1253).
BUG FIXES
Fix styling of bibliography for
bs4_book()(thanks, @Selbosh, #1277).Fix an issue with Pandoc 2.17 and internationalization of Proof-like environment (#1302).
Fix an issue with Pandoc 2.17 and cross referencing sections in non HTML format (thanks, @N0rbert, #1301).
Fix an issue with Pandoc 2.15 and footnote relocation in each chapter (#1275).
Fix an issue with
html_book()andtoc.cssnot working correctly with recent pandoc (thanks, @florisvdh, #1268).Fix an issue with unneeded
header-attr.jsinserted by rmarkdown while bookdown already cleans attributes (thanks, @salim-b, #865).
MAJOR CHANGES
The
theoremandproofknitr engines no longer use theblock2knitr engine to create theorem/proof environments, but write out fencedDivs instead, which is the new syntax for these environments. Note that this means these environments are no longer supported in EPUB output (they work only in HTML and PDF), but hopefully the support will be back in the future (thanks, @deleeuw, #1178).The tag
<meta property="og:url">has been removed from the default HTML template and thegitbooktemplate (thanks, @jtbayly, #970).
CHANGES IN bookdown VERSION 0.24
CRAN release: 2021-09-02
MAJOR CHANGES
-
The default search engine for
gitbookhas been changed fromlunrtofuse. If you want to switch back tolunr, you may set:
MINOR CHANGES
Reverted the fix for #1223 since it only affects a specific version of Pandoc (2.14.1). If this issue affects you, please see #1223 for workarounds.
bs4_book()now has thetemplateargument likegitbook()(thanks, @shinneuro, #1247).
BUG FIXES
extra_dependenciesingitbook()will now be appended after Gitbook’s dependencies so that it does not get overridden (thanks, @ThierryO, @linogaliana, #1101, #1248).Fix an issue with Fenced Divs for Theorem & Proof environments in the Lua filter (thanks, @tchevri, #1233).
gitbook(self_contained = TRUE)was slow when the output contains base64-encoded images (thanks, @king2bob, #1236).The search config
search: trueorsearch: falseforgitbookthrows a misleading error (thanks, @GegznaV, #1238).
CHANGES IN bookdown VERSION 0.23
CRAN release: 2021-08-13
NEW FEATURES
This version has included a new RStudio template project to start an HTML book in
bookdown::gitbookorbookdown::bs4_book. Template projects can be created using the RStudio IDE menu “New Project”, or using one of the two new functions,create_gitbook()orcreate_bs4_book(), to easily create the template that you want to start with from within the R console (#225, #1123, #1201).Added an argument
global_numberingto most output format functions in this package to control the figure/table numbering scheme (thanks, @elfunesto #948, @Kodiologist #1057). IfTRUE, number figures and tables globally throughout a document (e.g., Figure 1, Figure 2, …). IfFALSE, number them sequentially within sections (e.g., Figure 1.1, Figure 1.2, …, Figure 5.1, Figure 5.2, …). Previously, this numbering scheme was hard-coded internally according to thenumber_sectionsargument (global_numbering = !number_sections). Now the two arguments have become independent, e.g., you can useglobal_numbering = TRUEwithnumber_sections = TRUE.For HTML book formats, a default
404.htmlpage will now be created if none exists already. This page can be customized by adding a_404.mdor_404.Rmdfile which will be rendered to HTML and inserted in the book. Most web serving platforms (e.g. Netlify, GH Pages, etc.) will use this file named404.htmlin the root as a custom error page. Otherwise, like browsers do, a default 404 page is shown. For context, a 404 error indicates that the file can’t be found, and it happens when a browser can’t find a requested web page. This could happen with your online book if you shared a link to a section but change the name of this section leading to a change in url (#1035).-
The
bookdown::gitbookoutput format now supports an alternative search engine, namelyfuse.js, which has several advantages overlunr.js, the previous search engine forgitbook. Usingfuse.jswill fix a number of long-standing issues such as #734, #735, and #792. To enablefuse.js, set the search engine to befuseingitbook’s config in YAML, e.g.,Depending on user feedback, we may set
fuseto be the default search engine in a future version of bookdown. We will appreciate your testing and feedback! bs4_book(splib_bib = TRUE)can now be specified to have the same effect as ingitbook(). References will be shown at the end of each chapter and not only at the end of the book. This is useful withbs4_book()when a citation style not supporting footnotes is used because in that case, references are not shown inline in popups (thanks, @shirdekel, #1185).-
In
bs4_book(), improvement regarding copy button:- It has now a light icon instead of a text with white background (#1192).
- It will no more show on output block code when knitr’s option is
collapse = FALSE(#1197). - It will now be placed correctly on the right side of the code block, with a light color which gets darker on hover so that it is less obtrusive when overlapping text in block with long lines (#1204). If you want to customize part of the UI to change this default behavior, you can do it using a custom css with
bs4_book().
In
bs4_book(), copy button has now a light icon instead of a text with white background (#1192).bs4_book()has now some<meta>tags that allows sharing a published book on social media.cover-image,url,titleanddescriptionset in YAML will be used inindex.htmland then modified to be adapted per HTML page (#1034).repospecification inbs4_book()can now be done in a more flexible way: base url, branch name, subdir and icon can be specify. See?bookdown::bs4_book()for details (thanks, @maelle, #1036).epub_versionargument inepub_book()can now be set toepub2to create EPUB book of version 2. This follows an old change for default behavior in Pandoc 2.0 where the aliasepubdefaults toepub3and no moreepub2(thanks, @jtbayly, #1150).-
Theorem and Proof environment can now be used with
beamer_presentation2()using fenced Div syntax like thisHowever, as beamer defines its own LaTeX theorem environments, bookdown won’t add any definition in preamble as it is doing with
pdf_book(). This means user will have to define the ones supported by bookdown and not yet defined by beamer. Special environment from beamer (likefact) needs to be used with usual Custom Blocks syntax. See related issues for examples in their discussions thread (thanks, @XiangyunHuang, #1143, #1145).This change comes with several small improvements in
custom-enviromnent.luaforlatexandbeamerformat, including a new optionbookdown.theorem.preambleto opt-out bookdown addition of theorems and proofs definitions in LaTeX preamble. Set it toFALSEif you have conflict with some specific format for example (like #1001).
BUG FIXES
Removed the requirement for
.htmlfilenames to be alphanumeric, which fixes a common error “Automatically generated filenames contain duplicated ones: -” (thanks, @psychelzh #605, @AzureRabbit #902, @carloslederman #1000, Ritsu Kitagawa https://stackoverflow.com/q/60014350/559676, Shrek Tan).Fix an issue with
bookdown_site()where the comment insite:line key was not supported (thanks, @LDSamson, #1194).Figure reference links now point correctly to the top of figures (thanks, @GuillaumeBiessy, #1155).
When the
sitefield is quoted inindex.Rmd’s YAML data (i.e.,site: "bookdown::bookdown_site"), bookdown fails to identify the root directory of the book (thanks, @dchiu911, #1160).The figure/table labels are no longer duplicated in Word output generated from Pandoc 2.14.1 (thanks, @dewittpe, #1223).
When a book has multiple authors, the CSS styles for each author were inlined in the
<p>tags, and hence are hard to override. Now the classmulti-authoris applied to each individual author’s<p>tag, and the CSS rules are defined on this class instead (thanks, @robjhyndman, #1170).Style change in
bs4_book()where code block inside callout blocks will have their background fill the whole width of the bordered block (#1175).In
bs4_book(), math in footnotes is now rendered (@mine-cetinkaya-rundel, #1026)Fix an issue with
bs4_book()where text written using Line Block was not found in search (thanks, @dmklotz, #1141).
CHANGES IN bookdown VERSION 0.22
CRAN release: 2021-04-22
NEW FEATURES
New
bs4_book()theme - see?bs4_bookfor details about this new format (thanks, @hadley, #996).render_book()can now take a directory as input, i.erender_book("book_dir"), to render in this directory by using theindex.Rmdfile if it exists. The default is now to look forinput.Rmdis the current working directory. Previously, filename must have been provided (render_book()is now equivalent torender_book("index.Rmd")) (#990).hypothesisenvironment is now supported among Theorems and Proof (thanks, @shirdekel, #1102).In
_bookdown.yaml,labelfieldsfig,tabandeqcan now take a function asuifieldschapter_nameandappendix. This function takes the reference number as only argument and must return a character to be used as full label. The default is a string prepended before the reference number. This new feature gives more flexibility to change the default for other language, e.g append the label name after the number. See updated doc about Internationalization(thanks, Tamás Ferenc, #1114)Using the ‘Knit’ button now also works with a Rmd file in a sub-directory of the book project (when
rmd_subdiris used in_bookdown.yml) (#1122)WhatsApp sharing feature has been added for
gitbook()usingsharingkey inconfig. This enables sharing the bookdown URL in WhatsApp on Mobile and on Desktop (thanks, @prdm0, #1125).
BUG FIXES
Adapt CSS in
gitbook()andhtml_book()for correct displaying of<details><summary>content (thanks, @maelle, #971)When
split_bib = TRUE, references in footnotes are now also correctly relocated in the chapter (thanks, @jimhshen, #952)In
pdf_book(),toc_bib = TRUEnow works with natbib and biblatex ascitation_package(thanks, @qifei9, @umarcor, #450).CSS dependencies like
url('truetype/Spectral-ExtraLight.ttf')(with single quotes) are now correctly identified and moved (thanks, @RLesur, #991).fenced_theorems()now correctly transforms implicit label in chunk header to a fenced divs id. (thanks, @enixam, #982)References are now correctly relocated with Pandoc 2.11 when
split_bib = TRUEingitbook(). New citation processing in Pandoc 2.11 will also add new classes to the divs, and these are preserved when relocating. This allows for references styling using CSS (#981).The new syntax for theorem and proof environments introduced in bookdown requires Pandoc >= 2.3 instead of 2.0 (thanks, @markhymers, #979 #980).
serve_book()will refresh correctly now when using subdirectories withrmd_subdir(thanks, @shenfei, #834).Added the same CSS as in default Pandoc’s template for when a CSL is used (#1045).
Properly support multiple authors in the
gitbook()output format (thanks, @adamvi, #1095).No more warnings are thrown when passing several input files to
render_book(preview = TRUE)(#1091).Correctly remove reference IDs of tables (e.g
(#tab:lab)) generated by custom function (likegt::gt()) (#1099).In sepia or night mode, the background color during sidebar transition is now correct and no more white (#1100).
Fix an issue in
bs4_book()with encoding on system non-UTF8 by default (#1027).
MINOR CHANGES
-
anchor_sections = TRUEbecomes the default forbookdown::gitbook().
CHANGES IN bookdown VERSION 0.21
CRAN release: 2020-10-13
NEW FEATURES
Add the
number_sectionsargument tomarkdown_document2()and its family. This allows to have now figure references numbered by chapters in these formats, likeword_document2()orodt_document2()for example. This argument default toTRUElikehtml_document2()andpdf_document2(). Set it tonumber_sections = FALSEto get the same output as previous version without numbered chapters (thanks, @atusy, #756).Provided an alternative way to create theorem and proof environments using Pandoc’s fenced Divs. Previously, bookdown supports theorems and proofs in special code chunks like
```{theorem}. Now you can use the new syntax::: {.theorem}. You may use the helper functionbookdown::fence_theorems()to convert the former syntax to the latter. The main benefit of using fenced Divs is that you can write arbitrary content in a theorem environment (here “theorem” includes other environments such as lemma, corollary, and definition, etc.), such as R code chunks and inline R code, which was not possible previously. Note that this feature is only supported for LaTeX and HTML output formats at the moment. To learn more about the fenced Divs in general, you may read this section in R Markdown Cookbook: https://bookdown.org/yihui/rmarkdown-cookbook/custom-blocks.html (thanks, @tchevri #924, @cderv #940).
MAJOR CHANGES
The
--file-scopebehavior introduced in bookdown v0.20 is now disabled by default. This is due to broken TOC links for duplicate section names (e.g., “Exercises”; see #909) that have automatically generated identifiers.The
clean_envirargument ofbookdown::render_book()has been deprecated and will be removed in the future (thanks, @jenslaufer, #932).The function
kindlegen()has been deprecated, since Amazon no longer provides KindleGen. Please consider usingbookdown::calibre()instead if you want.mobioutput (#973).
MINOR CHANGES
- Updated documentation for
render_book()to make it clearer how options are set for theoutput_formatparameter (thanks, @jonathan-g, #958 #930).
CHANGES IN bookdown VERSION 0.20
CRAN release: 2020-06-23
NEW FEATURES
If
delete_merged_fileis set tofalsein_bookdown.yml, the merged (Rmd or md) file will not be deleted after the book is rendered (thanks, ilse pit, https://stackoverflow.com/q/61973608/559676).Numeric footnotes duplicated across chapters are now automatically renumbered. This is done by passing the
--file-scopeargument to pandoc (and having it operate on split out individual chapters of the target .md file rather than a combined file). This behavior can be toggled off by settingoptions(bookdown.render.file_scope = FALSE).
MINOR CHANGES
- Removed the
encodingargument frombookdown::render_book(). This argument has always been ignored in bookdown.
CHANGES IN bookdown VERSION 0.19
CRAN release: 2020-05-15
BUG FIXES
Multiline footnotes are now correctly rendered in HTML output (thanks, @jtbayly, @cderv, #876).
Text references do not work for
theoremenvironments (thanks, @ssp3nc3r, rstudio/tufte#75).When both
rmd_subdirandrmd_filesare provided in the config file_bookdown.yml, only the files specified inrmd_filesare now selected in addition to files underrmd_subdir. In the previous version, all files under the root directory are selected (thanks, @Gnossos #885, @cderv #886).When
rmd_subdiris provided in_bookdown.yml, the subdirectories were always alphabetically ordered instead of following the order of elements inrmd_subdir(thanks, @Rothdyt, #736).
MAJOR CHANGES
- Files with a leading
_in their names are always ignored, even if they are specified inrmd_filesin_bookdown.yml. Such files under subdirectories are also always ignored (#886).
CHANGES IN bookdown VERSION 0.18
CRAN release: 2020-03-05
NEW FEATURES
- Added an output format
context_document2, based on the newly developedrmarkdown::context_document(see rstudio/rmarkdown#1713, rstudio/rmarkdown#1715, and rstudio/rmarkdown#1725; thanks @jooyoungseo, @atusy, and @RLesur).
BUG FIXES
render_book()works correctly withoutput_dir = "."now (thanks, @julianre, @cderv, #857).Cross-referencing works correctly now with
gitbookwhen usingsplit_by: sectionorsplit_by: section+number(thanks, @ThierryO, @cderv, #787).When using the Knit-and-Merge approach to compile a book (
new_session: truein_bookdown.yml) and the fieldsbefore_chapter_scriptand/orafter_chapter_scriptare configured in_bookdown.yml, the original Rmd files are no longer touched (thanks, @clauswilke #405 and @bob-carpenter https://stackoverflow.com/q/50554196/559676), and the scripts specified inbefore/after_chapter_scriptare no longer inserted into the Rmd files (they are read and evaluated separately), so the line numbers will be correct in case of knitr errors (thanks, @arencambre, #852).
CHANGES IN bookdown VERSION 0.17
CRAN release: 2020-01-11
NEW FEATURES
- Added an output format
github_document2, which is a wrapper function based onmarkdown_document2usingrmarkdown::github_documentas the base format (thanks, @jooyoungseo, #831).
BUG FIXES
Fixed cross-reference issues with Pandoc 2.9+. Note that Pandoc 2.8 is not supported since it had a fairly short lifespan, but Pandoc below v2.8 or above v2.9 is still supported (thanks, @N0rbert @RLesur, #832; @jooyoungseo #845).
For output formats like
pdf_book, unused arguments passed tobase_formatwill be discarded (thanks, @jooyoungseo, #790).For the sake of backward-compatibility, prevent the commands
\frontmatter,\mainmatter, and\backmatterfrom being automatically added to the LaTeX output when the Pandoc version is higher than 2.7, because bookdown users may have added these commands by themselves (thanks, @remlapmot, rstudio/rmarkdown#1721).Fixed the issues yihui/bookdown-chinese#29 and yihui/bookdown-chinese#30. Such issues can occur on Windows when there are multibyte characters in the section headers, and users will run into the error “Error in file.exists(f): file name conversion problem - name too long?” (thanks, @kongdd @JiaxiangBU @gaospecial and other users who reported the same issue such as https://twitter.com/matsuchiy/status/1186653559405727744 and https://d.cosx.org/d/420961).
MINOR CHANGES
- The default value of
base_formatin themarkdown_document2format isrmarkdown::md_documentnow. Previously the default value is missing.
CHANGES IN bookdown VERSION 0.16
CRAN release: 2019-11-22
NEW FEATURES
You can also add a “view” button on the GitBook toolbar, similar to the “edit” and “history” buttons, which shows the page’s
.Rmdsource file on GitHub. Unlike “edit”, “view” does not require the reader to login to GitHub and fork the repo (thanks, @jtr13, #806).For
gitbookoutput, the font setting button can be removed viafontsettings: falsein theconfigoption. Similarly, the info button can be removed byinfo: falseinconfig(thanks, @mnazarov, #788).It is possible to customize the prefixes of appendix titles in
gitbookoutput now (the default is stillA,B,C, …, and now you can change them to something likeAppendix A,Appendix B, …); see the documentation at https://bookdown.org/yihui/bookdown/internationalization.html (thanks, @WerthPADOH, #783).Added
html_fragment2,html_notebook2,html_vignette2,ioslides_presentation2,slidy_presentation2, andbeamer_presentation2for cross-referencing capabilities on top of rmarkdown output formats (thanks, @jooyoungseo, #789 #823).
BUG FIXES
For the
gitbookoutput format, disabling thesharingmenu or buttons works again (thanks, @lwjohnst86, #812).For the
gitbookoutput format, toc collapsed by section now works with accents in chapter titles (thanks, @glimmerphoenix, @cderv, #819)For output formats
word_document2,powerpoint_presentation2, andodt_document2,$$is no longer added to equation environments when they are inside fenced code blocks (thanks, @N0rbert, #814).
CHANGES IN bookdown VERSION 0.15
CRAN release: 2019-11-12
BUG FIXES
Sharing to Facebook and Twitter is possible again. Google+ sharing has been disabled (with a warning) as this service no longer exists (thanks, @cderv, #802).
When using Pandoc 2.7.3 or later, footnotes are now placed again at the end of each chapter (#798, #801, thanks @cderv).
gitbook toolbar is not missing any more when rendering books with Pandoc 2.x and using
self_contained = TRUE(thanks, @Pindar777, @RLesur, @cderv, #739).
CHANGES IN bookdown VERSION 0.14
CRAN release: 2019-10-01
BUG FIXES
- Images specified in
toc: before:of thegitbookformat are not copied to the output directory (thanks, @dcossyleon, #763).
CHANGES IN bookdown VERSION 0.12
CRAN release: 2019-07-11
MINOR CHANGES
- Reverted #706 and removed the
clean_highlight_tagsargument inhtml_document2(); bookdown will no longer clean up the HTML tags of the syntax-highlighted code blocks.
CHANGES IN bookdown VERSION 0.11
CRAN release: 2019-05-28
BUG FIXES
- The fix for https://stackoverflow.com/q/56061122/559676 in the previous version was incorrect, causing
rmd_filesto fail when it is a character vector of Rmd filenames (thanks, Joyce Robbins and Hadley Wickham, https://stackoverflow.com/q/56118663/559676).
CHANGES IN bookdown VERSION 0.10
CRAN release: 2019-05-10
NEW FEATURES
Added an argument
clean_highlight_tagstohtml_document2()(thanks, @atusy, #706).For HTML output formats such as
gitbook, the abstract title (if the abstract is provided) can be customized via the fieldabstract-titlein the YAML frontmatter (thanks, @XiangyunHuang, #715).
BUG FIXES
Split reference sections in
gitbookignored the sorting definition of the citation style (thanks @GegznaV #661, @crsh #674).For the
gitbookoutput format, the content doesn’t get the focus when the page is loaded, which makes it fail to respond to keystrokes such as PageUp/PageDown/Up/Down (thanks, @darshanbaral #691, @aronatkins #699).For the
gitbookoutput format, when searching for keywords in code blocks, the automatic scroll to keywords doesn’t work (thanks, @colearendt, #700).The search keyword no longer persists across page loads for different books in the
gitbookformat (thanks, @aronatkins, #695).The keybindings
UpandDown(orEnter) in the search input of thegitbookoutput format work across all pages now; previously they only work on the current page (thanks, @dsblank, #657).When performing searching, the
gitbooksidebar will only display relevant TOC items that actually take users to the HTML pages containing the search keyword. Previously, some TOC items do not really take users to the search destination but an anchor on a page instead, which can be confusing (thanks, @aronatkins, #696).Hyphenated words will be correctly highlighted in the search results now if spaces are used in the search keyword instead of dashes, e.g., you can search for
hand-offusing the keywordhand off(thanks, @aronatkins, #701).When
rmd_filesis configured in_bookdown.yml,render_book()will fail if the output format is not HTML or LaTeX (thanks, Ladislas Nalborczyk, https://stackoverflow.com/q/56061122/559676).The colon after figure/table numbers is missing in Word and EPUB output (thanks, @upton9265, #618).
Multiple labels on the same line are allowed for Word output (thanks, @mdlincoln @h-k-kan @brooksambrose, #538).
MINOR CHANGES
Added alt/hover text to icons on the
gitbooktoolbar (thanks, @aronatkins, #698).Added an Information button to the
gitbooktoolbar to show the keybindings that are otherwise difficult for users to discover without reading the bookdown book (thanks, @aronatkins, #697).Added information about the keybindings Enter/Up/Down to the placeholder text and tooltip of the search input in
gitbookoutput (thanks, @pyltime, #660).
CHANGES IN bookdown VERSION 0.8
CRAN release: 2018-12-03
NEW FEATURES
Added Conjecture to the list of theorem environments.
In addition to
rmd_subdir: true, which searches all subdirectories, you can now provide a list of subdirectories to be recursively searched (#242).Added an argument
templatetogitbook()andepub_book()(thanks, @ThierryO, #570).Added an argument
table_csstogitbook()to allow customized css for tables. (thanks, @haozhu233, #642)You can also add a “history” button on the Gitbook toolbar, which is similar to the “edit” button, but shows the GIT history of a source file instead (thanks, @maelle #638, @noamross, #639).
Added a
quietargument toserve_book(), so that users can suppress stdout withbookdown::serve_book(quiet = TRUE)(thanks, @hammer, #633).For HTML output, the title of the current chapter or section will be added to the page title (in the
<title>tag). This will give readers more information when reading the results from search engines or Twitter cards. Previously, all pages would have identical titles (thanks, @benwhalley and @batpigandme, #544).
BUG FIXES
HTML output formats such as
gitbookandhtml_document2won’t work when only unnumbered parts (i.e.,# (PART\*)) are used (thanks, @tjmahr, #575).Previously the
rmd_filesparameter in_bookdown.ymlwould overridermd_subdir, but now both parameters can be used simultaneously (thanks, @ellisvalentiner, #600).Resources with URL encoded special characters are now correctly copied to the output directory (thanks, @AshesITR, #622).
serve_book()can now be used without error when rstudioapi is installed but RStudio is not being used (thanks, @jimhester, #637).Text references via
(ref:label)forbookdown::pdf_document()doesn’t always work (thanks, @brendanf, #616).
CHANGES IN bookdown VERSION 0.7
CRAN release: 2018-02-18
MINOR CHANGES
Added a new dependency tinytex to build PDF, and xfun for some utility functions.
Added the ability to share documents on LinkedIn with the
gitbookoutput format (thanks, @WeeBeasties, #523, https://stackoverflow.com/q/48494097/559676).
CHANGES IN bookdown VERSION 0.6
CRAN release: 2018-01-25
NEW FEATURES
Added an argument
config_filetorender_book()so that one can specify a custom config file; the default config file is still_bookdown.yml(thanks, @stephlocke, #465).Added a global option
bookdown.preview.cutoff(defaults to 30) for the preview moderender_book(preview = TRUE): when the number of lines of a chapter is smaller or equal to this number, the full chapter is included in the preview; otherwise, only the section titles are extracted from the chapter for preview.
BUG FIXES
Various compatibility issues with Pandoc 2.0 (thanks, @maxheld83 #479, @jerrythomas #481, @Hantabaru #483, @dataopt #504, and #478).
split_by = 'section'does not work completely correctly for the HTML output formats likegitbook(thanks, @dataopt, #502).
CHANGES IN bookdown VERSION 0.5
CRAN release: 2017-08-20
BUG FIXES
The book cannot be properly rendered when the option
book_filenamein_bookdown.ymlcontains a dot (thanks, @pinusm, #410).Proof and Remark blocks do not work well for EPUB output (thanks, @mamaciasq, #443).
When
split_by = 'section'for thegitbookoutput format, navigation buttons are missing on the page before the appendix (thanks, @dataopt, #409).
CHANGES IN bookdown VERSION 0.4
CRAN release: 2017-05-20
NEW FEATURES
Added special syntax for unnumbered part headers:
# (PART\*). Numbered parts should be written after# (PART)as before (thanks, @brooksambrose, https://stackoverflow.com/q/43688902/559676).The
gitbookoutput format also supportsabstractin YAML now (thanks, @maxheld83, #311).For the
gitbookoutput format, thedownloadsoption inconfigsupportsrmdnow (e.g.download: ["pdf", "epub", "rmd"]) if the edit link has been specified and is a link to Github (thanks, @coatless, #330).You can set the global R option
bookdown.post.latexviaoptions()to be a function to post-process the LaTeX output of thepdf_bookformat; see?bookdown::pdf_bookfor details (thanks, @nicksolomon, #373).
BUG FIXES
The HTML output file is not moved to the output directory when
split_by = 'none'inbookdown::gitbookorbookdown::html_book(https://stackoverflow.com/q/40976073/559676).The YAML option
includes: before_bodyworks correctly forgitbookoutput now (thanks, @benmarwick, #267).Theorem environments are not defined for LaTeX output unless a
theoremblock is present (thanks, @JeffreyRacine, #291).For
remarkandproofblocks, the chunk optionnamedid not work correctly for non-LaTeX output (thanks, @ugroempi, #347).Some text references do not work for HTML and Word output (thanks, @ugroempi, #363).
The option
chapter_namein_bookdown.ymldoes not work when it is specified as a function (thanks, @tzerk, 0c05c3828be).External assets such as fonts/css files should never be wiped when rendering a book to HTML (thanks, @nicholaelaw, #398).
MINOR CHANGES
The
daemonargument was removed fromserve_book(), but you can still pass it toservr::httw()via the...argument.Added a small space (padding) to the right of section numbers in
gitbookoutput, so that the section numbers are better separated from the titles (thanks, @aronatkins, #367).
CHANGES IN bookdown VERSION 0.3
CRAN release: 2016-11-28
NEW FEATURES
Added a Github button in the group of sharing buttons on the toolbar. By default, this button is not displayed. You have to set
github: yesundersharingin thegitbookconfigurations (https://bookdown.org/yihui/bookdown/html.html) and specify your Github repo using the top-level optiongithub-repoin the YAML metadata ofindex.Rmd, e.g.github-repo: rstudio/bookdown.The appendix heading will be preserved in
bookdown::html_document2output, e.g. if you have# (APPENDIX) Appendix {-}in your document, you will see the headingAppendixin the output. Previously it was removed.Parts in HTML output are also be numbered using roman numerals like LaTeX/PDF output.
BUG FIXES
Wrong part titles were inserted to the table of contents of PDF output (thanks, @florisvdh, #243).
Cross-references for appendices in
html_document2output did not work (thanks, @florisvdh, #245).Part titles were not correctly processed when they were longer than 20 characters in PDF output (thanks, @florisvdh, #246).
CHANGES IN bookdown VERSION 0.2
CRAN release: 2016-11-12
NEW FEATURES
Added arguments
toc_unnumberred,toc_appendix,toc_bib, andquote_footertopdf_book().Added support for cross-referencing equations in multi-page HTML output and EPUB; see https://bookdown.org/yihui/bookdown/ for the syntax (thanks, @deleeuw, #85).
Rmd files can live in subdirectories if you use the Merge-and-Knit approach (the default), and they will be found if the configuration option
rmd_subdiris true in_bookdown.yml(thanks, @leobuchignani, #205).
MAJOR CHANGES
- The
force_knitargument ofrender_book()was removed (to avoid confusion when switching output formats).
MINOR CHANGES
The merged R Markdown file will not be deleted if rendering failed so you can debug with this file (https://stackoverflow.com/q/38883222/559676).
The configurations
edit: textandchapter_namehave been moved from the top-level options to the sub-options oflanguage: uiin_bookdown.yml. See https://bookdown.org/yihui/bookdown/internationalization.html
BUG FIXES
Figures are not correctly numbered in Word output using the
bookdown::word_document2()format (thanks, @byzheng, #158).For the “Knit and Merge” approach (
new_session: yesin_bookdown.yml), certain parts like figures may not show up when switching from one output format to another (e.g. from HTML to LaTeX).The
rmd_filesoption in_bookdown.ymldoes not work when it is a list ofhtmlandlatexoptions (thanks, @ismayc, #177).Math expressions does not appear in the table of contents when the output format is
gitbook(thanks, @philomonk, #204).Footnotes of multiple paragraphs are not displayed on the current page (thanks, @axitdn, #234).
The output format
pdf_document2()also works with articles now when an R Markdown document contains bookdown-specific headers, such as parts or appendix headers (https://stackoverflow.com/q/40529798/559676).
