mirror of
https://github.com/johrpan/geposanui.git
synced 2025-10-26 03:07:24 +01:00
Move caching to geposan
This commit is contained in:
parent
33c8292690
commit
4cf5bff125
2 changed files with 3 additions and 34 deletions
11
R/server.R
11
R/server.R
|
|
@ -30,14 +30,9 @@ server <- function(input, output, session) {
|
|||
results <- withProgress(
|
||||
message = "Analyzing genes",
|
||||
value = 0.0, {
|
||||
run_cached(
|
||||
rlang::hash(preset),
|
||||
geposan::analyze,
|
||||
preset,
|
||||
function(progress) {
|
||||
setProgress(progress)
|
||||
}
|
||||
)
|
||||
geposan::analyze(preset, function(progress) {
|
||||
setProgress(progress)
|
||||
})
|
||||
}
|
||||
)
|
||||
|
||||
|
|
|
|||
26
R/utils.R
26
R/utils.R
|
|
@ -1,29 +1,3 @@
|
|||
# Run a function caching the result on the file system.
|
||||
#
|
||||
# The function will be called with the appended arguments. The [`id`] argument
|
||||
# will be used to identify the cache file on the file system and in log
|
||||
# messages.
|
||||
run_cached <- function(id, func, ...) {
|
||||
if (!dir.exists("cache")) {
|
||||
dir.create("cache")
|
||||
}
|
||||
|
||||
cache_file <- paste("cache/", id, ".rds", sep = "")
|
||||
|
||||
if (file.exists(cache_file)) {
|
||||
# If the cache file exists, we restore the data from it.
|
||||
readRDS(cache_file)
|
||||
} else {
|
||||
# If the cache file doesn't exist, we have to do the computation.
|
||||
data <- func(...)
|
||||
|
||||
# The results are cached for the next run.
|
||||
saveRDS(data, cache_file)
|
||||
|
||||
data
|
||||
}
|
||||
}
|
||||
|
||||
# This is needed to make data.table's and shiny's symbols available within the
|
||||
# package.
|
||||
#' @import data.table
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue