1
0
mirror of https://github.com/msberends/AMR.git synced 2025-01-23 18:24:34 +01:00

Compare commits

...

2 Commits

Author SHA1 Message Date
4a54d59f70 tinytest 2023-02-06 14:36:31 +01:00
75a4c1ef3e fixes2 2023-02-06 14:34:38 +01:00
6 changed files with 42 additions and 34 deletions

View File

@ -1,5 +1,5 @@
Package: AMR Package: AMR
Version: 1.8.2.9107 Version: 1.8.2.9109
Date: 2023-02-06 Date: 2023-02-06
Title: Antimicrobial Resistance Data Analysis Title: Antimicrobial Resistance Data Analysis
Description: Functions to simplify and standardise antimicrobial resistance (AMR) Description: Functions to simplify and standardise antimicrobial resistance (AMR)

View File

@ -1,4 +1,4 @@
# AMR 1.8.2.9107 # AMR 1.8.2.9109
*(this beta version will eventually become v2.0! We're happy to reach a new major milestone soon!)* *(this beta version will eventually become v2.0! We're happy to reach a new major milestone soon!)*

View File

@ -1424,30 +1424,6 @@ case_when <- function(...) {
out out
} }
# adapted from https://github.com/nathaneastwood/poorman/blob/52eb6947e0b4430cd588976ed8820013eddf955f/R/where.R#L17-L32
where <- function(fn) {
if (!is.function(fn)) {
stop_("`", deparse(substitute(fn)), "()` is not a valid predicate function.")
}
df <- pm_select_env$.data
cols <- pm_select_env$get_colnames()
if (is.null(df)) {
df <- get_current_data("where", call = FALSE)
cols <- colnames(df)
}
preds <- unlist(lapply(
df,
function(x, fn) {
do.call("fn", list(x))
},
fn
))
if (!is.logical(preds)) stop_("`where()` must be used with functions that return `TRUE` or `FALSE`.")
data_cols <- cols
cols <- data_cols[preds]
which(data_cols %in% cols)
}
# dplyr implementations ---- # dplyr implementations ----
@ -1478,6 +1454,7 @@ if (pkg_is_available("dplyr", also_load = FALSE)) {
ungroup <- import_fn("ungroup", "dplyr", error_on_fail = FALSE) ungroup <- import_fn("ungroup", "dplyr", error_on_fail = FALSE)
mutate <- import_fn("mutate", "dplyr", error_on_fail = FALSE) mutate <- import_fn("mutate", "dplyr", error_on_fail = FALSE)
bind_rows <- import_fn("bind_rows", "dplyr", error_on_fail = FALSE) bind_rows <- import_fn("bind_rows", "dplyr", error_on_fail = FALSE)
where <- import_fn("where", "dplyr", error_on_fail = FALSE)
} else { } else {
`%>%` <- `%pm>%` `%>%` <- `%pm>%`
anti_join <- pm_anti_join anti_join <- pm_anti_join
@ -1523,6 +1500,29 @@ if (pkg_is_available("dplyr", also_load = FALSE)) {
mat <- do.call(rbind, mat_list) mat <- do.call(rbind, mat_list)
as.data.frame(mat, stringsAsFactors = FALSE) as.data.frame(mat, stringsAsFactors = FALSE)
} }
where <- function(fn) {
# adapted from https://github.com/nathaneastwood/poorman/blob/52eb6947e0b4430cd588976ed8820013eddf955f/R/where.R#L17-L32
if (!is.function(fn)) {
stop_("`", deparse(substitute(fn)), "()` is not a valid predicate function.")
}
df <- pm_select_env$.data
cols <- pm_select_env$get_colnames()
if (is.null(df)) {
df <- get_current_data("where", call = FALSE)
cols <- colnames(df)
}
preds <- unlist(lapply(
df,
function(x, fn) {
do.call("fn", list(x))
},
fn
))
if (!is.logical(preds)) stop_("`where()` must be used with functions that return `TRUE` or `FALSE`.")
data_cols <- cols
cols <- data_cols[preds]
which(data_cols %in% cols)
}
} }

View File

@ -362,13 +362,13 @@ set_ab_names <- function(data, ..., property = "name", language = get_AMR_locale
} }
if (is.data.frame(data)) { if (is.data.frame(data)) {
if (tryCatch(length(list(...)) > 0, error = function(e) TRUE)) { if (tryCatch(length(c(...)) > 1, error = function(e) TRUE)) {
out <- tryCatch(suppressWarnings(unlist(list(...))), error = function(e) NULL) df <- tryCatch(suppressWarnings(select(data, ...)),
if (!is.null(out)) { error = function(e) {
df <- data[, out, drop = FALSE] data[, c(...), drop = FALSE]
} else { })
df <- select(data, ...) } else if (tryCatch(is.character(c(...)), error = function(e) FALSE)) {
} df <- data[, c(...), drop = FALSE]
} else { } else {
df <- data df <- data
} }

View File

@ -73,7 +73,8 @@ import_functions <- c(
"semi_join" = "dplyr", "semi_join" = "dplyr",
"showQuestion" = "rstudioapi", "showQuestion" = "rstudioapi",
"summarise" = "dplyr", "summarise" = "dplyr",
"ungroup" = "dplyr" "ungroup" = "dplyr",
"where" = "dplyr"
) )
# functions that are called directly with :: # functions that are called directly with ::

View File

@ -39,6 +39,13 @@ if (tryCatch(isTRUE(AMR:::import_fn("isJob", "rstudioapi")()), error = function(
.libPaths(c(Sys.getenv("R_LIBS_USER_GH_ACTIONS"), .libPaths())) .libPaths(c(Sys.getenv("R_LIBS_USER_GH_ACTIONS"), .libPaths()))
if (AMR:::pkg_is_available("tinytest", also_load = TRUE)) { if (AMR:::pkg_is_available("tinytest", also_load = TRUE)) {
library(AMR) library(AMR)
if (identical(AMR:::import_fn("select", "dplyr"), AMR:::select)) {
print("This test will rely on {dplyr} verbs")
message("This test will rely on {dplyr} verbs")
} else {
print("This test will rely on {poorman} verbs")
message("This test will rely on {poorman} verbs")
}
# set language # set language
set_AMR_locale("English") set_AMR_locale("English")
# set some functions if on old R # set some functions if on old R