R/persisters.R

Defines functions persister_fetch

Documented in persister_fetch

#' @title Cassette persisters
#' @description Keeps track of the cassette persisters in a hash-like object
#' @export
#' @keywords internal
#' @details There's only one option: `FileSystem`
#' \strong{Private Methods}
#'  \describe{
#'     \item{\code{persister_get()}}{
#'       Gets and sets a named persister
#'     }
#'   }
#' @examples
#' (aa <- Persisters$new())
#' aa$name
#' aa$persisters
#' yaml_serializer <- aa$persisters$new()
#' yaml_serializer
Persisters <- R6::R6Class(
  "Persisters",
  public = list(
    #' @field persisters (list) internal use, holds persister object
    persisters = list(),
    #' @field name (character)
    name = "FileSystem",

    #' @description Create a new `Persisters` object
    #' @param persisters (list) a list
    #' @param name (character) Persister name, only option right now
    #' is "FileSystem"
    #' @return A new `Persisters` object
    initialize = function(persisters = list(), name = "FileSystem") {
      self$persisters <- persisters
      self$name <- name
      private$persister_get()
    }
  ),

  private = list(
    # Gets and sets a named persister
    persister_get = function() {
      if (!self$name %in% 'FileSystem') {
        stop(sprintf("The requested VCR cassette persister (%s) is not registered.", self$name),
             call. = FALSE)
      }
      self$persisters <- switch(self$name, FileSystem = FileSystem)
    }
  )
)

#' @rdname Persisters
persister_fetch <- function(x = "FileSystem", file_name) {
  per <- Persisters$new(name = x)
  per <- per$persisters
  per$new(file_name = file_name)
}

Try the vcr package in your browser

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

vcr documentation built on July 9, 2023, 5:30 p.m.