diff options
| author | George Karpenkov <ekarpenkov@apple.com> | 2018-03-02 00:55:59 +0000 |
|---|---|---|
| committer | George Karpenkov <ekarpenkov@apple.com> | 2018-03-02 00:55:59 +0000 |
| commit | 0ffcaf7437972dd9f8ba9be50ac14570d4305681 (patch) | |
| tree | 93b339bb837780552e2d370b394058fcf5c16cec /clang/test/Analysis/nonnullparamchecker-crash.cpp | |
| parent | 534673a560f58a72c36e879cfa921c16fab51285 (diff) | |
| download | bcm5719-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.cpp | 11 |
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; +} |

