how to round durations to most significant unit ? (5 secs, 889 ms, and 811 μs => 5 secs)
Jonathan M Davis
jmdavisProg at gmx.com
Sun Feb 16 02:58:44 PST 2014
On Saturday, February 15, 2014 22:13:07 Steven Schveighoffer wrote:
> On Fri, 14 Feb 2014 17:14:03 -0500, Jonathan M Davis <jmdavisProg at gmx.com>
>
> wrote:
> > On Thursday, February 13, 2014 23:37:13 Timothee Cour wrote:
> >> Is there a function to do this?
> >> If not and I/someone writes it, is there interest to add it to
> >> std.datetime?
> >>
> >> Duration t = ...;
> >> t.to!string => 5 secs, 889 ms, and 811 μs
> >> t.round.to!string => 5 secs
> >>
> >> t=...;
> >> t.to!string => 889 ms, and 811 μs
> >> t.round.to!string => 889 secs
> >>
> >> Use case: shorter logs.
> >
> > There is no function for that, and no one's ever asked for anything like
> > it,
> > so I don't know how worthwhile it is to add. However, one possible
> > implementation would be
> >
> > auto roundToLargest(Duration d)
> > {
> >
> > foreach(units; TypeTuple!("weeks", "days", "hours", "minutes",
> > "seconds", "msecs", "usecs"))
> >
> > {
> >
> > immutable value = d.total!units();
> > if(value != 0)
> >
> > return dur!units(value);
> >
> > }
> >
> > return d;
> >
> > }
>
> You are doing the calculation for every test.
>
> Better:
> if(d >= dur!units(1))
> ...
Yeah. That would be better.
> Now, I think that the dur!units(1) should be statically determined, but if
> not, I think you could make it statically determined via enum.
It'll only be statically determined if it's in a context that requires it.
Unless something has changed recently, the compiler never tries to do CTFE if
it doesn't have to. So, you'd need to use an enum to force it.
- Jonathan M Davis
More information about the Digitalmars-d-learn
mailing list