-
Notifications
You must be signed in to change notification settings - Fork 186
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
use_lintr
adds .lintr to .Rbuildignore
#2396
base: main
Are you sure you want to change the base?
Changes from all commits
5d0f734
fdb2307
ee7c47c
7f538d0
fb9e003
8f9bb6f
81c7761
09a888a
25ada69
06f031a
dec9a9d
c54980d
6cb1b49
24624b9
302782e
bd56690
1226e0c
88acd40
9e9611b
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
#' Use lintr in your project | ||
#' | ||
#' Create a minimal lintr config file as a starting point for customization | ||
#' Create a minimal lintr config file as a starting point for customization and add it to the .Rbuildignore | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It should be |
||
#' | ||
#' @param path Path to project root, where a `.lintr` file should be created. | ||
#' If the `.lintr` file already exists, an error will be thrown. | ||
|
@@ -25,7 +25,7 @@ | |
#' lintr::lint_dir() | ||
#' } | ||
use_lintr <- function(path = ".", type = c("tidyverse", "full")) { | ||
config_file <- normalizePath(file.path(path, lintr_option("linter_file")), mustWork = FALSE) | ||
config_file <- normalizePath(file.path(path, lintr_option("linter_file")), mustWork = FALSE, winslash = "/") | ||
AshesITR marked this conversation as resolved.
Show resolved
Hide resolved
|
||
if (file.exists(config_file)) { | ||
stop("Found an existing configuration file at '", config_file, "'.", call. = FALSE) | ||
} | ||
|
@@ -43,5 +43,37 @@ use_lintr <- function(path = ".", type = c("tidyverse", "full")) { | |
) | ||
) | ||
write.dcf(the_config, config_file, width = Inf) | ||
|
||
if (file.exists(file.path(path, "DESCRIPTION"))) { | ||
# Some OS can only normalize a path if the associated file or folder exists, so the path needs to be re-normalized | ||
tryCatch({ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't understand this part. |
||
pkg_path <- normalizePath(path, mustWork = TRUE, winslash = "/") | ||
config_file <- normalizePath(file.path(path, lintr_option("linter_file")), mustWork = TRUE, winslash = "/") | ||
}, error = function(e) { | ||
stop("No entry could be added to the .Rbuildignore.", call. = FALSE) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This sounds like a warning is in order. The main side effect was caused at this point anyway. |
||
}) | ||
# Check if config_file is in package i.e. lintr_option("linter_file") != "../.lintr" | ||
if (startsWith(config_file, prefix = pkg_path)) { | ||
# Skip a extra character for the leading `/` | ||
rel_path <- substring(config_file, first = nchar(pkg_path) + 2L, last = nchar(config_file)) | ||
ignore_path <- file.path(pkg_path, ".Rbuildignore") | ||
if (!file.exists(ignore_path)) file.create(ignore_path) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This branch can be a |
||
# Follow the same procedure as base R to see if the file is already ignored | ||
ignore <- tryCatch({ | ||
trimws(readLines(ignore_path)) | ||
}, warning = function(e) { | ||
cat(file = ignore_path, "\n", append = TRUE) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why are you silently fixing the missing terminal newline here? |
||
trimws(readLines(ignore_path)) | ||
}) | ||
ignore <- ignore[nzchar(ignore)] | ||
already_ignored <- | ||
any(vapply(ignore, FUN = grepl, x = rel_path, perl = TRUE, ignore.case = TRUE, FUN.VALUE = logical(1L))) | ||
if (!already_ignored) { | ||
cat(file = ignore_path, rex::rex(start, rel_path, end), sep = "\n", append = TRUE) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. IINM the |
||
message("Adding ", rel_path, " to .Rbuildignore") | ||
} | ||
} | ||
} | ||
|
||
invisible(config_file) | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -35,3 +35,56 @@ test_that("use_lintr with type = full also works", { | |
lints <- lint_dir(tmp) | ||
expect_length(lints, 0L) | ||
}) | ||
|
||
test_that("No .Rbuildignore is created of packages", { | ||
tmp <- withr::local_tempdir() | ||
|
||
lintr_file <- use_lintr(path = tmp, type = "full") | ||
expect_false(file.exists(file.path(tmp, ".Rbuildignore"))) | ||
}) | ||
|
||
test_that("No .Rbuildignore is filled outside of packages", { | ||
tmp <- withr::local_tempdir() | ||
ignore <- file.path(tmp, ".Rbuildignore") | ||
file.create(ignore) | ||
|
||
lintr_file <- use_lintr(path = tmp, type = "full") | ||
expect_identical(readLines(ignore), character()) | ||
}) | ||
|
||
test_that("No .Rbuildignore is filled if matching regex exists", { | ||
tmp <- withr::local_tempdir() | ||
file.create(file.path(tmp, "DESCRIPTION")) | ||
ignore <- file.path(tmp, ".Rbuildignore") | ||
file.create(ignore) | ||
cat(file = ignore, ".*", sep = "\n") | ||
|
||
lintr_file <- use_lintr(path = tmp, type = "full") | ||
expect_identical(readLines(ignore), ".*") | ||
}) | ||
|
||
test_that("use_lintr creates the correct regex", { | ||
tmp <- withr::local_tempdir() | ||
file.create(file.path(tmp, "DESCRIPTION")) | ||
ignore <- file.path(tmp, ".Rbuildignore") | ||
file.create(ignore) | ||
cat(file = ignore, "^fu$", "^bar$", sep = "\n") | ||
|
||
expect_message({ | ||
lintr_file <- use_lintr(path = tmp, type = "full") | ||
}, regexp = "Adding .* to .Rbuildignore") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nit: the |
||
expect_identical(readLines(ignore), c("^fu$", "^bar$", "^\\.lintr$")) | ||
}) | ||
|
||
test_that("use_lintr handles missing final new line", { | ||
tmp <- withr::local_tempdir() | ||
file.create(file.path(tmp, "DESCRIPTION")) | ||
ignore <- file.path(tmp, ".Rbuildignore") | ||
file.create(ignore) | ||
cat(file = ignore, "^fu$\n^bar$") | ||
|
||
expect_message({ | ||
lintr_file <- use_lintr(path = tmp, type = "full") | ||
}, regexp = "Adding .* to .Rbuildignore") | ||
expect_identical(readLines(ignore), c("^fu$", "^bar$", "^\\.lintr$")) | ||
}) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Superfluous change