From 4e859c0edede084643d27e13060dc5f1275d2433 Mon Sep 17 00:00:00 2001 From: Christophe Dervieux Date: Mon, 22 Nov 2021 10:48:44 +0100 Subject: [PATCH] Add an option to opt-out using custom environment lua filter (#1288) Setting `options(bookdown.theorem.enabled = FALSE)` will not include the Lua filter that is used to handle custom environment in **bookdown** --- DESCRIPTION | 2 +- NEWS.md | 4 ++++ R/utils.R | 11 +++++++---- 3 files changed, 12 insertions(+), 5 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 9cf093857..cfe4a117d 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,7 +1,7 @@ Package: bookdown Type: Package Title: Authoring Books and Technical Documents with R Markdown -Version: 0.24.3 +Version: 0.24.4 Authors@R: c( person("Yihui", "Xie", role = c("aut", "cre"), email = "xie@yihui.name", comment = c(ORCID = "0000-0003-0645-5666")), person("JJ", "Allaire", role = "ctb"), diff --git a/NEWS.md b/NEWS.md index 86d6bd5a3..041fc95bc 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,5 +1,9 @@ # CHANGES IN bookdown VERSION 0.25 +## NEW FEATURES + +- Set option `bookdown.theorem.enabled = FALSE` to 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](https://bookdown.org/yihui/rmarkdown-cookbook/custom-blocks.html) syntax without **bookdown** interfering (thanks, @finkelshtein, #1285). + ## BUG FIXES - Fix an issue with Pandoc 2.15 and footnote relocation in each chapter (#1275). diff --git a/R/utils.R b/R/utils.R index 124bffd44..f9f204487 100644 --- a/R/utils.R +++ b/R/utils.R @@ -32,10 +32,13 @@ common_format_config = function( # provide file_scope if requested if (file_scope) config$file_scope = md_chapter_splitter - # prepend the custom-environment filter - config$pandoc$lua_filters = c( - lua_filter("custom-environment.lua"), config$pandoc$lua_filters - ) + # prepend the custom-environment filter unless opt-out + if (getOption("bookdown.theorem.enabled", TRUE)) { + config$pandoc$lua_filters = c( + lua_filter("custom-environment.lua"), + config$pandoc$lua_filters + ) + } # and add bookdown metadata file for the filter to work config$pandoc$args = c(bookdown_yml_arg(), config$pandoc$args)