R/init_datapkg.R

Defines functions init_datapkg

Documented in init_datapkg

#' Create folder structure for a new BLE LTER data package ID
#' Create these following items: folder structure, R project, reusable R script from template
#' @param base_path (character) Full file path to parent directory to initiate under. Defaults to "K:/Data", which is the shared BLE network drive, mapped to the K drive on An's PC.
#' @param dataset_id (numeric) Dataset ID
#' @param dataset_nickname (character)
#' @param data_year (numeric) The year of data that the generated script will process. E.g. you may be working with 2021 data in 2022. Defaults to the current calendar year if not specified.

#' @return Nothing in R, but new folder structure and R script from template
#' @export

init_datapkg <- function(dataset_id,
                         dataset_nickname,
                         base_path = "K:/Data",
                         data_year = NULL) {
  # data year is current year if not specified
  if (is.null(data_year))
    data_year <- as.integer(format(Sys.Date(), "%Y"))
  stopifnot(is.integer(dataset_id), is.integer(data_year))

  ## check for existing IDs
  dirs <- list.files(base_path)
  ids <-
    suppressMessages(as.integer(sapply(
      dirs, sub, pattern = "\\_.*", replacement = ""
    )))

  if (dataset_id %in% ids) {
    next_id <- max(ids, na.rm = T) + 1
    stop(paste("This dataset ID already exists. Next available ID:", next_id))
  }

  dsdir <-
    file.path(base_path,
              paste0(dataset_id, "_", dataset_nickname))

  if (!dir.exists(dsdir))
    dir.create(dsdir)

  # create sub-directories
  if (!dir.exists(file.path(dsdir, "FromPI")))
    dir.create(file.path(dsdir, "FromPI"))

  if (!dir.exists(file.path(dsdir, "Clean")))
    dir.create(file.path(dsdir, "Clean"))

  if (!dir.exists(file.path(dsdir, paste0("EML_RProject_", dataset_id)))) {
    dir.create(file.path(dsdir, paste0("EML_RProject_", dataset_id)))
    dir.create(file.path(dsdir, paste0("EML_RProject_", dataset_id), data_year))
  }
  # write README
  readme <-
    readLines(system.file("readme.txt", package = "bleutils"))
  writeLines(readme, file.path(dsdir, "README.txt"))

  message(paste("Created directory structure under", dsdir))

  # init data processing script
  init_script(
    dataset_id = dataset_id,
    file_dir = file.path(dsdir, paste0("EML_RProject_", dataset_id), data_year),
    type = "init"
  )
}
BLE-LTER/BLE-LTER-utils documentation built on Jan. 5, 2025, 5:38 p.m.