styleguide/Rguide.md

114 lines
3.1 KiB
Markdown
Raw Normal View History

# Google's R Style Guide
R is a high-level programming language used primarily for statistical computing
and graphics. The goal of the R Programming Style Guide is to make our R code
easier to read, share, and verify.
The Google R Style Guide is a fork of the
[Tidyverse Style Guide](https://style.tidyverse.org/) by Hadley Wickham
[license](https://creativecommons.org/licenses/by-sa/2.0/). Google modifications
were developed in collaboration with the internal R user community. The rest of
this document explains Google's primary differences with the Tidyverse guide,
and why these differences exist.
Google uses the [styler](https://github.com/r-lib/styler) package on every
checked in file to ensure code consistency and help reviewers focus on more
important issues.
## Syntax
### Naming conventions
Google prefers identifying functions with `BigCamelCase` to clearly distinguish
them from other objects.
```
# Good
DoNothing <- function() {
return(invisible(NULL))
}
```
The names of private functions should begin with a dot. This helps communicate
both the origin of the function and its intended use.
```
# Good
.DoNothingPrivately <- function() {
return(invisible(NULL))
}
```
We previously recommended naming objects with `dot.case`. We're moving away from
that, as it creates confusion with S3 methods.
### Don't use attach()
The possibilities for creating errors when using `attach()` are numerous.
## Pipes
### Right-hand assignment
We do not support using right-hand assignment.
```
# Bad
iris %>%
dplyr::summarize(max_petal = max(Petal.Width)) -> results
```
This convention differs substantially from practices in other languages and
makes it harder to see in code where an object is defined. E.g. searching for
`foo <-` is easier than searching for `foo <-` and `-> foo` (possibly split over
lines).
### Use explicit returns
Do not rely on R's implicit return feature. It is better to be clear about your
intent to `return()` an object.
```
# Good
AddValues <- function(x, y) {
return(x + y)
}
# Bad
AddValues <- function(x, y) {
x + y
}
```
### Qualifying namespaces
Users should explicitly qualify namespaces for all external functions.
```
# Good
purrr::map()
```
We discourage using the `@import` Roxygen tag to bring in all functions into a
NAMESPACE. Google has a very big R codebase, and importing all functions creates
too much risk for name collisions.
While there is a small performance penalty for using `::`, it makes it easier to
understand dependencies in your code. There are some exceptions to this rule.
* Infix functions (`%name%`) always need to be imported.
* Certain `rlang` pronouns, notably `.data`, need to be imported.
* Functions from default R packages, including `datasets`, `utils`,
`grDevices`, `graphics`, `stats` and `methods`. If needed, you can `@import`
the full package.
When importing functions, place the `@importFrom` tag in the Roxygen header
above the function where the external dependency is used.
## Documentation
### Package-level documentation
All packages should have a package documentation file, in a
`packagename-package.R` file.