aaron.ballman added a comment.

Just to clarify, this was a regression introduced during Clang 17 development 
and thus this doesn't need a release note?



================
Comment at: clang/include/clang/Sema/Sema.h:6568
+  CheckImmediateEscalatingFunctionDefinition(FunctionDecl *FD,
+                                             const sema::FunctionScopeInfo *);
 
----------------



================
Comment at: clang/lib/Sema/SemaDeclCXX.cpp:2441
 bool Sema::CheckImmediateEscalatingFunctionDefinition(
-    FunctionDecl *FD, bool HasImmediateEscalatingExpression) {
-  if (!FD->hasBody() || !getLangOpts().CPlusPlus20 ||
-      !FD->isImmediateEscalating())
+    FunctionDecl *FD, const sema::FunctionScopeInfo *FSI) {
+  if (!getLangOpts().CPlusPlus20 || !FD->isImmediateEscalating())
----------------



================
Comment at: clang/lib/Sema/SemaExpr.cpp:6222
+  CXXThisScopeRAII This(*this, Field->getParent(), Qualifiers(),
+                        Field->getParent() != nullptr);
+
----------------
Under what circumstances can we have a `FieldDecl` without a parent object? I 
think this can be `true`, right?


================
Comment at: clang/lib/Sema/SemaExpr.cpp:18413
+    // The outer context itself becomes immediate and further errors,
+    // if any, will be handled by DiagnoseImmediateEscalatingReason
+    if (DR->isImmediateEscalating())
----------------



================
Comment at: clang/test/CodeGenCXX/cxx2c-consteval-consteval.cpp:1-2
+// RUN: %clang_cc1 -emit-llvm %s -std=c++2a -triple x86_64-unknown-linux-gnu 
-o %t.ll
+// RUN: FileCheck -input-file=%t.ll %s
+
----------------



================
Comment at: clang/test/SemaCXX/cxx2a-consteval-default-params.cpp:58
+// expected-error@-1 {{call to immediate function 
'InitWithLambda::InitWithLambda' is not a constant expression}} \
+// expected-note@-1 {{in call to 'InitWithLambda()'}}
 
----------------
Helps make it more obvious this is a continuation of the previous comment.


================
Comment at: clang/test/SemaCXX/cxx2b-consteval-propagate.cpp:201-202
+}
+struct SS {
+  int x = f(0); // expected-error {{call to consteval function 'GH63742::f' is 
not a constant expression}} \
+                // expected-note  {{declared here}} \
----------------



================
Comment at: clang/test/SemaCXX/cxx2b-consteval-propagate.cpp:219
+constexpr S2::S2(){}
+S2 s = {};
+
----------------



================
Comment at: clang/test/SemaCXX/cxx2b-consteval-propagate.cpp:240
+struct SS {
+  int x = f(0); // expected-note {{undefined function 'f' cannot be used in a 
constant expression}}
+  SS() = default;
----------------



================
Comment at: clang/test/SemaCXX/cxx2b-consteval-propagate.cpp:245-246
+void test() {
+    [[maybe_unused]] SS s; // expected-error {{call to immediate function 
'DefaultedUse::SS::SS' is not a constant expression}} \
+                           //  expected-note {{in call to 'SS()'}}
+}
----------------
I don't have a suggestion yet on how to improve this, but this diagnostic did 
catch me by surprise because nothing about the declaration of `SS s;` makes me 
think "this should be a valid constant expression", so the error felt misplaced.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D155175

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

Reply via email to