C++ Logo

std-proposals

Advanced search

Re: [std-proposals] constexpr support for std::chrono::system_clock

From: Marcin Jaczewski <marcinjaczewski86_at_[hidden]>
Date: Thu, 6 Mar 2025 23:16:47 +0100
czw., 6 mar 2025 o 23:00 Thiago Macieira via Std-Proposals
<std-proposals_at_[hidden]> napisaƂ(a):
>
> On Thursday, 6 March 2025 13:43:47 Pacific Standard Time Nikolaos D. Bougalis
> via Std-Proposals wrote:
> > In looking, it seems to me that making std::chrono::system_clock usable in
> > constexpr contexts is pretty simple and invokes marking one function as
> > constexpr: now.
>
> Please don't. Your software should not depend on the time it was compiled at
> and should not change depending on that.
>
> std::chrono::system_clock::time_point now = {};
> if (!std::is_constant_evaluated()))
> now = std::chrono::system_clock::now();
>
> > Less exotic use cases include the ability to generate time-based UUIDs at
> > compile time, to seed random number generators at compile time, potentially
> > warn when old code is compiled (not that there's anything wrong with that!)
>
> Please make your software reproducible: it should be bitwise exactly identical
> if it is compiled by the same compiler.
>

Isn't this even worse? could this cause ODR violations?
As same inline function depend on time and two TU process it
a couple of seconds apart, now both TU will have code generated
differently.

> --
> Thiago Macieira - thiago (AT) macieira.info - thiago (AT) kde.org
> Principal Engineer - Intel DCAI Platform & System Engineering
>
>
>
> --
> Std-Proposals mailing list
> Std-Proposals_at_[hidden]
> https://lists.isocpp.org/mailman/listinfo.cgi/std-proposals

Received on 2025-03-06 22:17:00