R/model-helpers.R

Defines functions substitutions tag_file tag_pull tag_find

Documented in substitutions tag_file tag_find tag_pull

#' Find which items of a file read in as a character vector
#' include tags.
#'
#' @param text file as a character vector (1 element per line).
#' @return vector of line numbers with tags.
#' @export
tag_find <- function(text) text[grepl(pattern='// \\[\\[.*\\]\\]', x=text) %>% which]

#' Extract the tag from file read in as a vector of text strings.
#'
#' @param text file as a vector of text strings.
#' @return all tags
#' @export
tag_pull <- function(text)  gsub(pattern='// \\[\\[(.*)\\]\\]', replacement = '\\1', x=text)

#' File matching a tag.  Replaces '::' separator with '-' separator.
#'
#' @param tag text descriptor of file name.
#' @return implied file name
#' @export
tag_file <- function(tag) {
  files <- gsub(pattern='::', replacement='-', x=tag) %>% paste('chunk', sep='.')
  names(files) <- tag
  return(files)
}



#' Substitute tags for the referenced file content. 
#' 
#' @param model full path to model file with tags in it.  Must be specified.
#' @param search path to search for chunks to be inserted when tags
#'        are replaced. If not specified search is restricted to model
#'        directory.
#' @param output full path to file that model will be 
#'        written into. If not specified it is derived from the
#'        model path by replacing the extension with .stan
#' @export
substitutions <- function(model = NULL, search = NULL, output = NULL) {
  if (is.null(model)) 
    stop("Argument 'model' can not be left unspecified or NULL.")
  if (is.null(search))
    search <- dirname(model)
  
  model <- readLines(model)
  tags <- tag_find(model) 
  tag_names <- tag_pull(tags)
  chunk_files <- tag_file(tag_names)
  
  model_text <- paste(model, collapse="\n")
  for (tag in seq_along(tags)) {
    chunk_file <- find_file(search, chunk_files[tag])
    chunk <- readLines(chunk_file) %>% paste(collapse="\n")
    model_text <- gsub(pattern=tags[tag], replacement=paste("\n", chunk, "\n", sep=""), x=model_text, fixed=TRUE)
  }
  
  if (is.null(output)) {
    output_file = gsub(pattern='\\.[^\\.]*$', replacement='.stan', x=model)
  } else {
    output_file = output
  }
  writeLines(model_text, con=output_file)
  return(output_file)
}  
sakrejda/stannis documentation built on June 25, 2022, 3:19 a.m.