ckandeler created this revision. ckandeler added a reviewer: milianw. Herald added subscribers: cfe-commits, arphaman. Herald added a project: clang.
When a variable-length array is being captured in a lambda, the AST contains two captures, the first one having a null init expression. Visiting that one triggers an assertion, so skip it. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D82629 Files: clang/test/Index/evaluate-cursor.cpp clang/tools/libclang/CIndex.cpp Index: clang/tools/libclang/CIndex.cpp =================================================================== --- clang/tools/libclang/CIndex.cpp +++ clang/tools/libclang/CIndex.cpp @@ -3272,7 +3272,7 @@ } // Visit init captures for (auto InitExpr : E->capture_inits()) { - if (Visit(InitExpr)) + if (InitExpr && Visit(InitExpr)) return true; } Index: clang/test/Index/evaluate-cursor.cpp =================================================================== --- clang/test/Index/evaluate-cursor.cpp +++ clang/test/Index/evaluate-cursor.cpp @@ -29,6 +29,13 @@ constexpr static int calc_val() { return 1 + 2; } const auto the_value = calc_val() + sizeof(char); +void vlaTest() +{ + int msize = 4; + float arr[msize]; + [&arr]{}; +} + // RUN: c-index-test -evaluate-cursor-at=%s:4:7 \ // RUN: -evaluate-cursor-at=%s:8:7 \ // RUN: -evaluate-cursor-at=%s:8:11 -std=c++11 %s | FileCheck %s @@ -65,3 +72,7 @@ // CHECK-EXPR: Value: 3 // CHECK-EXPR: unsigned, Value: 4 // CHECK-EXPR: unsigned, Value: 1 + +// RUN: c-index-test -evaluate-cursor-at=%s:36:5 \ +// RUN: -std=c++11 %s | FileCheck -check-prefix=VLA %s +// VLA: Not Evaluatable
Index: clang/tools/libclang/CIndex.cpp =================================================================== --- clang/tools/libclang/CIndex.cpp +++ clang/tools/libclang/CIndex.cpp @@ -3272,7 +3272,7 @@ } // Visit init captures for (auto InitExpr : E->capture_inits()) { - if (Visit(InitExpr)) + if (InitExpr && Visit(InitExpr)) return true; } Index: clang/test/Index/evaluate-cursor.cpp =================================================================== --- clang/test/Index/evaluate-cursor.cpp +++ clang/test/Index/evaluate-cursor.cpp @@ -29,6 +29,13 @@ constexpr static int calc_val() { return 1 + 2; } const auto the_value = calc_val() + sizeof(char); +void vlaTest() +{ + int msize = 4; + float arr[msize]; + [&arr]{}; +} + // RUN: c-index-test -evaluate-cursor-at=%s:4:7 \ // RUN: -evaluate-cursor-at=%s:8:7 \ // RUN: -evaluate-cursor-at=%s:8:11 -std=c++11 %s | FileCheck %s @@ -65,3 +72,7 @@ // CHECK-EXPR: Value: 3 // CHECK-EXPR: unsigned, Value: 4 // CHECK-EXPR: unsigned, Value: 1 + +// RUN: c-index-test -evaluate-cursor-at=%s:36:5 \ +// RUN: -std=c++11 %s | FileCheck -check-prefix=VLA %s +// VLA: Not Evaluatable
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits