Skip to content
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

Add generic operations for hms #120

Open
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

AshesITR
Copy link

Opening this draft for early feedback.

Missinng POSIXct and POSIXlt currently.
One warning condition (difftime - Date) can't be reproduced exactly using the current implementation.
Let me know if that is a problem, because it seems hard to work around - the compatibility warning will be silenced for good by -.Date <- Ops.hms and this constellation is one where the C++ code regarding difftime has no manual disambiguation, firing the warning.

Fixes #119
Fixes #18

@AshesITR
Copy link
Author

NTS: Should also check this plays nicely with {lubridate} et al.

@krlmlr
Copy link
Member

krlmlr commented Aug 22, 2023

Thanks. The existing tests currently fail?

@AshesITR
Copy link
Author

Yes, the arith-tests regarding POSIX times.

@AshesITR AshesITR marked this pull request as ready for review August 22, 2023 05:39
@AshesITR
Copy link
Author

NB We produce this message:

Registered S3 methods overwritten by 'hms':
  method   from
  +.Date   base
  +.POSIXt base
  -.Date   base
  -.POSIXt base

@AshesITR
Copy link
Author

AshesITR commented Aug 22, 2023

R 3.6 and R 4.0 seem to behave differently. @krlmlr do you have an idea what was changed from 4.0 to 4.1?
Also, how to proceed?

Create backward-compatible behavior in the old versions (likely by branching in Ops.hms based on getRVersion() < "4.1")?
Looking at the failures, this seems like the right thing to do, because test-arith.R also produces failures on those versions.

@krlmlr
Copy link
Member

krlmlr commented Aug 23, 2023

I don't mind waiting until R 4.0 is phased out, or at least supporting this feature only for that version.

I plan to return to this package some time later in this year and can only offer very superficial advice in the meantime.

@AshesITR
Copy link
Author

AshesITR commented Aug 24, 2023

Wow, what a weird failure.
Not exporting the methods is ignored by R <= 4.0, causing test-arith failures and an incompatibility warning 😤

Incompatible methods ("+.Date", "Ops.hms") for "+"

The incompatibility warning will not be fixable in R < 4.1 because this fix is needed in eval.c:

https://github.com/wch/r-source/blob/61468d9909b8ab59a25172e584e4400427b40a27/src/main/eval.c#L4114-L4140

https://github.com/wch/r-source/blob/97fee142299e5b418cdaf1057eca0e12c250a2b8/src/main/eval.c#L3796-L3804

Seems like I have to add a working implementation for old R versions, too.

@AshesITR
Copy link
Author

I'm failing to reproduce the failure on 4.0.4 @ windows.

@krlmlr
Copy link
Member

krlmlr commented Jan 7, 2025

Much better now, only R 4.0 fails. Support for that is dropped in April, I think it's good to start reconsidering this.

Copy link
Member

@krlmlr krlmlr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! I'd really love to see this in hms, would make a good 2.0.0 .

# This logic is hard-coded in R for difftime
# cf. https://github.com/wch/r-source/blob/a46559e8f728317da979be60e401899ae60086b2/src/main/eval.c#L3406-L3419
if (.Generic == "+" && (inherits(e1, "Date") || inherits(e2, "Date"))) {
return(base::`+.Date`(e1, e2))
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should this wrap as hms?

expect_difftime_equal(2 * hms(1), hms(2))
expect_difftime_equal(hms(hours = 1) / 2, hms(minutes = 30))
expect_difftime_equal(-hms(1), hms(-1))
if (getRversion() < "4.1") {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can skip_if(getRversion() < "4.1") .

@@ -0,0 +1,108 @@
test_that("generic operations work as intended", {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The test chunk is too large, can you please split by topic?

@AshesITR
Copy link
Author

I'll see if I can put a little bit more time into this. Spare time for pet projects has taken a cut lately 😅

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

/ et al. drop class "hms" hms class dropped when doing arithmetic on hms objects
2 participants