Title: | Facilitate Citation of R Packages |
---|---|
Description: | Facilitates the citation of R packages used in analysis projects. Scans project for packages used, gets their citations, and produces a document with citations in the preferred bibliography format, ready to be pasted into reports or manuscripts. Alternatively, 'grateful' can be used directly within an 'R Markdown' or 'Quarto' document. |
Authors: | Francisco Rodriguez-Sanchez [aut, cre, cph] , Connor P. Jackson [aut] , Shaurita D. Hutchins [ctb], James M. Clawson [ctb] |
Maintainer: | Francisco Rodriguez-Sanchez <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.2.10 |
Built: | 2025-01-13 04:03:20 UTC |
Source: | https://github.com/Pakillo/grateful |
Find R packages used in a project, create a BibTeX file of references,
and generate a document with formatted package citations. Alternatively,
cite_packages
can be run directly within an 'R Markdown' or 'Quarto' document to
automatically include a paragraph citing all used packages and generate
a bibliography.
cite_packages( output = c("file", "paragraph", "table", "citekeys"), out.dir = NULL, out.format = c("html", "docx", "pdf", "Rmd", "md", "tex-fragment", "tex-document"), citation.style = NULL, pkgs = "All", omit = c("grateful"), cite.tidyverse = TRUE, dependencies = FALSE, include.RStudio = FALSE, passive.voice = FALSE, out.file = "grateful-report", bib.file = "grateful-refs", ... )
cite_packages( output = c("file", "paragraph", "table", "citekeys"), out.dir = NULL, out.format = c("html", "docx", "pdf", "Rmd", "md", "tex-fragment", "tex-document"), citation.style = NULL, pkgs = "All", omit = c("grateful"), cite.tidyverse = TRUE, dependencies = FALSE, include.RStudio = FALSE, passive.voice = FALSE, out.file = "grateful-report", bib.file = "grateful-refs", ... )
output |
Either
In all cases, a BibTeX file with package references is saved on disk
(see |
out.dir |
Directory to save the output document and a BibTeX file with
the references. It is recommended to set |
out.format |
Output format when |
citation.style |
Optional. Citation style to format references for a
particular journal
(see https://bookdown.org/yihui/rmarkdown-cookbook/bibliography.html).
If the CSL is not available in |
pkgs |
Character. Either "All" to include all packages used in scripts
within the project/folder (the default), or "Session" to include only packages
used in the current session.
Alternatively, |
omit |
Character vector of package names to be omitted from the citation
report. |
cite.tidyverse |
Logical. If |
dependencies |
Logical. Include the dependencies of your used packages?
If |
include.RStudio |
Logical. If |
passive.voice |
Logical. If |
out.file |
Desired name of the citation report to be created if
|
bib.file |
Desired name for the BibTeX file containing packages references ("grateful-refs" by default). |
... |
Other parameters passed to |
cite_packages
is a wrapper function that collects package names and versions
and saves their citation information in a BibTeX file
(using get_pkgs_info()
).
Then, the function is designed to handle different use cases:
If output = "file"
, cite_packages()
will generate an 'R Markdown' file
which includes a paragraph with in-text citations of all packages,
as well as a references list.
This document can be knitted to various formats via out.format
.
References can be formatted for a particular journal using citation.style
.
Thus, output = "file"
is best for obtaining a document separate from R,
to just cut and paste citations.
If output = "paragraph"
, cite_packages()
will return
a paragraph with in-text citations of all packages,
suitable to be used directly in an 'R Markdown' or 'Quarto' document.
To do so, include a reference to the generated bib.file
bibliography file in the YAML header of the document
(see https://pakillo.github.io/grateful/index.html#using-grateful-within-rmarkdown).
Alternatively, if output = "table"
, cite_packages()
will return
a table with package names, versions, and citations. Thus, if using 'R Markdown'
or 'Quarto', you can choose between getting a table or a text paragraph citing all packages.
Finally, you can use output = "citekeys"
to obtain a vector of citation keys,
and then call nocite_references()
within an 'R Markdown' or 'Quarto' document
to cite these packages in the reference list without mentioning them in the text.
If output = "file"
, cite_packages
will save two files in out.dir
:
a BibTeX file containing package references and a citation report with formatted
citations. cite_packages
will return the path to the citation report invisibly.
If output = "table"
or output = "paragraph"
, cite_packages
will return
a table or paragraph with package citations suitable to be used
within 'R Markdown' or 'Quarto' documents.
Citation keys are not guaranteed to be preserved when regenerated, particularly when packages are updated. This instability is not an issue when citations are used programmatically, as in the example below. But if references are put into the text manually, they may need to be updated periodically.
# To build a standalone document for citations cite_packages(out.dir = tempdir()) # Format references for a particular journal: cite_packages(citation.style = "peerj", out.dir = tempdir()) # Choose different output format: cite_packages(out.format = "docx", out.dir = tempdir()) # Cite only packages currently loaded: cite_packages(pkgs = "Session", out.dir = tempdir()) # Cite only user-provided packages: cite_packages(pkgs = c("renv", "remotes", "knitr"), out.dir = tempdir()) # Cite R as well as user-provided packages cite_packages(pkgs = c("base", "renv", "remotes", "knitr"), out.dir = tempdir()) # To include citations in an R Markdown or Quarto file # include this in YAML header: # bibliography: grateful-refs.bib # then call cite_packages within an R chunk: cite_packages(output = "paragraph", out.dir = tempdir()) # To include package citations in the reference list of an Rmarkdown document # without citing them in the text, include this in a chunk: nocite_references(cite_packages(output = "citekeys", out.dir = tempdir()))
# To build a standalone document for citations cite_packages(out.dir = tempdir()) # Format references for a particular journal: cite_packages(citation.style = "peerj", out.dir = tempdir()) # Choose different output format: cite_packages(out.format = "docx", out.dir = tempdir()) # Cite only packages currently loaded: cite_packages(pkgs = "Session", out.dir = tempdir()) # Cite only user-provided packages: cite_packages(pkgs = c("renv", "remotes", "knitr"), out.dir = tempdir()) # Cite R as well as user-provided packages cite_packages(pkgs = c("base", "renv", "remotes", "knitr"), out.dir = tempdir()) # To include citations in an R Markdown or Quarto file # include this in YAML header: # bibliography: grateful-refs.bib # then call cite_packages within an R chunk: cite_packages(output = "paragraph", out.dir = tempdir()) # To include package citations in the reference list of an Rmarkdown document # without citing them in the text, include this in a chunk: nocite_references(cite_packages(output = "citekeys", out.dir = tempdir()))
Get citations for packages
get_citations( pkgs = NULL, out.dir = NULL, bib.file = "grateful-refs", include.RStudio = FALSE )
get_citations( pkgs = NULL, out.dir = NULL, bib.file = "grateful-refs", include.RStudio = FALSE )
pkgs |
Character vector of package names, e.g. obtained by |
out.dir |
Directory to save the output document and a BibTeX file with
the references. It is recommended to set |
bib.file |
Desired name for the BibTeX file containing packages references ("grateful-refs" by default). |
include.RStudio |
Logical. If |
A file on the specified out.dir
containing the package references
in BibTeX format. If assigned a name, get_citations
will also return a list
with citation keys for each package (without @).
citekeys <- get_citations(c("knitr", "renv"), out.dir = tempdir()) pkgs <- scan_packages() citekeys <- get_citations(pkgs$pkg, out.dir = tempdir())
citekeys <- get_citations(c("knitr", "renv"), out.dir = tempdir()) pkgs <- scan_packages() citekeys <- get_citations(pkgs$pkg, out.dir = tempdir())
Get a journal citation style from the official internet repository
get_csl(name = NULL, out.dir = NULL)
get_csl(name = NULL, out.dir = NULL)
name |
Name of the journal, exactly as found in https://github.com/citation-style-language/styles. |
out.dir |
Directory to save the CSL file. |
The CSL file is saved in the selected directory, and the path is returned invisibly.
get_csl("peerj", out.dir = tempdir())
get_csl("peerj", out.dir = tempdir())
This function scans the project for R packages used, saves a BibTeX file with package references, and returns a data frame with package names, version, and citation keys.
get_pkgs_info( pkgs = "All", out.dir = NULL, omit = c("grateful"), cite.tidyverse = TRUE, dependencies = FALSE, bib.file = "grateful-refs", include.RStudio = FALSE, ... )
get_pkgs_info( pkgs = "All", out.dir = NULL, omit = c("grateful"), cite.tidyverse = TRUE, dependencies = FALSE, bib.file = "grateful-refs", include.RStudio = FALSE, ... )
pkgs |
Character. Either "All" to include all packages used in scripts
within the project/folder (the default), or "Session" to include only packages
used in the current session.
Alternatively, |
out.dir |
Directory to save the BibTeX file with references.
It is recommended to set |
omit |
Character vector of package names to be omitted from the citation
report. |
cite.tidyverse |
Logical. If |
dependencies |
Logical. Include the dependencies of your used packages?
If |
bib.file |
Desired name for the BibTeX file containing packages references ("grateful-refs" by default). |
include.RStudio |
Logical. If |
... |
Other parameters passed to |
A data.frame with package info, and a file containing package references in BibTeX format.
get_pkgs_info(out.dir = tempdir()) get_pkgs_info(pkgs = c("renv", "remotes"), out.dir = tempdir())
get_pkgs_info(out.dir = tempdir()) get_pkgs_info(pkgs = c("renv", "remotes"), out.dir = tempdir())
Include a metadata block of citation keys for including citations in references file without in-text citations.
nocite_references(citekeys, citation_processor = c("pandoc", "latex"))
nocite_references(citekeys, citation_processor = c("pandoc", "latex"))
citekeys |
Vector of citation keys in reference to a relevant BibTeX file. |
citation_processor |
Mechanism for citation processing when knitting to
PDF or otherwise using LaTeX. Selects the appropriate formatting of the
nocite command. Either "pandoc" or "latex". If processing with
pandoc-citeproc, use the nocite metadata block. If processing via a LaTeX
processor such as natbib or biblatex, put in the LaTeX |
When passed a list of citation keys, adds the @ to each, then builds the
nocite metadata field, returning via "as-is" output. Run this function either
inline or within a code chunk (with echo = FALSE
) to include this
metadata block within an RMarkdown document. The code chunk need not
explicitly state results = 'asis'
.
Call nocite_references
with either style = 'pandoc'
or
style = 'latex'
depending on whether you are processing citations with
pandoc-citeproc or a LaTeX citation processor such as biblatex or natbib.
This function is intended to cite R packages with citation keys passed from
get_citations()
or cite_packages(output = "citekeys")
,
but can accept an arbitrary vector of citation keys (without @)
found in a BibTeX file referenced in the YAML header.
"As is" text of metadata block, with comma-separated list of citation keys.
Connor P. Jackson
# include in YAML header: # bibliography: grateful-refs.bib # Get citation keys for the current RMarkdown document # (run after all packages have been loaded). citekeys <- cite_packages(output = "citekeys", out.dir = tempdir()) # Include in RMarkdown body for use with pandoc-citeproc: # `r nocite_references(citekeys, citation_processor = 'pandoc')`
# include in YAML header: # bibliography: grateful-refs.bib # Get citation keys for the current RMarkdown document # (run after all packages have been loaded). citekeys <- cite_packages(output = "citekeys", out.dir = tempdir()) # Include in RMarkdown body for use with pandoc-citeproc: # `r nocite_references(citekeys, citation_processor = 'pandoc')`
Scan a project or folder for packages used
scan_packages( pkgs = "All", omit = c("grateful"), cite.tidyverse = TRUE, dependencies = FALSE, ... )
scan_packages( pkgs = "All", omit = c("grateful"), cite.tidyverse = TRUE, dependencies = FALSE, ... )
pkgs |
Character. Either "All" to include all packages used in scripts
within the project/folder (the default), or "Session" to include only packages
used in the current session.
Alternatively, |
omit |
Character vector of package names to be omitted from the citation
report. |
cite.tidyverse |
Logical. If |
dependencies |
Logical. Include the dependencies of your used packages?
If |
... |
Other parameters passed to |
a data.frame with package names and versions
scan_packages() scan_packages(pkgs = "Session") scan_packages(pkgs = c("renv", "remotes", "knitr"))
scan_packages() scan_packages(pkgs = "Session") scan_packages(pkgs = c("renv", "remotes", "knitr"))