Yea let's just duration_cast before calling to_time_t<br><div class="gmail_quote"><div dir="ltr">On Sat, Oct 8, 2016 at 4:23 PM Pavel Labath <<a href="mailto:labath@google.com">labath@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">labath added inline comments.<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
================<br class="gmail_msg">
Comment at: include/lldb/Host/TimeValue.h:37-38<br class="gmail_msg">
explicit TimeValue(uint32_t seconds, uint64_t nanos = 0);<br class="gmail_msg">
+ TimeValue(std::chrono::time_point<std::chrono::system_clock,<br class="gmail_msg">
+ std::chrono::nanoseconds><br class="gmail_msg">
+ point)<br class="gmail_msg">
----------------<br class="gmail_msg">
labath wrote:<br class="gmail_msg">
> zturner wrote:<br class="gmail_msg">
> > Is there any reason to explicitly prefer a nanosecond clock here as opposed to `std::chrono::system_clock::duration`? For any system which doesn't have nanosecond resolution, using a nanosecond clock is pointless, and if some theoretical system had finer resolution, then using a nanosecond clock would be limiting. So how about just `std::chrono::time_point<std::chrono::system_clock>` and let the final argument be deduced?<br class="gmail_msg">
> If you let this argument be less precise you will get conversion errors if someone tries to pass in a time point which has higher precision (seconds are implicitly convertible to nanoseconds, but not the other way). And struct timespec already (theoretically) has nanosecond precision, so we would have to make an explicit choice to lose the precision at some level.<br class="gmail_msg">
><br class="gmail_msg">
> `chrono::system_clock::time_point` has the precision at which the host system clock hands out timestamps, but that doesn't mean it's impossible to get higher precision timestamps, particularly if we start dealing with remote systems.<br class="gmail_msg">
I've hit one more annoying issue `system_clock::to_time_t` will not accept a time point with precision greater than native system clock precision. Sort of makes sense, although it's pretty pointless since time_t has only second precision on all reasonable platforms. This means, if we use nanosecond precision everywhere, we would have to cast, or roll our own version of `to_time_t`. If we use native system clock precision, we lose the ability to represent nanoseconds in some cases (and there are filesystems storing timestamps with nanosecond precision), cannot represent `struct timespec` nor the current `TimeValue`s correctly, and our time functions would behave differently depending on the host os. I'd go with the first option as it seems to have less drawbacks.<br class="gmail_msg">
<br class="gmail_msg">
I'll try to come up with a coherent proposal on the llvm side. Since it seems we'll be putting these things there, I feel I should start by porting the usage in llvm anyway.<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
<a href="https://reviews.llvm.org/D25392" rel="noreferrer" class="gmail_msg" target="_blank">https://reviews.llvm.org/D25392</a><br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
</blockquote></div>