[Rd] side-effect of calling functions via `::`
Lionel Henry
lionel at rstudio.com
Fri Sep 1 13:47:07 CEST 2017
A package should probably never register a S3 method unless it owns
either the generic or the class. Here `formula.tools` owns neither.
Instead of registering the method, it should export it like a regular
function. This way S3 dispatch is based on lexical scoping rather than
session-wide side effect.
Lionel
> On 1 sept. 2017, at 12:57, Simon Barthelmé <simon.barthelme at gipsa-lab.fr> wrote:
>
> Dear list
>
> I'm not sure whether this is a bug or an unavoidable consequence of the way packages are loaded, but there can be surprising side effects of calling a function via package::function. Here's an example using the formula.tools package:
>
> form <- a ~ b
> as.character(form)
> formula.tools::lhs(form)
> as.character(form)
>
> The first call to as.character returns:
> [1] "~" "a" "b"
> The second returns:
> [1] "a ~ b"
>
> The reason being that formula.tools has:
> S3method(as.character,formula)
> in its namespace, which quietly supersedes the default one. In my case it led to a bug that was rather hard to track down because it looked like non-deterministic behaviour.
> Shouldn't there at least be a warning about such side effects, the way library() tells you about masking?
>
> Best
>
> Simon Barthelme
>
> ______________________________________________
> R-devel at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-devel
More information about the R-devel
mailing list