The hardware and bandwidth for this mirror is donated by METANET, the Webhosting and Full Service-Cloud Provider.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]metanet.ch.
This package helps accessing files relative to a project root to stop the working directory insanity. It is a low-level helper package for the here package.
library(rprojroot)
The rprojroot package works best when you have a “project”: all related files contained in a subdirectory that can be categorized using a strict criterion. Let’s create a package for demonstration.
dir <- tempfile() pkg <- usethis::create_package(dir) #> ✓ Creating '/tmp/RtmpBLE08t/file294c3c8acca7/' #> ✓ Setting active project to '/tmp/RtmpBLE08t/file294c3c8acca7' #> ✓ Creating 'R/' #> ✓ Writing 'DESCRIPTION' #> Package: file294c3c8acca7 #> Title: What the Package Does (One Line, Title Case) #> Version: 0.0.0.9000 #> Date: 2020-11-08 #> Authors@R (parsed): #> * Kirill Müller <krlmlr+r@mailbox.org> [aut, cre] (<https://orcid.org/0000-0002-1416-3412>) #> Description: What the package does (one paragraph). #> License: GPL-3 #> URL: https://github.com/krlmlr/rprojroot, #> https://krlmlr.github.io/rprojroot #> BugReports: https://github.com/krlmlr/rprojroot/issues #> Encoding: UTF-8 #> LazyData: true #> Roxygen: list(markdown = TRUE) #> RoxygenNote: 7.1.1.9000 #> ✓ Writing 'NAMESPACE' #> ✓ Setting active project to '<no active project>'
R packages satisfy the is_r_package
criterion. A
criterion is an object that contains a find_file()
function. With pkg
as working directory, the function works
like file.path()
,
rooted at the working directory:
setwd(pkg) is_r_package #> Root criterion: contains a file `DESCRIPTION` with contents matching `^Package: ` is_r_package$find_file() #> [1] "/tmp/RtmpBLE08t/file294c3c8acca7" is_r_package$find_file("tests", "testthat") #> [1] "/tmp/RtmpBLE08t/file294c3c8acca7/tests/testthat"
This works identically when starting from a subdirectory:
setwd(file.path(pkg, "R")) is_r_package$find_file() #> [1] "/tmp/RtmpBLE08t/file294c3c8acca7" is_r_package$find_file("tests", "testthat") #> [1] "/tmp/RtmpBLE08t/file294c3c8acca7/tests/testthat"
There is one exception: if the first component passed to
find_file()
is already an absolute path. This allows safely
applying this function to paths that may be absolute or relative:
setwd(file.path(pkg, "R")) path <- is_r_package$find_file() is_r_package$find_file(path, "tests", "testthat") #> [1] "/tmp/RtmpBLE08t/file294c3c8acca7/tests/testthat"
As long as you are sure that your working directory is somewhere inside your project, you can retrieve the project root.
Install the package from CRAN:
install.package("rprojroot")
See the documentation for more detail.
Please note that the rprojroot project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.
These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.