1 // RUN: %clang_cc1 -verify -fopenmp -ferror-limit 100 %s
2 
3 void foo() {
4 }
5 
6 bool foobool(int argc) {
7   return argc;
8 }
9 
10 struct S1; // expected-note {{declared here}}
11 
12 template <class T, class S> // expected-note {{declared here}}
13 int tmain(T argc, S **argv) {
14   #pragma omp parallel sections if // expected-error {{expected '(' after 'if'}}
15   {
16     foo();
17   }
18   #pragma omp parallel sections if ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
19   {
20     foo();
21   }
22   #pragma omp parallel sections if () // expected-error {{expected expression}}
23   {
24     foo();
25   }
26   #pragma omp parallel sections if (argc // expected-error {{expected ')'}} expected-note {{to match this '('}}
27   {
28     foo();
29   }
30   #pragma omp parallel sections if (argc)) // expected-warning {{extra tokens at the end of '#pragma omp parallel sections' are ignored}}
31   {
32     foo();
33   }
34   #pragma omp parallel sections if (argc > 0 ? argv[1] : argv[2])
35   {
36     foo();
37   }
38   #pragma omp parallel sections if (foobool(argc)), if (true) // expected-error {{directive '#pragma omp parallel sections' cannot contain more than one 'if' clause}}
39   {
40     foo();
41   }
42   #pragma omp parallel sections if (S) // expected-error {{'S' does not refer to a value}}
43   {
44     foo();
45   }
46   #pragma omp parallel sections if (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}}
47   {
48     foo();
49   }
50   #pragma omp parallel sections if (argc argc) // expected-error {{expected ')'}} expected-note {{to match this '('}}
51   {
52     foo();
53   }
54   #pragma omp parallel sections if(argc)
55   {
56     foo();
57   }
58   #pragma omp parallel sections if(parallel : // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
59   {
60     foo();
61   }
62   #pragma omp parallel sections if(parallel : argc // expected-error {{expected ')'}} expected-note {{to match this '('}}
63   {
64     foo();
65   }
66   #pragma omp parallel sections if(parallel : argc)
67   {
68     foo();
69   }
70   #pragma omp parallel sections if(parallel : argc) if (for:argc) // expected-error {{directive name modifier 'for' is not allowed for '#pragma omp parallel sections'}}
71   {
72     foo();
73   }
74   #pragma omp parallel sections if(parallel : argc) if (parallel:argc) // expected-error {{directive '#pragma omp parallel sections' cannot contain more than one 'if' clause with 'parallel' name modifier}}
75   {
76     foo();
77   }
78   #pragma omp parallel sections if(parallel : argc) if (argc) // expected-error {{no more 'if' clause is allowed}} expected-note {{previous clause with directive name modifier specified here}}
79   {
80     foo();
81   }
82 
83   return 0;
84 }
85 
86 int main(int argc, char **argv) {
87   #pragma omp parallel sections if // expected-error {{expected '(' after 'if'}}
88   {
89     foo();
90   }
91   #pragma omp parallel sections if ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
92   {
93     foo();
94   }
95   #pragma omp parallel sections if () // expected-error {{expected expression}}
96   {
97     foo();
98   }
99   #pragma omp parallel sections if (argc // expected-error {{expected ')'}} expected-note {{to match this '('}}
100   {
101     foo();
102   }
103   #pragma omp parallel sections if (argc)) // expected-warning {{extra tokens at the end of '#pragma omp parallel sections' are ignored}}
104   {
105     foo();
106   }
107   #pragma omp parallel sections if (argc > 0 ? argv[1] : argv[2])
108   {
109     foo();
110   }
111   #pragma omp parallel sections if (foobool(argc)), if (true) // expected-error {{directive '#pragma omp parallel sections' cannot contain more than one 'if' clause}}
112   {
113     foo();
114   }
115   #pragma omp parallel sections if (S1) // expected-error {{'S1' does not refer to a value}}
116   {
117     foo();
118   }
119   #pragma omp parallel sections if (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}}
120   {
121     foo();
122   }
123   #pragma omp parallel sections if (argc argc) // expected-error {{expected ')'}} expected-note {{to match this '('}}
124   {
125     foo();
126   }
127   #pragma omp parallel sections if (1 0) // expected-error {{expected ')'}} expected-note {{to match this '('}}
128   {
129     foo();
130   }
131   #pragma omp parallel sections if(if(tmain(argc, argv) // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
132   {
133     foo();
134   }
135   #pragma omp parallel sections if(parallel : // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
136   {
137     foo();
138   }
139   #pragma omp parallel sections if(parallel : argc // expected-error {{expected ')'}} expected-note {{to match this '('}}
140   {
141     foo();
142   }
143   #pragma omp parallel sections if(parallel : argc)
144   {
145     foo();
146   }
147   #pragma omp parallel sections if(parallel : argc) if (for:argc) // expected-error {{directive name modifier 'for' is not allowed for '#pragma omp parallel sections'}}
148   {
149     foo();
150   }
151   #pragma omp parallel sections if(parallel : argc) if (parallel:argc) // expected-error {{directive '#pragma omp parallel sections' cannot contain more than one 'if' clause with 'parallel' name modifier}}
152   {
153     foo();
154   }
155   #pragma omp parallel sections if(parallel : argc) if (argc) // expected-error {{no more 'if' clause is allowed}} expected-note {{previous clause with directive name modifier specified here}}
156   {
157     foo();
158   }
159 
160   return tmain(argc, argv);
161 }
162