Stores an object in pkg
's user-cache pins board, i.e. caches it to the filesystem.
Usage
cache_obj(board, x, id, qs_preset = c("fast", "balanced", "high", "archive"))
Arguments
- board
- x
Object to be cached.
- id
Pin name uniquely identifying
x
in thepkg
's user-cache pins board. A character scalar which is safe to use in paths of common file systems. Necessary to retrievex
again usingget_obj()
. An already existing pin namedid
will be silently overwritten.- qs_preset
Serialization algorithm preset to use. See
qs::qsave()
(section Presets) for details.
Details
Note that cache_obj()
will always overwrite an already existing cached object of the same id
. See hash_fn_call()
for a convenient way to create an id
that uniquely identifies a function call. Or just use with_cache()
that internally relies on the former.
Note that reading in the cached result from the user-cache pins board (i.e. from the filesystem) might produce a noticeable delay depending on the size of the cached object. Therefore, it's only recommended to cache results that take a considerable amount of time to recompute. To avoid the overhead of re-reading a cached result when accessing it multiple times, you can always assign it to an R variable to benefit from direct storage in memory.
See also
Other object handling functions:
get_obj()
,
hash_fn_call()
,
is_cached()
,
rm_obj()
Examples
# if the fn below would be part of a real package, we could instead define `this_pkg` globally
# using `this_pkg <- utils::packageName()`; instead, we now cache to pkgpins's cache (which
# itself never uses the cache)
board <- pkgpins::board(pkg = "pkgpins")
# let's define a fn that returns R pkg sys deps from cache
pkg_sys_deps <- function(pkg,
os = "ubuntu",
os_version = "24.04",
use_cache = TRUE,
max_cache_age = "6h") {
fetch <- TRUE
if (use_cache) {
pin_name <- pkgpins::hash_fn_call(from_fn = "pkg_sys_deps",
pkg, os, os_version)
result <- pkgpins::get_obj(board = board,
id = pin_name,
max_age = max_cache_age)
fetch <- is.null(result)
}
if (fetch) {
result <-
jsonlite::fromJSON(txt = glue::glue("https://packagemanager.posit.co/__api__/repos/2/sysreqs",
"?all=false&pkgname={pkg}&distribution={os}",
"&release={os_version}"),
simplifyVector = FALSE) |>
purrr::list_flatten()
}
if (use_cache && fetch) {
pkgpins::cache_obj(board = board,
x = result,
id = pin_name)
}
result
}
# now get the sys deps for git2r for the first time (populating the cache)
pkg_sys_deps("git2r")
#> $requirements
#> $requirements$name
#> [1] "git2r"
#>
#> $requirements$requirements
#> $requirements$requirements$packages
#> $requirements$requirements$packages[[1]]
#> [1] "libgit2-dev"
#>
#>
#> $requirements$requirements$install_scripts
#> $requirements$requirements$install_scripts[[1]]
#> [1] "apt-get install -y libgit2-dev"
#>
#>
#>
#>
if (FALSE) { # \dontrun{
# for the `max_cache_age` (we've set a default of 6h), the cached result will be returned
# (as long as `use_cache = TRUE`):
bench::mark("with cache" = pkg_sys_deps("git2r"),
"without cache" = pkg_sys_deps("git2r", use_cache = FALSE),
iterations = 10,
relative = TRUE)} # }
# purge cache from the above example
pkgpins::purge_cache(board = board)