<div dir="ltr"><span id="gmail-docs-internal-guid-49cf159d-7fff-5928-68a8-1dc5d0b604b2"><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Hi all,</span></p><br><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Sorry for the delay here. I took a quick look at other popular date/time libraries and there seems to be a fairly strong preference for </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">minus</span><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> (JS/TS's Temporal library is the only other date/time library that I found which uses </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">until</span><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> for this concept):</span></p><br><ul style="margin-top:0px;margin-bottom:0px"><li dir="ltr" style="list-style-type:disc;font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline;white-space:pre"><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt" role="presentation"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Abseil's Time (C++) </span><a href="https://github.com/abseil/abseil-cpp/blob/master/absl/time/time.h#L880-L882" style="text-decoration-line:none"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline">overloads the </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline">-</span><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline"> (minus) operator</span></a><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> to allow for </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">end - start</span></p></li><li dir="ltr" style="list-style-type:disc;font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline;white-space:pre"><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt" role="presentation"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">NodaTime (.NET) </span><a href="https://nodatime.org/3.1.x/api/NodaTime.Instant.html#NodaTime_Instant_Minus_NodaTime_Instant_" style="text-decoration-line:none"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline">defines</span></a><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">end.minus(start)</span><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> (which also allows </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">end - start</span><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">)</span></p></li><li dir="ltr" style="list-style-type:disc;font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline;white-space:pre"><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt" role="presentation"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Kotlinx.datetime </span><a href="https://kotlinlang.org/api/kotlinx-datetime/kotlinx-datetime/kotlinx.datetime/-instant/" style="text-decoration-line:none"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline">defines</span></a><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">end.minus(start)</span><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> (which also allows </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">end - start</span><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">)</span></p></li><li dir="ltr" style="list-style-type:disc;font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline;white-space:pre"><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt" role="presentation"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Python's date/time API </span><a href="https://docs.python.org/3/library/datetime.html#datetime.datetime" style="text-decoration-line:none"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline">allows</span></a><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">end - start</span></p></li><li dir="ltr" style="list-style-type:disc;font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline;white-space:pre"><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt" role="presentation"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Temporal (JS/TS) </span><a href="https://tc39.es/proposal-temporal/docs/instant.html#until" style="text-decoration-line:none"><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;text-decoration-line:underline;vertical-align:baseline">defines</span></a><span style="font-size:11pt;background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">start.until(end)</span></p></li></ul><br><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">The first 4 APIs support both </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">instant - instant = duration</span><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> and </span><span style="font-size:11pt;font-family:"Roboto Mono",monospace;color:rgb(24,128,56);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">instant - duration = instant</span><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline"> — I find this quite natural.</span></p><br><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Additionally, "until" seems to imply it will return a positive duration. This is fine if you're certain that "end" is after "start". However, it becomes very confusing otherwise. E.g., if you ask: "how long from when you were married until now?". If you were married 4 years ago, that makes sense. But if your wedding is in 3 months, then the result is a negative duration (which often cause confusion). If you ask the question the other way around ("how long from now until your wedding day?"), that works if your wedding is in the future, but not so much if you were married 4 years ago (again, you'll get a negative duration).</span></p><br><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Additionally, the word "until" seems to imply a range with defined start/end points; e.g., "I'm out from Tuesday until next Thursday" --- that's more of a Range<Instant> (or an Interval which java.time doesn't have – but of course JodaTime did), not just a span of time (a Duration).</span></p><br><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Does that sway anybody's opinion?</span></p><br><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">Thanks,</span></p><p dir="ltr" style="line-height:1.38;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial,sans-serif;color:rgb(0,0,0);background-color:transparent;font-variant-numeric:normal;font-variant-east-asian:normal;font-variant-alternates:normal;vertical-align:baseline">-kak</span></p></span><br class="gmail-Apple-interchange-newline"></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, May 13, 2024 at 1:38 PM Naoto Sato <<a href="mailto:naoto.sato@oracle.com">naoto.sato@oracle.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi,<br>
<br>
With Stephen/Roger's comments, as well as Kevin's observation that <br>
until(end) has a good argument ordering that is easy to understand, I'd <br>
still propose `until()`. Please post if you have further comments.<br>
<br>
Naoto<br>
<br>
On 5/3/24 6:39 AM, Roger Riggs wrote:<br>
> Hi,<br>
> <br>
> I would also reinforce Stephen's early observation that the pattern for <br>
> "until" methods in java.time includes those of the XXXDate classes, with <br>
> a single Temporal parameter.  Period and Duration are similar values <br>
> holding relative TemporalAmounts.<br>
> <br>
>      public Period until(ChronoLocalDate endDateExclusive)<br>
> <br>
> In addition to Instant, the LocalTime class might also benefit from adding:<br>
> <br>
>      public Duration until(LocalTime endExclusive)`<br>
> <br>
> The API design of java.time included an emphasis on consistent naming <br>
> across the packages.<br>
> <br>
> Regards, Roger<br>
> <br>
> <br>
> On 5/2/24 4:01 PM, Naoto Sato wrote:<br>
>> `Temporal` interface is clear that its `minus` methods return objects <br>
>> of the same `Temporal` type, and `until` calculates the amount of time <br>
>> until another `Temporal` type. Introducing `Instant.minus` that <br>
>> returns `Duration` would be confusing to me.<br>
>><br>
>> Naoto<br>
>><br>
>> On 5/2/24 10:41 AM, Éamonn McManus wrote:<br>
>>> I'd say too that this makes intuitive sense based on algebra. If we <br>
>>> have:<br>
>>> /instant1/ + /duration/ = /instant2/<br>
>>> then we can subtract /duration/ from both sides:<br>
>>> /instant1 = instant2 - duration/<br>
>>> or we can subtract /instant1/ from both sides:<br>
>>> /duration = instant2 - instant1/<br>
>>><br>
>>> There's no manipulation we can do that would cause us to try to add <br>
>>> instants together, and it's a bit surprising for the API to allow the <br>
>>> first subtraction but not the second.<br>
>>> I also think that if I see instant2.minus(instant1) it's immediately <br>
>>> obvious to me what that means, while instant1.until(instant2) seems <br>
>>> both less discoverable and less obvious.<br>
>>><br>
>>> On Thu, 2 May 2024 at 10:29, Louis Wasserman <<a href="mailto:lowasser@google.com" target="_blank">lowasser@google.com</a> <br>
>>> <mailto:<a href="mailto:lowasser@google.com" target="_blank">lowasser@google.com</a>>> wrote:<br>
>>><br>
>>>     That doesn't follow for me at all.<br>
>>><br>
>>>     The structure formed by Instants and Durations is an affine space<br>
>>> <<a href="https://en.wikipedia.org/wiki/Affine_space#Definition" rel="noreferrer" target="_blank">https://en.wikipedia.org/wiki/Affine_space#Definition</a>>, with<br>
>>>     instants the points and durations the vectors.  (An affine space is<br>
>>>     a vector space without a distinguished origin, which of course<br>
>>>     Instants don't have.)  It is 100% standard to use the minus sign for<br>
>>>     the operation "point - point = vector," even when "point + point" is<br>
>>>     not defined, and to use all the other standard idioms for<br>
>>>     subtraction; the Wikipedia article uses "subtraction" and<br>
>>>     "difference" ubiquitously.<br>
>>><br>
>>>     Personally, I'd be willing to live with a different name for the<br>
>>>     operation, but consider "users keep getting it wrong" a strong<br>
>>>     enough argument all by itself for a version with the swapped<br>
>>>     argument order; it's not obvious to me that another API with the<br>
>>>     same argument order adds enough value over Duration.between to<br>
>>>     bother with.<br>
>>><br>
>>>     On Thu, May 2, 2024 at 10:04 AM Stephen Colebourne<br>
>>>     <<a href="mailto:scolebourne@joda.org" target="_blank">scolebourne@joda.org</a> <mailto:<a href="mailto:scolebourne@joda.org" target="_blank">scolebourne@joda.org</a>>> wrote:<br>
>>><br>
>>>         On Thu, 2 May 2024 at 15:58, Kurt Alfred Kluever <<a href="mailto:kak@google.com" target="_blank">kak@google.com</a><br>
>>> <mailto:<a href="mailto:kak@google.com" target="_blank">kak@google.com</a>>> wrote:<br>
>>>          > instant − instant = duration // what we're discussing<br>
>>>          > instant + duration = instant // satisfied by<br>
>>>         instant.plus(duration)<br>
>>>          > instant - duration = instant // satisfied by<br>
>>>         instant.minus(duration)<br>
>>>          > duration + duration = duration // satisfied by<br>
>>>         duration.plus(duration)<br>
>>>          > duration - duration = duration // satisfied by<br>
>>>         duration.minus(duration)<br>
>>>          > duration × real number = duration // satisfied by<br>
>>>         duration.multipliedBy(long)<br>
>>>          > duration ÷ real number = duration // satisfied by<br>
>>>         duration.dividedBy(long)<br>
>>>          ><br>
>>>          > All but the first operation have very clear translations from<br>
>>>         conceptual model to code. I'm hoping we can achieve the same<br>
>>>         clarity for instant - instant by using the obvious name:<br>
>>>         instant.minus(instant)<br>
>>><br>
>>>         But you can't have<br>
>>>           instant + instant = ???<br>
>>>         It doesn't make sense.<br>
>>><br>
>>>         This is at the heart of why minus isn't right in this case.<br>
>>>         Stephen<br>
>>><br>
>>><br>
>>><br>
>>>     --     Louis Wasserman (he/they)<br>
>>><br>
> <br>
</blockquote></div><br clear="all"><div><br></div><span class="gmail_signature_prefix">-- </span><br><div dir="ltr" class="gmail_signature"><font face="sans-serif"><span style="line-height:19px">kak</span></font></div>