R has a substantial body of documentation, comprising help files for the core packages and a set of manuals aimed at users (An Introduction to R, R Data Import/Export), system administrators (R Installation and Administration) and developers (Writing R Extensions, The R language definition, and R Internals). This documentation was developed by the R Core Team with input from external contributors. The continuing involvement of the user community is important in maintaining this valuable documentation.
The involvement of the community takes many forms, from contributing content, to making bug reports or raising an issue when the documentation could be more complete or made easier to follow.
This chapter is about the ways people can contribute to R’s documentation, with guidance on how to do that. Any time you feel that you can clarify or fill gaps in existing documentation, your contribution is welcome and appreciated. If you find it difficult to deal with the markup used in the source files, you can ask for help with that part too. Please do not let the material in this chapter stand between the documentation and your desire to help out. However, not every good faith effort to change or extend the documentation will be accepted - sometimes the suggested changes may be incorrect; other times, while a change in wording may make some things clearer and easier to understand, the finer details of some corner case may become less clear, leading to the suggested changes being declined or modified by a member of R Core before applying them (if they agree the issue is important enough to fix).
The R help files are written in “R documentation” (Rd) format, a markup language which resembles LaTeX. The .Rd file format can be further processed into a variety of formats, including LaTeX, HTML, and plain text. The .Rd files can be found in the man directory of the source code for the corresponding package.
There are three main parts of an .Rd file:
All the above information is included in a .Rd file within a series of sections with standard names (user-defined sections are also allowed). These sections are discussed below:
For example, the help file for base::mean() is found at https://svn.r-project.org/R/trunk/src/library/base/man/mean.Rd. The file mean.Rd has the content shown below:
% File src/library/base/man/mean.Rd % Part of the R package, https://www.R-project.org % Copyright 1995-2022 R Core Team % Distributed under GPL 2 or later \name \title \usage< mean(x, \dots) \method(x, trim = 0, na.rm = FALSE, \dots) > \alias \alias \arguments< \item, \link and \link objects. Complex vectors are allowed for \code, only.> \item\item or \code indicating whether \code values should be stripped before the computation proceeds.> \item > \description < Generic function for the (trimmed) arithmetic mean. >\value < If \codeis zero (the default), the arithmetic mean of the values in \code is computed, as a numeric or complex vector of length one. If \code is not logical (coerced to numeric), numeric (including integer) or complex, \code is returned, with a warning. If \code is non-zero, a symmetrically trimmed mean is computed with a fraction of \code observations deleted from each end before the mean is computed. > \references< Becker, R. A., Chambers, J. M. and Wilks, A. R. (1988) \emph. Wadsworth & Brooks/Cole. > \seealso< \code<\link >, \code<\link >, \code<\link > for row and column means. > \examples < x \keyword
Many R package developers write help files using the R package roxygen2, which generates .Rd files from comments in the corresponding .R files. However, in this guide we only consider .Rd files, because the help files for the base distribution are written and edited directly in .Rd format.
This section is based on the guidelines used by R Core developers for writing R help files. Extensive details of writing R documentation files can be found in the Writing R Extensions manual.
The language used in the documentations should follow these basic rules:
The R manuals are a part of the R sources. Hence, bug reports/patches can also be submitted via Bugzilla, e.g. Bug 15221 - R-admin/‘Installing R under Windows’: Missing argument name. Note that they are typically referred to by their file names as listed below:
Manual | Nickname |
---|---|
An Introduction to R | “R-intro” |
R Data Import/Export | “R-data” |
R Installation and Administration | “R-admin” |
Writing R Extensions | “R-exts” |
The R language definition | “R-lang” |
R Internals | “R-ints” |
Maintaining the accuracy of R’s documentations and keeping a high level of quality takes a lot of effort. Community members, like you, help with writing, editing, and updating content, and these contributions are appreciated and welcomed.
Looking at pre-existing documentation source files can be very helpful when getting started.
You can directly search for documentation issues/bugs on Bugzilla. Issues vary from typos to unclear documentation and items lacking documentation.
If you see a documentation issue that you would like to tackle, you can leave a comment on the issue saying you are going to try to solve the issue and mention roughly how long you think you will take to do so (this allows others to take on the issue if you happen to forget or lose interest).
If you find some typo or problem on CRAN after checking the problem or typo you can write a polite email to cran-sysadmin@r-project.org and one of the R-core members working with CRAN. You’ll probably get a prompt reply about how the issue is going to be fixed.
While an issue filed on Bugzilla means there is a known issue somewhere, that does not mean there are not other issues lurking about in the documentation. Proofreading a part of the documentation can often uncover problems.
If you decide to proofread, read a section of the documentation from start to finish, filing issues in Bugzilla for each major type of problem you find. It is best to avoid filing a single issue for an entire section containing multiple problems; instead, file several issues so that it is easier to break the work up for multiple people and more efficient review.
The Developer’s Guide (what you are reading now) uses the same process as the main R documentation, except for some small differences. The source lives in a GitHub repository and bug reports should be submitted to the devguide GitHub tracker.
Our dev guide workflow uses continuous integration and deployment so changes to the dev guide are normally published when the pull request is merged. How to contribute to this guide from the introduction.
If you find some typo or problem on the CRAN webpages you can write a polite email to CRAN@r-project.org to report it. As an alternative, one can also write to the R-devel mailing list or submit a bug report via R’s Bugzilla.
For improvements of the R-manuals or reporting typos or bugs in the R-manuals, submit a bug report to R’s Bugzilla.
For reporting bugs or typos on the webpages or documentation about a particular package, write to the corresponding package maintainer. To find the maintainer of a package, use the command maintainer("package-name") .
Note:
There is a #core-documentation channel on the R Contributors slack where you can discuss about the patches for improvements to R’s documentation.