rsmith added a comment.

There's no way for `-verify` to test for a diagnostic with an invalid location 
at the moment. Maybe add a FIXME and disable that portion of the test for C++11?


================
Comment at: lib/Sema/SemaDecl.cpp:10535-10538
@@ -10534,1 +10534,6 @@
           << attr->getRange();
+        APValue Value;
+        SmallVector<PartialDiagnosticAt, 8> Notes;
+        cast<Expr>(var->ensureEvaluatedStmt()->Value)->EvaluateAsInitializer(
+          Value, getASTContext(), var, Notes);
+        for (auto &it : Notes)
----------------
Can you capture the diagnostics from `checkInitIsICE` instead of recomputing 
them here? (It looks straightforward to add an overload that takes a vector of 
notes.) In the non-C++11 case, you can produce a note pointing to 
`CacheCulprit` instead.


Repository:
  rL LLVM

https://reviews.llvm.org/D24371



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

Reply via email to