R/markdown.R

Defines functions markdown_latex markdown_text markdown_commonmark markdown_man markdown_xml markdown_html

Documented in markdown_commonmark markdown_html markdown_latex markdown_man markdown_text markdown_xml

#' Parse and render markdown text
#'
#' Converts markdown text to several formats using John MacFarlane's [cmark](https://github.com/commonmark/cmark)
#' reference implementation. Supported output formats include `html`, `latex`, groff `man`, and normalized
#' "commonmark" markdown. In addition the markdown parse tree can be returned in xml format.
#'
#' Support for extensions (including tables and autolink) is provided via the Github
#' [fork](https://github.com/github/cmark-gfm) of cmark. For now these are opt-in and have to be
#' enabled with the `extensions` parameter. See also the manual page on [extensions].
#'
#' When smart punctuation is enabled, straight double and single quotes will be rendered as curly quotes,
#' depending on their position. Moreover `--` will be rendered as -- (en-dash), `---` will be
#' rendered as --- (em-dash), and `...` will be rendered as ... (ellipses).
#'
#' @useDynLib commonmark R_render_markdown
#' @aliases commonmark markdown
#' @export
#' @rdname commonmark
#' @name commonmark
#' @param text Markdown text
#' @param sourcepos Include source position attribute in output.
#' @param hardbreaks Treat newlines as hard line breaks. If this option is specified, hard wrapping is disabled
#' regardless of the value given with `width`.
#' @param smart Use smart punctuation. See details.
#' @param normalize Consolidate adjacent text nodes.
#' @param footnotes parse footnotes
#' @param extensions Enables Github extensions. Can be `TRUE` (all) `FALSE` (none) or a character
#' vector with a subset of available [extensions].
#' @param width Specify wrap width (default 0 = nowrap).
#' @examples md <- readLines("https://raw.githubusercontent.com/yihui/knitr/master/NEWS.md")
#' html <- markdown_html(md)
#' xml <- markdown_xml(md)
#' man <- markdown_man(md)
#' tex <- markdown_latex(md)
#' cm <- markdown_commonmark(md)
#' text <- markdown_text(md)
markdown_html <- function(text, hardbreaks = FALSE, smart = FALSE, normalize = FALSE, sourcepos = FALSE, footnotes = FALSE, extensions = FALSE){
  text <- enc2utf8(paste(text, collapse="\n"))
  extensions <- get_extensions(extensions)
  .Call(R_render_markdown, text, 1L, sourcepos, hardbreaks, smart, normalize, footnotes, 0L, extensions)
}

#' @export
#' @rdname commonmark
markdown_xml <- function(text, hardbreaks = FALSE, smart = FALSE, normalize = FALSE, sourcepos = FALSE, footnotes = FALSE, extensions = FALSE){
  text <- enc2utf8(paste(text, collapse="\n"))
  extensions <- get_extensions(extensions)
  .Call(R_render_markdown, text, 2L, sourcepos, hardbreaks, smart, normalize, footnotes, 0L, extensions)
}

#' @export
#' @rdname commonmark
markdown_man <- function(text, hardbreaks = FALSE, smart = FALSE, normalize = FALSE, footnotes = FALSE, width = 0, extensions = FALSE){
  text <- enc2utf8(paste(text, collapse="\n"))
  extensions <- get_extensions(extensions)
  .Call(R_render_markdown, text, 3L, FALSE, hardbreaks, smart, normalize, footnotes, as.integer(width), extensions)
}

#' @export
#' @rdname commonmark
markdown_commonmark <- function(text, hardbreaks = FALSE, smart = FALSE, normalize = FALSE, footnotes = FALSE, width = 0, extensions = FALSE){
  text <- enc2utf8(paste(text, collapse="\n"))
  extensions <- get_extensions(extensions)
  .Call(R_render_markdown, text, 4L, FALSE, hardbreaks, smart, normalize, footnotes, as.integer(width), extensions)
}

#' @export
#' @rdname commonmark
markdown_text <- function(text, hardbreaks = FALSE, smart = FALSE, normalize = FALSE, footnotes = FALSE, width = 0, extensions = FALSE){
  text <- enc2utf8(paste(text, collapse="\n"))
  extensions <- get_extensions(extensions)
  .Call(R_render_markdown, text, 5L, FALSE, hardbreaks, smart, normalize, footnotes, as.integer(width), extensions)
}

#' @export
#' @rdname commonmark
markdown_latex <- function(text, hardbreaks = FALSE, smart = FALSE, normalize = FALSE, footnotes = FALSE, width = 0, extensions = FALSE){
  text <- enc2utf8(paste(text, collapse="\n"))
  extensions <- get_extensions(extensions)
  .Call(R_render_markdown, text, 6L, FALSE, hardbreaks, smart, normalize, footnotes, as.integer(width), extensions)
}

Try the commonmark package in your browser

Any scripts or data that you put into this service are public.

commonmark documentation built on March 31, 2023, 8:48 p.m.