-
-
Notifications
You must be signed in to change notification settings - Fork 16
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow n()
in data_modify()
#535
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! I think there are cases where this implementation would fail, e.g. if someone passes 1:fun()
. Can you check for this?
You have more usecases than me with datawizard
but it seems that we gradually try to replace all functions from dplyr
, which I thought was not the main objective of datawizard
. I don't know if this needed in another package internally but if not, do we actually need to implement this instead of using dplyr
?
Also, if you want to add more bug fixes/features, I don't plan on releasing before the end of the week.
Co-authored-by: Etienne Bacher <52219252+etiennebacher@users.noreply.github.com>
Co-authored-by: Etienne Bacher <52219252+etiennebacher@users.noreply.github.com>
You're right, but we had this already for |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But I have no good idea for a use-case for fun()?
I think you can just check that the error message of data_modify(mtcars, b = fun())
is comprehensible.
But before that, please check my other comment.
I'm also not a fan of having this in |
But does |
Yes, that was certainly the initial idea of the package, but a) there are probably other people who use datawizard instead of dplyr/tidyr (e.g., @DominiqueMakowski - at least in the past - never really liked the NSE of tidyverse and prefers working with strings to identify variables etc., same like me) and b) maybe there will be other packages that prefer using datawizard for its minimal dependencies in their packages, and then it could be nice to have some features that are also supported by other packages. I personally don't mind implementing "common" features, but what do the other @easystats/maintainers think? Should we have a "stopping rule" of implementing features? |
I just meant that we should have a test for the error below: library(datawizard)
head(mtcars) |>
data_modify(x = n())
#> mpg cyl disp hp drat wt qsec vs am gear carb x
#> Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4 6
#> Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4 6
#> Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1 6
#> Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1 6
#> Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2 6
#> Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1 6
head(mtcars) |>
data_modify(x = fun())
#> Error: There was an error in the first expression. Attempt to apply
#> non-function. Possibly misspelled or not yet defined? |
@easystats/core-team Any opinions to ? |
Personally, I think the harm in adding extra features is limited (although I can also see Etienne's point about creating confusion). I think the potential benefit of new features ouweight the cons (although it also adds to future maintenance and development), so as long as you're motivated to do the associated work Daniel (and I think you are), I'd say go ahead 🥸 Sometimes in my packages I might want to internally rely on datawizard/easystats and I need dplyr just for one or two functions like |
So do we put this in 0.13.0? |
Yes, unless you feel the desperate need to merge it now. |
@easystats/maintainers any further comments on this? :-) |
Add it! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems like I'm the only one blocking this but I'm not a big datawizard
user compared to you so feel free to merge this once the bullet point in NEWS has been put in the good section
I had some usecases for it when I started contributing but I'm full in tidyverse code for all my projects now and rarely rely on |
@etiennebacher Maybe, if checks pass, you can merge this PR for the planned release? Just a minor code change.