llvm-project/clang/test/SemaCXX/warn-pure-virtual-call-from...

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

23 lines
785 B
C++
Raw Normal View History

// RUN: %clang_cc1 %s -fsyntax-only -verify -Wcall-to-pure-virtual-from-ctor-dtor
struct A {
A() { f(); } // expected-warning {{call to pure virtual member function 'f' has undefined behavior; overrides of 'f' in subclasses are not available in the constructor of 'A'}}
~A() { f(); } // expected-warning {{call to pure virtual member function 'f' has undefined behavior; overrides of 'f' in subclasses are not available in the destructor of 'A'}}
virtual void f() = 0; // expected-note 2 {{'f' declared here}}
};
// Don't warn (or note) when calling the function on a pointer. (PR10195)
struct B {
A *a;
B() { a->f(); };
~B() { a->f(); };
};
// Don't warn if the call is fully qualified. (PR23215)
struct C {
virtual void f() = 0;
C() {
C::f();
}
};