summaryrefslogtreecommitdiffstats
path: root/clang/test/Analysis/nonnullparamchecker-crash.cpp
diff options
context:
space:
mode:
authorGeorge Karpenkov <ekarpenkov@apple.com>2018-03-02 00:55:59 +0000
committerGeorge Karpenkov <ekarpenkov@apple.com>2018-03-02 00:55:59 +0000
commit0ffcaf7437972dd9f8ba9be50ac14570d4305681 (patch)
tree93b339bb837780552e2d370b394058fcf5c16cec /clang/test/Analysis/nonnullparamchecker-crash.cpp
parent534673a560f58a72c36e879cfa921c16fab51285 (diff)
downloadbcm5719-llvm-0ffcaf7437972dd9f8ba9be50ac14570d4305681.tar.gz
bcm5719-llvm-0ffcaf7437972dd9f8ba9be50ac14570d4305681.zip
[analyzer] Prevent crashing in NonNullParamChecker
https://bugs.llvm.org/show_bug.cgi?id=36381 rdar://37543426 Turns out, the type passed for the lambda capture was incorrect. One more argument to abandon the getSVal overload which does not require the type information. Differential Revision: https://reviews.llvm.org/D43925 llvm-svn: 326520
Diffstat (limited to 'clang/test/Analysis/nonnullparamchecker-crash.cpp')
-rw-r--r--clang/test/Analysis/nonnullparamchecker-crash.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/clang/test/Analysis/nonnullparamchecker-crash.cpp b/clang/test/Analysis/nonnullparamchecker-crash.cpp
new file mode 100644
index 00000000000..96e7f217059
--- /dev/null
+++ b/clang/test/Analysis/nonnullparamchecker-crash.cpp
@@ -0,0 +1,11 @@
+// RUN: %clang_analyze_cc1 -analyzer-checker=core -verify %s
+class C {};
+
+// expected-no-diagnostics
+void f(C i) {
+ auto lambda = [&] { f(i); };
+ typedef decltype(lambda) T;
+ T* blah = new T(lambda);
+ (*blah)();
+ delete blah;
+}
OpenPOWER on IntegriCloud