cor3ntin marked 20 inline comments as done.
cor3ntin added inline comments.


================
Comment at: clang/docs/ReleaseNotes.rst:507-508
   ``-std=gnu++14`` to their build settings to restore the previous behaviour.
+- Implemented DR2631. Invalid ``consteval`` calls in default arguments and 
default
+  member initializers are diagnosed when and if the default is used.
 
----------------
aaron.ballman wrote:
> cor3ntin wrote:
> > cor3ntin wrote:
> > > aaron.ballman wrote:
> > > > Should this be listed as a potentially breaking change as this now 1) 
> > > > potentially changes the value people were getting for 
> > > > `source_location::current()` as a default argument, and 2) potentially 
> > > > causes instantiation differences due to the change in ODR use?
> > > No because the current value of `source_location::current()` is invalid 
> > > per library wording ( i should reference the issue though) and 2/ i don't 
> > > think there are any difference in odr use except the point of diagnostic. 
> > > Or at least i don't think you could observe it?
> > The wording for source location
> > http://eel.is/c++draft/support.srcloc#cons-2 
> > 
> > Without that issue resolution this calls for magic.
> That's correct from a standards perspective, but I'm talking about the 
> reality which is that this is a behavioral change that our users could notice 
> and could impact code outside of library calls too.
> 
> FWIW, even with this issue resolution, library is calling for magic (magical 
> thinking) IMO -- it's a constant evaluated call that doesn't produce constant 
> results and thus isn't suitable to be called immediately... even in an 
> immediate context... despite being called an immediate function.
> 
> But thinking about it more... I think we don't need to call it out as a 
> potentially breaking change. Real consteval calls give the same answer every 
> time you call them with the same input, so this really should only impact 
> people using `source_location::current()` because that doesn't match the 
> consteval model.
I think there are several things to consider.

* This is a bug fix https://github.com/llvm/llvm-project/issues/56379
* libc++ does not ship `<source_location>` (specifically because of this bug)
* `<experimental/source_location>` is not affected (because the current call is 
not `consteval`)

I think we should call out the issue either way though.



================
Comment at: clang/test/SemaCXX/cxx2a-consteval-default-params.cpp:29-30
+        return defaulted;
+    }()  // expected-note {{in the default initalizer of 'defaulted'}}
+) {
+    return 0;
----------------
aaron.ballman wrote:
> I think it'd be useful to show that use in an unevaluated context still works.
agreed


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D136554/new/

https://reviews.llvm.org/D136554

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to