Skip to content

Commit

Permalink
chore: synced file(s) with ssi-dk/AEF-DDF
Browse files Browse the repository at this point in the history
  • Loading branch information
RasmusSkytte committed Jan 10, 2025
1 parent 7c0654c commit ae9436b
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 29 deletions.
18 changes: 2 additions & 16 deletions .lintr
Original file line number Diff line number Diff line change
@@ -1,21 +1,7 @@
linters: c(
diseasy_code_linters(),
all_linters(
line_length_linter = NULL, # We use 120, nolint-aware line length linter instead
cyclocomp_linter = NULL, # Not required in diseasy style guide
keyword_quote_linter = NULL, # Not required in diseasy style guide
implicit_integer_linter = NULL, # Not required in diseasy style guide
extraction_operator_linter = NULL, # Fails for .data$*
nonportable_path_linter = NULL, # Any \\ is flagged. Therefore fails when escaping backslashes
undesirable_function_linter = NULL, # Library calls in vignettes are flagged and any call to options
unnecessary_lambda_linter = NULL, # Fails for purrr::map with additional function arguments
strings_as_factors_linter = NULL, # Seems to be some backwards compatibility stuff.
expect_identical_linter = NULL # Seems a little aggressive to require this.
)
)
linters: diseasy_code_linters()
exclude_linter: paste0(
"^ *: *(", # Any number of spaces before and after the colon
paste(c(names(lintr::all_linters()), names(diseasy_code_linters())), collapse = "|"), # Any of our linters
paste(names(diseasy_code_linters()), collapse = "|"), # Any of our linters
",| )+(\\.|$)" # As a comma separated list (with optional spaces) followed by a period or end of line
)
exclusions: c(
Expand Down
44 changes: 32 additions & 12 deletions R/0_linters.R
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,25 @@
#' @return A list of linters
#' @noRd
diseasy_code_linters <- function() {
linters <- list(
"nolint_position_linter" = nolint_position_linter(120),
"nolint_line_length_linter" = nolint_line_length_linter(120),
"non_ascii_linter" = non_ascii_linter(),
"param_and_field_linter" = param_and_field_linter(),
"documentation_template_linter" = documentation_template_linter()
linters <- c(
list(
"nolint_position_linter" = nolint_position_linter(length = 120L),
"nolint_line_length_linter" = nolint_line_length_linter(length = 120L),
"non_ascii_linter" = non_ascii_linter(),
"param_and_field_linter" = param_and_field_linter(),
"documentation_template_linter" = documentation_template_linter()
),
lintr::all_linters(
line_length_linter = NULL, # We use 120, nolint-aware line length linter instead
cyclocomp_linter = NULL, # Not required in diseasy style guide
keyword_quote_linter = NULL, # Not required in diseasy style guide
implicit_integer_linter = NULL, # Not required in diseasy style guide
extraction_operator_linter = NULL, # Fails for .data$*
nonportable_path_linter = NULL, # Any \\ is flagged. Therefore fails when escaping backslashes
undesirable_function_linter = NULL, # Library calls in vignettes are flagged and any call to options
unnecessary_lambda_linter = NULL, # Fails for purrr::map with additional function arguments
strings_as_factors_linter = NULL # Seems to be some backwards compatibility stuff.
)
)

return(linters)
Expand Down Expand Up @@ -89,7 +102,9 @@ nolint_position_linter <- function(length = 80L) {
#' nolint_line_length_linter: Ensure lines adhere to a given character limit, ignoring `nolint` statements
#'
#' @param length (`numeric`)\cr
#' Maximum line length allowed. Default is 80L (Hollerith limit)..
#' Maximum line length allowed.
#' @param code_block_length (`numeric`)\cr
#' Maximum line length allowed for code blocks.
#' @examples
#' ## nolint_line_length_linter
#' # will produce lints
Expand All @@ -106,8 +121,9 @@ nolint_position_linter <- function(length = 80L) {
#'
#' @importFrom rlang .data
#' @noRd
nolint_line_length_linter <- function(length = 80L) {
nolint_line_length_linter <- function(length = 80L, code_block_length = 85L) {
general_msg <- paste("Lines should not be more than", length, "characters.")
code_block_msg <- paste("Code blocks should not be more than", code_block_length, "characters.")

lintr::Linter(
function(source_expression) {
Expand All @@ -122,14 +138,18 @@ nolint_line_length_linter <- function(length = 80L) {
file_lines_nolint_excluded <- source_expression$file_lines |>
purrr::map_chr(\(s) stringr::str_remove(s, nolint_regex))

# Switch mode based on extension
# .Rmd uses code_block_length
code_block <- endsWith(tolower(source_expression$filename), ".rmd")

line_lengths <- nchar(file_lines_nolint_excluded)
long_lines <- which(line_lengths > length)
long_lines <- which(line_lengths > ifelse(code_block, code_block_length, length))
Map(function(long_line, line_length) {
lintr::Lint(
filename = source_expression$filename,
line_number = long_line,
column_number = length + 1L, type = "style",
message = paste(general_msg, "This line is", line_length, "characters."),
column_number = ifelse(code_block, code_block_length, length) + 1L, type = "style",
message = paste(ifelse(code_block, code_block_msg, general_msg), "This line is", line_length, "characters."),
line = source_expression$file_lines[long_line],
ranges = list(c(1L, line_length))
)
Expand Down Expand Up @@ -316,7 +336,7 @@ param_and_field_linter <- function() {
#' @importFrom rlang .data
#' @noRd
documentation_template_linter <- function() {
general_msg <- paste("Documentation templates should used if available!")
general_msg <- paste("Documentation templates should used if available.")

lintr::Linter(
function(source_expression) {
Expand Down
3 changes: 2 additions & 1 deletion tests/testthat/test-0_linters.R
Original file line number Diff line number Diff line change
Expand Up @@ -61,9 +61,10 @@ test_that("param_and_field_linter works", {
test_that("documentation_template_linter works", {
skip_if_not_installed("lintr")
skip_if_not_installed("devtools")
skip_if(!identical(Sys.getenv("R_CHECK"), "true"), "Skip if running in R_check")

lintr::expect_lint(
"#' @param observable (`character(1)`)\\cr", # rd_observable defined in R/0_documentation.R # nolint: documentation_template_linter
"#' @param observable text", # rd_observable defined in R/0_documentation.R # nolint: documentation_template_linter, param_and_field_linter
list("line_number" = 1, "type" = "style"),
documentation_template_linter()
)
Expand Down

0 comments on commit ae9436b

Please sign in to comment.