================ @@ -3629,17 +3644,17 @@ static bool evaluateVarDeclInit(EvalInfo &Info, const Expr *E, Result = VD->getEvaluatedValue(); - // C++23 [expr.const]p8 - // ... For such an object that is not usable in constant expressions, the - // dynamic type of the object is constexpr-unknown. For such a reference that - // is not usable in constant expressions, the reference is treated as binding - // to an unspecified object of the referenced type whose lifetime and that of - // all subobjects includes the entire constant evaluation and whose dynamic - // type is constexpr-unknown. - if (AllowConstexprUnknown) { - if (!Result) + if (!Result) { + if (AllowConstexprUnknown) { Result = &Info.CurrentCall->createConstexprUnknownAPValues(VD, Base); + } else { + return false; + } ---------------- cor3ntin wrote:
```suggestion if (!Result) { if (AllowConstexprUnknown) Result = &Info.CurrentCall->createConstexprUnknownAPValues(VD, Base); else return false; ``` https://github.com/llvm/llvm-project/pull/132990 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits