Skip to content

Commit

Permalink
Allow initialising a project directory
Browse files Browse the repository at this point in the history
  • Loading branch information
richfitz committed Jun 3, 2024
1 parent 39c2747 commit d4b52f0
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 12 deletions.
30 changes: 19 additions & 11 deletions R/root.R
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,9 @@
##' location; if `TRUE` you will always have all the packets that
##' you hold metadata about.
##'
##' @param force Logical, indicating if we shold initialise orderly
##' even if the directory is not empty.
##'
##' @return The full, normalised, path to the root,
##' invisibly. Typically this is called only for its side effect.
##'
Expand All @@ -65,25 +68,30 @@
orderly_init <- function(root = ".",
path_archive = "archive",
use_file_store = FALSE,
require_complete_tree = FALSE) {
require_complete_tree = FALSE,
force = FALSE) {
assert_scalar_character(root)
has_orderly_config <- file.exists(file.path(root, "orderly_config.yml"))
if (!has_orderly_config && file.exists(root)) {
if (!is_directory(root)) {
cli::cli_abort("'root' exists but is not a directory")
}
if (!file.exists(file.path(root, ".outpack"))) {
## We may need to relax this, but it's not really clear to me
## how the user gets into this position; they have a bunch of
## files there and they want to a root into it?
##
## One option is provide a boolean arg to proceed anyway in this
## case, at the moment there's not a lot that can be done to
## undo this situation.
if (length(dir(root, all.files = TRUE, no.. = TRUE)) > 0) {
if (!file.exists(file.path(root, ".outpack")) && !force) {
allowed <- c(".outpack",
".git", ".gitignore",
".Rhistory",
"*.Rproj", ".Rproj.user")
contents <- dir(root, all.files = TRUE, no.. = TRUE)
m <- vapply(glob2rx(allowed), grepl, logical(length(contents)), contents)
if (!is.matrix(m)) { # exactly one file to compare
m <- rbind(m)
}
err <- contents[!apply(m, 1, any)]
if (length(err) > 0) {
cli::cli_abort(c(
"'root' exists but is not empty, or an outpack archive",
i = "Please have a chat with us if this is something you need to do"))
x = "Found existing file{?s}: {.file {err}}",
i = "Use 'force = TRUE' to initialise anyway"))
}
}
}
Expand Down
6 changes: 5 additions & 1 deletion man/orderly_init.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

25 changes: 25 additions & 0 deletions tests/testthat/test-init.R
Original file line number Diff line number Diff line change
Expand Up @@ -188,3 +188,28 @@ test_that("create root in wd by default", {
expect_true(file.exists(file.path(path, ".outpack")))
expect_true(file.exists(file.path(path, "orderly_config.yml")))
})


test_that("allow rstudio files to exist for init", {
tmp <- withr::local_tempdir()
file.create(file.path(tmp, "foo.Rproj"))
dir.create(file.path(tmp, ".Rproj.user"))
dir.create(file.path(tmp, ".git"))
file.create(file.path(tmp, ".Rhistory"))
file.create(file.path(tmp, ".gitignore"))

expect_no_error(orderly_init_quietly(tmp))
expect_true(file.exists(file.path(tmp, ".outpack")))
expect_true(file.exists(file.path(tmp, "orderly_config.yml")))
})


test_that("force initialisation of non-empty directory", {
tmp <- tempfile()
fs::dir_create(tmp)
on.exit(unlink(tmp, recursive = TRUE))
file.create(file.path(tmp, "file"))
expect_no_error(orderly_init_quietly(tmp, force = TRUE))
expect_true(file.exists(file.path(tmp, ".outpack")))
expect_true(file.exists(file.path(tmp, "orderly_config.yml")))
})

0 comments on commit d4b52f0

Please sign in to comment.