Wrapper functions to access the packages options for default working directories. Note: there is an active binding made to Paths, so a user can use Paths$cachePath for example instead of getPaths()$cachePath

.paths()

getPaths()

Paths

setPaths(
  cachePath,
  inputPath,
  modulePath,
  outputPath,
  rasterPath,
  scratchPath,
  terraPath,
  silent = FALSE
)

Format

An object of class list of length 7.

Arguments

cachePath

The default local directory in which to cache simulation outputs. If not specified, defaults to getOption("reproducible.cachePath").

inputPath

The default local directory in which to look for simulation inputs If not specified, defaults to getOption("spades.inputPath").

modulePath

The default local directory where modules and data will be downloaded and stored. If not specified, defaults to getOption("spades.modulePath").

outputPath

The default local directory in which to save simulation outputs. If not specified, defaults to getOption("spades.outputPath").

rasterPath

The default local directory in which to save transient raster files. If not specified, defaults to file.path(getOption("spades.scratchPath"), "raster"). Important note: this location may not be cleaned up automatically, so be sure to monitor this directory and remove unnecessary temp files that may contribute to excessive disk usage. This option will be deprecated in a future release.

scratchPath

The default local directory in which to save transient files. If not specified, defaults to getOption("spades.scratchPath"). Important note: this location may not be cleaned up automatically, so be sure to monitor this directory and remove unnecessary temp files that may contribute to excessive disk usage.

terraPath

The default local directory in which to save transient terra files. If not specified, defaults to file.path(getOption("spades.scratchPath"), "terra"). Important note: this location may not be cleaned up automatically, so be sure to monitor this directory and remove unnecessary temp files that may contribute to excessive disk usage.

silent

Logical. Should the messaging occur.

Value

getPaths returns a named list of the user's default working directories. setPaths is invoked for the side effect of setting these directories.

Author

Alex Chubaty

Examples

# \donttest{
getPaths()                       ## returns the current default working paths
#> $cachePath
#> [1] "/tmp/RtmpIQ0Aky/myProject/cache"
#> 
#> $inputPath
#> [1] "/tmp/RtmpIQ0Aky/myProject/inputs"
#> 
#> $modulePath
#> [1] "/tmp/RtmpIQ0Aky/myProject/modules"
#> 
#> $outputPath
#> [1] "/tmp/RtmpIQ0Aky/myProject/outputs"
#> 
#> $rasterPath
#> [1] "/tmp/RtmpIQ0Aky/SpaDES/scratch/raster"
#> 
#> $scratchPath
#> [1] "/tmp/RtmpIQ0Aky/SpaDES/scratch"
#> 
#> $terraPath
#> [1] "/tmp/RtmpIQ0Aky/SpaDES/scratch/terra"
#> 

## set individual custom paths
setPaths(cachePath = file.path(tempdir(), "cache"))
#> Setting:
#>   options(
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>   )
#> Paths set to:
#>   options(
#>     rasterTmpDir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/raster'
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/myProject/inputs'
#>     spades.outputPath = '/tmp/RtmpIQ0Aky/myProject/outputs'
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/myProject/modules'
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/SpaDES/scratch'
#>   )
#>   terra::terraOptions(tempdir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/terra'
setPaths(inputPath = file.path(tempdir(), "inputs"))
#> Setting:
#>   options(
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/inputs'
#>   )
#> Paths set to:
#>   options(
#>     rasterTmpDir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/raster'
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/inputs'
#>     spades.outputPath = '/tmp/RtmpIQ0Aky/myProject/outputs'
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/myProject/modules'
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/SpaDES/scratch'
#>   )
#>   terra::terraOptions(tempdir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/terra'
setPaths(modulePath = file.path(tempdir(), "modules"))
#> Setting:
#>   options(
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/modules'
#>   )
#> Paths set to:
#>   options(
#>     rasterTmpDir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/raster'
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/inputs'
#>     spades.outputPath = '/tmp/RtmpIQ0Aky/myProject/outputs'
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/modules'
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/SpaDES/scratch'
#>   )
#>   terra::terraOptions(tempdir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/terra'
setPaths(outputPath = file.path(tempdir(), "outputs"))
#> Setting:
#>   options(
#>     spades.outputPath = '/tmp/RtmpIQ0Aky/outputs'
#>   )
#> Paths set to:
#>   options(
#>     rasterTmpDir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/raster'
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/inputs'
#>     spades.outputPath = '/tmp/RtmpIQ0Aky/outputs'
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/modules'
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/SpaDES/scratch'
#>   )
#>   terra::terraOptions(tempdir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/terra'
setPaths(scratchPath = file.path(tempdir(), "scratch"))
#> Setting:
#>   options(
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/scratch'
#>   )
#> Paths set to:
#>   options(
#>     rasterTmpDir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/raster'
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/inputs'
#>     spades.outputPath = '/tmp/RtmpIQ0Aky/outputs'
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/modules'
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/scratch'
#>   )
#>   terra::terraOptions(tempdir = '/tmp/RtmpIQ0Aky/SpaDES/scratch/terra'

