R/stylesheet.R

Defines functions read_stylesheet is_stylesheet stylesheet

Documented in stylesheet

#' The {tinkr} stylesheet
#'
#' This function returns the path to the {tinkr} stylesheet
#'
#' @return a single element character vector representing the path to the 
#'   stylesheet used by {tinkr}.
#' @export
#' @examples
#' tinkr::stylesheet()
stylesheet <- function() {
  system.file("stylesheets", "xml2md_gfm.xsl", package = "tinkr")
}

is_stylesheet <- function(stylesheet) {
  inherits(stylesheet, "xml_document") && 
    length(xml2::xml_name(stylesheet)) == 1L    &&
    xml2::xml_name(stylesheet) == "stylesheet"
}

read_stylesheet <- function(stylesheet_path) {
  
  # if the stylesheet already is an XML stylesheet, just return.
  if (is_stylesheet(stylesheet_path)) {
    return(stylesheet_path)
  }

  null_or_na <- is.null(stylesheet_path) ||
    length(stylesheet_path) != 1L ||
    any(is.na(stylesheet_path))

  if (null_or_na) {
    stop("'stylesheet_path' must be a path to an XSL stylesheet", call. = FALSE)
  }
  if (!file.exists(stylesheet_path)) {
    stop(glue::glue("The file '{stylesheet_path}' does not exist."), call. = FALSE)
  }
  out <- xml2::read_xml(stylesheet_path)
  if (is_stylesheet(out)) {
    return(out)
  } else {
    stop(glue::glue("'{stylesheet_path}' is not a valid stylesheet"))
  }
  
}

Try the tinkr package in your browser

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

tinkr documentation built on March 31, 2023, 8:12 p.m.