1c0dca6deSReid Kleckner // RUN: %clang_cc1 -std=c++11 -fms-extensions -fms-compatibility -fsyntax-only -triple=i386-pc-win32 -verify %s
2c0dca6deSReid Kleckner
3c0dca6deSReid Kleckner struct A { int a; };
4c0dca6deSReid Kleckner
5c0dca6deSReid Kleckner #pragma vtordisp(pop) // expected-warning {{#pragma vtordisp(pop, ...) failed: stack empty}}
6c0dca6deSReid Kleckner #pragma vtordisp(push, 0)
7c0dca6deSReid Kleckner #pragma vtordisp(push, 1)
8c0dca6deSReid Kleckner #pragma vtordisp(push, 2)
9c0dca6deSReid Kleckner struct B : virtual A { int b; };
10c0dca6deSReid Kleckner #pragma vtordisp(pop)
11c0dca6deSReid Kleckner #pragma vtordisp(pop)
12c0dca6deSReid Kleckner #pragma vtordisp(pop)
13c0dca6deSReid Kleckner #pragma vtordisp(pop) // expected-warning {{#pragma vtordisp(pop, ...) failed: stack empty}}
14c0dca6deSReid Kleckner
15c0dca6deSReid Kleckner #pragma vtordisp(push, 3) // expected-warning {{expected integer between 0 and 2 inclusive in '#pragma vtordisp' - ignored}}
16c0dca6deSReid Kleckner #pragma vtordisp()
17c0dca6deSReid Kleckner
18c0dca6deSReid Kleckner #define ONE 1
19c0dca6deSReid Kleckner #pragma vtordisp(push, ONE)
20c0dca6deSReid Kleckner #define TWO 1
21c0dca6deSReid Kleckner #pragma vtordisp(push, TWO)
22c0dca6deSReid Kleckner
23c0dca6deSReid Kleckner // Test a reset.
24c0dca6deSReid Kleckner #pragma vtordisp()
25*2290dacaSDenis Zobnin #pragma vtordisp(pop) // stack should NOT be affected by reset.
26*2290dacaSDenis Zobnin // Now stack contains '1'.
27c0dca6deSReid Kleckner
28c0dca6deSReid Kleckner #pragma vtordisp( // expected-warning {{unknown action for '#pragma vtordisp' - ignored}}
29c0dca6deSReid Kleckner #pragma vtordisp(asdf) // expected-warning {{unknown action for '#pragma vtordisp' - ignored}}
30c0dca6deSReid Kleckner #pragma vtordisp(,) // expected-warning {{unknown action for '#pragma vtordisp' - ignored}}
31c0dca6deSReid Kleckner #pragma vtordisp // expected-warning {{missing '(' after '#pragma vtordisp' - ignoring}}
32c0dca6deSReid Kleckner #pragma vtordisp(3) // expected-warning {{expected integer between 0 and 2 inclusive in '#pragma vtordisp' - ignored}}
33c0dca6deSReid Kleckner #pragma vtordisp(), stuff // expected-warning {{extra tokens}}
34c0dca6deSReid Kleckner
35c0dca6deSReid Kleckner struct C {
363d42f340SAlexey Bataev #pragma vtordisp()
37c0dca6deSReid Kleckner struct D : virtual A {
38c0dca6deSReid Kleckner };
39c0dca6deSReid Kleckner };
403d42f340SAlexey Bataev
413d42f340SAlexey Bataev struct E {
423d42f340SAlexey Bataev virtual ~E();
433d42f340SAlexey Bataev virtual void f();
443d42f340SAlexey Bataev };
453d42f340SAlexey Bataev
46*2290dacaSDenis Zobnin #pragma vtordisp(pop) // After this stack should be empty.
473d42f340SAlexey Bataev #pragma vtordisp(pop) // expected-warning {{#pragma vtordisp(pop, ...) failed: stack empty}}
483d42f340SAlexey Bataev
g()493d42f340SAlexey Bataev void g() {
503d42f340SAlexey Bataev #pragma vtordisp(push, 2)
513d42f340SAlexey Bataev struct F : virtual E {
523d42f340SAlexey Bataev virtual ~F();
533d42f340SAlexey Bataev virtual void f();
543d42f340SAlexey Bataev };
553d42f340SAlexey Bataev }
563d42f340SAlexey Bataev
573d42f340SAlexey Bataev #pragma vtordisp(pop) // OK because of local vtordisp(2) in g().
583d42f340SAlexey Bataev
593d42f340SAlexey Bataev struct G {
fG603d42f340SAlexey Bataev void f() {
613d42f340SAlexey Bataev #pragma vtordisp(push, 2) // Method-local pragma - stack will be restored on exit.
623d42f340SAlexey Bataev }
633d42f340SAlexey Bataev };
643d42f340SAlexey Bataev
653d42f340SAlexey Bataev // Stack is restored on exit from G::f(), nothing to pop.
663d42f340SAlexey Bataev #pragma vtordisp(pop) // expected-warning {{#pragma vtordisp(pop, ...) failed: stack empty}}
673d42f340SAlexey Bataev
g2()683d42f340SAlexey Bataev int g2()
693d42f340SAlexey Bataev // FIXME: Our implementation based on token insertion makes it impossible for
703d42f340SAlexey Bataev // the pragma to appear everywhere we should support it.
713d42f340SAlexey Bataev // #pragma vtordisp()
723d42f340SAlexey Bataev {
733d42f340SAlexey Bataev return 0;
743d42f340SAlexey Bataev }
75