[inteprocess] timed_lock absolute time
data:image/s3,"s3://crabby-images/6d56c/6d56cbeeeb9fb0c666908dd23c3154bc129dd5c6" alt=""
Is the "absolute time" mentioned when using a mutex and timed_lock a local time or a UTC time ? I am guessing a local time but I just want to make sure.
data:image/s3,"s3://crabby-images/6d56c/6d56cbeeeb9fb0c666908dd23c3154bc129dd5c6" alt=""
On 12/29/2011 5:50 PM, Ion Gaztañaga wrote:
El 27/12/2011 2:17, Edward Diener escribió:
Is the "absolute time" mentioned when using a mutex and timed_lock a local time or a UTC time ? I am guessing a local time but I just want to make sure.
If you see code, it's universal_time() (UTC)
I do not know what you mean by "if you see code". If I want to set a duration of 10 seconds beyond the current time for my timed_lock to expire, are you saying I should pass: boost::date_time::second_clockboost::posix_time::ptime::universal_time() + boost::posix_time::seconds(10) instead of boost::date_time::second_clockboost::posix_time::ptime::local_time() + boost::posix_time::seconds(10) ? Eddie
data:image/s3,"s3://crabby-images/38c13/38c13dc5a3211b15354ca494d1f3a396af2dcaf0" alt=""
El 30/12/2011 1:56, Edward Diener escribió:
On 12/29/2011 5:50 PM, Ion Gaztañaga wrote:
El 27/12/2011 2:17, Edward Diener escribió:
Is the "absolute time" mentioned when using a mutex and timed_lock a local time or a UTC time ? I am guessing a local time but I just want to make sure.
If you see code, it's universal_time() (UTC)
I do not know what you mean by "if you see code". If I want to set a duration of 10 seconds beyond the current time for my timed_lock to expire, are you saying I should pass:
boost::date_time::second_clockboost::posix_time::ptime::universal_time() + boost::posix_time::seconds(10)
Yes. I should document it, but internally the library uses universal_time(). Ion
data:image/s3,"s3://crabby-images/6d56c/6d56cbeeeb9fb0c666908dd23c3154bc129dd5c6" alt=""
On 12/30/2011 3:51 AM, Ion Gaztañaga wrote:
El 30/12/2011 1:56, Edward Diener escribió:
On 12/29/2011 5:50 PM, Ion Gaztañaga wrote:
El 27/12/2011 2:17, Edward Diener escribió:
Is the "absolute time" mentioned when using a mutex and timed_lock a local time or a UTC time ? I am guessing a local time but I just want to make sure.
If you see code, it's universal_time() (UTC)
I do not know what you mean by "if you see code". If I want to set a duration of 10 seconds beyond the current time for my timed_lock to expire, are you saying I should pass:
boost::date_time::second_clockboost::posix_time::ptime::universal_time()
+ boost::posix_time::seconds(10)
Yes. I should document it, but internally the library uses universal_time().
OK, that is a surprise ! You really need to document that all timed locks in interprocess use UTC and not local time. IMO saying "absolute time" as you do in the doc does not infer UTC, and it is more than natural to wrongly assume local time.
data:image/s3,"s3://crabby-images/38c13/38c13dc5a3211b15354ca494d1f3a396af2dcaf0" alt=""
Yes. I should document it, but internally the library uses universal_time().
OK, that is a surprise ! You really need to document that all timed locks in interprocess use UTC and not local time. IMO saying "absolute time" as you do in the doc does not infer UTC, and it is more than natural to wrongly assume local time.
I'm not an expert on time interfaces, so maybe it was an incorrect choice. Hopefully porting it to C++11 will solve those problems. Let's see if we can find some time soon to do it. Thanks for the bug reports, Ion
participants (2)
-
Edward Diener
-
Ion Gaztañaga