blob: 743c5ad0fa8cdecd0fa6f3092e651887fbffe37e [file] [log] [blame] [edit]
// RUN: %clang_analyze_cc1 %s \
// RUN: -analyzer-checker=debug.AnalysisOrder \
// RUN: -analyzer-config debug.AnalysisOrder:EvalCall=true \
// RUN: -analyzer-config debug.AnalysisOrder:PreCall=true \
// RUN: -analyzer-config debug.AnalysisOrder:PostCall=true \
// RUN: 2>&1 | FileCheck %s
// This test ensures that eval::Call event will be triggered for constructors.
class C {
public:
C(){};
C(int x){};
C(int x, int y){};
};
void foo() {
C C0;
C C1(42);
C *C2 = new C{2, 3};
delete C2;
}
// CHECK: PreCall (C::C) [CXXConstructorCall]
// CHECK-NEXT: EvalCall (C::C) {argno: 0} [CXXConstructorCall]
// CHECK-NEXT: PostCall (C::C) [CXXConstructorCall]
// CHECK-NEXT: PreCall (C::C) [CXXConstructorCall]
// CHECK-NEXT: EvalCall (C::C) {argno: 1} [CXXConstructorCall]
// CHECK-NEXT: PostCall (C::C) [CXXConstructorCall]
// CHECK-NEXT: PreCall (operator new) [CXXAllocatorCall]
// COMMENT: Operator new calls (CXXNewExpr) are intentionally not eval-called,
// COMMENT: because it does not make sense to eval call user-provided functions.
// COMMENT: 1) If the new operator can be inlined, then don't prevent it from
// COMMENT: inlining by having an eval-call of that operator.
// COMMENT: 2) If it can't be inlined, then the default conservative modeling
// COMMENT: is what we anyways want anyway.
// COMMENT: So the EvalCall event will not be triggered for operator new calls.
// CHECK-NOT: EvalCall
// CHECK-NEXT: PostCall (operator new) [CXXAllocatorCall]
// CHECK-NEXT: PreCall (C::C) [CXXConstructorCall]
// CHECK-NEXT: EvalCall (C::C) {argno: 2} [CXXConstructorCall]
// CHECK-NEXT: PostCall (C::C) [CXXConstructorCall]
// CHECK-NEXT: PreCall (operator delete) [CXXDeallocatorCall]
// COMMENT: Same reasoning as for CXXNewExprs above.
// CHECK-NOT: EvalCall
// CHECK-NEXT: PostCall (operator delete) [CXXDeallocatorCall]