[clang] [clang] Use new interpreter in EvaluateAsConstantExpr if requested (PR #70763)

Timm Baeder via cfe-commits cfe-commits at lists.llvm.org
Tue Nov 14 06:24:19 PST 2023


================
@@ -129,7 +129,13 @@ class ByteCodeExprGen : public ConstStmtVisitor<ByteCodeExprGen<Emitter>, bool>,
 
   /// Classifies a type.
   std::optional<PrimType> classify(const Expr *E) const {
-    return E->isGLValue() ? PT_Ptr : classify(E->getType());
+    if (E->isGLValue()) {
+      if (E->getType()->isFunctionType())
+        return PT_FnPtr;
+      return PT_Ptr;
+    }
+
+    return classify(E->getType());
----------------
tbaederr wrote:

This is basically just an oversight;  This should've been added when we added function pointers. This case was just never exercised. I can tell you what test case trips this up as soon as my local build finished.

https://github.com/llvm/llvm-project/pull/70763


More information about the cfe-commits mailing list