Skip to content

Releases: yihui/xfun

xfun 0.50

07 Jan 15:25
Compare
Choose a tag to compare
  • The function isFALSE() has been removed from this package. The deprecation notice was given two years ago: https://yihui.org/en/2023/02/xfun-isfalse/

  • Added a new function tabset() to represent a list with a tabset. The representation is similar to str(), but uses a visual form.

  • Factored out the function taml_load() and exported it (TAML is a tiny subset of YAML). Also added a new function taml_save() to convert simple lists to YAML.

  • The print argument of record() can accept non-function values now, in which case print() (or show() for S4 objects) will be used as the print function.

  • The record() results can also be formatted to Markdown via format(record(), to = 'markdown').

  • Moved knitr::combine_words() into this package as xfun::join_words(). The former has become a simple wrapper of the latter.

  • Similarly, moved knitr::write_bib() into this package as xfun::pkg_bib().

  • Moved the internal function str_wrap() from knitr and exported it as xfun::str_wrap().

  • Exported the internal find_globals() and find_locals() functions.

  • md_table() escapes | in the table to \| instead of | now.

  • yaml_load(use_yaml = FALSE) allows for indenting sub-fields by any number of spaces now (thanks, @J-Moravec, #95). Previously, one level of indentation must use exactly 2 spaces.

  • divide_chunk() no longer requires every line of chunk options to be commented out when the engine uses a pair of comment delimiters (such as /* and */ for CSS) instead of a single comment character. It suffices to use the opening delimiter at the beginning and closing delimiter at the end, e.g.,

    ```{css}
    /*| echo=FALSE,
        label='foo' */
    ```

    Previously, every line must be commented out like:

    ```{css}
    /*| echo=FALSE, */
    /*| label='foo' */
    ```
  • The package has a website now: https://git.yihui.org/xfun/

xfun 0.49

31 Oct 18:17
Compare
Choose a tag to compare
  • Added an argument use_block = FALSE to protect_math(). When use_block = TRUE, a $$ $$ expression that spans across multiple lines will be protected in a code block.

  • protect_math() will ignore $ $ if there are backticks after the opening $ or before the closing $, e.g., $`this is not math`$.

  • protect_math() allows for parentheses () around math expressions now, e.g., ($x$) was previously not recognized but is recognized now (thanks, @AlbertLei, yihui/litedown#34).

  • record() works with quote() now (thanks, @ben-schwen, yihui/litedown#38).

  • html_escape() will not escape double quotes (i.e., convert "" to ") by default, and the conversion will be done only for html_escape(attr = TRUE).

  • The arguments before and after of read_all() can take functions of two arguments now, with the second argument being the content of each file.

  • Added an argument start to make_fence().

xfun 0.48

03 Oct 23:54
Compare
Choose a tag to compare
  • Added utilities for HTML tags: html_tag(), html_escape(), html_escape(), and html_view(). Removed the soft dependency on the htmltools package accordingly.

  • base_pkgs() is faster now: it calls tools::standard_package_names() if the function exists (R >= 4.4.0), otherwise it just returns a constant vector of base package names (thanks, @arnaudgallou, #91).

  • Added a function mime_type() to obtain the MIME types of files via mime::guess_type() if mime is installed, otherwise it will call tools:::mime_type(), and fall back to using a system command (e.g., file --mime-type) to obtain the types.

  • Added a function file_rename() to deal with file.rename() failures by calling file.copy() (thanks, @Giqles @katrinabrock, rstudio/bookdown#804).

  • new_app() will use utils::browseURL() to open the app if options('viewer') is not configured (thanks, @AlbertLei, yihui/litedown#29).

  • Added a method record_print.record_asis() to return the object as is.

xfun 0.47

17 Aug 04:27
Compare
Choose a tag to compare
  • Added functions lazy_save() and lazy_load() to save objects to files and lazy-load them.

  • Fixed a bug in record(dev = svglite::svglite) that misplaced plots when low-level plot functions are used (thanks, @liao961120, yihui/litedown#17).

  • Specified the lowest R version required (v3.2.0) for this package.

xfun 0.46

22 Jul 22:03
Compare
Choose a tag to compare
  • md_table() should add a vertical ellipsis to row names when rows are truncated by the limit argument.

  • session_info() recognizes Positron now (thanks, @chuxinyuan, #89).

xfun 0.45

16 Jun 23:58
Compare
Choose a tag to compare
  • For record() with verbose = 1 or 2, invisible NULL is no longer printed.

  • Rscript_call() will show the actual error message (if an error occurred) during calling the function in a new R session.

xfun 0.44

15 May 12:51
Compare
Choose a tag to compare
  • Added a function cache_exec() to cache the execution of an expression either in memory or on disk. It is much more general and flexible than cache_rds(). For example, it supports custom reading/writing methods for cache files, and can load locally created variables in the expression while loading cache.

  • Added an argument cache to record() to make it possible to enable caching.

  • Added arguments message and warning to record() to decide whether messages and warnings should be recorded.

  • Changed the default value of the argument error of record() from FALSE to NA. Now FALSE means to suppress error messages, and NA means to throw errors normally. This is for consistency with the message and warning arguments.

  • Added an S3 generic function record_print(), which is similar to knitr::knit_print() but for the purpose of printing visible values in record().

  • The record() funciton gained new arguments print and print.args to support custom printing functions and arguments.

  • Added a function md_table(), which is a minimal Markdown table generator.

  • Exported the internal function md5() to calculate the MD5 checksums of R objects. The function is essentially a workaround for tools::md5sum() (see HenrikBengtsson/Wishlist-for-R#21).

  • For fenced_block(), a space is added between the backticks and the language name, e.g., ```r has become ``` r now. This will affect snapshot tests based on Markdown (an example).

  • Added a shorthand fenced_div() for fenced_block(char = ':').

  • write_utf8() returns the con argument (typically a file path) now. Previously, it returns NULL.

  • Added an experimental function new_app() to create a local web application.

  • The returned value of yaml_body() contains a new element lines in the list indicating the line numbers of YAML metadata if exists.

  • Removed the skip argument from split_source().

  • For split_source(line_number = TRUE), the attribute name for line numbers in the returned value was changed from line_start (a single starting line number) to lines (both the starting and ending numbers).

  • Fixed an edge case in prose_index(), in which inline code was incorrectly recognized as a code block fence.

xfun 0.43

25 Mar 16:57
Compare
Choose a tag to compare
  • Added a function upload_imgur(), which was adapted from knitr::imgur_upload(). The latter will call the former in the future. xfun::upload_imgur() allows users to choose whether to use the system command curl or the R package curl to upload the image. It also has a new argument include_xml to specify whether the XML response needs to be included in the returned value.

  • Added a function fenced_block() to create a fenced block in Markdown (thanks, @cderv, yihui/knitr#2331). The block can be either a code block or a fenced Div.

  • Fixed a bug in xfun::record() when the argument verbose = 1 or 2.

xfun 0.42

08 Feb 19:25
Compare
Choose a tag to compare
  • isFALSE() has been fully deprecated for R >= 3.5.0, and will be completely removed from this package in the future (https://yihui.org/en/2023/02/xfun-isfalse/).

  • Added a function record() to run R code and record the results, which is similar to evaluate::evaluate() but less sophisticated and technically simpler. One major difference is that xfun::record() records plots directly to files instead of saving them as display lists.

  • yaml_load() gained an envir argument, which can be used to specify the environment to evaluate R expressions in YAML (i.e., expressions written after !expr or !r). This is not straightforward in the upstream yaml package (thanks, @viking, vubiostat/r-yaml#54).

  • yaml_body() gained the ... argument to pass more arguments to yaml_load().

  • split_source() gained a merge_comments argument to merge consecutive lines of comments into the next code block, a line_number argument to store the line number of each expression in the returned value, and a skip argument to skip the rest of the code when the skip token is found.

  • check_old_package() has been vectorized, i.e., the arguments name and version can take vectors now.

  • Factored out the code for parsing chunk options and dividing a chunk into chunk options and chunk body from knitr to this package as functions csv_options() and divide_chunk(), respectively. They will be used by knitr and other packages in future.

  • Added a function decimal_dot() to evaluate an expression after forcing options(OutDec = '.') and Sys.setlocale(LC_NUMERIC = 'C') (for rstudio/rmarkdown#2525).

xfun 0.41

01 Nov 14:05
Compare
Choose a tag to compare
  • process_file() will write to the file only if the processed text is different with the input text. This is to avoid writing files unnecessarily.

  • session_info() will remove extra blank lines (thanks, @chuxinyuan, #82) and also omit the time zone info.