# NOTE: on loading and attaching SpaDES.core,
# an active binding is made to "Paths"

getPaths()
#> $cachePath
#> [1] "/tmp/RtmpIQ0Aky/cache"
#> 
#> $inputPath
#> [1] "/tmp/RtmpIQ0Aky/inputs"
#> 
#> $modulePath
#> [1] "/tmp/RtmpIQ0Aky/modules"
#> 
#> $outputPath
#> [1] "/tmp/RtmpIQ0Aky/outputs"
#> 
#> $rasterPath
#> [1] "/tmp/RtmpIQ0Aky/scratch/raster"
#> 
#> $scratchPath
#> [1] "/tmp/RtmpIQ0Aky/scratch"
#> 
#> $terraPath
#> [1] "/tmp/RtmpIQ0Aky/scratch/terra"
#> 
Paths ## same as getPaths() above
#> $cachePath
#> [1] "/tmp/RtmpIQ0Aky/cache"
#> 
#> $inputPath
#> [1] "/tmp/RtmpIQ0Aky/inputs"
#> 
#> $modulePath
#> [1] "/tmp/RtmpIQ0Aky/modules"
#> 
#> $outputPath
#> [1] "/tmp/RtmpIQ0Aky/outputs"
#> 
#> $rasterPath
#> [1] "/tmp/RtmpIQ0Aky/scratch/raster"
#> 
#> $scratchPath
#> [1] "/tmp/RtmpIQ0Aky/scratch"
#> 
#> $terraPath
#> [1] "/tmp/RtmpIQ0Aky/scratch/terra"
#> 
setPaths(outputPath = tempdir())
#> Setting:
#>   options(
#>     spades.outputPath = '/tmp/RtmpIQ0Aky'
#>   )
#> Paths set to:
#>   options(
#>     rasterTmpDir = '/tmp/RtmpIQ0Aky/scratch/raster'
#>     reproducible.cachePath = '/tmp/RtmpIQ0Aky/cache'
#>     spades.inputPath = '/tmp/RtmpIQ0Aky/inputs'
#>     spades.outputPath = '/tmp/RtmpIQ0Aky'
#>     spades.modulePath = '/tmp/RtmpIQ0Aky/modules'
#>     spades.scratchPath = '/tmp/RtmpIQ0Aky/scratch'
#>   )
#>   terra::terraOptions(tempdir = '/tmp/RtmpIQ0Aky/scratch/terra'
Paths # shows change
#> $cachePath
#> [1] "/tmp/RtmpIQ0Aky/cache"
#> 
#> $inputPath
#> [1] "/tmp/RtmpIQ0Aky/inputs"
#> 
#> $modulePath
#> [1] "/tmp/RtmpIQ0Aky/modules"
#> 
#> $outputPath
#> [1] "/tmp/RtmpIQ0Aky"
#> 
#> $rasterPath
#> [1] "/tmp/RtmpIQ0Aky/scratch/raster"
#> 
#> $scratchPath
#> [1] "/tmp/RtmpIQ0Aky/scratch"
#> 
#> $terraPath
#> [1] "/tmp/RtmpIQ0Aky/scratch/terra"
#> 
# }