hubert.reinterpretcast added inline comments.

================
Comment at: clang/lib/Sema/SemaDeclCXX.cpp:1904-1906
+        if (!SemaRef.LangOpts.CPlusPlus2b &&
+            CheckLiteralType(SemaRef, Kind, VD->getLocation(), VD->getType(),
                              diag::err_constexpr_local_var_non_literal_type,
----------------
This seems to unconditionally error in pre-C++2b modes. For consistency, this 
should be a `-Wc++2b-extensions` warning.


================
Comment at: clang/test/CXX/dcl.dcl/dcl.spec/dcl.constexpr/dtor.cpp:1
-// RUN: %clang_cc1 -std=c++2a -verify %s
 
----------------
aaron.ballman wrote:
> I think we want to keep testing the C++20 behavior and want new tests for the 
> C++2b behavior. We still need to be sure we're correct in C++20 mode given 
> the differences (even in extensions because `-pedantic-errors` is a thing). 
> So I'd recommend splitting this test into two or using an additional RUN line.
@cor3ntin, I don't think Aaron's comment has been addressed. I think keeping 
`-std=c++2a` and adding `-Wc++2b-extensions` would be appropriate. I know there 
are tests elsewhere that also focus on paragraph 3, but this test has coverage 
specifically for destructors.


================
Comment at: clang/test/CXX/dcl.dcl/dcl.spec/dcl.constexpr/p3-2b.cpp:38
+  if (!b)
+    NonLiteral n;
+}
----------------
For consistency, this should warn (under `-Wpre-c++2b-compat`).


================
Comment at: clang/test/CXX/dcl.dcl/dcl.spec/dcl.constexpr/p3.cpp:1-3
+// RUN: %clang_cc1 -verify -fcxx-exceptions -triple=x86_64-linux-gnu 
-std=c++11 -Werror=c++14-extensions -Werror=c++20-extensions 
-Werror=c++2b-extensions %s
+// RUN: %clang_cc1 -verify -fcxx-exceptions -triple=x86_64-linux-gnu 
-std=c++14 -DCXX14 -Werror=c++20-extensions -Werror=c++2b-extensions %s
+// RUN: %clang_cc1 -verify -fcxx-exceptions -triple=x86_64-linux-gnu 
-std=c++20 -DCXX14 -DCXX20 -Werror=c++2b-extensions %s
----------------
The use `-Werror` hides potential issues where the error is categorically 
produced (instead of under the warning group).

Considering that there is a relevant design consistency issue of exactly that 
sort right now that this test could have highlighted (but didn't), a change to 
stop using `-Werror` may be prudent.


================
Comment at: clang/test/SemaCXX/constant-expression-cxx14.cpp:47
 static_assert(g(2) == 42, "");
-constexpr int h(int n) {
-  static const int m = n; // expected-error {{static variable not permitted in 
a constexpr function}}
----------------
aaron.ballman wrote:
> I think we should keep this test coverage by adding 
> `-Werror=c++2b-extensions` to the RUN line for C++2b.
@aaron.ballman, the tests have been restored; however, they test the extension 
behaviour now. The `-Werror=c++2b-extensions` version of the tests are covered 
by the tests elsewhere that focus on [dcl.constexpr] paragraph 3.


================
Comment at: clang/test/SemaCXX/constant-expression-cxx2b.cpp:3-13
+constexpr int f(int n) {  // expected-error {{constexpr function never 
produces a constant expression}}
+  static const int m = n; // expected-warning {{definition of a static 
variable in a constexpr function is incompatible with C++ standards before 
C++2b}} \
+                          // expected-note {{control flows through the 
declaration of a static variable}}
+  return m;
+}
+constexpr int g(int n) {        // expected-error {{constexpr function never 
produces a constant expression}}
+  thread_local const int m = n; // expected-warning {{definition of a 
thread_local variable in a constexpr function is incompatible with C++ 
standards before C++2b}} \
----------------
Suggest to remove the `return m;` versions of the tests. They are redundant for 
the purpose of verifying that "control flows through [ ... ]" is enough for the 
function to never produce a constant expression.


================
Comment at: clang/test/SemaCXX/constant-expression-cxx2b.cpp:30
+  return m;
+}
+
----------------
Call `j`. Just make it go though the early return.


================
Comment at: clang/test/SemaCXX/constant-expression-cxx2b.cpp:38
+  return m;
+}
+
----------------
Same comment as for `j` above (but for `k`).


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D111400

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

Reply via email to