mirror of
https://github.com/msberends/AMR.git
synced 2025-01-23 14:24:35 +01:00
Compare commits
2 Commits
f7dd890b79
...
4a54d59f70
Author | SHA1 | Date | |
---|---|---|---|
4a54d59f70 | |||
75a4c1ef3e |
@ -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)
|
||||||
|
2
NEWS.md
2
NEWS.md
@ -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!)*
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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 ::
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user