xref: /aosp_15_r20/external/clang/test/Preprocessor/pragma_microsoft.c (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 %s -fsyntax-only -verify -fms-extensions -Wunknown-pragmas
2*67e74705SXin Li // RUN: not %clang_cc1 %s -fms-extensions -E | FileCheck %s
3*67e74705SXin Li // REQUIRES: non-ps4-sdk
4*67e74705SXin Li 
5*67e74705SXin Li // rdar://6495941
6*67e74705SXin Li 
7*67e74705SXin Li #define FOO 1
8*67e74705SXin Li #define BAR "2"
9*67e74705SXin Li 
10*67e74705SXin Li #pragma comment(linker,"foo=" FOO) // expected-error {{pragma comment requires parenthesized identifier and optional string}}
11*67e74705SXin Li // CHECK: #pragma comment(linker,"foo=" 1)
12*67e74705SXin Li #pragma comment(linker," bar=" BAR)
13*67e74705SXin Li // CHECK: #pragma comment(linker," bar=" "2")
14*67e74705SXin Li 
15*67e74705SXin Li #pragma comment( user, "Compiled on " __DATE__ " at " __TIME__ )
16*67e74705SXin Li // CHECK: {{#pragma comment\( user, \"Compiled on \".*\" at \".*\" \)}}
17*67e74705SXin Li 
18*67e74705SXin Li #pragma comment(foo)    // expected-error {{unknown kind of pragma comment}}
19*67e74705SXin Li // CHECK: #pragma comment(foo)
20*67e74705SXin Li #pragma comment(compiler,)     // expected-error {{expected string literal in pragma comment}}
21*67e74705SXin Li // CHECK: #pragma comment(compiler,)
22*67e74705SXin Li #define foo compiler
23*67e74705SXin Li #pragma comment(foo)   // macro expand kind.
24*67e74705SXin Li // CHECK: #pragma comment(compiler)
25*67e74705SXin Li #pragma comment(foo) x // expected-error {{pragma comment requires}}
26*67e74705SXin Li // CHECK: #pragma comment(compiler) x
27*67e74705SXin Li 
28*67e74705SXin Li #pragma comment(user, "foo\abar\nbaz\tsome	thing")
29*67e74705SXin Li // CHECK: #pragma comment(user, "foo\abar\nbaz\tsome	thing")
30*67e74705SXin Li 
31*67e74705SXin Li #pragma detect_mismatch("test", "1")
32*67e74705SXin Li // CHECK: #pragma detect_mismatch("test", "1")
33*67e74705SXin Li #pragma detect_mismatch()  // expected-error {{expected string literal in pragma detect_mismatch}}
34*67e74705SXin Li // CHECK: #pragma detect_mismatch()
35*67e74705SXin Li #pragma detect_mismatch("test") // expected-error {{pragma detect_mismatch is malformed; it requires two comma-separated string literals}}
36*67e74705SXin Li // CHECK: #pragma detect_mismatch("test")
37*67e74705SXin Li #pragma detect_mismatch("test", 1) // expected-error {{expected string literal in pragma detect_mismatch}}
38*67e74705SXin Li // CHECK: #pragma detect_mismatch("test", 1)
39*67e74705SXin Li #pragma detect_mismatch("test", BAR)
40*67e74705SXin Li // CHECK: #pragma detect_mismatch("test", "2")
41*67e74705SXin Li 
42*67e74705SXin Li // __pragma
43*67e74705SXin Li 
44*67e74705SXin Li __pragma(comment(linker," bar=" BAR))
45*67e74705SXin Li // CHECK: #pragma comment(linker," bar=" "2")
46*67e74705SXin Li 
47*67e74705SXin Li #define MACRO_WITH__PRAGMA { \
48*67e74705SXin Li   __pragma(warning(push)); \
49*67e74705SXin Li   __pragma(warning(disable: 10000)); \
50*67e74705SXin Li   1 + (2 > 3) ? 4 : 5; \
51*67e74705SXin Li   __pragma(warning(pop)); \
52*67e74705SXin Li }
53*67e74705SXin Li 
f()54*67e74705SXin Li void f()
55*67e74705SXin Li {
56*67e74705SXin Li   __pragma() // expected-warning{{unknown pragma ignored}}
57*67e74705SXin Li // CHECK: #pragma
58*67e74705SXin Li 
59*67e74705SXin Li   // If we ever actually *support* __pragma(warning(disable: x)),
60*67e74705SXin Li   // this warning should go away.
61*67e74705SXin Li   MACRO_WITH__PRAGMA // expected-warning {{lower precedence}} \
62*67e74705SXin Li                      // expected-note 2 {{place parentheses}}
63*67e74705SXin Li // CHECK: #pragma warning(push)
64*67e74705SXin Li // CHECK: #pragma warning(disable: 10000)
65*67e74705SXin Li // CHECK: ; 1 + (2 > 3) ? 4 : 5;
66*67e74705SXin Li // CHECK: #pragma warning(pop)
67*67e74705SXin Li }
68*67e74705SXin Li 
69*67e74705SXin Li 
70*67e74705SXin Li // This should include macro_arg_directive even though the include
71*67e74705SXin Li // is looking for test.h  This allows us to assign to "n"
72*67e74705SXin Li #pragma include_alias("test.h", "macro_arg_directive.h" )
73*67e74705SXin Li #include "test.h"
test(void)74*67e74705SXin Li void test( void ) {
75*67e74705SXin Li   n = 12;
76*67e74705SXin Li }
77*67e74705SXin Li 
78*67e74705SXin Li #pragma include_alias(<bar.h>, "bar.h") // expected-warning {{angle-bracketed include <bar.h> cannot be aliased to double-quoted include "bar.h"}}
79*67e74705SXin Li #pragma include_alias("foo.h", <bar.h>) // expected-warning {{double-quoted include "foo.h" cannot be aliased to angle-bracketed include <bar.h>}}
80*67e74705SXin Li #pragma include_alias("test.h") // expected-warning {{pragma include_alias expected ','}}
81*67e74705SXin Li 
82*67e74705SXin Li // Make sure that the names match exactly for a replacement, including path information.  If
83*67e74705SXin Li // this were to fail, we would get a file not found error
84*67e74705SXin Li #pragma include_alias(".\pp-record.h", "does_not_exist.h")
85*67e74705SXin Li #include "pp-record.h"
86*67e74705SXin Li 
87*67e74705SXin Li #pragma include_alias(12) // expected-warning {{pragma include_alias expected include filename}}
88*67e74705SXin Li 
89*67e74705SXin Li // It's expected that we can map "bar" and <bar> separately
90*67e74705SXin Li #define test
91*67e74705SXin Li // We can't actually look up stdio.h because we're using cc1 without header paths, but this will ensure
92*67e74705SXin Li // that we get the right bar.h, because the "bar.h" will undef test for us, where <bar.h> won't
93*67e74705SXin Li #pragma include_alias(<bar.h>, <stdio.h>)
94*67e74705SXin Li #pragma include_alias("bar.h", "pr2086.h")  // This should #undef test
95*67e74705SXin Li 
96*67e74705SXin Li #include "bar.h"
97*67e74705SXin Li #if defined(test)
98*67e74705SXin Li // This should not warn because test should not be defined
99*67e74705SXin Li #pragma include_alias("test.h")
100*67e74705SXin Li #endif
101*67e74705SXin Li 
102*67e74705SXin Li // Test to make sure there are no use-after-free problems
103*67e74705SXin Li #define B "pp-record.h"
104*67e74705SXin Li #pragma include_alias("quux.h", B)
g()105*67e74705SXin Li void g() {}
106*67e74705SXin Li #include "quux.h"
107*67e74705SXin Li 
108*67e74705SXin Li // Make sure that empty includes don't work
109*67e74705SXin Li #pragma include_alias("", "foo.h")  // expected-error {{empty filename}}
110*67e74705SXin Li #pragma include_alias(<foo.h>, <>)  // expected-error {{empty filename}}
111*67e74705SXin Li 
112*67e74705SXin Li // Test that we ignore pragma warning.
113*67e74705SXin Li #pragma warning(push)
114*67e74705SXin Li // CHECK: #pragma warning(push)
115*67e74705SXin Li #pragma warning(push, 1)
116*67e74705SXin Li // CHECK: #pragma warning(push, 1)
117*67e74705SXin Li #pragma warning(disable : 4705)
118*67e74705SXin Li // CHECK: #pragma warning(disable: 4705)
119*67e74705SXin Li #pragma warning(disable : 123 456 789 ; error : 321)
120*67e74705SXin Li // CHECK: #pragma warning(disable: 123 456 789)
121*67e74705SXin Li // CHECK: #pragma warning(error: 321)
122*67e74705SXin Li #pragma warning(once : 321)
123*67e74705SXin Li // CHECK: #pragma warning(once: 321)
124*67e74705SXin Li #pragma warning(suppress : 321)
125*67e74705SXin Li // CHECK: #pragma warning(suppress: 321)
126*67e74705SXin Li #pragma warning(default : 321)
127*67e74705SXin Li // CHECK: #pragma warning(default: 321)
128*67e74705SXin Li #pragma warning(pop)
129*67e74705SXin Li // CHECK: #pragma warning(pop)
130*67e74705SXin Li #pragma warning(1: 123)
131*67e74705SXin Li // CHECK: #pragma warning(1: 123)
132*67e74705SXin Li #pragma warning(2: 234 567)
133*67e74705SXin Li // CHECK: #pragma warning(2: 234 567)
134*67e74705SXin Li #pragma warning(3: 123; 4: 678)
135*67e74705SXin Li // CHECK: #pragma warning(3: 123)
136*67e74705SXin Li // CHECK: #pragma warning(4: 678)
137*67e74705SXin Li #pragma warning(5: 123) // expected-warning {{expected 'push', 'pop', 'default', 'disable', 'error', 'once', 'suppress', 1, 2, 3, or 4}}
138*67e74705SXin Li 
139*67e74705SXin Li #pragma warning(push, 0)
140*67e74705SXin Li // CHECK: #pragma warning(push, 0)
141*67e74705SXin Li // FIXME: We could probably support pushing warning level 0.
142*67e74705SXin Li #pragma warning(pop)
143*67e74705SXin Li // CHECK: #pragma warning(pop)
144*67e74705SXin Li 
145*67e74705SXin Li #pragma warning  // expected-warning {{expected '('}}
146*67e74705SXin Li #pragma warning(   // expected-warning {{expected 'push', 'pop', 'default', 'disable', 'error', 'once', 'suppress', 1, 2, 3, or 4}}
147*67e74705SXin Li #pragma warning()   // expected-warning {{expected 'push', 'pop', 'default', 'disable', 'error', 'once', 'suppress', 1, 2, 3, or 4}}
148*67e74705SXin Li #pragma warning(push 4)  // expected-warning {{expected ')'}}
149*67e74705SXin Li // CHECK: #pragma warning(push)
150*67e74705SXin Li #pragma warning(push  // expected-warning {{expected ')'}}
151*67e74705SXin Li // CHECK: #pragma warning(push)
152*67e74705SXin Li #pragma warning(push, 5)  // expected-warning {{requires a level between 0 and 4}}
153*67e74705SXin Li #pragma warning(pop, 1)  // expected-warning {{expected ')'}}
154*67e74705SXin Li // CHECK: #pragma warning(pop)
155*67e74705SXin Li #pragma warning(push, 1) asdf // expected-warning {{extra tokens at end of #pragma warning directive}}
156*67e74705SXin Li // CHECK: #pragma warning(push, 1)
157*67e74705SXin Li #pragma warning(disable 4705) // expected-warning {{expected ':'}}
158*67e74705SXin Li #pragma warning(disable : 0) // expected-warning {{expected a warning number}}
159*67e74705SXin Li #pragma warning(default 321) // expected-warning {{expected ':'}}
160*67e74705SXin Li #pragma warning(asdf : 321) // expected-warning {{expected 'push', 'pop'}}
161*67e74705SXin Li #pragma warning(push, -1) // expected-warning {{requires a level between 0 and 4}}
162*67e74705SXin Li 
163*67e74705SXin Li // Test that runtime_checks is parsed but ignored.
164*67e74705SXin Li #pragma runtime_checks("sc", restore) // no-warning
165