mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-25 18:46:05 +00:00

Previously, information about `ConstructionContextLayer` was not propagated thru causing the expression like: Var c = (createVar()); To produce unrelated temporary for the `createVar()` result and conjure a new symbol for the value of `c` in C++17 mode. Reviewed By: steakhal Patch By: tomasz-kaminski-sonarsource! Differential Revision: https://reviews.llvm.org/D102835
36 lines
1.2 KiB
C++
36 lines
1.2 KiB
C++
// RUN: %clang_analyze_cc1 \
|
|
// RUN: -analyzer-checker=cplusplus.NewDelete,unix.Malloc \
|
|
// RUN: -analyzer-config add-pop-up-notes=false \
|
|
// RUN: -analyzer-output=text -verify %s
|
|
// RUN: %clang_analyze_cc1 \
|
|
// RUN: -analyzer-checker=cplusplus.NewDelete,unix.Malloc \
|
|
// RUN: -analyzer-config add-pop-up-notes=false \
|
|
// RUN: -analyzer-output=plist %s -o %t.plist
|
|
// RUN: %normalize_plist <%t.plist | diff -ub \
|
|
// RUN: %S/Inputs/expected-plists/NewDelete-path-notes.cpp.plist -
|
|
|
|
void test() {
|
|
int *p = new int;
|
|
// expected-note@-1 {{Memory is allocated}}
|
|
if (p) // expected-note {{Taking true branch}}
|
|
delete p;
|
|
// expected-note@-1 {{Memory is released}}
|
|
|
|
delete p; // expected-warning {{Attempt to free released memory}}
|
|
// expected-note@-1 {{Attempt to free released memory}}
|
|
}
|
|
|
|
struct Odd {
|
|
void kill() {
|
|
delete this; // expected-note {{Memory is released}}
|
|
}
|
|
};
|
|
|
|
void test(Odd *odd) {
|
|
odd->kill(); // expected-note{{Calling 'Odd::kill'}}
|
|
// expected-note@-1 {{Returning; memory was released}}
|
|
delete odd; // expected-warning {{Attempt to free released memory}}
|
|
// expected-note@-1 {{Attempt to free released memory}}
|
|
}
|
|
|