OSDN Git Service

gcc:
[pf3gnuchains/gcc-fork.git] / gcc / c-parser.c
1 /* Parser for C and Objective-C.
2    Copyright (C) 1987, 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3    1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
4
5    Parser actions based on the old Bison parser; structure somewhat
6    influenced by and fragments based on the C++ parser.
7
8 This file is part of GCC.
9
10 GCC is free software; you can redistribute it and/or modify it under
11 the terms of the GNU General Public License as published by the Free
12 Software Foundation; either version 2, or (at your option) any later
13 version.
14
15 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
16 WARRANTY; without even the implied warranty of MERCHANTABILITY or
17 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
18 for more details.
19
20 You should have received a copy of the GNU General Public License
21 along with GCC; see the file COPYING.  If not, write to the Free
22 Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
23 02110-1301, USA.  */
24
25 /* TODO:
26
27    Make sure all relevant comments, and all relevant code from all
28    actions, brought over from old parser.  Verify exact correspondence
29    of syntax accepted.
30
31    Add testcases covering every input symbol in every state in old and
32    new parsers.
33
34    Include full syntax for GNU C, including erroneous cases accepted
35    with error messages, in syntax productions in comments.
36
37    Make more diagnostics in the front end generally take an explicit
38    location rather than implicitly using input_location.  */
39
40 #include "config.h"
41 #include "system.h"
42 #include "coretypes.h"
43 #include "tm.h"
44 #include "tree.h"
45 #include "rtl.h"
46 #include "langhooks.h"
47 #include "input.h"
48 #include "cpplib.h"
49 #include "timevar.h"
50 #include "c-pragma.h"
51 #include "c-tree.h"
52 #include "flags.h"
53 #include "output.h"
54 #include "toplev.h"
55 #include "ggc.h"
56 #include "c-common.h"
57 #include "vec.h"
58 #include "target.h"
59 #include "cgraph.h"
60
61 \f
62 /* Miscellaneous data and functions needed for the parser.  */
63
64 int yydebug;
65
66 /* Objective-C specific parser/lexer information.  */
67
68 static int objc_pq_context = 0;
69
70 /* The following flag is needed to contextualize Objective-C lexical
71    analysis.  In some cases (e.g., 'int NSObject;'), it is undesirable
72    to bind an identifier to an Objective-C class, even if a class with
73    that name exists.  */
74 static int objc_need_raw_identifier = 0;
75 #define OBJC_NEED_RAW_IDENTIFIER(VAL)           \
76   do {                                          \
77     if (c_dialect_objc ())                      \
78       objc_need_raw_identifier = VAL;           \
79   } while (0)
80
81 /* The reserved keyword table.  */
82 struct resword
83 {
84   const char *word;
85   ENUM_BITFIELD(rid) rid : 16;
86   unsigned int disable   : 16;
87 };
88
89 /* Disable mask.  Keywords are disabled if (reswords[i].disable &
90    mask) is _true_.  */
91 #define D_C89   0x01    /* not in C89 */
92 #define D_EXT   0x02    /* GCC extension */
93 #define D_EXT89 0x04    /* GCC extension incorporated in C99 */
94 #define D_OBJC  0x08    /* Objective C only */
95
96 static const struct resword reswords[] =
97 {
98   { "_Bool",            RID_BOOL,       0 },
99   { "_Complex",         RID_COMPLEX,    0 },
100   { "_Decimal32",       RID_DFLOAT32,  D_EXT },
101   { "_Decimal64",       RID_DFLOAT64,  D_EXT },
102   { "_Decimal128",      RID_DFLOAT128, D_EXT },
103   { "__FUNCTION__",     RID_FUNCTION_NAME, 0 },
104   { "__PRETTY_FUNCTION__", RID_PRETTY_FUNCTION_NAME, 0 },
105   { "__alignof",        RID_ALIGNOF,    0 },
106   { "__alignof__",      RID_ALIGNOF,    0 },
107   { "__asm",            RID_ASM,        0 },
108   { "__asm__",          RID_ASM,        0 },
109   { "__attribute",      RID_ATTRIBUTE,  0 },
110   { "__attribute__",    RID_ATTRIBUTE,  0 },
111   { "__builtin_choose_expr", RID_CHOOSE_EXPR, 0 },
112   { "__builtin_offsetof", RID_OFFSETOF, 0 },
113   { "__builtin_types_compatible_p", RID_TYPES_COMPATIBLE_P, 0 },
114   { "__builtin_va_arg", RID_VA_ARG,     0 },
115   { "__complex",        RID_COMPLEX,    0 },
116   { "__complex__",      RID_COMPLEX,    0 },
117   { "__const",          RID_CONST,      0 },
118   { "__const__",        RID_CONST,      0 },
119   { "__extension__",    RID_EXTENSION,  0 },
120   { "__func__",         RID_C99_FUNCTION_NAME, 0 },
121   { "__imag",           RID_IMAGPART,   0 },
122   { "__imag__",         RID_IMAGPART,   0 },
123   { "__inline",         RID_INLINE,     0 },
124   { "__inline__",       RID_INLINE,     0 },
125   { "__label__",        RID_LABEL,      0 },
126   { "__real",           RID_REALPART,   0 },
127   { "__real__",         RID_REALPART,   0 },
128   { "__restrict",       RID_RESTRICT,   0 },
129   { "__restrict__",     RID_RESTRICT,   0 },
130   { "__signed",         RID_SIGNED,     0 },
131   { "__signed__",       RID_SIGNED,     0 },
132   { "__thread",         RID_THREAD,     0 },
133   { "__typeof",         RID_TYPEOF,     0 },
134   { "__typeof__",       RID_TYPEOF,     0 },
135   { "__volatile",       RID_VOLATILE,   0 },
136   { "__volatile__",     RID_VOLATILE,   0 },
137   { "asm",              RID_ASM,        D_EXT },
138   { "auto",             RID_AUTO,       0 },
139   { "break",            RID_BREAK,      0 },
140   { "case",             RID_CASE,       0 },
141   { "char",             RID_CHAR,       0 },
142   { "const",            RID_CONST,      0 },
143   { "continue",         RID_CONTINUE,   0 },
144   { "default",          RID_DEFAULT,    0 },
145   { "do",               RID_DO,         0 },
146   { "double",           RID_DOUBLE,     0 },
147   { "else",             RID_ELSE,       0 },
148   { "enum",             RID_ENUM,       0 },
149   { "extern",           RID_EXTERN,     0 },
150   { "float",            RID_FLOAT,      0 },
151   { "for",              RID_FOR,        0 },
152   { "goto",             RID_GOTO,       0 },
153   { "if",               RID_IF,         0 },
154   { "inline",           RID_INLINE,     D_EXT89 },
155   { "int",              RID_INT,        0 },
156   { "long",             RID_LONG,       0 },
157   { "register",         RID_REGISTER,   0 },
158   { "restrict",         RID_RESTRICT,   D_C89 },
159   { "return",           RID_RETURN,     0 },
160   { "short",            RID_SHORT,      0 },
161   { "signed",           RID_SIGNED,     0 },
162   { "sizeof",           RID_SIZEOF,     0 },
163   { "static",           RID_STATIC,     0 },
164   { "struct",           RID_STRUCT,     0 },
165   { "switch",           RID_SWITCH,     0 },
166   { "typedef",          RID_TYPEDEF,    0 },
167   { "typeof",           RID_TYPEOF,     D_EXT },
168   { "union",            RID_UNION,      0 },
169   { "unsigned",         RID_UNSIGNED,   0 },
170   { "void",             RID_VOID,       0 },
171   { "volatile",         RID_VOLATILE,   0 },
172   { "while",            RID_WHILE,      0 },
173   /* These Objective-C keywords are recognized only immediately after
174      an '@'.  */
175   { "class",            RID_AT_CLASS,           D_OBJC },
176   { "compatibility_alias", RID_AT_ALIAS,        D_OBJC },
177   { "defs",             RID_AT_DEFS,            D_OBJC },
178   { "encode",           RID_AT_ENCODE,          D_OBJC },
179   { "end",              RID_AT_END,             D_OBJC },
180   { "implementation",   RID_AT_IMPLEMENTATION,  D_OBJC },
181   { "interface",        RID_AT_INTERFACE,       D_OBJC },
182   { "private",          RID_AT_PRIVATE,         D_OBJC },
183   { "protected",        RID_AT_PROTECTED,       D_OBJC },
184   { "protocol",         RID_AT_PROTOCOL,        D_OBJC },
185   { "public",           RID_AT_PUBLIC,          D_OBJC },
186   { "selector",         RID_AT_SELECTOR,        D_OBJC },
187   { "throw",            RID_AT_THROW,           D_OBJC },
188   { "try",              RID_AT_TRY,             D_OBJC },
189   { "catch",            RID_AT_CATCH,           D_OBJC },
190   { "finally",          RID_AT_FINALLY,         D_OBJC },
191   { "synchronized",     RID_AT_SYNCHRONIZED,    D_OBJC },
192   /* These are recognized only in protocol-qualifier context
193      (see above) */
194   { "bycopy",           RID_BYCOPY,             D_OBJC },
195   { "byref",            RID_BYREF,              D_OBJC },
196   { "in",               RID_IN,                 D_OBJC },
197   { "inout",            RID_INOUT,              D_OBJC },
198   { "oneway",           RID_ONEWAY,             D_OBJC },
199   { "out",              RID_OUT,                D_OBJC },
200 };
201 #define N_reswords (sizeof reswords / sizeof (struct resword))
202
203 /* All OpenMP clauses.  OpenMP 2.5.  */
204 typedef enum pragma_omp_clause {
205   PRAGMA_OMP_CLAUSE_NONE = 0,
206
207   PRAGMA_OMP_CLAUSE_COPYIN,
208   PRAGMA_OMP_CLAUSE_COPYPRIVATE,
209   PRAGMA_OMP_CLAUSE_DEFAULT,
210   PRAGMA_OMP_CLAUSE_FIRSTPRIVATE,
211   PRAGMA_OMP_CLAUSE_IF,
212   PRAGMA_OMP_CLAUSE_LASTPRIVATE,
213   PRAGMA_OMP_CLAUSE_NOWAIT,
214   PRAGMA_OMP_CLAUSE_NUM_THREADS,
215   PRAGMA_OMP_CLAUSE_ORDERED,
216   PRAGMA_OMP_CLAUSE_PRIVATE,
217   PRAGMA_OMP_CLAUSE_REDUCTION,
218   PRAGMA_OMP_CLAUSE_SCHEDULE,
219   PRAGMA_OMP_CLAUSE_SHARED
220 } pragma_omp_clause;
221
222
223 /* Initialization routine for this file.  */
224
225 void
226 c_parse_init (void)
227 {
228   /* The only initialization required is of the reserved word
229      identifiers.  */
230   unsigned int i;
231   tree id;
232   int mask = (flag_isoc99 ? 0 : D_C89)
233               | (flag_no_asm ? (flag_isoc99 ? D_EXT : D_EXT|D_EXT89) : 0);
234
235   if (!c_dialect_objc ())
236      mask |= D_OBJC;
237
238   ridpointers = GGC_CNEWVEC (tree, (int) RID_MAX);
239   for (i = 0; i < N_reswords; i++)
240     {
241       /* If a keyword is disabled, do not enter it into the table
242          and so create a canonical spelling that isn't a keyword.  */
243       if (reswords[i].disable & mask)
244         continue;
245
246       id = get_identifier (reswords[i].word);
247       C_RID_CODE (id) = reswords[i].rid;
248       C_IS_RESERVED_WORD (id) = 1;
249       ridpointers [(int) reswords[i].rid] = id;
250     }
251 }
252 \f
253 /* The C lexer intermediates between the lexer in cpplib and c-lex.c
254    and the C parser.  Unlike the C++ lexer, the parser structure
255    stores the lexer information instead of using a separate structure.
256    Identifiers are separated into ordinary identifiers, type names,
257    keywords and some other Objective-C types of identifiers, and some
258    look-ahead is maintained.
259
260    ??? It might be a good idea to lex the whole file up front (as for
261    C++).  It would then be possible to share more of the C and C++
262    lexer code, if desired.  */
263
264 /* The following local token type is used.  */
265
266 /* A keyword.  */
267 #define CPP_KEYWORD ((enum cpp_ttype) (N_TTYPES + 1))
268
269 /* More information about the type of a CPP_NAME token.  */
270 typedef enum c_id_kind {
271   /* An ordinary identifier.  */
272   C_ID_ID,
273   /* An identifier declared as a typedef name.  */
274   C_ID_TYPENAME,
275   /* An identifier declared as an Objective-C class name.  */
276   C_ID_CLASSNAME,
277   /* Not an identifier.  */
278   C_ID_NONE
279 } c_id_kind;
280
281 /* A single C token after string literal concatenation and conversion
282    of preprocessing tokens to tokens.  */
283 typedef struct c_token GTY (())
284 {
285   /* The kind of token.  */
286   ENUM_BITFIELD (cpp_ttype) type : 8;
287   /* If this token is a CPP_NAME, this value indicates whether also
288      declared as some kind of type.  Otherwise, it is C_ID_NONE.  */
289   ENUM_BITFIELD (c_id_kind) id_kind : 8;
290   /* If this token is a keyword, this value indicates which keyword.
291      Otherwise, this value is RID_MAX.  */
292   ENUM_BITFIELD (rid) keyword : 8;
293   /* If this token is a CPP_PRAGMA, this indicates the pragma that
294      was seen.  Otherwise it is PRAGMA_NONE.  */
295   ENUM_BITFIELD (pragma_kind) pragma_kind : 7;
296   /* True if this token is from a system header.  */
297   BOOL_BITFIELD in_system_header : 1;
298   /* The value associated with this token, if any.  */
299   tree value;
300   /* The location at which this token was found.  */
301   location_t location;
302 } c_token;
303
304 /* A parser structure recording information about the state and
305    context of parsing.  Includes lexer information with up to two
306    tokens of look-ahead; more are not needed for C.  */
307 typedef struct c_parser GTY(())
308 {
309   /* The look-ahead tokens.  */
310   c_token tokens[2];
311   /* How many look-ahead tokens are available (0, 1 or 2).  */
312   short tokens_avail;
313   /* True if a syntax error is being recovered from; false otherwise.
314      c_parser_error sets this flag.  It should clear this flag when
315      enough tokens have been consumed to recover from the error.  */
316   BOOL_BITFIELD error : 1;
317   /* True if we're processing a pragma, and shouldn't automatically
318      consume CPP_PRAGMA_EOL.  */
319   BOOL_BITFIELD in_pragma : 1;
320 } c_parser;
321
322
323 /* The actual parser and external interface.  ??? Does this need to be
324    garbage-collected?  */
325
326 static GTY (()) c_parser *the_parser;
327
328
329 /* Read in and lex a single token, storing it in *TOKEN.  */
330
331 static void
332 c_lex_one_token (c_token *token)
333 {
334   timevar_push (TV_LEX);
335
336   token->type = c_lex_with_flags (&token->value, &token->location, NULL);
337   token->id_kind = C_ID_NONE;
338   token->keyword = RID_MAX;
339   token->pragma_kind = PRAGMA_NONE;
340   token->in_system_header = in_system_header;
341
342   switch (token->type)
343     {
344     case CPP_NAME:
345       {
346         tree decl;
347
348         int objc_force_identifier = objc_need_raw_identifier;
349         OBJC_NEED_RAW_IDENTIFIER (0);
350
351         if (C_IS_RESERVED_WORD (token->value))
352           {
353             enum rid rid_code = C_RID_CODE (token->value);
354
355             if (c_dialect_objc ())
356               {
357                 if (!OBJC_IS_AT_KEYWORD (rid_code)
358                     && (!OBJC_IS_PQ_KEYWORD (rid_code) || objc_pq_context))
359                   {
360                     /* Return the canonical spelling for this keyword.  */
361                     token->value = ridpointers[(int) rid_code];
362                     token->type = CPP_KEYWORD;
363                     token->keyword = rid_code;
364                     break;
365                   }
366               }
367             else
368               {
369                 /* Return the canonical spelling for this keyword.  */
370                 token->value = ridpointers[(int) rid_code];
371                 token->type = CPP_KEYWORD;
372                 token->keyword = rid_code;
373                 break;
374               }
375           }
376
377         decl = lookup_name (token->value);
378         if (decl)
379           {
380             if (TREE_CODE (decl) == TYPE_DECL)
381               {
382                 token->id_kind = C_ID_TYPENAME;
383                 break;
384               }
385           }
386         else if (c_dialect_objc ())
387           {
388             tree objc_interface_decl = objc_is_class_name (token->value);
389             /* Objective-C class names are in the same namespace as
390                variables and typedefs, and hence are shadowed by local
391                declarations.  */
392             if (objc_interface_decl
393                 && (global_bindings_p ()
394                     || (!objc_force_identifier && !decl)))
395               {
396                 token->value = objc_interface_decl;
397                 token->id_kind = C_ID_CLASSNAME;
398                 break;
399               }
400           }
401         token->id_kind = C_ID_ID;
402       }
403       break;
404     case CPP_AT_NAME:
405       /* This only happens in Objective-C; it must be a keyword.  */
406       token->type = CPP_KEYWORD;
407       token->keyword = C_RID_CODE (token->value);
408       break;
409     case CPP_COLON:
410     case CPP_COMMA:
411     case CPP_CLOSE_PAREN:
412     case CPP_SEMICOLON:
413       /* These tokens may affect the interpretation of any identifiers
414          following, if doing Objective-C.  */
415       OBJC_NEED_RAW_IDENTIFIER (0);
416       break;
417     case CPP_PRAGMA:
418       /* We smuggled the cpp_token->u.pragma value in an INTEGER_CST.  */
419       token->pragma_kind = TREE_INT_CST_LOW (token->value);
420       token->value = NULL;
421       break;
422     default:
423       break;
424     }
425   timevar_pop (TV_LEX);
426 }
427
428 /* Return a pointer to the next token from PARSER, reading it in if
429    necessary.  */
430
431 static inline c_token *
432 c_parser_peek_token (c_parser *parser)
433 {
434   if (parser->tokens_avail == 0)
435     {
436       c_lex_one_token (&parser->tokens[0]);
437       parser->tokens_avail = 1;
438     }
439   return &parser->tokens[0];
440 }
441
442 /* Return true if the next token from PARSER has the indicated
443    TYPE.  */
444
445 static inline bool
446 c_parser_next_token_is (c_parser *parser, enum cpp_ttype type)
447 {
448   return c_parser_peek_token (parser)->type == type;
449 }
450
451 /* Return true if the next token from PARSER does not have the
452    indicated TYPE.  */
453
454 static inline bool
455 c_parser_next_token_is_not (c_parser *parser, enum cpp_ttype type)
456 {
457   return !c_parser_next_token_is (parser, type);
458 }
459
460 /* Return true if the next token from PARSER is the indicated
461    KEYWORD.  */
462
463 static inline bool
464 c_parser_next_token_is_keyword (c_parser *parser, enum rid keyword)
465 {
466   c_token *token;
467
468   /* Peek at the next token.  */
469   token = c_parser_peek_token (parser);
470   /* Check to see if it is the indicated keyword.  */
471   return token->keyword == keyword;
472 }
473
474 /* Return true if TOKEN can start a type name,
475    false otherwise.  */
476 static bool
477 c_token_starts_typename (c_token *token)
478 {
479   switch (token->type)
480     {
481     case CPP_NAME:
482       switch (token->id_kind)
483         {
484         case C_ID_ID:
485           return false;
486         case C_ID_TYPENAME:
487           return true;
488         case C_ID_CLASSNAME:
489           gcc_assert (c_dialect_objc ());
490           return true;
491         default:
492           gcc_unreachable ();
493         }
494     case CPP_KEYWORD:
495       switch (token->keyword)
496         {
497         case RID_UNSIGNED:
498         case RID_LONG:
499         case RID_SHORT:
500         case RID_SIGNED:
501         case RID_COMPLEX:
502         case RID_INT:
503         case RID_CHAR:
504         case RID_FLOAT:
505         case RID_DOUBLE:
506         case RID_VOID:
507         case RID_DFLOAT32:
508         case RID_DFLOAT64:
509         case RID_DFLOAT128:
510         case RID_BOOL:
511         case RID_ENUM:
512         case RID_STRUCT:
513         case RID_UNION:
514         case RID_TYPEOF:
515         case RID_CONST:
516         case RID_VOLATILE:
517         case RID_RESTRICT:
518         case RID_ATTRIBUTE:
519           return true;
520         default:
521           return false;
522         }
523     case CPP_LESS:
524       if (c_dialect_objc ())
525         return true;
526       return false;
527     default:
528       return false;
529     }
530 }
531
532 /* Return true if the next token from PARSER can start a type name,
533    false otherwise.  */
534 static inline bool
535 c_parser_next_token_starts_typename (c_parser *parser)
536 {
537   c_token *token = c_parser_peek_token (parser);
538   return c_token_starts_typename (token);
539 }
540
541 /* Return true if TOKEN can start declaration specifiers, false
542    otherwise.  */
543 static bool
544 c_token_starts_declspecs (c_token *token)
545 {
546   switch (token->type)
547     {
548     case CPP_NAME:
549       switch (token->id_kind)
550         {
551         case C_ID_ID:
552           return false;
553         case C_ID_TYPENAME:
554           return true;
555         case C_ID_CLASSNAME:
556           gcc_assert (c_dialect_objc ());
557           return true;
558         default:
559           gcc_unreachable ();
560         }
561     case CPP_KEYWORD:
562       switch (token->keyword)
563         {
564         case RID_STATIC:
565         case RID_EXTERN:
566         case RID_REGISTER:
567         case RID_TYPEDEF:
568         case RID_INLINE:
569         case RID_AUTO:
570         case RID_THREAD:
571         case RID_UNSIGNED:
572         case RID_LONG:
573         case RID_SHORT:
574         case RID_SIGNED:
575         case RID_COMPLEX:
576         case RID_INT:
577         case RID_CHAR:
578         case RID_FLOAT:
579         case RID_DOUBLE:
580         case RID_VOID:
581         case RID_DFLOAT32:
582         case RID_DFLOAT64:
583         case RID_DFLOAT128:
584         case RID_BOOL:
585         case RID_ENUM:
586         case RID_STRUCT:
587         case RID_UNION:
588         case RID_TYPEOF:
589         case RID_CONST:
590         case RID_VOLATILE:
591         case RID_RESTRICT:
592         case RID_ATTRIBUTE:
593           return true;
594         default:
595           return false;
596         }
597     case CPP_LESS:
598       if (c_dialect_objc ())
599         return true;
600       return false;
601     default:
602       return false;
603     }
604 }
605
606 /* Return true if the next token from PARSER can start declaration
607    specifiers, false otherwise.  */
608 static inline bool
609 c_parser_next_token_starts_declspecs (c_parser *parser)
610 {
611   c_token *token = c_parser_peek_token (parser);
612   return c_token_starts_declspecs (token);
613 }
614
615 /* Return a pointer to the next-but-one token from PARSER, reading it
616    in if necessary.  The next token is already read in.  */
617
618 static c_token *
619 c_parser_peek_2nd_token (c_parser *parser)
620 {
621   if (parser->tokens_avail >= 2)
622     return &parser->tokens[1];
623   gcc_assert (parser->tokens_avail == 1);
624   gcc_assert (parser->tokens[0].type != CPP_EOF);
625   gcc_assert (parser->tokens[0].type != CPP_PRAGMA_EOL);
626   c_lex_one_token (&parser->tokens[1]);
627   parser->tokens_avail = 2;
628   return &parser->tokens[1];
629 }
630
631 /* Consume the next token from PARSER.  */
632
633 static void
634 c_parser_consume_token (c_parser *parser)
635 {
636   gcc_assert (parser->tokens_avail >= 1);
637   gcc_assert (parser->tokens[0].type != CPP_EOF);
638   gcc_assert (!parser->in_pragma || parser->tokens[0].type != CPP_PRAGMA_EOL);
639   gcc_assert (parser->error || parser->tokens[0].type != CPP_PRAGMA);
640   if (parser->tokens_avail == 2)
641     parser->tokens[0] = parser->tokens[1];
642   parser->tokens_avail--;
643 }
644
645 /* Expect the current token to be a #pragma.  Consume it and remember
646    that we've begun parsing a pragma.  */
647
648 static void
649 c_parser_consume_pragma (c_parser *parser)
650 {
651   gcc_assert (!parser->in_pragma);
652   gcc_assert (parser->tokens_avail >= 1);
653   gcc_assert (parser->tokens[0].type == CPP_PRAGMA);
654   if (parser->tokens_avail == 2)
655     parser->tokens[0] = parser->tokens[1];
656   parser->tokens_avail--;
657   parser->in_pragma = true;
658 }
659
660 /* Update the globals input_location and in_system_header from
661    TOKEN.  */
662 static inline void
663 c_parser_set_source_position_from_token (c_token *token)
664 {
665   if (token->type != CPP_EOF)
666     {
667       input_location = token->location;
668       in_system_header = token->in_system_header;
669     }
670 }
671
672 /* Issue a diagnostic of the form
673       FILE:LINE: MESSAGE before TOKEN
674    where TOKEN is the next token in the input stream of PARSER.
675    MESSAGE (specified by the caller) is usually of the form "expected
676    OTHER-TOKEN".
677
678    Do not issue a diagnostic if still recovering from an error.
679
680    ??? This is taken from the C++ parser, but building up messages in
681    this way is not i18n-friendly and some other approach should be
682    used.  */
683
684 static void
685 c_parser_error (c_parser *parser, const char *gmsgid)
686 {
687   c_token *token = c_parser_peek_token (parser);
688   if (parser->error)
689     return;
690   parser->error = true;
691   if (!gmsgid)
692     return;
693   /* This diagnostic makes more sense if it is tagged to the line of
694      the token we just peeked at.  */
695   c_parser_set_source_position_from_token (token);
696   c_parse_error (gmsgid,
697                  /* Because c_parse_error does not understand
698                     CPP_KEYWORD, keywords are treated like
699                     identifiers.  */
700                  (token->type == CPP_KEYWORD ? CPP_NAME : token->type),
701                  token->value);
702 }
703
704 /* If the next token is of the indicated TYPE, consume it.  Otherwise,
705    issue the error MSGID.  If MSGID is NULL then a message has already
706    been produced and no message will be produced this time.  Returns
707    true if found, false otherwise.  */
708
709 static bool
710 c_parser_require (c_parser *parser,
711                   enum cpp_ttype type,
712                   const char *msgid)
713 {
714   if (c_parser_next_token_is (parser, type))
715     {
716       c_parser_consume_token (parser);
717       return true;
718     }
719   else
720     {
721       c_parser_error (parser, msgid);
722       return false;
723     }
724 }
725
726 /* If the next token is the indicated keyword, consume it.  Otherwise,
727    issue the error MSGID.  Returns true if found, false otherwise.  */
728
729 static bool
730 c_parser_require_keyword (c_parser *parser,
731                           enum rid keyword,
732                           const char *msgid)
733 {
734   if (c_parser_next_token_is_keyword (parser, keyword))
735     {
736       c_parser_consume_token (parser);
737       return true;
738     }
739   else
740     {
741       c_parser_error (parser, msgid);
742       return false;
743     }
744 }
745
746 /* Like c_parser_require, except that tokens will be skipped until the
747    desired token is found.  An error message is still produced if the
748    next token is not as expected.  If MSGID is NULL then a message has
749    already been produced and no message will be produced this
750    time.  */
751
752 static void
753 c_parser_skip_until_found (c_parser *parser,
754                            enum cpp_ttype type,
755                            const char *msgid)
756 {
757   unsigned nesting_depth = 0;
758
759   if (c_parser_require (parser, type, msgid))
760     return;
761
762   /* Skip tokens until the desired token is found.  */
763   while (true)
764     {
765       /* Peek at the next token.  */
766       c_token *token = c_parser_peek_token (parser);
767       /* If we've reached the token we want, consume it and stop.  */
768       if (token->type == type && !nesting_depth)
769         {
770           c_parser_consume_token (parser);
771           break;
772         }
773
774       /* If we've run out of tokens, stop.  */
775       if (token->type == CPP_EOF)
776         return;
777       if (token->type == CPP_PRAGMA_EOL && parser->in_pragma)
778         return;
779       if (token->type == CPP_OPEN_BRACE
780           || token->type == CPP_OPEN_PAREN
781           || token->type == CPP_OPEN_SQUARE)
782         ++nesting_depth;
783       else if (token->type == CPP_CLOSE_BRACE
784                || token->type == CPP_CLOSE_PAREN
785                || token->type == CPP_CLOSE_SQUARE)
786         {
787           if (nesting_depth-- == 0)
788             break;
789         }
790       /* Consume this token.  */
791       c_parser_consume_token (parser);
792     }
793   parser->error = false;
794 }
795
796 /* Skip tokens until the end of a parameter is found, but do not
797    consume the comma, semicolon or closing delimiter.  */
798
799 static void
800 c_parser_skip_to_end_of_parameter (c_parser *parser)
801 {
802   unsigned nesting_depth = 0;
803
804   while (true)
805     {
806       c_token *token = c_parser_peek_token (parser);
807       if ((token->type == CPP_COMMA || token->type == CPP_SEMICOLON)
808           && !nesting_depth)
809         break;
810       /* If we've run out of tokens, stop.  */
811       if (token->type == CPP_EOF)
812         return;
813       if (token->type == CPP_PRAGMA_EOL && parser->in_pragma)
814         return;
815       if (token->type == CPP_OPEN_BRACE
816           || token->type == CPP_OPEN_PAREN
817           || token->type == CPP_OPEN_SQUARE)
818         ++nesting_depth;
819       else if (token->type == CPP_CLOSE_BRACE
820                || token->type == CPP_CLOSE_PAREN
821                || token->type == CPP_CLOSE_SQUARE)
822         {
823           if (nesting_depth-- == 0)
824             break;
825         }
826       /* Consume this token.  */
827       c_parser_consume_token (parser);
828     }
829   parser->error = false;
830 }
831
832 /* Expect to be at the end of the pragma directive and consume an
833    end of line marker.  */
834
835 static void
836 c_parser_skip_to_pragma_eol (c_parser *parser)
837 {
838   gcc_assert (parser->in_pragma);
839   parser->in_pragma = false;
840
841   if (!c_parser_require (parser, CPP_PRAGMA_EOL, "expected end of line"))
842     while (true)
843       {
844         c_token *token = c_parser_peek_token (parser);
845         if (token->type == CPP_EOF)
846           break;
847         if (token->type == CPP_PRAGMA_EOL)
848           {
849             c_parser_consume_token (parser);
850             break;
851           }
852         c_parser_consume_token (parser);
853       }
854
855   parser->error = false;
856 }
857
858 /* Skip tokens until we have consumed an entire block, or until we
859    have consumed a non-nested ';'.  */
860
861 static void
862 c_parser_skip_to_end_of_block_or_statement (c_parser *parser)
863 {
864   unsigned nesting_depth = 0;
865   bool save_error = parser->error;
866
867   while (true)
868     {
869       c_token *token;
870
871       /* Peek at the next token.  */
872       token = c_parser_peek_token (parser);
873
874       switch (token->type)
875         {
876         case CPP_EOF:
877           return;
878
879         case CPP_PRAGMA_EOL:
880           if (parser->in_pragma)
881             return;
882           break;
883
884         case CPP_SEMICOLON:
885           /* If the next token is a ';', we have reached the
886              end of the statement.  */
887           if (!nesting_depth)
888             {
889               /* Consume the ';'.  */
890               c_parser_consume_token (parser);
891               goto finished;
892             }
893           break;
894
895         case CPP_CLOSE_BRACE:
896           /* If the next token is a non-nested '}', then we have
897              reached the end of the current block.  */
898           if (nesting_depth == 0 || --nesting_depth == 0)
899             {
900               c_parser_consume_token (parser);
901               goto finished;
902             }
903           break;
904
905         case CPP_OPEN_BRACE:
906           /* If it the next token is a '{', then we are entering a new
907              block.  Consume the entire block.  */
908           ++nesting_depth;
909           break;
910
911         case CPP_PRAGMA:
912           /* If we see a pragma, consume the whole thing at once.  We
913              have some safeguards against consuming pragmas willy-nilly.
914              Normally, we'd expect to be here with parser->error set,
915              which disables these safeguards.  But it's possible to get
916              here for secondary error recovery, after parser->error has
917              been cleared.  */
918           c_parser_consume_pragma (parser);
919           c_parser_skip_to_pragma_eol (parser);
920           parser->error = save_error;
921           continue;
922
923         default:
924           break;
925         }
926
927       c_parser_consume_token (parser);
928     }
929
930  finished:
931   parser->error = false;
932 }
933
934 /* Save the warning flags which are controlled by __extension__.  */
935
936 static inline int
937 disable_extension_diagnostics (void)
938 {
939   int ret = (pedantic
940              | (warn_pointer_arith << 1)
941              | (warn_traditional << 2)
942              | (flag_iso << 3));
943   pedantic = 0;
944   warn_pointer_arith = 0;
945   warn_traditional = 0;
946   flag_iso = 0;
947   return ret;
948 }
949
950 /* Restore the warning flags which are controlled by __extension__.
951    FLAGS is the return value from disable_extension_diagnostics.  */
952
953 static inline void
954 restore_extension_diagnostics (int flags)
955 {
956   pedantic = flags & 1;
957   warn_pointer_arith = (flags >> 1) & 1;
958   warn_traditional = (flags >> 2) & 1;
959   flag_iso = (flags >> 3) & 1;
960 }
961
962 /* Possibly kinds of declarator to parse.  */
963 typedef enum c_dtr_syn {
964   /* A normal declarator with an identifier.  */
965   C_DTR_NORMAL,
966   /* An abstract declarator (maybe empty).  */
967   C_DTR_ABSTRACT,
968   /* A parameter declarator: may be either, but after a type name does
969      not redeclare a typedef name as an identifier if it can
970      alternatively be interpreted as a typedef name; see DR#009,
971      applied in C90 TC1, omitted from C99 and reapplied in C99 TC2
972      following DR#249.  For example, given a typedef T, "int T" and
973      "int *T" are valid parameter declarations redeclaring T, while
974      "int (T)" and "int * (T)" and "int (T[])" and "int (T (int))" are
975      abstract declarators rather than involving redundant parentheses;
976      the same applies with attributes inside the parentheses before
977      "T".  */
978   C_DTR_PARM
979 } c_dtr_syn;
980
981 static void c_parser_external_declaration (c_parser *);
982 static void c_parser_asm_definition (c_parser *);
983 static void c_parser_declaration_or_fndef (c_parser *, bool, bool, bool, bool);
984 static void c_parser_declspecs (c_parser *, struct c_declspecs *, bool, bool,
985                                 bool);
986 static struct c_typespec c_parser_enum_specifier (c_parser *);
987 static struct c_typespec c_parser_struct_or_union_specifier (c_parser *);
988 static tree c_parser_struct_declaration (c_parser *);
989 static struct c_typespec c_parser_typeof_specifier (c_parser *);
990 static struct c_declarator *c_parser_declarator (c_parser *, bool, c_dtr_syn,
991                                                  bool *);
992 static struct c_declarator *c_parser_direct_declarator (c_parser *, bool,
993                                                         c_dtr_syn, bool *);
994 static struct c_declarator *c_parser_direct_declarator_inner (c_parser *,
995                                                               bool,
996                                                               struct c_declarator *);
997 static struct c_arg_info *c_parser_parms_declarator (c_parser *, bool, tree);
998 static struct c_arg_info *c_parser_parms_list_declarator (c_parser *, tree);
999 static struct c_parm *c_parser_parameter_declaration (c_parser *, tree);
1000 static tree c_parser_simple_asm_expr (c_parser *);
1001 static tree c_parser_attributes (c_parser *);
1002 static struct c_type_name *c_parser_type_name (c_parser *);
1003 static struct c_expr c_parser_initializer (c_parser *);
1004 static struct c_expr c_parser_braced_init (c_parser *, tree, bool);
1005 static void c_parser_initelt (c_parser *);
1006 static void c_parser_initval (c_parser *, struct c_expr *);
1007 static tree c_parser_compound_statement (c_parser *);
1008 static void c_parser_compound_statement_nostart (c_parser *);
1009 static void c_parser_label (c_parser *);
1010 static void c_parser_statement (c_parser *);
1011 static void c_parser_statement_after_labels (c_parser *);
1012 static void c_parser_if_statement (c_parser *);
1013 static void c_parser_switch_statement (c_parser *);
1014 static void c_parser_while_statement (c_parser *);
1015 static void c_parser_do_statement (c_parser *);
1016 static void c_parser_for_statement (c_parser *);
1017 static tree c_parser_asm_statement (c_parser *);
1018 static tree c_parser_asm_operands (c_parser *, bool);
1019 static tree c_parser_asm_clobbers (c_parser *);
1020 static struct c_expr c_parser_expr_no_commas (c_parser *, struct c_expr *);
1021 static struct c_expr c_parser_conditional_expression (c_parser *,
1022                                                       struct c_expr *);
1023 static struct c_expr c_parser_binary_expression (c_parser *, struct c_expr *);
1024 static struct c_expr c_parser_cast_expression (c_parser *, struct c_expr *);
1025 static struct c_expr c_parser_unary_expression (c_parser *);
1026 static struct c_expr c_parser_sizeof_expression (c_parser *);
1027 static struct c_expr c_parser_alignof_expression (c_parser *);
1028 static struct c_expr c_parser_postfix_expression (c_parser *);
1029 static struct c_expr c_parser_postfix_expression_after_paren_type (c_parser *,
1030                                                                    struct c_type_name *);
1031 static struct c_expr c_parser_postfix_expression_after_primary (c_parser *,
1032                                                                 struct c_expr);
1033 static struct c_expr c_parser_expression (c_parser *);
1034 static struct c_expr c_parser_expression_conv (c_parser *);
1035 static tree c_parser_expr_list (c_parser *, bool);
1036 static void c_parser_omp_construct (c_parser *);
1037 static void c_parser_omp_threadprivate (c_parser *);
1038 static void c_parser_omp_barrier (c_parser *);
1039 static void c_parser_omp_flush (c_parser *);
1040
1041 enum pragma_context { pragma_external, pragma_stmt, pragma_compound };
1042 static bool c_parser_pragma (c_parser *, enum pragma_context);
1043
1044 /* These Objective-C parser functions are only ever called when
1045    compiling Objective-C.  */
1046 static void c_parser_objc_class_definition (c_parser *);
1047 static void c_parser_objc_class_instance_variables (c_parser *);
1048 static void c_parser_objc_class_declaration (c_parser *);
1049 static void c_parser_objc_alias_declaration (c_parser *);
1050 static void c_parser_objc_protocol_definition (c_parser *);
1051 static enum tree_code c_parser_objc_method_type (c_parser *);
1052 static void c_parser_objc_method_definition (c_parser *);
1053 static void c_parser_objc_methodprotolist (c_parser *);
1054 static void c_parser_objc_methodproto (c_parser *);
1055 static tree c_parser_objc_method_decl (c_parser *);
1056 static tree c_parser_objc_type_name (c_parser *);
1057 static tree c_parser_objc_protocol_refs (c_parser *);
1058 static void c_parser_objc_try_catch_statement (c_parser *);
1059 static void c_parser_objc_synchronized_statement (c_parser *);
1060 static tree c_parser_objc_selector (c_parser *);
1061 static tree c_parser_objc_selector_arg (c_parser *);
1062 static tree c_parser_objc_receiver (c_parser *);
1063 static tree c_parser_objc_message_args (c_parser *);
1064 static tree c_parser_objc_keywordexpr (c_parser *);
1065
1066 /* Parse a translation unit (C90 6.7, C99 6.9).
1067
1068    translation-unit:
1069      external-declarations
1070
1071    external-declarations:
1072      external-declaration
1073      external-declarations external-declaration
1074
1075    GNU extensions:
1076
1077    translation-unit:
1078      empty
1079 */
1080
1081 static void
1082 c_parser_translation_unit (c_parser *parser)
1083 {
1084   if (c_parser_next_token_is (parser, CPP_EOF))
1085     {
1086       if (pedantic)
1087         pedwarn ("ISO C forbids an empty source file");
1088     }
1089   else
1090     {
1091       void *obstack_position = obstack_alloc (&parser_obstack, 0);
1092       do
1093         {
1094           ggc_collect ();
1095           c_parser_external_declaration (parser);
1096           obstack_free (&parser_obstack, obstack_position);
1097         }
1098       while (c_parser_next_token_is_not (parser, CPP_EOF));
1099     }
1100 }
1101
1102 /* Parse an external declaration (C90 6.7, C99 6.9).
1103
1104    external-declaration:
1105      function-definition
1106      declaration
1107
1108    GNU extensions:
1109
1110    external-declaration:
1111      asm-definition
1112      ;
1113      __extension__ external-declaration
1114
1115    Objective-C:
1116
1117    external-declaration:
1118      objc-class-definition
1119      objc-class-declaration
1120      objc-alias-declaration
1121      objc-protocol-definition
1122      objc-method-definition
1123      @end
1124 */
1125
1126 static void
1127 c_parser_external_declaration (c_parser *parser)
1128 {
1129   int ext;
1130   switch (c_parser_peek_token (parser)->type)
1131     {
1132     case CPP_KEYWORD:
1133       switch (c_parser_peek_token (parser)->keyword)
1134         {
1135         case RID_EXTENSION:
1136           ext = disable_extension_diagnostics ();
1137           c_parser_consume_token (parser);
1138           c_parser_external_declaration (parser);
1139           restore_extension_diagnostics (ext);
1140           break;
1141         case RID_ASM:
1142           c_parser_asm_definition (parser);
1143           break;
1144         case RID_AT_INTERFACE:
1145         case RID_AT_IMPLEMENTATION:
1146           gcc_assert (c_dialect_objc ());
1147           c_parser_objc_class_definition (parser);
1148           break;
1149         case RID_AT_CLASS:
1150           gcc_assert (c_dialect_objc ());
1151           c_parser_objc_class_declaration (parser);
1152           break;
1153         case RID_AT_ALIAS:
1154           gcc_assert (c_dialect_objc ());
1155           c_parser_objc_alias_declaration (parser);
1156           break;
1157         case RID_AT_PROTOCOL:
1158           gcc_assert (c_dialect_objc ());
1159           c_parser_objc_protocol_definition (parser);
1160           break;
1161         case RID_AT_END:
1162           gcc_assert (c_dialect_objc ());
1163           c_parser_consume_token (parser);
1164           objc_finish_implementation ();
1165           break;
1166         default:
1167           goto decl_or_fndef;
1168         }
1169       break;
1170     case CPP_SEMICOLON:
1171       if (pedantic)
1172         pedwarn ("ISO C does not allow extra %<;%> outside of a function");
1173       c_parser_consume_token (parser);
1174       break;
1175     case CPP_PRAGMA:
1176       c_parser_pragma (parser, pragma_external);
1177       break;
1178     case CPP_PLUS:
1179     case CPP_MINUS:
1180       if (c_dialect_objc ())
1181         {
1182           c_parser_objc_method_definition (parser);
1183           break;
1184         }
1185       /* Else fall through, and yield a syntax error trying to parse
1186          as a declaration or function definition.  */
1187     default:
1188     decl_or_fndef:
1189       /* A declaration or a function definition.  We can only tell
1190          which after parsing the declaration specifiers, if any, and
1191          the first declarator.  */
1192       c_parser_declaration_or_fndef (parser, true, true, false, true);
1193       break;
1194     }
1195 }
1196
1197
1198 /* Parse a declaration or function definition (C90 6.5, 6.7.1, C99
1199    6.7, 6.9.1).  If FNDEF_OK is true, a function definition is
1200    accepted; otherwise (old-style parameter declarations) only other
1201    declarations are accepted.  If NESTED is true, we are inside a
1202    function or parsing old-style parameter declarations; any functions
1203    encountered are nested functions and declaration specifiers are
1204    required; otherwise we are at top level and functions are normal
1205    functions and declaration specifiers may be optional.  If EMPTY_OK
1206    is true, empty declarations are OK (subject to all other
1207    constraints); otherwise (old-style parameter declarations) they are
1208    diagnosed.  If START_ATTR_OK is true, the declaration specifiers
1209    may start with attributes; otherwise they may not.
1210
1211    declaration:
1212      declaration-specifiers init-declarator-list[opt] ;
1213
1214    function-definition:
1215      declaration-specifiers[opt] declarator declaration-list[opt]
1216        compound-statement
1217
1218    declaration-list:
1219      declaration
1220      declaration-list declaration
1221
1222    init-declarator-list:
1223      init-declarator
1224      init-declarator-list , init-declarator
1225
1226    init-declarator:
1227      declarator simple-asm-expr[opt] attributes[opt]
1228      declarator simple-asm-expr[opt] attributes[opt] = initializer
1229
1230    GNU extensions:
1231
1232    nested-function-definition:
1233      declaration-specifiers declarator declaration-list[opt]
1234        compound-statement
1235
1236    The simple-asm-expr and attributes are GNU extensions.
1237
1238    This function does not handle __extension__; that is handled in its
1239    callers.  ??? Following the old parser, __extension__ may start
1240    external declarations, declarations in functions and declarations
1241    at the start of "for" loops, but not old-style parameter
1242    declarations.
1243
1244    C99 requires declaration specifiers in a function definition; the
1245    absence is diagnosed through the diagnosis of implicit int.  In GNU
1246    C we also allow but diagnose declarations without declaration
1247    specifiers, but only at top level (elsewhere they conflict with
1248    other syntax).
1249    
1250    OpenMP:
1251    
1252    declaration:
1253      threadprivate-directive  */
1254
1255 static void
1256 c_parser_declaration_or_fndef (c_parser *parser, bool fndef_ok, bool empty_ok,
1257                                bool nested, bool start_attr_ok)
1258 {
1259   struct c_declspecs *specs;
1260   tree prefix_attrs;
1261   tree all_prefix_attrs;
1262   bool diagnosed_no_specs = false;
1263
1264   specs = build_null_declspecs ();
1265   c_parser_declspecs (parser, specs, true, true, start_attr_ok);
1266   if (parser->error)
1267     {
1268       c_parser_skip_to_end_of_block_or_statement (parser);
1269       return;
1270     }
1271   if (nested && !specs->declspecs_seen_p)
1272     {
1273       c_parser_error (parser, "expected declaration specifiers");
1274       c_parser_skip_to_end_of_block_or_statement (parser);
1275       return;
1276     }
1277   finish_declspecs (specs);
1278   if (c_parser_next_token_is (parser, CPP_SEMICOLON))
1279     {
1280       if (empty_ok)
1281         shadow_tag (specs);
1282       else
1283         {
1284           shadow_tag_warned (specs, 1);
1285           pedwarn ("empty declaration");
1286         }
1287       c_parser_consume_token (parser);
1288       return;
1289     }
1290   pending_xref_error ();
1291   prefix_attrs = specs->attrs;
1292   all_prefix_attrs = prefix_attrs;
1293   specs->attrs = NULL_TREE;
1294   while (true)
1295     {
1296       struct c_declarator *declarator;
1297       bool dummy = false;
1298       tree fnbody;
1299       /* Declaring either one or more declarators (in which case we
1300          should diagnose if there were no declaration specifiers) or a
1301          function definition (in which case the diagnostic for
1302          implicit int suffices).  */
1303       declarator = c_parser_declarator (parser, specs->type_seen_p,
1304                                         C_DTR_NORMAL, &dummy);
1305       if (declarator == NULL)
1306         {
1307           c_parser_skip_to_end_of_block_or_statement (parser);
1308           return;
1309         }
1310       if (c_parser_next_token_is (parser, CPP_EQ)
1311           || c_parser_next_token_is (parser, CPP_COMMA)
1312           || c_parser_next_token_is (parser, CPP_SEMICOLON)
1313           || c_parser_next_token_is_keyword (parser, RID_ASM)
1314           || c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
1315         {
1316           tree asm_name = NULL_TREE;
1317           tree postfix_attrs = NULL_TREE;
1318           if (!diagnosed_no_specs && !specs->declspecs_seen_p)
1319             {
1320               diagnosed_no_specs = true;
1321               pedwarn ("data definition has no type or storage class");
1322             }
1323           /* Having seen a data definition, there cannot now be a
1324              function definition.  */
1325           fndef_ok = false;
1326           if (c_parser_next_token_is_keyword (parser, RID_ASM))
1327             asm_name = c_parser_simple_asm_expr (parser);
1328           if (c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
1329             postfix_attrs = c_parser_attributes (parser);
1330           if (c_parser_next_token_is (parser, CPP_EQ))
1331             {
1332               tree d;
1333               struct c_expr init;
1334               c_parser_consume_token (parser);
1335               /* The declaration of the variable is in effect while
1336                  its initializer is parsed.  */
1337               d = start_decl (declarator, specs, true,
1338                               chainon (postfix_attrs, all_prefix_attrs));
1339               if (!d)
1340                 d = error_mark_node;
1341               start_init (d, asm_name, global_bindings_p ());
1342               init = c_parser_initializer (parser);
1343               finish_init ();
1344               if (d != error_mark_node)
1345                 {
1346                   maybe_warn_string_init (TREE_TYPE (d), init);
1347                   finish_decl (d, init.value, asm_name);
1348                 }
1349             }
1350           else
1351             {
1352               tree d = start_decl (declarator, specs, false,
1353                                    chainon (postfix_attrs,
1354                                             all_prefix_attrs));
1355               if (d)
1356                 finish_decl (d, NULL_TREE, asm_name);
1357             }
1358           if (c_parser_next_token_is (parser, CPP_COMMA))
1359             {
1360               c_parser_consume_token (parser);
1361               if (c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
1362                 all_prefix_attrs = chainon (c_parser_attributes (parser),
1363                                             prefix_attrs);
1364               else
1365                 all_prefix_attrs = prefix_attrs;
1366               continue;
1367             }
1368           else if (c_parser_next_token_is (parser, CPP_SEMICOLON))
1369             {
1370               c_parser_consume_token (parser);
1371               return;
1372             }
1373           else
1374             {
1375               c_parser_error (parser, "expected %<,%> or %<;%>");
1376               c_parser_skip_to_end_of_block_or_statement (parser);
1377               return;
1378             }
1379         }
1380       else if (!fndef_ok)
1381         {
1382           c_parser_error (parser, "expected %<=%>, %<,%>, %<;%>, "
1383                           "%<asm%> or %<__attribute__%>");
1384           c_parser_skip_to_end_of_block_or_statement (parser);
1385           return;
1386         }
1387       /* Function definition (nested or otherwise).  */
1388       if (nested)
1389         {
1390           if (pedantic)
1391             pedwarn ("ISO C forbids nested functions");
1392           push_function_context ();
1393         }
1394       if (!start_function (specs, declarator, all_prefix_attrs))
1395         {
1396           /* This can appear in many cases looking nothing like a
1397              function definition, so we don't give a more specific
1398              error suggesting there was one.  */
1399           c_parser_error (parser, "expected %<=%>, %<,%>, %<;%>, %<asm%> "
1400                           "or %<__attribute__%>");
1401           if (nested)
1402             pop_function_context ();
1403           break;
1404         }
1405       /* Parse old-style parameter declarations.  ??? Attributes are
1406          not allowed to start declaration specifiers here because of a
1407          syntax conflict between a function declaration with attribute
1408          suffix and a function definition with an attribute prefix on
1409          first old-style parameter declaration.  Following the old
1410          parser, they are not accepted on subsequent old-style
1411          parameter declarations either.  However, there is no
1412          ambiguity after the first declaration, nor indeed on the
1413          first as long as we don't allow postfix attributes after a
1414          declarator with a nonempty identifier list in a definition;
1415          and postfix attributes have never been accepted here in
1416          function definitions either.  */
1417       while (c_parser_next_token_is_not (parser, CPP_EOF)
1418              && c_parser_next_token_is_not (parser, CPP_OPEN_BRACE))
1419         c_parser_declaration_or_fndef (parser, false, false, true, false);
1420       DECL_SOURCE_LOCATION (current_function_decl)
1421         = c_parser_peek_token (parser)->location;
1422       store_parm_decls ();
1423       fnbody = c_parser_compound_statement (parser);
1424       if (nested)
1425         {
1426           tree decl = current_function_decl;
1427           add_stmt (fnbody);
1428           finish_function ();
1429           pop_function_context ();
1430           add_stmt (build_stmt (DECL_EXPR, decl));
1431         }
1432       else
1433         {
1434           add_stmt (fnbody);
1435           finish_function ();
1436         }
1437       break;
1438     }
1439 }
1440
1441 /* Parse an asm-definition (asm() outside a function body).  This is a
1442    GNU extension.
1443
1444    asm-definition:
1445      simple-asm-expr ;
1446 */
1447
1448 static void
1449 c_parser_asm_definition (c_parser *parser)
1450 {
1451   tree asm_str = c_parser_simple_asm_expr (parser);
1452   if (asm_str)
1453     cgraph_add_asm_node (asm_str);
1454   c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
1455 }
1456
1457 /* Parse some declaration specifiers (possibly none) (C90 6.5, C99
1458    6.7), adding them to SPECS (which may already include some).
1459    Storage class specifiers are accepted iff SCSPEC_OK; type
1460    specifiers are accepted iff TYPESPEC_OK; attributes are accepted at
1461    the start iff START_ATTR_OK.
1462
1463    declaration-specifiers:
1464      storage-class-specifier declaration-specifiers[opt]
1465      type-specifier declaration-specifiers[opt]
1466      type-qualifier declaration-specifiers[opt]
1467      function-specifier declaration-specifiers[opt]
1468
1469    Function specifiers (inline) are from C99, and are currently
1470    handled as storage class specifiers, as is __thread.
1471
1472    C90 6.5.1, C99 6.7.1:
1473    storage-class-specifier:
1474      typedef
1475      extern
1476      static
1477      auto
1478      register
1479
1480    C99 6.7.4:
1481    function-specifier:
1482      inline
1483
1484    C90 6.5.2, C99 6.7.2:
1485    type-specifier:
1486      void
1487      char
1488      short
1489      int
1490      long
1491      float
1492      double
1493      signed
1494      unsigned
1495      _Bool
1496      _Complex
1497      [_Imaginary removed in C99 TC2]
1498      struct-or-union-specifier
1499      enum-specifier
1500      typedef-name
1501
1502    (_Bool and _Complex are new in C99.)
1503
1504    C90 6.5.3, C99 6.7.3:
1505
1506    type-qualifier:
1507      const
1508      restrict
1509      volatile
1510
1511    (restrict is new in C99.)
1512
1513    GNU extensions:
1514
1515    declaration-specifiers:
1516      attributes declaration-specifiers[opt]
1517
1518    storage-class-specifier:
1519      __thread
1520
1521    type-specifier:
1522      typeof-specifier
1523      _Decimal32
1524      _Decimal64
1525      _Decimal128
1526
1527    Objective-C:
1528
1529    type-specifier:
1530      class-name objc-protocol-refs[opt]
1531      typedef-name objc-protocol-refs
1532      objc-protocol-refs
1533 */
1534
1535 static void
1536 c_parser_declspecs (c_parser *parser, struct c_declspecs *specs,
1537                     bool scspec_ok, bool typespec_ok, bool start_attr_ok)
1538 {
1539   bool attrs_ok = start_attr_ok;
1540   bool seen_type = specs->type_seen_p;
1541   while (c_parser_next_token_is (parser, CPP_NAME)
1542          || c_parser_next_token_is (parser, CPP_KEYWORD)
1543          || (c_dialect_objc () && c_parser_next_token_is (parser, CPP_LESS)))
1544     {
1545       struct c_typespec t;
1546       tree attrs;
1547       if (c_parser_next_token_is (parser, CPP_NAME))
1548         {
1549           tree value = c_parser_peek_token (parser)->value;
1550           c_id_kind kind = c_parser_peek_token (parser)->id_kind;
1551           /* This finishes the specifiers unless a type name is OK, it
1552              is declared as a type name and a type name hasn't yet
1553              been seen.  */
1554           if (!typespec_ok || seen_type
1555               || (kind != C_ID_TYPENAME && kind != C_ID_CLASSNAME))
1556             break;
1557           c_parser_consume_token (parser);
1558           seen_type = true;
1559           attrs_ok = true;
1560           if (kind == C_ID_TYPENAME
1561               && (!c_dialect_objc ()
1562                   || c_parser_next_token_is_not (parser, CPP_LESS)))
1563             {
1564               t.kind = ctsk_typedef;
1565               /* For a typedef name, record the meaning, not the name.
1566                  In case of 'foo foo, bar;'.  */
1567               t.spec = lookup_name (value);
1568             }
1569           else
1570             {
1571               tree proto = NULL_TREE;
1572               gcc_assert (c_dialect_objc ());
1573               t.kind = ctsk_objc;
1574               if (c_parser_next_token_is (parser, CPP_LESS))
1575                 proto = c_parser_objc_protocol_refs (parser);
1576               t.spec = objc_get_protocol_qualified_type (value, proto);
1577             }
1578           declspecs_add_type (specs, t);
1579           continue;
1580         }
1581       if (c_parser_next_token_is (parser, CPP_LESS))
1582         {
1583           /* Make "<SomeProtocol>" equivalent to "id <SomeProtocol>" -
1584              nisse@lysator.liu.se.  */
1585           tree proto;
1586           gcc_assert (c_dialect_objc ());
1587           if (!typespec_ok || seen_type)
1588             break;
1589           proto = c_parser_objc_protocol_refs (parser);
1590           t.kind = ctsk_objc;
1591           t.spec = objc_get_protocol_qualified_type (NULL_TREE, proto);
1592           declspecs_add_type (specs, t);
1593           continue;
1594         }
1595       gcc_assert (c_parser_next_token_is (parser, CPP_KEYWORD));
1596       switch (c_parser_peek_token (parser)->keyword)
1597         {
1598         case RID_STATIC:
1599         case RID_EXTERN:
1600         case RID_REGISTER:
1601         case RID_TYPEDEF:
1602         case RID_INLINE:
1603         case RID_AUTO:
1604         case RID_THREAD:
1605           if (!scspec_ok)
1606             goto out;
1607           attrs_ok = true;
1608           /* TODO: Distinguish between function specifiers (inline)
1609              and storage class specifiers, either here or in
1610              declspecs_add_scspec.  */
1611           declspecs_add_scspec (specs, c_parser_peek_token (parser)->value);
1612           c_parser_consume_token (parser);
1613           break;
1614         case RID_UNSIGNED:
1615         case RID_LONG:
1616         case RID_SHORT:
1617         case RID_SIGNED:
1618         case RID_COMPLEX:
1619         case RID_INT:
1620         case RID_CHAR:
1621         case RID_FLOAT:
1622         case RID_DOUBLE:
1623         case RID_VOID:
1624         case RID_DFLOAT32:
1625         case RID_DFLOAT64:
1626         case RID_DFLOAT128:
1627         case RID_BOOL:
1628           if (!typespec_ok)
1629             goto out;
1630           attrs_ok = true;
1631           seen_type = true;
1632           OBJC_NEED_RAW_IDENTIFIER (1);
1633           t.kind = ctsk_resword;
1634           t.spec = c_parser_peek_token (parser)->value;
1635           declspecs_add_type (specs, t);
1636           c_parser_consume_token (parser);
1637           break;
1638         case RID_ENUM:
1639           if (!typespec_ok)
1640             goto out;
1641           attrs_ok = true;
1642           seen_type = true;
1643           t = c_parser_enum_specifier (parser);
1644           declspecs_add_type (specs, t);
1645           break;
1646         case RID_STRUCT:
1647         case RID_UNION:
1648           if (!typespec_ok)
1649             goto out;
1650           attrs_ok = true;
1651           seen_type = true;
1652           t = c_parser_struct_or_union_specifier (parser);
1653           declspecs_add_type (specs, t);
1654           break;
1655         case RID_TYPEOF:
1656           /* ??? The old parser rejected typeof after other type
1657              specifiers, but is a syntax error the best way of
1658              handling this?  */
1659           if (!typespec_ok || seen_type)
1660             goto out;
1661           attrs_ok = true;
1662           seen_type = true;
1663           t = c_parser_typeof_specifier (parser);
1664           declspecs_add_type (specs, t);
1665           break;
1666         case RID_CONST:
1667         case RID_VOLATILE:
1668         case RID_RESTRICT:
1669           attrs_ok = true;
1670           declspecs_add_qual (specs, c_parser_peek_token (parser)->value);
1671           c_parser_consume_token (parser);
1672           break;
1673         case RID_ATTRIBUTE:
1674           if (!attrs_ok)
1675             goto out;
1676           attrs = c_parser_attributes (parser);
1677           declspecs_add_attrs (specs, attrs);
1678           break;
1679         default:
1680           goto out;
1681         }
1682     }
1683  out: ;
1684 }
1685
1686 /* Parse an enum specifier (C90 6.5.2.2, C99 6.7.2.2).
1687
1688    enum-specifier:
1689      enum attributes[opt] identifier[opt] { enumerator-list } attributes[opt]
1690      enum attributes[opt] identifier[opt] { enumerator-list , } attributes[opt]
1691      enum attributes[opt] identifier
1692
1693    The form with trailing comma is new in C99.  The forms with
1694    attributes are GNU extensions.  In GNU C, we accept any expression
1695    without commas in the syntax (assignment expressions, not just
1696    conditional expressions); assignment expressions will be diagnosed
1697    as non-constant.
1698
1699    enumerator-list:
1700      enumerator
1701      enumerator-list , enumerator
1702
1703    enumerator:
1704      enumeration-constant
1705      enumeration-constant = constant-expression
1706 */
1707
1708 static struct c_typespec
1709 c_parser_enum_specifier (c_parser *parser)
1710 {
1711   struct c_typespec ret;
1712   tree attrs;
1713   tree ident = NULL_TREE;
1714   gcc_assert (c_parser_next_token_is_keyword (parser, RID_ENUM));
1715   c_parser_consume_token (parser);
1716   attrs = c_parser_attributes (parser);
1717   if (c_parser_next_token_is (parser, CPP_NAME))
1718     {
1719       ident = c_parser_peek_token (parser)->value;
1720       c_parser_consume_token (parser);
1721     }
1722   if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
1723     {
1724       /* Parse an enum definition.  */
1725       tree type = start_enum (ident);
1726       tree postfix_attrs;
1727       /* We chain the enumerators in reverse order, then put them in
1728          forward order at the end.  */
1729       tree values = NULL_TREE;
1730       c_parser_consume_token (parser);
1731       while (true)
1732         {
1733           tree enum_id;
1734           tree enum_value;
1735           tree enum_decl;
1736           bool seen_comma;
1737           if (c_parser_next_token_is_not (parser, CPP_NAME))
1738             {
1739               c_parser_error (parser, "expected identifier");
1740               c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL);
1741               values = error_mark_node;
1742               break;
1743             }
1744           enum_id = c_parser_peek_token (parser)->value;
1745           c_parser_consume_token (parser);
1746           if (c_parser_next_token_is (parser, CPP_EQ))
1747             {
1748               c_parser_consume_token (parser);
1749               enum_value = c_parser_expr_no_commas (parser, NULL).value;
1750             }
1751           else
1752             enum_value = NULL_TREE;
1753           enum_decl = build_enumerator (enum_id, enum_value);
1754           TREE_CHAIN (enum_decl) = values;
1755           values = enum_decl;
1756           seen_comma = false;
1757           if (c_parser_next_token_is (parser, CPP_COMMA))
1758             {
1759               seen_comma = true;
1760               c_parser_consume_token (parser);
1761             }
1762           if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
1763             {
1764               if (seen_comma && pedantic && !flag_isoc99)
1765                 pedwarn ("comma at end of enumerator list");
1766               c_parser_consume_token (parser);
1767               break;
1768             }
1769           if (!seen_comma)
1770             {
1771               c_parser_error (parser, "expected %<,%> or %<}%>");
1772               c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL);
1773               values = error_mark_node;
1774               break;
1775             }
1776         }
1777       postfix_attrs = c_parser_attributes (parser);
1778       ret.spec = finish_enum (type, nreverse (values),
1779                               chainon (attrs, postfix_attrs));
1780       ret.kind = ctsk_tagdef;
1781       return ret;
1782     }
1783   else if (!ident)
1784     {
1785       c_parser_error (parser, "expected %<{%>");
1786       ret.spec = error_mark_node;
1787       ret.kind = ctsk_tagref;
1788       return ret;
1789     }
1790   ret = parser_xref_tag (ENUMERAL_TYPE, ident);
1791   /* In ISO C, enumerated types can be referred to only if already
1792      defined.  */
1793   if (pedantic && !COMPLETE_TYPE_P (ret.spec))
1794     pedwarn ("ISO C forbids forward references to %<enum%> types");
1795   return ret;
1796 }
1797
1798 /* Parse a struct or union specifier (C90 6.5.2.1, C99 6.7.2.1).
1799
1800    struct-or-union-specifier:
1801      struct-or-union attributes[opt] identifier[opt]
1802        { struct-contents } attributes[opt]
1803      struct-or-union attributes[opt] identifier
1804
1805    struct-contents:
1806      struct-declaration-list
1807
1808    struct-declaration-list:
1809      struct-declaration ;
1810      struct-declaration-list struct-declaration ;
1811
1812    GNU extensions:
1813
1814    struct-contents:
1815      empty
1816      struct-declaration
1817      struct-declaration-list struct-declaration
1818
1819    struct-declaration-list:
1820      struct-declaration-list ;
1821      ;
1822
1823    (Note that in the syntax here, unlike that in ISO C, the semicolons
1824    are included here rather than in struct-declaration, in order to
1825    describe the syntax with extra semicolons and missing semicolon at
1826    end.)
1827
1828    Objective-C:
1829
1830    struct-declaration-list:
1831      @defs ( class-name )
1832
1833    (Note this does not include a trailing semicolon, but can be
1834    followed by further declarations, and gets a pedwarn-if-pedantic
1835    when followed by a semicolon.)  */
1836
1837 static struct c_typespec
1838 c_parser_struct_or_union_specifier (c_parser *parser)
1839 {
1840   struct c_typespec ret;
1841   tree attrs;
1842   tree ident = NULL_TREE;
1843   enum tree_code code;
1844   switch (c_parser_peek_token (parser)->keyword)
1845     {
1846     case RID_STRUCT:
1847       code = RECORD_TYPE;
1848       break;
1849     case RID_UNION:
1850       code = UNION_TYPE;
1851       break;
1852     default:
1853       gcc_unreachable ();
1854     }
1855   c_parser_consume_token (parser);
1856   attrs = c_parser_attributes (parser);
1857   if (c_parser_next_token_is (parser, CPP_NAME))
1858     {
1859       ident = c_parser_peek_token (parser)->value;
1860       c_parser_consume_token (parser);
1861     }
1862   if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
1863     {
1864       /* Parse a struct or union definition.  Start the scope of the
1865          tag before parsing components.  */
1866       tree type = start_struct (code, ident);
1867       tree postfix_attrs;
1868       /* We chain the components in reverse order, then put them in
1869          forward order at the end.  Each struct-declaration may
1870          declare multiple components (comma-separated), so we must use
1871          chainon to join them, although when parsing each
1872          struct-declaration we can use TREE_CHAIN directly.
1873
1874          The theory behind all this is that there will be more
1875          semicolon separated fields than comma separated fields, and
1876          so we'll be minimizing the number of node traversals required
1877          by chainon.  */
1878       tree contents = NULL_TREE;
1879       c_parser_consume_token (parser);
1880       /* Handle the Objective-C @defs construct,
1881          e.g. foo(sizeof(struct{ @defs(ClassName) }));.  */
1882       if (c_parser_next_token_is_keyword (parser, RID_AT_DEFS))
1883         {
1884           tree name;
1885           gcc_assert (c_dialect_objc ());
1886           c_parser_consume_token (parser);
1887           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
1888             goto end_at_defs;
1889           if (c_parser_next_token_is (parser, CPP_NAME)
1890               && c_parser_peek_token (parser)->id_kind == C_ID_CLASSNAME)
1891             {
1892               name = c_parser_peek_token (parser)->value;
1893               c_parser_consume_token (parser);
1894             }
1895           else
1896             {
1897               c_parser_error (parser, "expected class name");
1898               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
1899               goto end_at_defs;
1900             }
1901           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
1902                                      "expected %<)%>");
1903           contents = nreverse (objc_get_class_ivars (name));
1904         }
1905     end_at_defs:
1906       /* Parse the struct-declarations and semicolons.  Problems with
1907          semicolons are diagnosed here; empty structures are diagnosed
1908          elsewhere.  */
1909       while (true)
1910         {
1911           tree decls;
1912           /* Parse any stray semicolon.  */
1913           if (c_parser_next_token_is (parser, CPP_SEMICOLON))
1914             {
1915               if (pedantic)
1916                 pedwarn ("extra semicolon in struct or union specified");
1917               c_parser_consume_token (parser);
1918               continue;
1919             }
1920           /* Stop if at the end of the struct or union contents.  */
1921           if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
1922             {
1923               c_parser_consume_token (parser);
1924               break;
1925             }
1926           /* Accept #pragmas at struct scope.  */
1927           if (c_parser_next_token_is (parser, CPP_PRAGMA))
1928             {
1929               c_parser_pragma (parser, pragma_external);
1930               continue;
1931             }
1932           /* Parse some comma-separated declarations, but not the
1933              trailing semicolon if any.  */
1934           decls = c_parser_struct_declaration (parser);
1935           contents = chainon (decls, contents);
1936           /* If no semicolon follows, either we have a parse error or
1937              are at the end of the struct or union and should
1938              pedwarn.  */
1939           if (c_parser_next_token_is (parser, CPP_SEMICOLON))
1940             c_parser_consume_token (parser);
1941           else
1942             {
1943               if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
1944                 pedwarn ("no semicolon at end of struct or union");
1945               else
1946                 {
1947                   c_parser_error (parser, "expected %<;%>");
1948                   c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL);
1949                   break;
1950                 }
1951             }
1952         }
1953       postfix_attrs = c_parser_attributes (parser);
1954       ret.spec = finish_struct (type, nreverse (contents),
1955                                 chainon (attrs, postfix_attrs));
1956       ret.kind = ctsk_tagdef;
1957       return ret;
1958     }
1959   else if (!ident)
1960     {
1961       c_parser_error (parser, "expected %<{%>");
1962       ret.spec = error_mark_node;
1963       ret.kind = ctsk_tagref;
1964       return ret;
1965     }
1966   ret = parser_xref_tag (code, ident);
1967   return ret;
1968 }
1969
1970 /* Parse a struct-declaration (C90 6.5.2.1, C99 6.7.2.1), *without*
1971    the trailing semicolon.
1972
1973    struct-declaration:
1974      specifier-qualifier-list struct-declarator-list
1975
1976    specifier-qualifier-list:
1977      type-specifier specifier-qualifier-list[opt]
1978      type-qualifier specifier-qualifier-list[opt]
1979      attributes specifier-qualifier-list[opt]
1980
1981    struct-declarator-list:
1982      struct-declarator
1983      struct-declarator-list , attributes[opt] struct-declarator
1984
1985    struct-declarator:
1986      declarator attributes[opt]
1987      declarator[opt] : constant-expression attributes[opt]
1988
1989    GNU extensions:
1990
1991    struct-declaration:
1992      __extension__ struct-declaration
1993      specifier-qualifier-list
1994
1995    Unlike the ISO C syntax, semicolons are handled elsewhere.  The use
1996    of attributes where shown is a GNU extension.  In GNU C, we accept
1997    any expression without commas in the syntax (assignment
1998    expressions, not just conditional expressions); assignment
1999    expressions will be diagnosed as non-constant.  */
2000
2001 static tree
2002 c_parser_struct_declaration (c_parser *parser)
2003 {
2004   struct c_declspecs *specs;
2005   tree prefix_attrs;
2006   tree all_prefix_attrs;
2007   tree decls;
2008   if (c_parser_next_token_is_keyword (parser, RID_EXTENSION))
2009     {
2010       int ext;
2011       tree decl;
2012       ext = disable_extension_diagnostics ();
2013       c_parser_consume_token (parser);
2014       decl = c_parser_struct_declaration (parser);
2015       restore_extension_diagnostics (ext);
2016       return decl;
2017     }
2018   specs = build_null_declspecs ();
2019   c_parser_declspecs (parser, specs, false, true, true);
2020   if (parser->error)
2021     return NULL_TREE;
2022   if (!specs->declspecs_seen_p)
2023     {
2024       c_parser_error (parser, "expected specifier-qualifier-list");
2025       return NULL_TREE;
2026     }
2027   finish_declspecs (specs);
2028   if (c_parser_next_token_is (parser, CPP_SEMICOLON))
2029     {
2030       tree ret;
2031       if (!specs->type_seen_p)
2032         {
2033           if (pedantic)
2034             pedwarn ("ISO C forbids member declarations with no members");
2035           shadow_tag_warned (specs, pedantic);
2036           ret = NULL_TREE;
2037         }
2038       else
2039         {
2040           /* Support for unnamed structs or unions as members of
2041              structs or unions (which is [a] useful and [b] supports
2042              MS P-SDK).  */
2043           ret = grokfield (build_id_declarator (NULL_TREE), specs, NULL_TREE);
2044         }
2045       return ret;
2046     }
2047   pending_xref_error ();
2048   prefix_attrs = specs->attrs;
2049   all_prefix_attrs = prefix_attrs;
2050   specs->attrs = NULL_TREE;
2051   decls = NULL_TREE;
2052   while (true)
2053     {
2054       /* Declaring one or more declarators or un-named bit-fields.  */
2055       struct c_declarator *declarator;
2056       bool dummy = false;
2057       if (c_parser_next_token_is (parser, CPP_COLON))
2058         declarator = build_id_declarator (NULL_TREE);
2059       else
2060         declarator = c_parser_declarator (parser, specs->type_seen_p,
2061                                           C_DTR_NORMAL, &dummy);
2062       if (declarator == NULL)
2063         {
2064           c_parser_skip_to_end_of_block_or_statement (parser);
2065           break;
2066         }
2067       if (c_parser_next_token_is (parser, CPP_COLON)
2068           || c_parser_next_token_is (parser, CPP_COMMA)
2069           || c_parser_next_token_is (parser, CPP_SEMICOLON)
2070           || c_parser_next_token_is (parser, CPP_CLOSE_BRACE)
2071           || c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
2072         {
2073           tree postfix_attrs = NULL_TREE;
2074           tree width = NULL_TREE;
2075           tree d;
2076           if (c_parser_next_token_is (parser, CPP_COLON))
2077             {
2078               c_parser_consume_token (parser);
2079               width = c_parser_expr_no_commas (parser, NULL).value;
2080             }
2081           if (c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
2082             postfix_attrs = c_parser_attributes (parser);
2083           d = grokfield (declarator, specs, width);
2084           decl_attributes (&d, chainon (postfix_attrs,
2085                                         all_prefix_attrs), 0);
2086           TREE_CHAIN (d) = decls;
2087           decls = d;
2088           if (c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
2089             all_prefix_attrs = chainon (c_parser_attributes (parser),
2090                                         prefix_attrs);
2091           else
2092             all_prefix_attrs = prefix_attrs;
2093           if (c_parser_next_token_is (parser, CPP_COMMA))
2094             c_parser_consume_token (parser);
2095           else if (c_parser_next_token_is (parser, CPP_SEMICOLON)
2096                    || c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
2097             {
2098               /* Semicolon consumed in caller.  */
2099               break;
2100             }
2101           else
2102             {
2103               c_parser_error (parser, "expected %<,%>, %<;%> or %<}%>");
2104               break;
2105             }
2106         }
2107       else
2108         {
2109           c_parser_error (parser,
2110                           "expected %<:%>, %<,%>, %<;%>, %<}%> or "
2111                           "%<__attribute__%>");
2112           break;
2113         }
2114     }
2115   return decls;
2116 }
2117
2118 /* Parse a typeof specifier (a GNU extension).
2119
2120    typeof-specifier:
2121      typeof ( expression )
2122      typeof ( type-name )
2123 */
2124
2125 static struct c_typespec
2126 c_parser_typeof_specifier (c_parser *parser)
2127 {
2128   struct c_typespec ret;
2129   ret.kind = ctsk_typeof;
2130   ret.spec = error_mark_node;
2131   gcc_assert (c_parser_next_token_is_keyword (parser, RID_TYPEOF));
2132   c_parser_consume_token (parser);
2133   skip_evaluation++;
2134   in_typeof++;
2135   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
2136     {
2137       skip_evaluation--;
2138       in_typeof--;
2139       return ret;
2140     }
2141   if (c_parser_next_token_starts_typename (parser))
2142     {
2143       struct c_type_name *type = c_parser_type_name (parser);
2144       skip_evaluation--;
2145       in_typeof--;
2146       if (type != NULL)
2147         {
2148           ret.spec = groktypename (type);
2149           pop_maybe_used (variably_modified_type_p (ret.spec, NULL_TREE));
2150         }
2151     }
2152   else
2153     {
2154       bool was_vm;
2155       struct c_expr expr = c_parser_expression (parser);
2156       skip_evaluation--;
2157       in_typeof--;
2158       if (TREE_CODE (expr.value) == COMPONENT_REF
2159           && DECL_C_BIT_FIELD (TREE_OPERAND (expr.value, 1)))
2160         error ("%<typeof%> applied to a bit-field");
2161       ret.spec = TREE_TYPE (expr.value);
2162       was_vm = variably_modified_type_p (ret.spec, NULL_TREE);
2163       /* This should be returned with the type so that when the type
2164          is evaluated, this can be evaluated.  For now, we avoid
2165          evaluation when the context might.  */
2166       if (!skip_evaluation && was_vm)
2167         {
2168           tree e = expr.value;
2169
2170           /* If the expression is not of a type to which we cannot assign a line
2171              number, wrap the thing in a no-op NOP_EXPR.  */
2172           if (DECL_P (e) || CONSTANT_CLASS_P (e))
2173             e = build1 (NOP_EXPR, void_type_node, e);
2174
2175           if (EXPR_P (e))
2176             SET_EXPR_LOCATION (e, input_location);
2177
2178           add_stmt (e);
2179         }
2180       pop_maybe_used (was_vm);
2181     }
2182   c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
2183   return ret;
2184 }
2185
2186 /* Parse a declarator, possibly an abstract declarator (C90 6.5.4,
2187    6.5.5, C99 6.7.5, 6.7.6).  If TYPE_SEEN_P then a typedef name may
2188    be redeclared; otherwise it may not.  KIND indicates which kind of
2189    declarator is wanted.  Returns a valid declarator except in the
2190    case of a syntax error in which case NULL is returned.  *SEEN_ID is
2191    set to true if an identifier being declared is seen; this is used
2192    to diagnose bad forms of abstract array declarators and to
2193    determine whether an identifier list is syntactically permitted.
2194
2195    declarator:
2196      pointer[opt] direct-declarator
2197
2198    direct-declarator:
2199      identifier
2200      ( attributes[opt] declarator )
2201      direct-declarator array-declarator
2202      direct-declarator ( parameter-type-list )
2203      direct-declarator ( identifier-list[opt] )
2204
2205    pointer:
2206      * type-qualifier-list[opt]
2207      * type-qualifier-list[opt] pointer
2208
2209    type-qualifier-list:
2210      type-qualifier
2211      attributes
2212      type-qualifier-list type-qualifier
2213      type-qualifier-list attributes
2214
2215    parameter-type-list:
2216      parameter-list
2217      parameter-list , ...
2218
2219    parameter-list:
2220      parameter-declaration
2221      parameter-list , parameter-declaration
2222
2223    parameter-declaration:
2224      declaration-specifiers declarator attributes[opt]
2225      declaration-specifiers abstract-declarator[opt] attributes[opt]
2226
2227    identifier-list:
2228      identifier
2229      identifier-list , identifier
2230
2231    abstract-declarator:
2232      pointer
2233      pointer[opt] direct-abstract-declarator
2234
2235    direct-abstract-declarator:
2236      ( attributes[opt] abstract-declarator )
2237      direct-abstract-declarator[opt] array-declarator
2238      direct-abstract-declarator[opt] ( parameter-type-list[opt] )
2239
2240    GNU extensions:
2241
2242    direct-declarator:
2243      direct-declarator ( parameter-forward-declarations
2244                          parameter-type-list[opt] )
2245
2246    direct-abstract-declarator:
2247      direct-abstract-declarator[opt] ( parameter-forward-declarations
2248                                        parameter-type-list[opt] )
2249
2250    parameter-forward-declarations:
2251      parameter-list ;
2252      parameter-forward-declarations parameter-list ;
2253
2254    The uses of attributes shown above are GNU extensions.
2255
2256    Some forms of array declarator are not included in C99 in the
2257    syntax for abstract declarators; these are disallowed elsewhere.
2258    This may be a defect (DR#289).
2259
2260    This function also accepts an omitted abstract declarator as being
2261    an abstract declarator, although not part of the formal syntax.  */
2262
2263 static struct c_declarator *
2264 c_parser_declarator (c_parser *parser, bool type_seen_p, c_dtr_syn kind,
2265                      bool *seen_id)
2266 {
2267   /* Parse any initial pointer part.  */
2268   if (c_parser_next_token_is (parser, CPP_MULT))
2269     {
2270       struct c_declspecs *quals_attrs = build_null_declspecs ();
2271       struct c_declarator *inner;
2272       c_parser_consume_token (parser);
2273       c_parser_declspecs (parser, quals_attrs, false, false, true);
2274       inner = c_parser_declarator (parser, type_seen_p, kind, seen_id);
2275       if (inner == NULL)
2276         return NULL;
2277       else
2278         return make_pointer_declarator (quals_attrs, inner);
2279     }
2280   /* Now we have a direct declarator, direct abstract declarator or
2281      nothing (which counts as a direct abstract declarator here).  */
2282   return c_parser_direct_declarator (parser, type_seen_p, kind, seen_id);
2283 }
2284
2285 /* Parse a direct declarator or direct abstract declarator; arguments
2286    as c_parser_declarator.  */
2287
2288 static struct c_declarator *
2289 c_parser_direct_declarator (c_parser *parser, bool type_seen_p, c_dtr_syn kind,
2290                             bool *seen_id)
2291 {
2292   /* The direct declarator must start with an identifier (possibly
2293      omitted) or a parenthesized declarator (possibly abstract).  In
2294      an ordinary declarator, initial parentheses must start a
2295      parenthesized declarator.  In an abstract declarator or parameter
2296      declarator, they could start a parenthesized declarator or a
2297      parameter list.  To tell which, the open parenthesis and any
2298      following attributes must be read.  If a declaration specifier
2299      follows, then it is a parameter list; if the specifier is a
2300      typedef name, there might be an ambiguity about redeclaring it,
2301      which is resolved in the direction of treating it as a typedef
2302      name.  If a close parenthesis follows, it is also an empty
2303      parameter list, as the syntax does not permit empty abstract
2304      declarators.  Otherwise, it is a parenthesized declarator (in
2305      which case the analysis may be repeated inside it, recursively).
2306
2307      ??? There is an ambiguity in a parameter declaration "int
2308      (__attribute__((foo)) x)", where x is not a typedef name: it
2309      could be an abstract declarator for a function, or declare x with
2310      parentheses.  The proper resolution of this ambiguity needs
2311      documenting.  At present we follow an accident of the old
2312      parser's implementation, whereby the first parameter must have
2313      some declaration specifiers other than just attributes.  Thus as
2314      a parameter declaration it is treated as a parenthesized
2315      parameter named x, and as an abstract declarator it is
2316      rejected.
2317
2318      ??? Also following the old parser, attributes inside an empty
2319      parameter list are ignored, making it a list not yielding a
2320      prototype, rather than giving an error or making it have one
2321      parameter with implicit type int.
2322
2323      ??? Also following the old parser, typedef names may be
2324      redeclared in declarators, but not Objective-C class names.  */
2325
2326   if (kind != C_DTR_ABSTRACT
2327       && c_parser_next_token_is (parser, CPP_NAME)
2328       && ((type_seen_p
2329            && c_parser_peek_token (parser)->id_kind == C_ID_TYPENAME)
2330           || c_parser_peek_token (parser)->id_kind == C_ID_ID))
2331     {
2332       struct c_declarator *inner
2333         = build_id_declarator (c_parser_peek_token (parser)->value);
2334       *seen_id = true;
2335       inner->id_loc = c_parser_peek_token (parser)->location;
2336       c_parser_consume_token (parser);
2337       return c_parser_direct_declarator_inner (parser, *seen_id, inner);
2338     }
2339
2340   if (kind != C_DTR_NORMAL
2341       && c_parser_next_token_is (parser, CPP_OPEN_SQUARE))
2342     {
2343       struct c_declarator *inner = build_id_declarator (NULL_TREE);
2344       return c_parser_direct_declarator_inner (parser, *seen_id, inner);
2345     }
2346
2347   /* Either we are at the end of an abstract declarator, or we have
2348      parentheses.  */
2349
2350   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
2351     {
2352       tree attrs;
2353       struct c_declarator *inner;
2354       c_parser_consume_token (parser);
2355       attrs = c_parser_attributes (parser);
2356       if (kind != C_DTR_NORMAL
2357           && (c_parser_next_token_starts_declspecs (parser)
2358               || c_parser_next_token_is (parser, CPP_CLOSE_PAREN)))
2359         {
2360           struct c_arg_info *args
2361             = c_parser_parms_declarator (parser, kind == C_DTR_NORMAL,
2362                                          attrs);
2363           if (args == NULL)
2364             return NULL;
2365           else
2366             {
2367               inner
2368                 = build_function_declarator (args,
2369                                              build_id_declarator (NULL_TREE));
2370               return c_parser_direct_declarator_inner (parser, *seen_id,
2371                                                        inner);
2372             }
2373         }
2374       /* A parenthesized declarator.  */
2375       inner = c_parser_declarator (parser, type_seen_p, kind, seen_id);
2376       if (inner != NULL && attrs != NULL)
2377         inner = build_attrs_declarator (attrs, inner);
2378       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2379         {
2380           c_parser_consume_token (parser);
2381           if (inner == NULL)
2382             return NULL;
2383           else
2384             return c_parser_direct_declarator_inner (parser, *seen_id, inner);
2385         }
2386       else
2387         {
2388           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2389                                      "expected %<)%>");
2390           return NULL;
2391         }
2392     }
2393   else
2394     {
2395       if (kind == C_DTR_NORMAL)
2396         {
2397           c_parser_error (parser, "expected identifier or %<(%>");
2398           return NULL;
2399         }
2400       else
2401         return build_id_declarator (NULL_TREE);
2402     }
2403 }
2404
2405 /* Parse part of a direct declarator or direct abstract declarator,
2406    given that some (in INNER) has already been parsed; ID_PRESENT is
2407    true if an identifier is present, false for an abstract
2408    declarator.  */
2409
2410 static struct c_declarator *
2411 c_parser_direct_declarator_inner (c_parser *parser, bool id_present,
2412                                   struct c_declarator *inner)
2413 {
2414   /* Parse a sequence of array declarators and parameter lists.  */
2415   if (c_parser_next_token_is (parser, CPP_OPEN_SQUARE))
2416     {
2417       struct c_declarator *declarator;
2418       struct c_declspecs *quals_attrs = build_null_declspecs ();
2419       bool static_seen;
2420       bool star_seen;
2421       tree dimen;
2422       c_parser_consume_token (parser);
2423       c_parser_declspecs (parser, quals_attrs, false, false, true);
2424       static_seen = c_parser_next_token_is_keyword (parser, RID_STATIC);
2425       if (static_seen)
2426         c_parser_consume_token (parser);
2427       if (static_seen && !quals_attrs->declspecs_seen_p)
2428         c_parser_declspecs (parser, quals_attrs, false, false, true);
2429       if (!quals_attrs->declspecs_seen_p)
2430         quals_attrs = NULL;
2431       /* If "static" is present, there must be an array dimension.
2432          Otherwise, there may be a dimension, "*", or no
2433          dimension.  */
2434       if (static_seen)
2435         {
2436           star_seen = false;
2437           dimen = c_parser_expr_no_commas (parser, NULL).value;
2438         }
2439       else
2440         {
2441           if (c_parser_next_token_is (parser, CPP_CLOSE_SQUARE))
2442             {
2443               dimen = NULL_TREE;
2444               star_seen = false;
2445             }
2446           else if (c_parser_next_token_is (parser, CPP_MULT))
2447             {
2448               if (c_parser_peek_2nd_token (parser)->type == CPP_CLOSE_SQUARE)
2449                 {
2450                   dimen = NULL_TREE;
2451                   star_seen = true;
2452                   c_parser_consume_token (parser);
2453                 }
2454               else
2455                 {
2456                   star_seen = false;
2457                   dimen = c_parser_expr_no_commas (parser, NULL).value;
2458                 }
2459             }
2460           else
2461             {
2462               star_seen = false;
2463               dimen = c_parser_expr_no_commas (parser, NULL).value;
2464             }
2465         }
2466       if (c_parser_next_token_is (parser, CPP_CLOSE_SQUARE))
2467         c_parser_consume_token (parser);
2468       else
2469         {
2470           c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
2471                                      "expected %<]%>");
2472           return NULL;
2473         }
2474       declarator = build_array_declarator (dimen, quals_attrs, static_seen,
2475                                            star_seen);
2476       if (declarator == NULL)
2477         return NULL;
2478       inner = set_array_declarator_inner (declarator, inner, !id_present);
2479       return c_parser_direct_declarator_inner (parser, id_present, inner);
2480     }
2481   else if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
2482     {
2483       tree attrs;
2484       struct c_arg_info *args;
2485       c_parser_consume_token (parser);
2486       attrs = c_parser_attributes (parser);
2487       args = c_parser_parms_declarator (parser, id_present, attrs);
2488       if (args == NULL)
2489         return NULL;
2490       else
2491         {
2492           inner = build_function_declarator (args, inner);
2493           return c_parser_direct_declarator_inner (parser, id_present, inner);
2494         }
2495     }
2496   return inner;
2497 }
2498
2499 /* Parse a parameter list or identifier list, including the closing
2500    parenthesis but not the opening one.  ATTRS are the attributes at
2501    the start of the list.  ID_LIST_OK is true if an identifier list is
2502    acceptable; such a list must not have attributes at the start.  */
2503
2504 static struct c_arg_info *
2505 c_parser_parms_declarator (c_parser *parser, bool id_list_ok, tree attrs)
2506 {
2507   push_scope ();
2508   declare_parm_level ();
2509   /* If the list starts with an identifier, it is an identifier list.
2510      Otherwise, it is either a prototype list or an empty list.  */
2511   if (id_list_ok
2512       && !attrs
2513       && c_parser_next_token_is (parser, CPP_NAME)
2514       && c_parser_peek_token (parser)->id_kind == C_ID_ID)
2515     {
2516       tree list = NULL_TREE, *nextp = &list;
2517       while (c_parser_next_token_is (parser, CPP_NAME)
2518              && c_parser_peek_token (parser)->id_kind == C_ID_ID)
2519         {
2520           *nextp = build_tree_list (NULL_TREE,
2521                                     c_parser_peek_token (parser)->value);
2522           nextp = & TREE_CHAIN (*nextp);
2523           c_parser_consume_token (parser);
2524           if (c_parser_next_token_is_not (parser, CPP_COMMA))
2525             break;
2526           c_parser_consume_token (parser);
2527           if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2528             {
2529               c_parser_error (parser, "expected identifier");
2530               break;
2531             }
2532         }
2533       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2534         {
2535           struct c_arg_info *ret = XOBNEW (&parser_obstack, struct c_arg_info);
2536           ret->parms = 0;
2537           ret->tags = 0;
2538           ret->types = list;
2539           ret->others = 0;
2540           ret->had_vla_unspec = 0;
2541           c_parser_consume_token (parser);
2542           pop_scope ();
2543           return ret;
2544         }
2545       else
2546         {
2547           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2548                                      "expected %<)%>");
2549           pop_scope ();
2550           return NULL;
2551         }
2552     }
2553   else
2554     {
2555       struct c_arg_info *ret = c_parser_parms_list_declarator (parser, attrs);
2556       pop_scope ();
2557       return ret;
2558     }
2559 }
2560
2561 /* Parse a parameter list (possibly empty), including the closing
2562    parenthesis but not the opening one.  ATTRS are the attributes at
2563    the start of the list.  */
2564
2565 static struct c_arg_info *
2566 c_parser_parms_list_declarator (c_parser *parser, tree attrs)
2567 {
2568   bool good_parm = false;
2569   /* ??? Following the old parser, forward parameter declarations may
2570      use abstract declarators, and if no real parameter declarations
2571      follow the forward declarations then this is not diagnosed.  Also
2572      note as above that attributes are ignored as the only contents of
2573      the parentheses, or as the only contents after forward
2574      declarations.  */
2575   if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2576     {
2577       struct c_arg_info *ret = XOBNEW (&parser_obstack, struct c_arg_info);
2578       ret->parms = 0;
2579       ret->tags = 0;
2580       ret->types = 0;
2581       ret->others = 0;
2582       ret->had_vla_unspec = 0;
2583       c_parser_consume_token (parser);
2584       return ret;
2585     }
2586   if (c_parser_next_token_is (parser, CPP_ELLIPSIS))
2587     {
2588       struct c_arg_info *ret = XOBNEW (&parser_obstack, struct c_arg_info);
2589       ret->parms = 0;
2590       ret->tags = 0;
2591       ret->others = 0;
2592       ret->had_vla_unspec = 0;
2593       /* Suppress -Wold-style-definition for this case.  */
2594       ret->types = error_mark_node;
2595       error ("ISO C requires a named argument before %<...%>");
2596       c_parser_consume_token (parser);
2597       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2598         {
2599           c_parser_consume_token (parser);
2600           return ret;
2601         }
2602       else
2603         {
2604           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2605                                      "expected %<)%>");
2606           return NULL;
2607         }
2608     }
2609   /* Nonempty list of parameters, either terminated with semicolon
2610      (forward declarations; recurse) or with close parenthesis (normal
2611      function) or with ", ... )" (variadic function).  */
2612   while (true)
2613     {
2614       /* Parse a parameter.  */
2615       struct c_parm *parm = c_parser_parameter_declaration (parser, attrs);
2616       attrs = NULL_TREE;
2617       if (parm != NULL)
2618         {
2619           good_parm = true;
2620           push_parm_decl (parm);
2621         }
2622       if (c_parser_next_token_is (parser, CPP_SEMICOLON))
2623         {
2624           tree new_attrs;
2625           c_parser_consume_token (parser);
2626           mark_forward_parm_decls ();
2627           new_attrs = c_parser_attributes (parser);
2628           return c_parser_parms_list_declarator (parser, new_attrs);
2629         }
2630       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2631         {
2632           c_parser_consume_token (parser);
2633           if (good_parm)
2634             return get_parm_info (false);
2635           else
2636             {
2637               struct c_arg_info *ret
2638                 = XOBNEW (&parser_obstack, struct c_arg_info);
2639               ret->parms = 0;
2640               ret->tags = 0;
2641               ret->types = 0;
2642               ret->others = 0;
2643               ret->had_vla_unspec = 0;
2644               return ret;
2645             }
2646         }
2647       if (!c_parser_require (parser, CPP_COMMA,
2648                              "expected %<;%>, %<,%> or %<)%>"))
2649         {
2650           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
2651           return NULL;
2652         }
2653       if (c_parser_next_token_is (parser, CPP_ELLIPSIS))
2654         {
2655           c_parser_consume_token (parser);
2656           if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2657             {
2658               c_parser_consume_token (parser);
2659               if (good_parm)
2660                 return get_parm_info (true);
2661               else
2662                 {
2663                   struct c_arg_info *ret
2664                     = XOBNEW (&parser_obstack, struct c_arg_info);
2665                   ret->parms = 0;
2666                   ret->tags = 0;
2667                   ret->types = 0;
2668                   ret->others = 0;
2669                   ret->had_vla_unspec = 0;
2670                   return ret;
2671                 }
2672             }
2673           else
2674             {
2675               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2676                                          "expected %<)%>");
2677               return NULL;
2678             }
2679         }
2680     }
2681 }
2682
2683 /* Parse a parameter declaration.  ATTRS are the attributes at the
2684    start of the declaration if it is the first parameter.  */
2685
2686 static struct c_parm *
2687 c_parser_parameter_declaration (c_parser *parser, tree attrs)
2688 {
2689   struct c_declspecs *specs;
2690   struct c_declarator *declarator;
2691   tree prefix_attrs;
2692   tree postfix_attrs = NULL_TREE;
2693   bool dummy = false;
2694   if (!c_parser_next_token_starts_declspecs (parser))
2695     {
2696       /* ??? In some Objective-C cases '...' isn't applicable so there
2697          should be a different message.  */
2698       c_parser_error (parser,
2699                       "expected declaration specifiers or %<...%>");
2700       c_parser_skip_to_end_of_parameter (parser);
2701       return NULL;
2702     }
2703   specs = build_null_declspecs ();
2704   if (attrs)
2705     {
2706       declspecs_add_attrs (specs, attrs);
2707       attrs = NULL_TREE;
2708     }
2709   c_parser_declspecs (parser, specs, true, true, true);
2710   finish_declspecs (specs);
2711   pending_xref_error ();
2712   prefix_attrs = specs->attrs;
2713   specs->attrs = NULL_TREE;
2714   declarator = c_parser_declarator (parser, specs->type_seen_p,
2715                                     C_DTR_PARM, &dummy);
2716   if (declarator == NULL)
2717     {
2718       c_parser_skip_until_found (parser, CPP_COMMA, NULL);
2719       return NULL;
2720     }
2721   if (c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
2722     postfix_attrs = c_parser_attributes (parser);
2723   return build_c_parm (specs, chainon (postfix_attrs, prefix_attrs),
2724                        declarator);
2725 }
2726
2727 /* Parse a string literal in an asm expression.  It should not be
2728    translated, and wide string literals are an error although
2729    permitted by the syntax.  This is a GNU extension.
2730
2731    asm-string-literal:
2732      string-literal
2733
2734    ??? At present, following the old parser, the caller needs to have
2735    set c_lex_string_translate to 0.  It would be better to follow the
2736    C++ parser rather than using the c_lex_string_translate kludge.  */
2737
2738 static tree
2739 c_parser_asm_string_literal (c_parser *parser)
2740 {
2741   tree str;
2742   if (c_parser_next_token_is (parser, CPP_STRING))
2743     {
2744       str = c_parser_peek_token (parser)->value;
2745       c_parser_consume_token (parser);
2746     }
2747   else if (c_parser_next_token_is (parser, CPP_WSTRING))
2748     {
2749       error ("wide string literal in %<asm%>");
2750       str = build_string (1, "");
2751       c_parser_consume_token (parser);
2752     }
2753   else
2754     {
2755       c_parser_error (parser, "expected string literal");
2756       str = NULL_TREE;
2757     }
2758   return str;
2759 }
2760
2761 /* Parse a simple asm expression.  This is used in restricted
2762    contexts, where a full expression with inputs and outputs does not
2763    make sense.  This is a GNU extension.
2764
2765    simple-asm-expr:
2766      asm ( asm-string-literal )
2767 */
2768
2769 static tree
2770 c_parser_simple_asm_expr (c_parser *parser)
2771 {
2772   tree str;
2773   gcc_assert (c_parser_next_token_is_keyword (parser, RID_ASM));
2774   /* ??? Follow the C++ parser rather than using the
2775      c_lex_string_translate kludge.  */
2776   c_lex_string_translate = 0;
2777   c_parser_consume_token (parser);
2778   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
2779     {
2780       c_lex_string_translate = 1;
2781       return NULL_TREE;
2782     }
2783   str = c_parser_asm_string_literal (parser);
2784   c_lex_string_translate = 1;
2785   if (!c_parser_require (parser, CPP_CLOSE_PAREN, "expected %<)%>"))
2786     {
2787       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
2788       return NULL_TREE;
2789     }
2790   return str;
2791 }
2792
2793 /* Parse (possibly empty) attributes.  This is a GNU extension.
2794
2795    attributes:
2796      empty
2797      attributes attribute
2798
2799    attribute:
2800      __attribute__ ( ( attribute-list ) )
2801
2802    attribute-list:
2803      attrib
2804      attribute_list , attrib
2805
2806    attrib:
2807      empty
2808      any-word
2809      any-word ( identifier )
2810      any-word ( identifier , nonempty-expr-list )
2811      any-word ( expr-list )
2812
2813    where the "identifier" must not be declared as a type, and
2814    "any-word" may be any identifier (including one declared as a
2815    type), a reserved word storage class specifier, type specifier or
2816    type qualifier.  ??? This still leaves out most reserved keywords
2817    (following the old parser), shouldn't we include them, and why not
2818    allow identifiers declared as types to start the arguments?  */
2819
2820 static tree
2821 c_parser_attributes (c_parser *parser)
2822 {
2823   tree attrs = NULL_TREE;
2824   while (c_parser_next_token_is_keyword (parser, RID_ATTRIBUTE))
2825     {
2826       /* ??? Follow the C++ parser rather than using the
2827          c_lex_string_translate kludge.  */
2828       c_lex_string_translate = 0;
2829       c_parser_consume_token (parser);
2830       if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
2831         {
2832           c_lex_string_translate = 1;
2833           return attrs;
2834         }
2835       if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
2836         {
2837           c_lex_string_translate = 1;
2838           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
2839           return attrs;
2840         }
2841       /* Parse the attribute list.  */
2842       while (c_parser_next_token_is (parser, CPP_COMMA)
2843              || c_parser_next_token_is (parser, CPP_NAME)
2844              || c_parser_next_token_is (parser, CPP_KEYWORD))
2845         {
2846           tree attr, attr_name, attr_args;
2847           if (c_parser_next_token_is (parser, CPP_COMMA))
2848             {
2849               c_parser_consume_token (parser);
2850               continue;
2851             }
2852           if (c_parser_next_token_is (parser, CPP_KEYWORD))
2853             {
2854               /* ??? See comment above about what keywords are
2855                  accepted here.  */
2856               bool ok;
2857               switch (c_parser_peek_token (parser)->keyword)
2858                 {
2859                 case RID_STATIC:
2860                 case RID_UNSIGNED:
2861                 case RID_LONG:
2862                 case RID_CONST:
2863                 case RID_EXTERN:
2864                 case RID_REGISTER:
2865                 case RID_TYPEDEF:
2866                 case RID_SHORT:
2867                 case RID_INLINE:
2868                 case RID_VOLATILE:
2869                 case RID_SIGNED:
2870                 case RID_AUTO:
2871                 case RID_RESTRICT:
2872                 case RID_COMPLEX:
2873                 case RID_THREAD:
2874                 case RID_INT:
2875                 case RID_CHAR:
2876                 case RID_FLOAT:
2877                 case RID_DOUBLE:
2878                 case RID_VOID:
2879                 case RID_DFLOAT32:
2880                 case RID_DFLOAT64:
2881                 case RID_DFLOAT128:
2882                 case RID_BOOL:
2883                   ok = true;
2884                   break;
2885                 default:
2886                   ok = false;
2887                   break;
2888                 }
2889               if (!ok)
2890                 break;
2891             }
2892           attr_name = c_parser_peek_token (parser)->value;
2893           c_parser_consume_token (parser);
2894           if (c_parser_next_token_is_not (parser, CPP_OPEN_PAREN))
2895             {
2896               attr = build_tree_list (attr_name, NULL_TREE);
2897               attrs = chainon (attrs, attr);
2898               continue;
2899             }
2900           c_parser_consume_token (parser);
2901           /* Parse the attribute contents.  If they start with an
2902              identifier which is followed by a comma or close
2903              parenthesis, then the arguments start with that
2904              identifier; otherwise they are an expression list.  */
2905           if (c_parser_next_token_is (parser, CPP_NAME)
2906               && c_parser_peek_token (parser)->id_kind == C_ID_ID
2907               && ((c_parser_peek_2nd_token (parser)->type == CPP_COMMA)
2908                   || (c_parser_peek_2nd_token (parser)->type
2909                       == CPP_CLOSE_PAREN)))
2910             {
2911               tree arg1 = c_parser_peek_token (parser)->value;
2912               c_parser_consume_token (parser);
2913               if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2914                 attr_args = build_tree_list (NULL_TREE, arg1);
2915               else
2916                 {
2917                   c_parser_consume_token (parser);
2918                   attr_args = tree_cons (NULL_TREE, arg1,
2919                                          c_parser_expr_list (parser, false));
2920                 }
2921             }
2922           else
2923             {
2924               if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2925                 attr_args = NULL_TREE;
2926               else
2927                 attr_args = c_parser_expr_list (parser, false);
2928             }
2929           attr = build_tree_list (attr_name, attr_args);
2930           if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2931             c_parser_consume_token (parser);
2932           else
2933             {
2934               c_lex_string_translate = 1;
2935               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2936                                          "expected %<)%>");
2937               return attrs;
2938             }
2939           attrs = chainon (attrs, attr);
2940         }
2941       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2942         c_parser_consume_token (parser);
2943       else
2944         {
2945           c_lex_string_translate = 1;
2946           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2947                                      "expected %<)%>");
2948           return attrs;
2949         }
2950       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
2951         c_parser_consume_token (parser);
2952       else
2953         {
2954           c_lex_string_translate = 1;
2955           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
2956                                      "expected %<)%>");
2957           return attrs;
2958         }
2959       c_lex_string_translate = 1;
2960     }
2961   return attrs;
2962 }
2963
2964 /* Parse a type name (C90 6.5.5, C99 6.7.6).
2965
2966    type-name:
2967      specifier-qualifier-list abstract-declarator[opt]
2968 */
2969
2970 static struct c_type_name *
2971 c_parser_type_name (c_parser *parser)
2972 {
2973   struct c_declspecs *specs = build_null_declspecs ();
2974   struct c_declarator *declarator;
2975   struct c_type_name *ret;
2976   bool dummy = false;
2977   c_parser_declspecs (parser, specs, false, true, true);
2978   if (!specs->declspecs_seen_p)
2979     {
2980       c_parser_error (parser, "expected specifier-qualifier-list");
2981       return NULL;
2982     }
2983   pending_xref_error ();
2984   finish_declspecs (specs);
2985   declarator = c_parser_declarator (parser, specs->type_seen_p,
2986                                     C_DTR_ABSTRACT, &dummy);
2987   if (declarator == NULL)
2988     return NULL;
2989   ret = XOBNEW (&parser_obstack, struct c_type_name);
2990   ret->specs = specs;
2991   ret->declarator = declarator;
2992   return ret;
2993 }
2994
2995 /* Parse an initializer (C90 6.5.7, C99 6.7.8).
2996
2997    initializer:
2998      assignment-expression
2999      { initializer-list }
3000      { initializer-list , }
3001
3002    initializer-list:
3003      designation[opt] initializer
3004      initializer-list , designation[opt] initializer
3005
3006    designation:
3007      designator-list =
3008
3009    designator-list:
3010      designator
3011      designator-list designator
3012
3013    designator:
3014      array-designator
3015      . identifier
3016
3017    array-designator:
3018      [ constant-expression ]
3019
3020    GNU extensions:
3021
3022    initializer:
3023      { }
3024
3025    designation:
3026      array-designator
3027      identifier :
3028
3029    array-designator:
3030      [ constant-expression ... constant-expression ]
3031
3032    Any expression without commas is accepted in the syntax for the
3033    constant-expressions, with non-constant expressions rejected later.
3034
3035    This function is only used for top-level initializers; for nested
3036    ones, see c_parser_initval.  */
3037
3038 static struct c_expr
3039 c_parser_initializer (c_parser *parser)
3040 {
3041   if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
3042     return c_parser_braced_init (parser, NULL_TREE, false);
3043   else
3044     {
3045       struct c_expr ret;
3046       ret = c_parser_expr_no_commas (parser, NULL);
3047       if (TREE_CODE (ret.value) != STRING_CST
3048           && TREE_CODE (ret.value) != COMPOUND_LITERAL_EXPR)
3049         ret = default_function_array_conversion (ret);
3050       return ret;
3051     }
3052 }
3053
3054 /* Parse a braced initializer list.  TYPE is the type specified for a
3055    compound literal, and NULL_TREE for other initializers and for
3056    nested braced lists.  NESTED_P is true for nested braced lists,
3057    false for the list of a compound literal or the list that is the
3058    top-level initializer in a declaration.  */
3059
3060 static struct c_expr
3061 c_parser_braced_init (c_parser *parser, tree type, bool nested_p)
3062 {
3063   gcc_assert (c_parser_next_token_is (parser, CPP_OPEN_BRACE));
3064   c_parser_consume_token (parser);
3065   if (nested_p)
3066     push_init_level (0);
3067   else
3068     really_start_incremental_init (type);
3069   if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
3070     {
3071       if (pedantic)
3072         pedwarn ("ISO C forbids empty initializer braces");
3073     }
3074   else
3075     {
3076       /* Parse a non-empty initializer list, possibly with a trailing
3077          comma.  */
3078       while (true)
3079         {
3080           c_parser_initelt (parser);
3081           if (parser->error)
3082             break;
3083           if (c_parser_next_token_is (parser, CPP_COMMA))
3084             c_parser_consume_token (parser);
3085           else
3086             break;
3087           if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
3088             break;
3089         }
3090     }
3091   if (c_parser_next_token_is_not (parser, CPP_CLOSE_BRACE))
3092     {
3093       struct c_expr ret;
3094       ret.value = error_mark_node;
3095       ret.original_code = ERROR_MARK;
3096       c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, "expected %<}%>");
3097       return ret;
3098     }
3099   c_parser_consume_token (parser);
3100   return pop_init_level (0);
3101 }
3102
3103 /* Parse a nested initializer, including designators.  */
3104
3105 static void
3106 c_parser_initelt (c_parser *parser)
3107 {
3108   /* Parse any designator or designator list.  A single array
3109      designator may have the subsequent "=" omitted in GNU C, but a
3110      longer list or a structure member designator may not.  */
3111   if (c_parser_next_token_is (parser, CPP_NAME)
3112       && c_parser_peek_2nd_token (parser)->type == CPP_COLON)
3113     {
3114       /* Old-style structure member designator.  */
3115       set_init_label (c_parser_peek_token (parser)->value);
3116       if (pedantic)
3117         pedwarn ("obsolete use of designated initializer with %<:%>");
3118       c_parser_consume_token (parser);
3119       c_parser_consume_token (parser);
3120     }
3121   else
3122     {
3123       /* des_seen is 0 if there have been no designators, 1 if there
3124          has been a single array designator and 2 otherwise.  */
3125       int des_seen = 0;
3126       while (c_parser_next_token_is (parser, CPP_OPEN_SQUARE)
3127              || c_parser_next_token_is (parser, CPP_DOT))
3128         {
3129           int des_prev = des_seen;
3130           if (des_seen < 2)
3131             des_seen++;
3132           if (c_parser_next_token_is (parser, CPP_DOT))
3133             {
3134               des_seen = 2;
3135               c_parser_consume_token (parser);
3136               if (c_parser_next_token_is (parser, CPP_NAME))
3137                 {
3138                   set_init_label (c_parser_peek_token (parser)->value);
3139                   c_parser_consume_token (parser);
3140                 }
3141               else
3142                 {
3143                   struct c_expr init;
3144                   init.value = error_mark_node;
3145                   init.original_code = ERROR_MARK;
3146                   c_parser_error (parser, "expected identifier");
3147                   c_parser_skip_until_found (parser, CPP_COMMA, NULL);
3148                   process_init_element (init);
3149                   return;
3150                 }
3151             }
3152           else
3153             {
3154               tree first, second;
3155               /* ??? Following the old parser, [ objc-receiver
3156                  objc-message-args ] is accepted as an initializer,
3157                  being distinguished from a designator by what follows
3158                  the first assignment expression inside the square
3159                  brackets, but after a first array designator a
3160                  subsequent square bracket is for Objective-C taken to
3161                  start an expression, using the obsolete form of
3162                  designated initializer without '=', rather than
3163                  possibly being a second level of designation: in LALR
3164                  terms, the '[' is shifted rather than reducing
3165                  designator to designator-list.  */
3166               if (des_prev == 1 && c_dialect_objc ())
3167                 {
3168                   des_seen = des_prev;
3169                   break;
3170                 }
3171               if (des_prev == 0 && c_dialect_objc ())
3172                 {
3173                   /* This might be an array designator or an
3174                      Objective-C message expression.  If the former,
3175                      continue parsing here; if the latter, parse the
3176                      remainder of the initializer given the starting
3177                      primary-expression.  ??? It might make sense to
3178                      distinguish when des_prev == 1 as well; see
3179                      previous comment.  */
3180                   tree rec, args;
3181                   struct c_expr mexpr;
3182                   c_parser_consume_token (parser);
3183                   if (c_parser_peek_token (parser)->type == CPP_NAME
3184                       && ((c_parser_peek_token (parser)->id_kind
3185                            == C_ID_TYPENAME)
3186                           || (c_parser_peek_token (parser)->id_kind
3187                               == C_ID_CLASSNAME)))
3188                     {
3189                       /* Type name receiver.  */
3190                       tree id = c_parser_peek_token (parser)->value;
3191                       c_parser_consume_token (parser);
3192                       rec = objc_get_class_reference (id);
3193                       goto parse_message_args;
3194                     }
3195                   first = c_parser_expr_no_commas (parser, NULL).value;
3196                   if (c_parser_next_token_is (parser, CPP_ELLIPSIS)
3197                       || c_parser_next_token_is (parser, CPP_CLOSE_SQUARE))
3198                     goto array_desig_after_first;
3199                   /* Expression receiver.  So far only one part
3200                      without commas has been parsed; there might be
3201                      more of the expression.  */
3202                   rec = first;
3203                   while (c_parser_next_token_is (parser, CPP_COMMA))
3204                     {
3205                       struct c_expr next;
3206                       c_parser_consume_token (parser);
3207                       next = c_parser_expr_no_commas (parser, NULL);
3208                       next = default_function_array_conversion (next);
3209                       rec = build_compound_expr (rec, next.value);
3210                     }
3211                 parse_message_args:
3212                   /* Now parse the objc-message-args.  */
3213                   args = c_parser_objc_message_args (parser);
3214                   c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
3215                                              "expected %<]%>");
3216                   mexpr.value
3217                     = objc_build_message_expr (build_tree_list (rec, args));
3218                   mexpr.original_code = ERROR_MARK;
3219                   /* Now parse and process the remainder of the
3220                      initializer, starting with this message
3221                      expression as a primary-expression.  */
3222                   c_parser_initval (parser, &mexpr);
3223                   return;
3224                 }
3225               c_parser_consume_token (parser);
3226               first = c_parser_expr_no_commas (parser, NULL).value;
3227             array_desig_after_first:
3228               if (c_parser_next_token_is (parser, CPP_ELLIPSIS))
3229                 {
3230                   c_parser_consume_token (parser);
3231                   second = c_parser_expr_no_commas (parser, NULL).value;
3232                 }
3233               else
3234                 second = NULL_TREE;
3235               if (c_parser_next_token_is (parser, CPP_CLOSE_SQUARE))
3236                 {
3237                   c_parser_consume_token (parser);
3238                   set_init_index (first, second);
3239                   if (pedantic && second)
3240                     pedwarn ("ISO C forbids specifying range of "
3241                              "elements to initialize");
3242                 }
3243               else
3244                 c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
3245                                            "expected %<]%>");
3246             }
3247         }
3248       if (des_seen >= 1)
3249         {
3250           if (c_parser_next_token_is (parser, CPP_EQ))
3251             {
3252               if (pedantic && !flag_isoc99)
3253                 pedwarn ("ISO C90 forbids specifying subobject to initialize");
3254               c_parser_consume_token (parser);
3255             }
3256           else
3257             {
3258               if (des_seen == 1)
3259                 {
3260                   if (pedantic)
3261                     pedwarn ("obsolete use of designated initializer "
3262                              "without %<=%>");
3263                 }
3264               else
3265                 {
3266                   struct c_expr init;
3267                   init.value = error_mark_node;
3268                   init.original_code = ERROR_MARK;
3269                   c_parser_error (parser, "expected %<=%>");
3270                   c_parser_skip_until_found (parser, CPP_COMMA, NULL);
3271                   process_init_element (init);
3272                   return;
3273                 }
3274             }
3275         }
3276     }
3277   c_parser_initval (parser, NULL);
3278 }
3279
3280 /* Parse a nested initializer; as c_parser_initializer but parses
3281    initializers within braced lists, after any designators have been
3282    applied.  If AFTER is not NULL then it is an Objective-C message
3283    expression which is the primary-expression starting the
3284    initializer.  */
3285
3286 static void
3287 c_parser_initval (c_parser *parser, struct c_expr *after)
3288 {
3289   struct c_expr init;
3290   gcc_assert (!after || c_dialect_objc ());
3291   if (c_parser_next_token_is (parser, CPP_OPEN_BRACE) && !after)
3292     init = c_parser_braced_init (parser, NULL_TREE, true);
3293   else
3294     {
3295       init = c_parser_expr_no_commas (parser, after);
3296       if (init.value != NULL_TREE
3297           && TREE_CODE (init.value) != STRING_CST
3298           && TREE_CODE (init.value) != COMPOUND_LITERAL_EXPR)
3299         init = default_function_array_conversion (init);
3300     }
3301   process_init_element (init);
3302 }
3303
3304 /* Parse a compound statement (possibly a function body) (C90 6.6.2,
3305    C99 6.8.2).
3306
3307    compound-statement:
3308      { block-item-list[opt] }
3309      { label-declarations block-item-list }
3310
3311    block-item-list:
3312      block-item
3313      block-item-list block-item
3314
3315    block-item:
3316      nested-declaration
3317      statement
3318
3319    nested-declaration:
3320      declaration
3321
3322    GNU extensions:
3323
3324    compound-statement:
3325      { label-declarations block-item-list }
3326
3327    nested-declaration:
3328      __extension__ nested-declaration
3329      nested-function-definition
3330
3331    label-declarations:
3332      label-declaration
3333      label-declarations label-declaration
3334
3335    label-declaration:
3336      __label__ identifier-list ;
3337
3338    Allowing the mixing of declarations and code is new in C99.  The
3339    GNU syntax also permits (not shown above) labels at the end of
3340    compound statements, which yield an error.  We don't allow labels
3341    on declarations; this might seem like a natural extension, but
3342    there would be a conflict between attributes on the label and
3343    prefix attributes on the declaration.  ??? The syntax follows the
3344    old parser in requiring something after label declarations.
3345    Although they are erroneous if the labels declared aren't defined,
3346    is it useful for the syntax to be this way?
3347    
3348    OpenMP:
3349    
3350    block-item:
3351      openmp-directive
3352
3353    openmp-directive:
3354      barrier-directive
3355      flush-directive  */
3356
3357 static tree
3358 c_parser_compound_statement (c_parser *parser)
3359 {
3360   tree stmt;
3361   if (!c_parser_require (parser, CPP_OPEN_BRACE, "expected %<{%>"))
3362     return error_mark_node;
3363   stmt = c_begin_compound_stmt (true);
3364   c_parser_compound_statement_nostart (parser);
3365   return c_end_compound_stmt (stmt, true);
3366 }
3367
3368 /* Parse a compound statement except for the opening brace.  This is
3369    used for parsing both compound statements and statement expressions
3370    (which follow different paths to handling the opening).  */
3371
3372 static void
3373 c_parser_compound_statement_nostart (c_parser *parser)
3374 {
3375   bool last_stmt = false;
3376   bool last_label = false;
3377   if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
3378     {
3379       c_parser_consume_token (parser);
3380       return;
3381     }
3382   if (c_parser_next_token_is_keyword (parser, RID_LABEL))
3383     {
3384       /* Read zero or more forward-declarations for labels that nested
3385          functions can jump to.  */
3386       while (c_parser_next_token_is_keyword (parser, RID_LABEL))
3387         {
3388           c_parser_consume_token (parser);
3389           /* Any identifiers, including those declared as type names,
3390              are OK here.  */
3391           while (true)
3392             {
3393               tree label;
3394               if (c_parser_next_token_is_not (parser, CPP_NAME))
3395                 {
3396                   c_parser_error (parser, "expected identifier");
3397                   break;
3398                 }
3399               label
3400                 = declare_label (c_parser_peek_token (parser)->value);
3401               C_DECLARED_LABEL_FLAG (label) = 1;
3402               add_stmt (build_stmt (DECL_EXPR, label));
3403               c_parser_consume_token (parser);
3404               if (c_parser_next_token_is (parser, CPP_COMMA))
3405                 c_parser_consume_token (parser);
3406               else
3407                 break;
3408             }
3409           c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
3410         }
3411       /* ??? Locating this diagnostic on the token after the
3412          declarations end follows the old parser, but it might be
3413          better to locate it where the declarations start instead.  */
3414       if (pedantic)
3415         pedwarn ("ISO C forbids label declarations");
3416     }
3417   /* We must now have at least one statement, label or declaration.  */
3418   if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
3419     {
3420       c_parser_error (parser, "expected declaration or statement");
3421       c_parser_consume_token (parser);
3422       return;
3423     }
3424   while (c_parser_next_token_is_not (parser, CPP_CLOSE_BRACE))
3425     {
3426       location_t loc = c_parser_peek_token (parser)->location;
3427       if (c_parser_next_token_is_keyword (parser, RID_CASE)
3428           || c_parser_next_token_is_keyword (parser, RID_DEFAULT)
3429           || (c_parser_next_token_is (parser, CPP_NAME)
3430               && c_parser_peek_2nd_token (parser)->type == CPP_COLON))
3431         {
3432           last_label = true;
3433           last_stmt = false;
3434           c_parser_label (parser);
3435         }
3436       else if (!last_label
3437                && c_parser_next_token_starts_declspecs (parser))
3438         {
3439           last_label = false;
3440           c_parser_declaration_or_fndef (parser, true, true, true, true);
3441           if (last_stmt
3442               && ((pedantic && !flag_isoc99)
3443                   || warn_declaration_after_statement))
3444             pedwarn_c90 ("%HISO C90 forbids mixed declarations and code",
3445                          &loc);
3446           last_stmt = false;
3447         }
3448       else if (!last_label
3449                && c_parser_next_token_is_keyword (parser, RID_EXTENSION))
3450         {
3451           /* __extension__ can start a declaration, but is also an
3452              unary operator that can start an expression.  Consume all
3453              but the last of a possible series of __extension__ to
3454              determine which.  */
3455           while (c_parser_peek_2nd_token (parser)->type == CPP_KEYWORD
3456                  && (c_parser_peek_2nd_token (parser)->keyword
3457                      == RID_EXTENSION))
3458             c_parser_consume_token (parser);
3459           if (c_token_starts_declspecs (c_parser_peek_2nd_token (parser)))
3460             {
3461               int ext;
3462               ext = disable_extension_diagnostics ();
3463               c_parser_consume_token (parser);
3464               last_label = false;
3465               c_parser_declaration_or_fndef (parser, true, true, true, true);
3466               /* Following the old parser, __extension__ does not
3467                  disable this diagnostic.  */
3468               restore_extension_diagnostics (ext);
3469               if (last_stmt
3470                   && ((pedantic && !flag_isoc99)
3471                       || warn_declaration_after_statement))
3472                 pedwarn_c90 ("%HISO C90 forbids mixed declarations and code",
3473                              &loc);
3474               last_stmt = false;
3475             }
3476           else
3477             goto statement;
3478         }
3479       else if (c_parser_next_token_is (parser, CPP_PRAGMA))
3480         {
3481           /* External pragmas, and some omp pragmas, are not associated
3482              with regular c code, and so are not to be considered statements
3483              syntactically.  This ensures that the user doesn't put them
3484              places that would turn into syntax errors if the directive
3485              were ignored.  */
3486           if (c_parser_pragma (parser, pragma_compound))
3487             last_label = false, last_stmt = true;
3488         }
3489       else if (c_parser_next_token_is (parser, CPP_EOF))
3490         {
3491           c_parser_error (parser, "expected declaration or statement");
3492           return;
3493         }
3494       else
3495         {
3496         statement:
3497           last_label = false;
3498           last_stmt = true;
3499           c_parser_statement_after_labels (parser);
3500         }
3501     }
3502   if (last_label)
3503     error ("label at end of compound statement");
3504   c_parser_consume_token (parser);
3505 }
3506
3507 /* Parse a label (C90 6.6.1, C99 6.8.1).
3508
3509    label:
3510      identifier : attributes[opt]
3511      case constant-expression :
3512      default :
3513
3514    GNU extensions:
3515
3516    label:
3517      case constant-expression ... constant-expression :
3518
3519    The use of attributes on labels is a GNU extension.  The syntax in
3520    GNU C accepts any expressions without commas, non-constant
3521    expressions being rejected later.  */
3522
3523 static void
3524 c_parser_label (c_parser *parser)
3525 {
3526   location_t loc1 = c_parser_peek_token (parser)->location;
3527   tree label = NULL_TREE;
3528   if (c_parser_next_token_is_keyword (parser, RID_CASE))
3529     {
3530       tree exp1, exp2;
3531       c_parser_consume_token (parser);
3532       exp1 = c_parser_expr_no_commas (parser, NULL).value;
3533       if (c_parser_next_token_is (parser, CPP_COLON))
3534         {
3535           c_parser_consume_token (parser);
3536           label = do_case (exp1, NULL_TREE);
3537         }
3538       else if (c_parser_next_token_is (parser, CPP_ELLIPSIS))
3539         {
3540           c_parser_consume_token (parser);
3541           exp2 = c_parser_expr_no_commas (parser, NULL).value;
3542           if (c_parser_require (parser, CPP_COLON, "expected %<:%>"))
3543             label = do_case (exp1, exp2);
3544         }
3545       else
3546         c_parser_error (parser, "expected %<:%> or %<...%>");
3547     }
3548   else if (c_parser_next_token_is_keyword (parser, RID_DEFAULT))
3549     {
3550       c_parser_consume_token (parser);
3551       if (c_parser_require (parser, CPP_COLON, "expected %<:%>"))
3552         label = do_case (NULL_TREE, NULL_TREE);
3553     }
3554   else
3555     {
3556       tree name = c_parser_peek_token (parser)->value;
3557       tree tlab;
3558       location_t loc2;
3559       tree attrs;
3560       gcc_assert (c_parser_next_token_is (parser, CPP_NAME));
3561       c_parser_consume_token (parser);
3562       gcc_assert (c_parser_next_token_is (parser, CPP_COLON));
3563       loc2 = c_parser_peek_token (parser)->location;
3564       c_parser_consume_token (parser);
3565       attrs = c_parser_attributes (parser);
3566       tlab = define_label (loc2, name);
3567       if (tlab)
3568         {
3569           decl_attributes (&tlab, attrs, 0);
3570           label = add_stmt (build_stmt (LABEL_EXPR, tlab));
3571         }
3572     }
3573   if (label)
3574     SET_EXPR_LOCATION (label, loc1);
3575 }
3576
3577 /* Parse a statement (C90 6.6, C99 6.8).
3578
3579    statement:
3580      labeled-statement
3581      compound-statement
3582      expression-statement
3583      selection-statement
3584      iteration-statement
3585      jump-statement
3586
3587    labeled-statement:
3588      label statement
3589
3590    expression-statement:
3591      expression[opt] ;
3592
3593    selection-statement:
3594      if-statement
3595      switch-statement
3596
3597    iteration-statement:
3598      while-statement
3599      do-statement
3600      for-statement
3601
3602    jump-statement:
3603      goto identifier ;
3604      continue ;
3605      break ;
3606      return expression[opt] ;
3607
3608    GNU extensions:
3609
3610    statement:
3611      asm-statement
3612
3613    jump-statement:
3614      goto * expression ;
3615
3616    Objective-C:
3617
3618    statement:
3619      objc-throw-statement
3620      objc-try-catch-statement
3621      objc-synchronized-statement
3622
3623    objc-throw-statement:
3624      @throw expression ;
3625      @throw ;
3626
3627    OpenMP:
3628
3629    statement:
3630      openmp-construct
3631
3632    openmp-construct:
3633      parallel-construct
3634      for-construct
3635      sections-construct
3636      single-construct
3637      parallel-for-construct
3638      parallel-sections-construct
3639      master-construct
3640      critical-construct
3641      atomic-construct
3642      ordered-construct
3643
3644    parallel-construct:
3645      parallel-directive structured-block
3646
3647    for-construct:
3648      for-directive iteration-statement
3649
3650    sections-construct:
3651      sections-directive section-scope
3652
3653    single-construct:
3654      single-directive structured-block
3655
3656    parallel-for-construct:
3657      parallel-for-directive iteration-statement
3658
3659    parallel-sections-construct:
3660      parallel-sections-directive section-scope
3661
3662    master-construct:
3663      master-directive structured-block
3664
3665    critical-construct:
3666      critical-directive structured-block
3667
3668    atomic-construct:
3669      atomic-directive expression-statement
3670
3671    ordered-construct:
3672      ordered-directive structured-block  */
3673
3674 static void
3675 c_parser_statement (c_parser *parser)
3676 {
3677   while (c_parser_next_token_is_keyword (parser, RID_CASE)
3678          || c_parser_next_token_is_keyword (parser, RID_DEFAULT)
3679          || (c_parser_next_token_is (parser, CPP_NAME)
3680              && c_parser_peek_2nd_token (parser)->type == CPP_COLON))
3681     c_parser_label (parser);
3682   c_parser_statement_after_labels (parser);
3683 }
3684
3685 /* Parse a statement, other than a labeled statement.  */
3686
3687 static void
3688 c_parser_statement_after_labels (c_parser *parser)
3689 {
3690   location_t loc = c_parser_peek_token (parser)->location;
3691   tree stmt = NULL_TREE;
3692   switch (c_parser_peek_token (parser)->type)
3693     {
3694     case CPP_OPEN_BRACE:
3695       add_stmt (c_parser_compound_statement (parser));
3696       break;
3697     case CPP_KEYWORD:
3698       switch (c_parser_peek_token (parser)->keyword)
3699         {
3700         case RID_IF:
3701           c_parser_if_statement (parser);
3702           break;
3703         case RID_SWITCH:
3704           c_parser_switch_statement (parser);
3705           break;
3706         case RID_WHILE:
3707           c_parser_while_statement (parser);
3708           break;
3709         case RID_DO:
3710           c_parser_do_statement (parser);
3711           break;
3712         case RID_FOR:
3713           c_parser_for_statement (parser);
3714           break;
3715         case RID_GOTO:
3716           c_parser_consume_token (parser);
3717           if (c_parser_next_token_is (parser, CPP_NAME))
3718             {
3719               stmt = c_finish_goto_label (c_parser_peek_token (parser)->value);
3720               c_parser_consume_token (parser);
3721             }
3722           else if (c_parser_next_token_is (parser, CPP_MULT))
3723             {
3724               c_parser_consume_token (parser);
3725               stmt = c_finish_goto_ptr (c_parser_expression (parser).value);
3726             }
3727           else
3728             c_parser_error (parser, "expected identifier or %<*%>");
3729           goto expect_semicolon;
3730         case RID_CONTINUE:
3731           c_parser_consume_token (parser);
3732           stmt = c_finish_bc_stmt (&c_cont_label, false);
3733           goto expect_semicolon;
3734         case RID_BREAK:
3735           c_parser_consume_token (parser);
3736           stmt = c_finish_bc_stmt (&c_break_label, true);
3737           goto expect_semicolon;
3738         case RID_RETURN:
3739           c_parser_consume_token (parser);
3740           if (c_parser_next_token_is (parser, CPP_SEMICOLON))
3741             {
3742               stmt = c_finish_return (NULL_TREE);
3743               c_parser_consume_token (parser);
3744             }
3745           else
3746             {
3747               stmt = c_finish_return (c_parser_expression_conv (parser).value);
3748               goto expect_semicolon;
3749             }
3750           break;
3751         case RID_ASM:
3752           stmt = c_parser_asm_statement (parser);
3753           break;
3754         case RID_AT_THROW:
3755           gcc_assert (c_dialect_objc ());
3756           c_parser_consume_token (parser);
3757           if (c_parser_next_token_is (parser, CPP_SEMICOLON))
3758             {
3759               stmt = objc_build_throw_stmt (NULL_TREE);
3760               c_parser_consume_token (parser);
3761             }
3762           else
3763             {
3764               stmt
3765                 = objc_build_throw_stmt (c_parser_expression (parser).value);
3766               goto expect_semicolon;
3767             }
3768           break;
3769         case RID_AT_TRY:
3770           gcc_assert (c_dialect_objc ());
3771           c_parser_objc_try_catch_statement (parser);
3772           break;
3773         case RID_AT_SYNCHRONIZED:
3774           gcc_assert (c_dialect_objc ());
3775           c_parser_objc_synchronized_statement (parser);
3776           break;
3777         default:
3778           goto expr_stmt;
3779         }
3780       break;
3781     case CPP_SEMICOLON:
3782       c_parser_consume_token (parser);
3783       break;
3784     case CPP_CLOSE_PAREN:
3785     case CPP_CLOSE_SQUARE:
3786       /* Avoid infinite loop in error recovery:
3787          c_parser_skip_until_found stops at a closing nesting
3788          delimiter without consuming it, but here we need to consume
3789          it to proceed further.  */
3790       c_parser_error (parser, "expected statement");
3791       c_parser_consume_token (parser);
3792       break;
3793     case CPP_PRAGMA:
3794       c_parser_pragma (parser, pragma_stmt);
3795       break;
3796     default:
3797     expr_stmt:
3798       stmt = c_finish_expr_stmt (c_parser_expression_conv (parser).value);
3799     expect_semicolon:
3800       c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
3801       break;
3802     }
3803   /* Two cases cannot and do not have line numbers associated: If stmt
3804      is degenerate, such as "2;", then stmt is an INTEGER_CST, which
3805      cannot hold line numbers.  But that's OK because the statement
3806      will either be changed to a MODIFY_EXPR during gimplification of
3807      the statement expr, or discarded.  If stmt was compound, but
3808      without new variables, we will have skipped the creation of a
3809      BIND and will have a bare STATEMENT_LIST.  But that's OK because
3810      (recursively) all of the component statements should already have
3811      line numbers assigned.  ??? Can we discard no-op statements
3812      earlier?  */
3813   if (stmt && EXPR_P (stmt))
3814     SET_EXPR_LOCATION (stmt, loc);
3815 }
3816
3817 /* Parse a parenthesized condition from an if, do or while statement.
3818
3819    condition:
3820      ( expression )
3821 */
3822 static tree
3823 c_parser_paren_condition (c_parser *parser)
3824 {
3825   location_t loc;
3826   tree cond;
3827   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
3828     return error_mark_node;
3829   loc = c_parser_peek_token (parser)->location;
3830   cond = c_objc_common_truthvalue_conversion
3831     (c_parser_expression_conv (parser).value);
3832   if (EXPR_P (cond))
3833     SET_EXPR_LOCATION (cond, loc);
3834   c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
3835   return cond;
3836 }
3837
3838 /* Parse a statement which is a block in C99.  */
3839
3840 static tree
3841 c_parser_c99_block_statement (c_parser *parser)
3842 {
3843   tree block = c_begin_compound_stmt (flag_isoc99);
3844   c_parser_statement (parser);
3845   return c_end_compound_stmt (block, flag_isoc99);
3846 }
3847
3848 /* Parse the body of an if statement or the else half thereof.  This
3849    is just parsing a statement but (a) it is a block in C99, (b) we
3850    track whether the body is an if statement for the sake of
3851    -Wparentheses warnings, (c) we handle an empty body specially for
3852    the sake of -Wextra warnings.  */
3853
3854 static tree
3855 c_parser_if_body (c_parser *parser, bool *if_p)
3856 {
3857   tree block = c_begin_compound_stmt (flag_isoc99);
3858   while (c_parser_next_token_is_keyword (parser, RID_CASE)
3859          || c_parser_next_token_is_keyword (parser, RID_DEFAULT)
3860          || (c_parser_next_token_is (parser, CPP_NAME)
3861              && c_parser_peek_2nd_token (parser)->type == CPP_COLON))
3862     c_parser_label (parser);
3863   *if_p = c_parser_next_token_is_keyword (parser, RID_IF);
3864   if (extra_warnings && c_parser_next_token_is (parser, CPP_SEMICOLON))
3865     add_stmt (build_empty_stmt ());
3866   c_parser_statement_after_labels (parser);
3867   return c_end_compound_stmt (block, flag_isoc99);
3868 }
3869
3870 /* Parse an if statement (C90 6.6.4, C99 6.8.4).
3871
3872    if-statement:
3873      if ( expression ) statement
3874      if ( expression ) statement else statement
3875 */
3876
3877 static void
3878 c_parser_if_statement (c_parser *parser)
3879 {
3880   tree block;
3881   location_t loc;
3882   tree cond;
3883   bool first_if = false, second_if = false;
3884   tree first_body, second_body;
3885   gcc_assert (c_parser_next_token_is_keyword (parser, RID_IF));
3886   c_parser_consume_token (parser);
3887   block = c_begin_compound_stmt (flag_isoc99);
3888   loc = c_parser_peek_token (parser)->location;
3889   cond = c_parser_paren_condition (parser);
3890   first_body = c_parser_if_body (parser, &first_if);
3891   if (c_parser_next_token_is_keyword (parser, RID_ELSE))
3892     {
3893       c_parser_consume_token (parser);
3894       second_body = c_parser_if_body (parser, &second_if);
3895     }
3896   else
3897     second_body = NULL_TREE;
3898   c_finish_if_stmt (loc, cond, first_body, second_body, first_if);
3899   add_stmt (c_end_compound_stmt (block, flag_isoc99));
3900 }
3901
3902 /* Parse a switch statement (C90 6.6.4, C99 6.8.4).
3903
3904    switch-statement:
3905      switch (expression) statement
3906 */
3907
3908 static void
3909 c_parser_switch_statement (c_parser *parser)
3910 {
3911   tree block, expr, body, save_break;
3912   gcc_assert (c_parser_next_token_is_keyword (parser, RID_SWITCH));
3913   c_parser_consume_token (parser);
3914   block = c_begin_compound_stmt (flag_isoc99);
3915   if (c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
3916     {
3917       expr = c_parser_expression (parser).value;
3918       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
3919     }
3920   else
3921     expr = error_mark_node;
3922   c_start_case (expr);
3923   save_break = c_break_label;
3924   c_break_label = NULL_TREE;
3925   body = c_parser_c99_block_statement (parser);
3926   c_finish_case (body);
3927   if (c_break_label)
3928     add_stmt (build1 (LABEL_EXPR, void_type_node, c_break_label));
3929   c_break_label = save_break;
3930   add_stmt (c_end_compound_stmt (block, flag_isoc99));
3931 }
3932
3933 /* Parse a while statement (C90 6.6.5, C99 6.8.5).
3934
3935    while-statement:
3936       while (expression) statement
3937 */
3938
3939 static void
3940 c_parser_while_statement (c_parser *parser)
3941 {
3942   tree block, cond, body, save_break, save_cont;
3943   location_t loc;
3944   gcc_assert (c_parser_next_token_is_keyword (parser, RID_WHILE));
3945   c_parser_consume_token (parser);
3946   block = c_begin_compound_stmt (flag_isoc99);
3947   loc = c_parser_peek_token (parser)->location;
3948   cond = c_parser_paren_condition (parser);
3949   save_break = c_break_label;
3950   c_break_label = NULL_TREE;
3951   save_cont = c_cont_label;
3952   c_cont_label = NULL_TREE;
3953   body = c_parser_c99_block_statement (parser);
3954   c_finish_loop (loc, cond, NULL, body, c_break_label, c_cont_label, true);
3955   add_stmt (c_end_compound_stmt (block, flag_isoc99));
3956   c_break_label = save_break;
3957   c_cont_label = save_cont;
3958 }
3959
3960 /* Parse a do statement (C90 6.6.5, C99 6.8.5).
3961
3962    do-statement:
3963      do statement while ( expression ) ;
3964 */
3965
3966 static void
3967 c_parser_do_statement (c_parser *parser)
3968 {
3969   tree block, cond, body, save_break, save_cont, new_break, new_cont;
3970   location_t loc;
3971   gcc_assert (c_parser_next_token_is_keyword (parser, RID_DO));
3972   c_parser_consume_token (parser);
3973   block = c_begin_compound_stmt (flag_isoc99);
3974   loc = c_parser_peek_token (parser)->location;
3975   save_break = c_break_label;
3976   c_break_label = NULL_TREE;
3977   save_cont = c_cont_label;
3978   c_cont_label = NULL_TREE;
3979   body = c_parser_c99_block_statement (parser);
3980   c_parser_require_keyword (parser, RID_WHILE, "expected %<while%>");
3981   new_break = c_break_label;
3982   c_break_label = save_break;
3983   new_cont = c_cont_label;
3984   c_cont_label = save_cont;
3985   cond = c_parser_paren_condition (parser);
3986   if (!c_parser_require (parser, CPP_SEMICOLON, "expected %<;%>"))
3987     c_parser_skip_to_end_of_block_or_statement (parser);
3988   c_finish_loop (loc, cond, NULL, body, new_break, new_cont, false);
3989   add_stmt (c_end_compound_stmt (block, flag_isoc99));
3990 }
3991
3992 /* Parse a for statement (C90 6.6.5, C99 6.8.5).
3993
3994    for-statement:
3995      for ( expression[opt] ; expression[opt] ; expression[opt] ) statement
3996      for ( nested-declaration expression[opt] ; expression[opt] ) statement
3997
3998    The form with a declaration is new in C99.
3999
4000    ??? In accordance with the old parser, the declaration may be a
4001    nested function, which is then rejected in check_for_loop_decls,
4002    but does it make any sense for this to be included in the grammar?
4003    Note in particular that the nested function does not include a
4004    trailing ';', whereas the "declaration" production includes one.
4005    Also, can we reject bad declarations earlier and cheaper than
4006    check_for_loop_decls?  */
4007
4008 static void
4009 c_parser_for_statement (c_parser *parser)
4010 {
4011   tree block, cond, incr, save_break, save_cont, body;
4012   location_t loc;
4013   gcc_assert (c_parser_next_token_is_keyword (parser, RID_FOR));
4014   loc = c_parser_peek_token (parser)->location;
4015   c_parser_consume_token (parser);
4016   block = c_begin_compound_stmt (flag_isoc99);
4017   if (c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
4018     {
4019       /* Parse the initialization declaration or expression.  */
4020       if (c_parser_next_token_is (parser, CPP_SEMICOLON))
4021         {
4022           c_parser_consume_token (parser);
4023           c_finish_expr_stmt (NULL_TREE);
4024         }
4025       else if (c_parser_next_token_starts_declspecs (parser))
4026         {
4027           c_parser_declaration_or_fndef (parser, true, true, true, true);
4028           check_for_loop_decls ();
4029         }
4030       else if (c_parser_next_token_is_keyword (parser, RID_EXTENSION))
4031         {
4032           /* __extension__ can start a declaration, but is also an
4033              unary operator that can start an expression.  Consume all
4034              but the last of a possible series of __extension__ to
4035              determine which.  */
4036           while (c_parser_peek_2nd_token (parser)->type == CPP_KEYWORD
4037                  && (c_parser_peek_2nd_token (parser)->keyword
4038                      == RID_EXTENSION))
4039             c_parser_consume_token (parser);
4040           if (c_token_starts_declspecs (c_parser_peek_2nd_token (parser)))
4041             {
4042               int ext;
4043               ext = disable_extension_diagnostics ();
4044               c_parser_consume_token (parser);
4045               c_parser_declaration_or_fndef (parser, true, true, true, true);
4046               restore_extension_diagnostics (ext);
4047               check_for_loop_decls ();
4048             }
4049           else
4050             goto init_expr;
4051         }
4052       else
4053         {
4054         init_expr:
4055           c_finish_expr_stmt (c_parser_expression (parser).value);
4056           c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
4057         }
4058       /* Parse the loop condition.  */
4059       loc = c_parser_peek_token (parser)->location;
4060       if (c_parser_next_token_is (parser, CPP_SEMICOLON))
4061         {
4062           c_parser_consume_token (parser);
4063           cond = NULL_TREE;
4064         }
4065       else
4066         {
4067           tree ocond = c_parser_expression_conv (parser).value;
4068           cond = c_objc_common_truthvalue_conversion (ocond);
4069           if (EXPR_P (cond))
4070             SET_EXPR_LOCATION (cond, loc);
4071           c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
4072         }
4073       /* Parse the increment expression.  */
4074       if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
4075         incr = c_process_expr_stmt (NULL_TREE);
4076       else
4077         incr = c_process_expr_stmt (c_parser_expression (parser).value);
4078       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
4079     }
4080   else
4081     {
4082       cond = error_mark_node;
4083       incr = error_mark_node;
4084     }
4085   save_break = c_break_label;
4086   c_break_label = NULL_TREE;
4087   save_cont = c_cont_label;
4088   c_cont_label = NULL_TREE;
4089   body = c_parser_c99_block_statement (parser);
4090   c_finish_loop (loc, cond, incr, body, c_break_label, c_cont_label, true);
4091   add_stmt (c_end_compound_stmt (block, flag_isoc99));
4092   c_break_label = save_break;
4093   c_cont_label = save_cont;
4094 }
4095
4096 /* Parse an asm statement, a GNU extension.  This is a full-blown asm
4097    statement with inputs, outputs, clobbers, and volatile tag
4098    allowed.
4099
4100    asm-statement:
4101      asm type-qualifier[opt] ( asm-argument ) ;
4102
4103    asm-argument:
4104      asm-string-literal
4105      asm-string-literal : asm-operands[opt]
4106      asm-string-literal : asm-operands[opt] : asm-operands[opt]
4107      asm-string-literal : asm-operands[opt] : asm-operands[opt] : asm-clobbers
4108
4109    Qualifiers other than volatile are accepted in the syntax but
4110    warned for.  */
4111
4112 static tree
4113 c_parser_asm_statement (c_parser *parser)
4114 {
4115   tree quals, str, outputs, inputs, clobbers, ret;
4116   bool simple;
4117   gcc_assert (c_parser_next_token_is_keyword (parser, RID_ASM));
4118   c_parser_consume_token (parser);
4119   if (c_parser_next_token_is_keyword (parser, RID_VOLATILE))
4120     {
4121       quals = c_parser_peek_token (parser)->value;
4122       c_parser_consume_token (parser);
4123     }
4124   else if (c_parser_next_token_is_keyword (parser, RID_CONST)
4125            || c_parser_next_token_is_keyword (parser, RID_RESTRICT))
4126     {
4127       warning (0, "%E qualifier ignored on asm",
4128                c_parser_peek_token (parser)->value);
4129       quals = NULL_TREE;
4130       c_parser_consume_token (parser);
4131     }
4132   else
4133     quals = NULL_TREE;
4134   /* ??? Follow the C++ parser rather than using the
4135      c_lex_string_translate kludge.  */
4136   c_lex_string_translate = 0;
4137   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
4138     {
4139       c_lex_string_translate = 1;
4140       return NULL_TREE;
4141     }
4142   str = c_parser_asm_string_literal (parser);
4143   if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
4144     {
4145       simple = true;
4146       outputs = NULL_TREE;
4147       inputs = NULL_TREE;
4148       clobbers = NULL_TREE;
4149       goto done_asm;
4150     }
4151   if (!c_parser_require (parser, CPP_COLON, "expected %<:%> or %<)%>"))
4152     {
4153       c_lex_string_translate = 1;
4154       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
4155       return NULL_TREE;
4156     }
4157   simple = false;
4158   /* Parse outputs.  */
4159   if (c_parser_next_token_is (parser, CPP_COLON)
4160       || c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
4161     outputs = NULL_TREE;
4162   else
4163     outputs = c_parser_asm_operands (parser, false);
4164   if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
4165     {
4166       inputs = NULL_TREE;
4167       clobbers = NULL_TREE;
4168       goto done_asm;
4169     }
4170   if (!c_parser_require (parser, CPP_COLON, "expected %<:%> or %<)%>"))
4171     {
4172       c_lex_string_translate = 1;
4173       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
4174       return NULL_TREE;
4175     }
4176   /* Parse inputs.  */
4177   if (c_parser_next_token_is (parser, CPP_COLON)
4178       || c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
4179     inputs = NULL_TREE;
4180   else
4181     inputs = c_parser_asm_operands (parser, true);
4182   if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
4183     {
4184       clobbers = NULL_TREE;
4185       goto done_asm;
4186     }
4187   if (!c_parser_require (parser, CPP_COLON, "expected %<:%> or %<)%>"))
4188     {
4189       c_lex_string_translate = 1;
4190       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
4191       return NULL_TREE;
4192     }
4193   /* Parse clobbers.  */
4194   clobbers = c_parser_asm_clobbers (parser);
4195  done_asm:
4196   c_lex_string_translate = 1;
4197   if (!c_parser_require (parser, CPP_CLOSE_PAREN, "expected %<)%>"))
4198     {
4199       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
4200       return NULL_TREE;
4201     }
4202   if (!c_parser_require (parser, CPP_SEMICOLON, "expected %<;%>"))
4203     c_parser_skip_to_end_of_block_or_statement (parser);
4204   ret = build_asm_stmt (quals, build_asm_expr (str, outputs, inputs,
4205                                                clobbers, simple));
4206   return ret;
4207 }
4208
4209 /* Parse asm operands, a GNU extension.  If CONVERT_P (for inputs but
4210    not outputs), apply the default conversion of functions and arrays
4211    to pointers.
4212
4213    asm-operands:
4214      asm-operand
4215      asm-operands , asm-operand
4216
4217    asm-operand:
4218      asm-string-literal ( expression )
4219      [ identifier ] asm-string-literal ( expression )
4220 */
4221
4222 static tree
4223 c_parser_asm_operands (c_parser *parser, bool convert_p)
4224 {
4225   tree list = NULL_TREE;
4226   while (true)
4227     {
4228       tree name, str;
4229       struct c_expr expr;
4230       if (c_parser_next_token_is (parser, CPP_OPEN_SQUARE))
4231         {
4232           c_parser_consume_token (parser);
4233           if (c_parser_next_token_is (parser, CPP_NAME))
4234             {
4235               tree id = c_parser_peek_token (parser)->value;
4236               c_parser_consume_token (parser);
4237               name = build_string (IDENTIFIER_LENGTH (id),
4238                                    IDENTIFIER_POINTER (id));
4239             }
4240           else
4241             {
4242               c_parser_error (parser, "expected identifier");
4243               c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE, NULL);
4244               return NULL_TREE;
4245             }
4246           c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
4247                                      "expected %<]%>");
4248         }
4249       else
4250         name = NULL_TREE;
4251       str = c_parser_asm_string_literal (parser);
4252       if (str == NULL_TREE)
4253         return NULL_TREE;
4254       c_lex_string_translate = 1;
4255       if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
4256         {
4257           c_lex_string_translate = 0;
4258           return NULL_TREE;
4259         }
4260       expr = c_parser_expression (parser);
4261       if (convert_p)
4262         expr = default_function_array_conversion (expr);
4263       c_lex_string_translate = 0;
4264       if (!c_parser_require (parser, CPP_CLOSE_PAREN, "expected %<)%>"))
4265         {
4266           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
4267           return NULL_TREE;
4268         }
4269       list = chainon (list, build_tree_list (build_tree_list (name, str),
4270                                              expr.value));
4271       if (c_parser_next_token_is (parser, CPP_COMMA))
4272         c_parser_consume_token (parser);
4273       else
4274         break;
4275     }
4276   return list;
4277 }
4278
4279 /* Parse asm clobbers, a GNU extension.
4280
4281    asm-clobbers:
4282      asm-string-literal
4283      asm-clobbers , asm-string-literal
4284 */
4285
4286 static tree
4287 c_parser_asm_clobbers (c_parser *parser)
4288 {
4289   tree list = NULL_TREE;
4290   while (true)
4291     {
4292       tree str = c_parser_asm_string_literal (parser);
4293       if (str)
4294         list = tree_cons (NULL_TREE, str, list);
4295       else
4296         return NULL_TREE;
4297       if (c_parser_next_token_is (parser, CPP_COMMA))
4298         c_parser_consume_token (parser);
4299       else
4300         break;
4301     }
4302   return list;
4303 }
4304
4305 /* Parse an expression other than a compound expression; that is, an
4306    assignment expression (C90 6.3.16, C99 6.5.16).  If AFTER is not
4307    NULL then it is an Objective-C message expression which is the
4308    primary-expression starting the expression as an initializer.
4309
4310    assignment-expression:
4311      conditional-expression
4312      unary-expression assignment-operator assignment-expression
4313
4314    assignment-operator: one of
4315      = *= /= %= += -= <<= >>= &= ^= |=
4316
4317    In GNU C we accept any conditional expression on the LHS and
4318    diagnose the invalid lvalue rather than producing a syntax
4319    error.  */
4320
4321 static struct c_expr
4322 c_parser_expr_no_commas (c_parser *parser, struct c_expr *after)
4323 {
4324   struct c_expr lhs, rhs, ret;
4325   enum tree_code code;
4326   gcc_assert (!after || c_dialect_objc ());
4327   lhs = c_parser_conditional_expression (parser, after);
4328   switch (c_parser_peek_token (parser)->type)
4329     {
4330     case CPP_EQ:
4331       code = NOP_EXPR;
4332       break;
4333     case CPP_MULT_EQ:
4334       code = MULT_EXPR;
4335       break;
4336     case CPP_DIV_EQ:
4337       code = TRUNC_DIV_EXPR;
4338       break;
4339     case CPP_MOD_EQ:
4340       code = TRUNC_MOD_EXPR;
4341       break;
4342     case CPP_PLUS_EQ:
4343       code = PLUS_EXPR;
4344       break;
4345     case CPP_MINUS_EQ:
4346       code = MINUS_EXPR;
4347       break;
4348     case CPP_LSHIFT_EQ:
4349       code = LSHIFT_EXPR;
4350       break;
4351     case CPP_RSHIFT_EQ:
4352       code = RSHIFT_EXPR;
4353       break;
4354     case CPP_AND_EQ:
4355       code = BIT_AND_EXPR;
4356       break;
4357     case CPP_XOR_EQ:
4358       code = BIT_XOR_EXPR;
4359       break;
4360     case CPP_OR_EQ:
4361       code = BIT_IOR_EXPR;
4362       break;
4363     default:
4364       return lhs;
4365     }
4366   c_parser_consume_token (parser);
4367   rhs = c_parser_expr_no_commas (parser, NULL);
4368   rhs = default_function_array_conversion (rhs);
4369   ret.value = build_modify_expr (lhs.value, code, rhs.value);
4370   if (code == NOP_EXPR)
4371     ret.original_code = MODIFY_EXPR;
4372   else
4373     {
4374       TREE_NO_WARNING (ret.value) = 1;
4375       ret.original_code = ERROR_MARK;
4376     }
4377   return ret;
4378 }
4379
4380 /* Parse a conditional expression (C90 6.3.15, C99 6.5.15).  If AFTER
4381    is not NULL then it is an Objective-C message expression which is
4382    the primary-expression starting the expression as an initializer.
4383
4384    conditional-expression:
4385      logical-OR-expression
4386      logical-OR-expression ? expression : conditional-expression
4387
4388    GNU extensions:
4389
4390    conditional-expression:
4391      logical-OR-expression ? : conditional-expression
4392 */
4393
4394 static struct c_expr
4395 c_parser_conditional_expression (c_parser *parser, struct c_expr *after)
4396 {
4397   struct c_expr cond, exp1, exp2, ret;
4398   gcc_assert (!after || c_dialect_objc ());
4399   cond = c_parser_binary_expression (parser, after);
4400   if (c_parser_next_token_is_not (parser, CPP_QUERY))
4401     return cond;
4402   cond = default_function_array_conversion (cond);
4403   c_parser_consume_token (parser);
4404   if (c_parser_next_token_is (parser, CPP_COLON))
4405     {
4406       if (pedantic)
4407         pedwarn ("ISO C forbids omitting the middle term of a ?: expression");
4408       /* Make sure first operand is calculated only once.  */
4409       exp1.value = save_expr (default_conversion (cond.value));
4410       cond.value = c_objc_common_truthvalue_conversion (exp1.value);
4411       skip_evaluation += cond.value == truthvalue_true_node;
4412     }
4413   else
4414     {
4415       cond.value
4416         = c_objc_common_truthvalue_conversion
4417         (default_conversion (cond.value));
4418       skip_evaluation += cond.value == truthvalue_false_node;
4419       exp1 = c_parser_expression_conv (parser);
4420       skip_evaluation += ((cond.value == truthvalue_true_node)
4421                           - (cond.value == truthvalue_false_node));
4422     }
4423   if (!c_parser_require (parser, CPP_COLON, "expected %<:%>"))
4424     {
4425       skip_evaluation -= cond.value == truthvalue_true_node;
4426       ret.value = error_mark_node;
4427       ret.original_code = ERROR_MARK;
4428       return ret;
4429     }
4430   exp2 = c_parser_conditional_expression (parser, NULL);
4431   exp2 = default_function_array_conversion (exp2);
4432   skip_evaluation -= cond.value == truthvalue_true_node;
4433   ret.value = build_conditional_expr (cond.value, exp1.value, exp2.value);
4434   ret.original_code = ERROR_MARK;
4435   return ret;
4436 }
4437
4438 /* Parse a binary expression; that is, a logical-OR-expression (C90
4439    6.3.5-6.3.14, C99 6.5.5-6.5.14).  If AFTER is not NULL then it is
4440    an Objective-C message expression which is the primary-expression
4441    starting the expression as an initializer.
4442
4443    multiplicative-expression:
4444      cast-expression
4445      multiplicative-expression * cast-expression
4446      multiplicative-expression / cast-expression
4447      multiplicative-expression % cast-expression
4448
4449    additive-expression:
4450      multiplicative-expression
4451      additive-expression + multiplicative-expression
4452      additive-expression - multiplicative-expression
4453
4454    shift-expression:
4455      additive-expression
4456      shift-expression << additive-expression
4457      shift-expression >> additive-expression
4458
4459    relational-expression:
4460      shift-expression
4461      relational-expression < shift-expression
4462      relational-expression > shift-expression
4463      relational-expression <= shift-expression
4464      relational-expression >= shift-expression
4465
4466    equality-expression:
4467      relational-expression
4468      equality-expression == relational-expression
4469      equality-expression != relational-expression
4470
4471    AND-expression:
4472      equality-expression
4473      AND-expression & equality-expression
4474
4475    exclusive-OR-expression:
4476      AND-expression
4477      exclusive-OR-expression ^ AND-expression
4478
4479    inclusive-OR-expression:
4480      exclusive-OR-expression
4481      inclusive-OR-expression | exclusive-OR-expression
4482
4483    logical-AND-expression:
4484      inclusive-OR-expression
4485      logical-AND-expression && inclusive-OR-expression
4486
4487    logical-OR-expression:
4488      logical-AND-expression
4489      logical-OR-expression || logical-AND-expression
4490 */
4491
4492 static struct c_expr
4493 c_parser_binary_expression (c_parser *parser, struct c_expr *after)
4494 {
4495   /* A binary expression is parsed using operator-precedence parsing,
4496      with the operands being cast expressions.  All the binary
4497      operators are left-associative.  Thus a binary expression is of
4498      form:
4499
4500      E0 op1 E1 op2 E2 ...
4501
4502      which we represent on a stack.  On the stack, the precedence
4503      levels are strictly increasing.  When a new operator is
4504      encountered of higher precedence than that at the top of the
4505      stack, it is pushed; its LHS is the top expression, and its RHS
4506      is everything parsed until it is popped.  When a new operator is
4507      encountered with precedence less than or equal to that at the top
4508      of the stack, triples E[i-1] op[i] E[i] are popped and replaced
4509      by the result of the operation until the operator at the top of
4510      the stack has lower precedence than the new operator or there is
4511      only one element on the stack; then the top expression is the LHS
4512      of the new operator.  In the case of logical AND and OR
4513      expressions, we also need to adjust skip_evaluation as
4514      appropriate when the operators are pushed and popped.  */
4515
4516   /* The precedence levels, where 0 is a dummy lowest level used for
4517      the bottom of the stack.  */
4518   enum prec {
4519     PREC_NONE,
4520     PREC_LOGOR,
4521     PREC_LOGAND,
4522     PREC_BITOR,
4523     PREC_BITXOR,
4524     PREC_BITAND,
4525     PREC_EQ,
4526     PREC_REL,
4527     PREC_SHIFT,
4528     PREC_ADD,
4529     PREC_MULT,
4530     NUM_PRECS
4531   };
4532   struct {
4533     /* The expression at this stack level.  */
4534     struct c_expr expr;
4535     /* The precedence of the operator on its left, PREC_NONE at the
4536        bottom of the stack.  */
4537     enum prec prec;
4538     /* The operation on its left.  */
4539     enum tree_code op;
4540   } stack[NUM_PRECS];
4541   int sp;
4542 #define POP                                                                   \
4543   do {                                                                        \
4544     switch (stack[sp].op)                                                     \
4545       {                                                                       \
4546       case TRUTH_ANDIF_EXPR:                                                  \
4547         skip_evaluation -= stack[sp - 1].expr.value == truthvalue_false_node; \
4548         break;                                                                \
4549       case TRUTH_ORIF_EXPR:                                                   \
4550         skip_evaluation -= stack[sp - 1].expr.value == truthvalue_true_node;  \
4551         break;                                                                \
4552       default:                                                                \
4553         break;                                                                \
4554       }                                                                       \
4555     stack[sp - 1].expr                                                        \
4556       = default_function_array_conversion (stack[sp - 1].expr);               \
4557     stack[sp].expr                                                            \
4558       = default_function_array_conversion (stack[sp].expr);                   \
4559     stack[sp - 1].expr = parser_build_binary_op (stack[sp].op,                \
4560                                                  stack[sp - 1].expr,          \
4561                                                  stack[sp].expr);             \
4562     sp--;                                                                     \
4563   } while (0)
4564   gcc_assert (!after || c_dialect_objc ());
4565   stack[0].expr = c_parser_cast_expression (parser, after);
4566   stack[0].prec = PREC_NONE;
4567   sp = 0;
4568   while (true)
4569     {
4570       enum prec oprec;
4571       enum tree_code ocode;
4572       if (parser->error)
4573         goto out;
4574       switch (c_parser_peek_token (parser)->type)
4575         {
4576         case CPP_MULT:
4577           oprec = PREC_MULT;
4578           ocode = MULT_EXPR;
4579           break;
4580         case CPP_DIV:
4581           oprec = PREC_MULT;
4582           ocode = TRUNC_DIV_EXPR;
4583           break;
4584         case CPP_MOD:
4585           oprec = PREC_MULT;
4586           ocode = TRUNC_MOD_EXPR;
4587           break;
4588         case CPP_PLUS:
4589           oprec = PREC_ADD;
4590           ocode = PLUS_EXPR;
4591           break;
4592         case CPP_MINUS:
4593           oprec = PREC_ADD;
4594           ocode = MINUS_EXPR;
4595           break;
4596         case CPP_LSHIFT:
4597           oprec = PREC_SHIFT;
4598           ocode = LSHIFT_EXPR;
4599           break;
4600         case CPP_RSHIFT:
4601           oprec = PREC_SHIFT;
4602           ocode = RSHIFT_EXPR;
4603           break;
4604         case CPP_LESS:
4605           oprec = PREC_REL;
4606           ocode = LT_EXPR;
4607           break;
4608         case CPP_GREATER:
4609           oprec = PREC_REL;
4610           ocode = GT_EXPR;
4611           break;
4612         case CPP_LESS_EQ:
4613           oprec = PREC_REL;
4614           ocode = LE_EXPR;
4615           break;
4616         case CPP_GREATER_EQ:
4617           oprec = PREC_REL;
4618           ocode = GE_EXPR;
4619           break;
4620         case CPP_EQ_EQ:
4621           oprec = PREC_EQ;
4622           ocode = EQ_EXPR;
4623           break;
4624         case CPP_NOT_EQ:
4625           oprec = PREC_EQ;
4626           ocode = NE_EXPR;
4627           break;
4628         case CPP_AND:
4629           oprec = PREC_BITAND;
4630           ocode = BIT_AND_EXPR;
4631           break;
4632         case CPP_XOR:
4633           oprec = PREC_BITXOR;
4634           ocode = BIT_XOR_EXPR;
4635           break;
4636         case CPP_OR:
4637           oprec = PREC_BITOR;
4638           ocode = BIT_IOR_EXPR;
4639           break;
4640         case CPP_AND_AND:
4641           oprec = PREC_LOGAND;
4642           ocode = TRUTH_ANDIF_EXPR;
4643           break;
4644         case CPP_OR_OR:
4645           oprec = PREC_LOGOR;
4646           ocode = TRUTH_ORIF_EXPR;
4647           break;
4648         default:
4649           /* Not a binary operator, so end of the binary
4650              expression.  */
4651           goto out;
4652         }
4653       c_parser_consume_token (parser);
4654       while (oprec <= stack[sp].prec)
4655         POP;
4656       switch (ocode)
4657         {
4658         case TRUTH_ANDIF_EXPR:
4659           stack[sp].expr
4660             = default_function_array_conversion (stack[sp].expr);
4661           stack[sp].expr.value = c_objc_common_truthvalue_conversion
4662             (default_conversion (stack[sp].expr.value));
4663           skip_evaluation += stack[sp].expr.value == truthvalue_false_node;
4664           break;
4665         case TRUTH_ORIF_EXPR:
4666           stack[sp].expr
4667             = default_function_array_conversion (stack[sp].expr);
4668           stack[sp].expr.value = c_objc_common_truthvalue_conversion
4669             (default_conversion (stack[sp].expr.value));
4670           skip_evaluation += stack[sp].expr.value == truthvalue_true_node;
4671           break;
4672         default:
4673           break;
4674         }
4675       sp++;
4676       stack[sp].expr = c_parser_cast_expression (parser, NULL);
4677       stack[sp].prec = oprec;
4678       stack[sp].op = ocode;
4679     }
4680  out:
4681   while (sp > 0)
4682     POP;
4683   return stack[0].expr;
4684 #undef POP
4685 }
4686
4687 /* Parse a cast expression (C90 6.3.4, C99 6.5.4).  If AFTER is not
4688    NULL then it is an Objective-C message expression which is the
4689    primary-expression starting the expression as an initializer.
4690
4691    cast-expression:
4692      unary-expression
4693      ( type-name ) unary-expression
4694 */
4695
4696 static struct c_expr
4697 c_parser_cast_expression (c_parser *parser, struct c_expr *after)
4698 {
4699   gcc_assert (!after || c_dialect_objc ());
4700   if (after)
4701     return c_parser_postfix_expression_after_primary (parser, *after);
4702   /* If the expression begins with a parenthesized type name, it may
4703      be either a cast or a compound literal; we need to see whether
4704      the next character is '{' to tell the difference.  If not, it is
4705      an unary expression.  */
4706   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN)
4707       && c_token_starts_typename (c_parser_peek_2nd_token (parser)))
4708     {
4709       struct c_type_name *type_name;
4710       struct c_expr ret;
4711       struct c_expr expr;
4712       c_parser_consume_token (parser);
4713       type_name = c_parser_type_name (parser);
4714       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
4715       if (type_name == NULL)
4716         {
4717           ret.value = error_mark_node;
4718           ret.original_code = ERROR_MARK;
4719           return ret;
4720         }
4721
4722       /* Save casted types in the function's used types hash table.  */
4723       used_types_insert (type_name->specs->type);
4724
4725       if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
4726         return c_parser_postfix_expression_after_paren_type (parser,
4727                                                              type_name);
4728       expr = c_parser_cast_expression (parser, NULL);
4729       expr = default_function_array_conversion (expr);
4730       ret.value = c_cast_expr (type_name, expr.value);
4731       ret.original_code = ERROR_MARK;
4732       return ret;
4733     }
4734   else
4735     return c_parser_unary_expression (parser);
4736 }
4737
4738 /* Parse an unary expression (C90 6.3.3, C99 6.5.3).
4739
4740    unary-expression:
4741      postfix-expression
4742      ++ unary-expression
4743      -- unary-expression
4744      unary-operator cast-expression
4745      sizeof unary-expression
4746      sizeof ( type-name )
4747
4748    unary-operator: one of
4749      & * + - ~ !
4750
4751    GNU extensions:
4752
4753    unary-expression:
4754      __alignof__ unary-expression
4755      __alignof__ ( type-name )
4756      && identifier
4757
4758    unary-operator: one of
4759      __extension__ __real__ __imag__
4760
4761    In addition, the GNU syntax treats ++ and -- as unary operators, so
4762    they may be applied to cast expressions with errors for non-lvalues
4763    given later.  */
4764
4765 static struct c_expr
4766 c_parser_unary_expression (c_parser *parser)
4767 {
4768   int ext;
4769   struct c_expr ret, op;
4770   switch (c_parser_peek_token (parser)->type)
4771     {
4772     case CPP_PLUS_PLUS:
4773       c_parser_consume_token (parser);
4774       op = c_parser_cast_expression (parser, NULL);
4775       op = default_function_array_conversion (op);
4776       return parser_build_unary_op (PREINCREMENT_EXPR, op);
4777     case CPP_MINUS_MINUS:
4778       c_parser_consume_token (parser);
4779       op = c_parser_cast_expression (parser, NULL);
4780       op = default_function_array_conversion (op);
4781       return parser_build_unary_op (PREDECREMENT_EXPR, op);
4782     case CPP_AND:
4783       c_parser_consume_token (parser);
4784       return parser_build_unary_op (ADDR_EXPR,
4785                                     c_parser_cast_expression (parser, NULL));
4786     case CPP_MULT:
4787       c_parser_consume_token (parser);
4788       op = c_parser_cast_expression (parser, NULL);
4789       op = default_function_array_conversion (op);
4790       ret.value = build_indirect_ref (op.value, "unary *");
4791       ret.original_code = ERROR_MARK;
4792       return ret;
4793     case CPP_PLUS:
4794       c_parser_consume_token (parser);
4795       if (!c_dialect_objc () && !in_system_header)
4796         warning (OPT_Wtraditional,
4797                  "traditional C rejects the unary plus operator");
4798       op = c_parser_cast_expression (parser, NULL);
4799       op = default_function_array_conversion (op);
4800       return parser_build_unary_op (CONVERT_EXPR, op);
4801     case CPP_MINUS:
4802       c_parser_consume_token (parser);
4803       op = c_parser_cast_expression (parser, NULL);
4804       op = default_function_array_conversion (op);
4805       return parser_build_unary_op (NEGATE_EXPR, op);
4806     case CPP_COMPL:
4807       c_parser_consume_token (parser);
4808       op = c_parser_cast_expression (parser, NULL);
4809       op = default_function_array_conversion (op);
4810       return parser_build_unary_op (BIT_NOT_EXPR, op);
4811     case CPP_NOT:
4812       c_parser_consume_token (parser);
4813       op = c_parser_cast_expression (parser, NULL);
4814       op = default_function_array_conversion (op);
4815       return parser_build_unary_op (TRUTH_NOT_EXPR, op);
4816     case CPP_AND_AND:
4817       /* Refer to the address of a label as a pointer.  */
4818       c_parser_consume_token (parser);
4819       if (c_parser_next_token_is (parser, CPP_NAME))
4820         {
4821           ret.value = finish_label_address_expr
4822             (c_parser_peek_token (parser)->value);
4823           c_parser_consume_token (parser);
4824         }
4825       else
4826         {
4827           c_parser_error (parser, "expected identifier");
4828           ret.value = error_mark_node;
4829         }
4830         ret.original_code = ERROR_MARK;
4831         return ret;
4832     case CPP_KEYWORD:
4833       switch (c_parser_peek_token (parser)->keyword)
4834         {
4835         case RID_SIZEOF:
4836           return c_parser_sizeof_expression (parser);
4837         case RID_ALIGNOF:
4838           return c_parser_alignof_expression (parser);
4839         case RID_EXTENSION:
4840           c_parser_consume_token (parser);
4841           ext = disable_extension_diagnostics ();
4842           ret = c_parser_cast_expression (parser, NULL);
4843           restore_extension_diagnostics (ext);
4844           return ret;
4845         case RID_REALPART:
4846           c_parser_consume_token (parser);
4847           op = c_parser_cast_expression (parser, NULL);
4848           op = default_function_array_conversion (op);
4849           return parser_build_unary_op (REALPART_EXPR, op);
4850         case RID_IMAGPART:
4851           c_parser_consume_token (parser);
4852           op = c_parser_cast_expression (parser, NULL);
4853           op = default_function_array_conversion (op);
4854           return parser_build_unary_op (IMAGPART_EXPR, op);
4855         default:
4856           return c_parser_postfix_expression (parser);
4857         }
4858     default:
4859       return c_parser_postfix_expression (parser);
4860     }
4861 }
4862
4863 /* Parse a sizeof expression.  */
4864
4865 static struct c_expr
4866 c_parser_sizeof_expression (c_parser *parser)
4867 {
4868   struct c_expr expr;
4869   gcc_assert (c_parser_next_token_is_keyword (parser, RID_SIZEOF));
4870   c_parser_consume_token (parser);
4871   skip_evaluation++;
4872   in_sizeof++;
4873   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN)
4874       && c_token_starts_typename (c_parser_peek_2nd_token (parser)))
4875     {
4876       /* Either sizeof ( type-name ) or sizeof unary-expression
4877          starting with a compound literal.  */
4878       struct c_type_name *type_name;
4879       c_parser_consume_token (parser);
4880       type_name = c_parser_type_name (parser);
4881       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
4882       if (type_name == NULL)
4883         {
4884           struct c_expr ret;
4885           skip_evaluation--;
4886           in_sizeof--;
4887           ret.value = error_mark_node;
4888           ret.original_code = ERROR_MARK;
4889           return ret;
4890         }
4891       if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
4892         {
4893           expr = c_parser_postfix_expression_after_paren_type (parser,
4894                                                                type_name);
4895           goto sizeof_expr;
4896         }
4897       /* sizeof ( type-name ).  */
4898       skip_evaluation--;
4899       in_sizeof--;
4900       if (type_name->declarator->kind == cdk_array
4901           && type_name->declarator->u.array.vla_unspec_p)
4902         {
4903           /* C99 6.7.5.2p4 */
4904           error ("%<[*]%> not allowed in other than a declaration");
4905         }
4906       return c_expr_sizeof_type (type_name);
4907     }
4908   else
4909     {
4910       expr = c_parser_unary_expression (parser);
4911     sizeof_expr:
4912       skip_evaluation--;
4913       in_sizeof--;
4914       if (TREE_CODE (expr.value) == COMPONENT_REF
4915           && DECL_C_BIT_FIELD (TREE_OPERAND (expr.value, 1)))
4916         error ("%<sizeof%> applied to a bit-field");
4917       return c_expr_sizeof_expr (expr);
4918     }
4919 }
4920
4921 /* Parse an alignof expression.  */
4922
4923 static struct c_expr
4924 c_parser_alignof_expression (c_parser *parser)
4925 {
4926   struct c_expr expr;
4927   gcc_assert (c_parser_next_token_is_keyword (parser, RID_ALIGNOF));
4928   c_parser_consume_token (parser);
4929   skip_evaluation++;
4930   in_alignof++;
4931   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN)
4932       && c_token_starts_typename (c_parser_peek_2nd_token (parser)))
4933     {
4934       /* Either __alignof__ ( type-name ) or __alignof__
4935          unary-expression starting with a compound literal.  */
4936       struct c_type_name *type_name;
4937       struct c_expr ret;
4938       c_parser_consume_token (parser);
4939       type_name = c_parser_type_name (parser);
4940       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
4941       if (type_name == NULL)
4942         {
4943           struct c_expr ret;
4944           skip_evaluation--;
4945           in_alignof--;
4946           ret.value = error_mark_node;
4947           ret.original_code = ERROR_MARK;
4948           return ret;
4949         }
4950       if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
4951         {
4952           expr = c_parser_postfix_expression_after_paren_type (parser,
4953                                                                type_name);
4954           goto alignof_expr;
4955         }
4956       /* alignof ( type-name ).  */
4957       skip_evaluation--;
4958       in_alignof--;
4959       ret.value = c_alignof (groktypename (type_name));
4960       ret.original_code = ERROR_MARK;
4961       return ret;
4962     }
4963   else
4964     {
4965       struct c_expr ret;
4966       expr = c_parser_unary_expression (parser);
4967     alignof_expr:
4968       skip_evaluation--;
4969       in_alignof--;
4970       ret.value = c_alignof_expr (expr.value);
4971       ret.original_code = ERROR_MARK;
4972       return ret;
4973     }
4974 }
4975
4976 /* Parse a postfix expression (C90 6.3.1-6.3.2, C99 6.5.1-6.5.2).
4977
4978    postfix-expression:
4979      primary-expression
4980      postfix-expression [ expression ]
4981      postfix-expression ( argument-expression-list[opt] )
4982      postfix-expression . identifier
4983      postfix-expression -> identifier
4984      postfix-expression ++
4985      postfix-expression --
4986      ( type-name ) { initializer-list }
4987      ( type-name ) { initializer-list , }
4988
4989    argument-expression-list:
4990      argument-expression
4991      argument-expression-list , argument-expression
4992
4993    primary-expression:
4994      identifier
4995      constant
4996      string-literal
4997      ( expression )
4998
4999    GNU extensions:
5000
5001    primary-expression:
5002      __func__
5003        (treated as a keyword in GNU C)
5004      __FUNCTION__
5005      __PRETTY_FUNCTION__
5006      ( compound-statement )
5007      __builtin_va_arg ( assignment-expression , type-name )
5008      __builtin_offsetof ( type-name , offsetof-member-designator )
5009      __builtin_choose_expr ( assignment-expression ,
5010                              assignment-expression ,
5011                              assignment-expression )
5012      __builtin_types_compatible_p ( type-name , type-name )
5013
5014    offsetof-member-designator:
5015      identifier
5016      offsetof-member-designator . identifier
5017      offsetof-member-designator [ expression ]
5018
5019    Objective-C:
5020
5021    primary-expression:
5022      [ objc-receiver objc-message-args ]
5023      @selector ( objc-selector-arg )
5024      @protocol ( identifier )
5025      @encode ( type-name )
5026      objc-string-literal
5027 */
5028
5029 static struct c_expr
5030 c_parser_postfix_expression (c_parser *parser)
5031 {
5032   struct c_expr expr, e1, e2, e3;
5033   struct c_type_name *t1, *t2;
5034   switch (c_parser_peek_token (parser)->type)
5035     {
5036     case CPP_NUMBER:
5037     case CPP_CHAR:
5038     case CPP_WCHAR:
5039       expr.value = c_parser_peek_token (parser)->value;
5040       expr.original_code = ERROR_MARK;
5041       c_parser_consume_token (parser);
5042       break;
5043     case CPP_STRING:
5044     case CPP_WSTRING:
5045       expr.value = c_parser_peek_token (parser)->value;
5046       expr.original_code = STRING_CST;
5047       c_parser_consume_token (parser);
5048       break;
5049     case CPP_OBJC_STRING:
5050       gcc_assert (c_dialect_objc ());
5051       expr.value
5052         = objc_build_string_object (c_parser_peek_token (parser)->value);
5053       expr.original_code = ERROR_MARK;
5054       c_parser_consume_token (parser);
5055       break;
5056     case CPP_NAME:
5057       if (c_parser_peek_token (parser)->id_kind != C_ID_ID)
5058         {
5059           c_parser_error (parser, "expected expression");
5060           expr.value = error_mark_node;
5061           expr.original_code = ERROR_MARK;
5062           break;
5063         }
5064       {
5065         tree id = c_parser_peek_token (parser)->value;
5066         location_t loc = c_parser_peek_token (parser)->location;
5067         c_parser_consume_token (parser);
5068         expr.value = build_external_ref (id,
5069                                          (c_parser_peek_token (parser)->type
5070                                           == CPP_OPEN_PAREN), loc);
5071         expr.original_code = ERROR_MARK;
5072       }
5073       break;
5074     case CPP_OPEN_PAREN:
5075       /* A parenthesized expression, statement expression or compound
5076          literal.  */
5077       if (c_parser_peek_2nd_token (parser)->type == CPP_OPEN_BRACE)
5078         {
5079           /* A statement expression.  */
5080           tree stmt;
5081           c_parser_consume_token (parser);
5082           c_parser_consume_token (parser);
5083           if (cur_stmt_list == NULL)
5084             {
5085               error ("braced-group within expression allowed "
5086                      "only inside a function");
5087               parser->error = true;
5088               c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL);
5089               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5090               expr.value = error_mark_node;
5091               expr.original_code = ERROR_MARK;
5092               break;
5093             }
5094           stmt = c_begin_stmt_expr ();
5095           c_parser_compound_statement_nostart (parser);
5096           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5097                                      "expected %<)%>");
5098           if (pedantic)
5099             pedwarn ("ISO C forbids braced-groups within expressions");
5100           expr.value = c_finish_stmt_expr (stmt);
5101           expr.original_code = ERROR_MARK;
5102         }
5103       else if (c_token_starts_typename (c_parser_peek_2nd_token (parser)))
5104         {
5105           /* A compound literal.  ??? Can we actually get here rather
5106              than going directly to
5107              c_parser_postfix_expression_after_paren_type from
5108              elsewhere?  */
5109           struct c_type_name *type_name;
5110           c_parser_consume_token (parser);
5111           type_name = c_parser_type_name (parser);
5112           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5113                                      "expected %<)%>");
5114           if (type_name == NULL)
5115             {
5116               expr.value = error_mark_node;
5117               expr.original_code = ERROR_MARK;
5118             }
5119           else
5120             expr = c_parser_postfix_expression_after_paren_type (parser,
5121                                                                  type_name);
5122         }
5123       else
5124         {
5125           /* A parenthesized expression.  */
5126           c_parser_consume_token (parser);
5127           expr = c_parser_expression (parser);
5128           if (TREE_CODE (expr.value) == MODIFY_EXPR)
5129             TREE_NO_WARNING (expr.value) = 1;
5130           expr.original_code = ERROR_MARK;
5131           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5132                                      "expected %<)%>");
5133         }
5134       break;
5135     case CPP_KEYWORD:
5136       switch (c_parser_peek_token (parser)->keyword)
5137         {
5138         case RID_FUNCTION_NAME:
5139         case RID_PRETTY_FUNCTION_NAME:
5140         case RID_C99_FUNCTION_NAME:
5141           expr.value = fname_decl (c_parser_peek_token (parser)->keyword,
5142                                    c_parser_peek_token (parser)->value);
5143           expr.original_code = ERROR_MARK;
5144           c_parser_consume_token (parser);
5145           break;
5146         case RID_VA_ARG:
5147           c_parser_consume_token (parser);
5148           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5149             {
5150               expr.value = error_mark_node;
5151               expr.original_code = ERROR_MARK;
5152               break;
5153             }
5154           e1 = c_parser_expr_no_commas (parser, NULL);
5155           if (!c_parser_require (parser, CPP_COMMA, "expected %<,%>"))
5156             {
5157               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5158               expr.value = error_mark_node;
5159               expr.original_code = ERROR_MARK;
5160               break;
5161             }
5162           t1 = c_parser_type_name (parser);
5163           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5164                                      "expected %<)%>");
5165           if (t1 == NULL)
5166             {
5167               expr.value = error_mark_node;
5168               expr.original_code = ERROR_MARK;
5169             }
5170           else
5171             {
5172               expr.value = build_va_arg (e1.value, groktypename (t1));
5173               expr.original_code = ERROR_MARK;
5174             }
5175           break;
5176         case RID_OFFSETOF:
5177           c_parser_consume_token (parser);
5178           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5179             {
5180               expr.value = error_mark_node;
5181               expr.original_code = ERROR_MARK;
5182               break;
5183             }
5184           t1 = c_parser_type_name (parser);
5185           if (t1 == NULL)
5186             {
5187               expr.value = error_mark_node;
5188               expr.original_code = ERROR_MARK;
5189               break;
5190             }
5191           if (!c_parser_require (parser, CPP_COMMA, "expected %<,%>"))
5192             {
5193               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5194               expr.value = error_mark_node;
5195               expr.original_code = ERROR_MARK;
5196               break;
5197             }
5198           {
5199             tree type = groktypename (t1);
5200             tree offsetof_ref;
5201             if (type == error_mark_node)
5202               offsetof_ref = error_mark_node;
5203             else
5204               offsetof_ref = build1 (INDIRECT_REF, type, NULL);
5205             /* Parse the second argument to __builtin_offsetof.  We
5206                must have one identifier, and beyond that we want to
5207                accept sub structure and sub array references.  */
5208             if (c_parser_next_token_is (parser, CPP_NAME))
5209               {
5210                 offsetof_ref = build_component_ref
5211                   (offsetof_ref, c_parser_peek_token (parser)->value);
5212                 c_parser_consume_token (parser);
5213                 while (c_parser_next_token_is (parser, CPP_DOT)
5214                        || c_parser_next_token_is (parser,
5215                                                   CPP_OPEN_SQUARE))
5216                   {
5217                     if (c_parser_next_token_is (parser, CPP_DOT))
5218                       {
5219                         c_parser_consume_token (parser);
5220                         if (c_parser_next_token_is_not (parser,
5221                                                         CPP_NAME))
5222                           {
5223                             c_parser_error (parser, "expected identifier");
5224                             break;
5225                           }
5226                         offsetof_ref = build_component_ref
5227                           (offsetof_ref,
5228                            c_parser_peek_token (parser)->value);
5229                         c_parser_consume_token (parser);
5230                       }
5231                     else
5232                       {
5233                         tree idx;
5234                         c_parser_consume_token (parser);
5235                         idx = c_parser_expression (parser).value;
5236                         c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
5237                                                    "expected %<]%>");
5238                         offsetof_ref = build_array_ref (offsetof_ref, idx);
5239                       }
5240                   }
5241               }
5242             else
5243               c_parser_error (parser, "expected identifier");
5244             c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5245                                        "expected %<)%>");
5246             expr.value = fold_offsetof (offsetof_ref);
5247             expr.original_code = ERROR_MARK;
5248           }
5249           break;
5250         case RID_CHOOSE_EXPR:
5251           c_parser_consume_token (parser);
5252           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5253             {
5254               expr.value = error_mark_node;
5255               expr.original_code = ERROR_MARK;
5256               break;
5257             }
5258           e1 = c_parser_expr_no_commas (parser, NULL);
5259           if (!c_parser_require (parser, CPP_COMMA, "expected %<,%>"))
5260             {
5261               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5262               expr.value = error_mark_node;
5263               expr.original_code = ERROR_MARK;
5264               break;
5265             }
5266           e2 = c_parser_expr_no_commas (parser, NULL);
5267           if (!c_parser_require (parser, CPP_COMMA, "expected %<,%>"))
5268             {
5269               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5270               expr.value = error_mark_node;
5271               expr.original_code = ERROR_MARK;
5272               break;
5273             }
5274           e3 = c_parser_expr_no_commas (parser, NULL);
5275           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5276                                      "expected %<)%>");
5277           {
5278             tree c;
5279
5280             c = fold (e1.value);
5281             if (TREE_CODE (c) != INTEGER_CST)
5282               error ("first argument to %<__builtin_choose_expr%> not"
5283                      " a constant");
5284             expr = integer_zerop (c) ? e3 : e2;
5285           }
5286           break;
5287         case RID_TYPES_COMPATIBLE_P:
5288           c_parser_consume_token (parser);
5289           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5290             {
5291               expr.value = error_mark_node;
5292               expr.original_code = ERROR_MARK;
5293               break;
5294             }
5295           t1 = c_parser_type_name (parser);
5296           if (t1 == NULL)
5297             {
5298               expr.value = error_mark_node;
5299               expr.original_code = ERROR_MARK;
5300               break;
5301             }
5302           if (!c_parser_require (parser, CPP_COMMA, "expected %<,%>"))
5303             {
5304               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5305               expr.value = error_mark_node;
5306               expr.original_code = ERROR_MARK;
5307               break;
5308             }
5309           t2 = c_parser_type_name (parser);
5310           if (t2 == NULL)
5311             {
5312               expr.value = error_mark_node;
5313               expr.original_code = ERROR_MARK;
5314               break;
5315             }
5316           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5317                                      "expected %<)%>");
5318           {
5319             tree e1, e2;
5320
5321             e1 = TYPE_MAIN_VARIANT (groktypename (t1));
5322             e2 = TYPE_MAIN_VARIANT (groktypename (t2));
5323
5324             expr.value = comptypes (e1, e2)
5325               ? build_int_cst (NULL_TREE, 1)
5326               : build_int_cst (NULL_TREE, 0);
5327             expr.original_code = ERROR_MARK;
5328           }
5329           break;
5330         case RID_AT_SELECTOR:
5331           gcc_assert (c_dialect_objc ());
5332           c_parser_consume_token (parser);
5333           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5334             {
5335               expr.value = error_mark_node;
5336               expr.original_code = ERROR_MARK;
5337               break;
5338             }
5339           {
5340             tree sel = c_parser_objc_selector_arg (parser);
5341             c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5342                                        "expected %<)%>");
5343             expr.value = objc_build_selector_expr (sel);
5344             expr.original_code = ERROR_MARK;
5345           }
5346           break;
5347         case RID_AT_PROTOCOL:
5348           gcc_assert (c_dialect_objc ());
5349           c_parser_consume_token (parser);
5350           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5351             {
5352               expr.value = error_mark_node;
5353               expr.original_code = ERROR_MARK;
5354               break;
5355             }
5356           if (c_parser_next_token_is_not (parser, CPP_NAME))
5357             {
5358               c_parser_error (parser, "expected identifier");
5359               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5360               expr.value = error_mark_node;
5361               expr.original_code = ERROR_MARK;
5362               break;
5363             }
5364           {
5365             tree id = c_parser_peek_token (parser)->value;
5366             c_parser_consume_token (parser);
5367             c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5368                                        "expected %<)%>");
5369             expr.value = objc_build_protocol_expr (id);
5370             expr.original_code = ERROR_MARK;
5371           }
5372           break;
5373         case RID_AT_ENCODE:
5374           /* Extension to support C-structures in the archiver.  */
5375           gcc_assert (c_dialect_objc ());
5376           c_parser_consume_token (parser);
5377           if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
5378             {
5379               expr.value = error_mark_node;
5380               expr.original_code = ERROR_MARK;
5381               break;
5382             }
5383           t1 = c_parser_type_name (parser);
5384           if (t1 == NULL)
5385             {
5386               expr.value = error_mark_node;
5387               expr.original_code = ERROR_MARK;
5388               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5389               break;
5390             }
5391           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5392                                      "expected %<)%>");
5393           {
5394             tree type = groktypename (t1);
5395             expr.value = objc_build_encode_expr (type);
5396             expr.original_code = ERROR_MARK;
5397           }
5398           break;
5399         default:
5400           c_parser_error (parser, "expected expression");
5401           expr.value = error_mark_node;
5402           expr.original_code = ERROR_MARK;
5403           break;
5404         }
5405       break;
5406     case CPP_OPEN_SQUARE:
5407       if (c_dialect_objc ())
5408         {
5409           tree receiver, args;
5410           c_parser_consume_token (parser);
5411           receiver = c_parser_objc_receiver (parser);
5412           args = c_parser_objc_message_args (parser);
5413           c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
5414                                      "expected %<]%>");
5415           expr.value = objc_build_message_expr (build_tree_list (receiver,
5416                                                                  args));
5417           expr.original_code = ERROR_MARK;
5418           break;
5419         }
5420       /* Else fall through to report error.  */
5421     default:
5422       c_parser_error (parser, "expected expression");
5423       expr.value = error_mark_node;
5424       expr.original_code = ERROR_MARK;
5425       break;
5426     }
5427   return c_parser_postfix_expression_after_primary (parser, expr);
5428 }
5429
5430 /* Parse a postfix expression after a parenthesized type name: the
5431    brace-enclosed initializer of a compound literal, possibly followed
5432    by some postfix operators.  This is separate because it is not
5433    possible to tell until after the type name whether a cast
5434    expression has a cast or a compound literal, or whether the operand
5435    of sizeof is a parenthesized type name or starts with a compound
5436    literal.  */
5437
5438 static struct c_expr
5439 c_parser_postfix_expression_after_paren_type (c_parser *parser,
5440                                               struct c_type_name *type_name)
5441 {
5442   tree type;
5443   struct c_expr init;
5444   struct c_expr expr;
5445   start_init (NULL_TREE, NULL, 0);
5446   type = groktypename (type_name);
5447   if (C_TYPE_VARIABLE_SIZE (type))
5448     {
5449       error ("compound literal has variable size");
5450       type = error_mark_node;
5451     }
5452   init = c_parser_braced_init (parser, type, false);
5453   finish_init ();
5454   maybe_warn_string_init (type, init);
5455
5456   if (pedantic && !flag_isoc99)
5457     pedwarn ("ISO C90 forbids compound literals");
5458   expr.value = build_compound_literal (type, init.value);
5459   expr.original_code = ERROR_MARK;
5460   return c_parser_postfix_expression_after_primary (parser, expr);
5461 }
5462
5463 /* Parse a postfix expression after the initial primary or compound
5464    literal; that is, parse a series of postfix operators.  */
5465
5466 static struct c_expr
5467 c_parser_postfix_expression_after_primary (c_parser *parser,
5468                                            struct c_expr expr)
5469 {
5470   tree ident, idx, exprlist;
5471   while (true)
5472     {
5473       switch (c_parser_peek_token (parser)->type)
5474         {
5475         case CPP_OPEN_SQUARE:
5476           /* Array reference.  */
5477           c_parser_consume_token (parser);
5478           idx = c_parser_expression (parser).value;
5479           c_parser_skip_until_found (parser, CPP_CLOSE_SQUARE,
5480                                      "expected %<]%>");
5481           expr.value = build_array_ref (expr.value, idx);
5482           expr.original_code = ERROR_MARK;
5483           break;
5484         case CPP_OPEN_PAREN:
5485           /* Function call.  */
5486           c_parser_consume_token (parser);
5487           if (c_parser_next_token_is (parser, CPP_CLOSE_PAREN))
5488             exprlist = NULL_TREE;
5489           else
5490             exprlist = c_parser_expr_list (parser, true);
5491           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
5492                                      "expected %<)%>");
5493           expr.value = build_function_call (expr.value, exprlist);
5494           expr.original_code = ERROR_MARK;
5495           break;
5496         case CPP_DOT:
5497           /* Structure element reference.  */
5498           c_parser_consume_token (parser);
5499           expr = default_function_array_conversion (expr);
5500           if (c_parser_next_token_is (parser, CPP_NAME))
5501             ident = c_parser_peek_token (parser)->value;
5502           else
5503             {
5504               c_parser_error (parser, "expected identifier");
5505               expr.value = error_mark_node;
5506               expr.original_code = ERROR_MARK;
5507               return expr;
5508             }
5509           c_parser_consume_token (parser);
5510           expr.value = build_component_ref (expr.value, ident);
5511           expr.original_code = ERROR_MARK;
5512           break;
5513         case CPP_DEREF:
5514           /* Structure element reference.  */
5515           c_parser_consume_token (parser);
5516           expr = default_function_array_conversion (expr);
5517           if (c_parser_next_token_is (parser, CPP_NAME))
5518             ident = c_parser_peek_token (parser)->value;
5519           else
5520             {
5521               c_parser_error (parser, "expected identifier");
5522               expr.value = error_mark_node;
5523               expr.original_code = ERROR_MARK;
5524               return expr;
5525             }
5526           c_parser_consume_token (parser);
5527           expr.value = build_component_ref (build_indirect_ref (expr.value,
5528                                                                 "->"), ident);
5529           expr.original_code = ERROR_MARK;
5530           break;
5531         case CPP_PLUS_PLUS:
5532           /* Postincrement.  */
5533           c_parser_consume_token (parser);
5534           expr = default_function_array_conversion (expr);
5535           expr.value = build_unary_op (POSTINCREMENT_EXPR, expr.value, 0);
5536           expr.original_code = ERROR_MARK;
5537           break;
5538         case CPP_MINUS_MINUS:
5539           /* Postdecrement.  */
5540           c_parser_consume_token (parser);
5541           expr = default_function_array_conversion (expr);
5542           expr.value = build_unary_op (POSTDECREMENT_EXPR, expr.value, 0);
5543           expr.original_code = ERROR_MARK;
5544           break;
5545         default:
5546           return expr;
5547         }
5548     }
5549 }
5550
5551 /* Parse an expression (C90 6.3.17, C99 6.5.17).
5552
5553    expression:
5554      assignment-expression
5555      expression , assignment-expression
5556 */
5557
5558 static struct c_expr
5559 c_parser_expression (c_parser *parser)
5560 {
5561   struct c_expr expr;
5562   expr = c_parser_expr_no_commas (parser, NULL);
5563   while (c_parser_next_token_is (parser, CPP_COMMA))
5564     {
5565       struct c_expr next;
5566       c_parser_consume_token (parser);
5567       next = c_parser_expr_no_commas (parser, NULL);
5568       next = default_function_array_conversion (next);
5569       expr.value = build_compound_expr (expr.value, next.value);
5570       expr.original_code = COMPOUND_EXPR;
5571     }
5572   return expr;
5573 }
5574
5575 /* Parse an expression and convert functions or arrays to
5576    pointers.  */
5577
5578 static struct c_expr
5579 c_parser_expression_conv (c_parser *parser)
5580 {
5581   struct c_expr expr;
5582   expr = c_parser_expression (parser);
5583   expr = default_function_array_conversion (expr);
5584   return expr;
5585 }
5586
5587 /* Parse a non-empty list of expressions.  If CONVERT_P, convert
5588    functions and arrays to pointers.
5589
5590    nonempty-expr-list:
5591      assignment-expression
5592      nonempty-expr-list , assignment-expression
5593 */
5594
5595 static tree
5596 c_parser_expr_list (c_parser *parser, bool convert_p)
5597 {
5598   struct c_expr expr;
5599   tree ret, cur;
5600   expr = c_parser_expr_no_commas (parser, NULL);
5601   if (convert_p)
5602     expr = default_function_array_conversion (expr);
5603   ret = cur = build_tree_list (NULL_TREE, expr.value);
5604   while (c_parser_next_token_is (parser, CPP_COMMA))
5605     {
5606       c_parser_consume_token (parser);
5607       expr = c_parser_expr_no_commas (parser, NULL);
5608       if (convert_p)
5609         expr = default_function_array_conversion (expr);
5610       cur = TREE_CHAIN (cur) = build_tree_list (NULL_TREE, expr.value);
5611     }
5612   return ret;
5613 }
5614
5615 \f
5616 /* Parse Objective-C-specific constructs.  */
5617
5618 /* Parse an objc-class-definition.
5619
5620    objc-class-definition:
5621      @interface identifier objc-superclass[opt] objc-protocol-refs[opt]
5622        objc-class-instance-variables[opt] objc-methodprotolist @end
5623      @implementation identifier objc-superclass[opt]
5624        objc-class-instance-variables[opt]
5625      @interface identifier ( identifier ) objc-protocol-refs[opt]
5626        objc-methodprotolist @end
5627      @implementation identifier ( identifier )
5628
5629    objc-superclass:
5630      : identifier
5631
5632    "@interface identifier (" must start "@interface identifier (
5633    identifier ) ...": objc-methodprotolist in the first production may
5634    not start with a parenthesized identifier as a declarator of a data
5635    definition with no declaration specifiers if the objc-superclass,
5636    objc-protocol-refs and objc-class-instance-variables are omitted.  */
5637
5638 static void
5639 c_parser_objc_class_definition (c_parser *parser)
5640 {
5641   bool iface_p;
5642   tree id1;
5643   tree superclass;
5644   if (c_parser_next_token_is_keyword (parser, RID_AT_INTERFACE))
5645     iface_p = true;
5646   else if (c_parser_next_token_is_keyword (parser, RID_AT_IMPLEMENTATION))
5647     iface_p = false;
5648   else
5649     gcc_unreachable ();
5650   c_parser_consume_token (parser);
5651   if (c_parser_next_token_is_not (parser, CPP_NAME))
5652     {
5653       c_parser_error (parser, "expected identifier");
5654       return;
5655     }
5656   id1 = c_parser_peek_token (parser)->value;
5657   c_parser_consume_token (parser);
5658   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
5659     {
5660       tree id2;
5661       tree proto = NULL_TREE;
5662       c_parser_consume_token (parser);
5663       if (c_parser_next_token_is_not (parser, CPP_NAME))
5664         {
5665           c_parser_error (parser, "expected identifier");
5666           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
5667           return;
5668         }
5669       id2 = c_parser_peek_token (parser)->value;
5670       c_parser_consume_token (parser);
5671       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
5672       if (!iface_p)
5673         {
5674           objc_start_category_implementation (id1, id2);
5675           return;
5676         }
5677       if (c_parser_next_token_is (parser, CPP_LESS))
5678         proto = c_parser_objc_protocol_refs (parser);
5679       objc_start_category_interface (id1, id2, proto);
5680       c_parser_objc_methodprotolist (parser);
5681       c_parser_require_keyword (parser, RID_AT_END, "expected %<@end%>");
5682       objc_finish_interface ();
5683       return;
5684     }
5685   if (c_parser_next_token_is (parser, CPP_COLON))
5686     {
5687       c_parser_consume_token (parser);
5688       if (c_parser_next_token_is_not (parser, CPP_NAME))
5689         {
5690           c_parser_error (parser, "expected identifier");
5691           return;
5692         }
5693       superclass = c_parser_peek_token (parser)->value;
5694       c_parser_consume_token (parser);
5695     }
5696   else
5697     superclass = NULL_TREE;
5698   if (iface_p)
5699     {
5700       tree proto = NULL_TREE;
5701       if (c_parser_next_token_is (parser, CPP_LESS))
5702         proto = c_parser_objc_protocol_refs (parser);
5703       objc_start_class_interface (id1, superclass, proto);
5704     }
5705   else
5706     objc_start_class_implementation (id1, superclass);
5707   if (c_parser_next_token_is (parser, CPP_OPEN_BRACE))
5708     c_parser_objc_class_instance_variables (parser);
5709   if (iface_p)
5710     {
5711       objc_continue_interface ();
5712       c_parser_objc_methodprotolist (parser);
5713       c_parser_require_keyword (parser, RID_AT_END, "expected %<@end%>");
5714       objc_finish_interface ();
5715     }
5716   else
5717     {
5718       objc_continue_implementation ();
5719       return;
5720     }
5721 }
5722
5723 /* Parse objc-class-instance-variables.
5724
5725    objc-class-instance-variables:
5726      { objc-instance-variable-decl-list[opt] }
5727
5728    objc-instance-variable-decl-list:
5729      objc-visibility-spec
5730      objc-instance-variable-decl ;
5731      ;
5732      objc-instance-variable-decl-list objc-visibility-spec
5733      objc-instance-variable-decl-list objc-instance-variable-decl ;
5734      objc-instance-variable-decl-list ;
5735
5736    objc-visibility-spec:
5737      @private
5738      @protected
5739      @public
5740
5741    objc-instance-variable-decl:
5742      struct-declaration
5743 */
5744
5745 static void
5746 c_parser_objc_class_instance_variables (c_parser *parser)
5747 {
5748   gcc_assert (c_parser_next_token_is (parser, CPP_OPEN_BRACE));
5749   c_parser_consume_token (parser);
5750   while (c_parser_next_token_is_not (parser, CPP_EOF))
5751     {
5752       tree decls;
5753       /* Parse any stray semicolon.  */
5754       if (c_parser_next_token_is (parser, CPP_SEMICOLON))
5755         {
5756           if (pedantic)
5757             pedwarn ("extra semicolon in struct or union specified");
5758           c_parser_consume_token (parser);
5759           continue;
5760         }
5761       /* Stop if at the end of the instance variables.  */
5762       if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
5763         {
5764           c_parser_consume_token (parser);
5765           break;
5766         }
5767       /* Parse any objc-visibility-spec.  */
5768       if (c_parser_next_token_is_keyword (parser, RID_AT_PRIVATE))
5769         {
5770           c_parser_consume_token (parser);
5771           objc_set_visibility (2);
5772           continue;
5773         }
5774       else if (c_parser_next_token_is_keyword (parser, RID_AT_PROTECTED))
5775         {
5776           c_parser_consume_token (parser);
5777           objc_set_visibility (0);
5778           continue;
5779         }
5780       else if (c_parser_next_token_is_keyword (parser, RID_AT_PUBLIC))
5781         {
5782           c_parser_consume_token (parser);
5783           objc_set_visibility (1);
5784           continue;
5785         }
5786       else if (c_parser_next_token_is (parser, CPP_PRAGMA))
5787         {
5788           c_parser_pragma (parser, pragma_external);
5789           continue;
5790         }
5791
5792       /* Parse some comma-separated declarations.  */
5793       decls = c_parser_struct_declaration (parser);
5794       {
5795         /* Comma-separated instance variables are chained together in
5796            reverse order; add them one by one.  */
5797         tree ivar = nreverse (decls);
5798         for (; ivar; ivar = TREE_CHAIN (ivar))
5799           objc_add_instance_variable (copy_node (ivar));
5800       }
5801       c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
5802     }
5803 }
5804
5805 /* Parse an objc-class-declaration.
5806
5807    objc-class-declaration:
5808      @class identifier-list ;
5809 */
5810
5811 static void
5812 c_parser_objc_class_declaration (c_parser *parser)
5813 {
5814   tree list = NULL_TREE;
5815   gcc_assert (c_parser_next_token_is_keyword (parser, RID_AT_CLASS));
5816   c_parser_consume_token (parser);
5817   /* Any identifiers, including those declared as type names, are OK
5818      here.  */
5819   while (true)
5820     {
5821       tree id;
5822       if (c_parser_next_token_is_not (parser, CPP_NAME))
5823         {
5824           c_parser_error (parser, "expected identifier");
5825           break;
5826         }
5827       id = c_parser_peek_token (parser)->value;
5828       list = chainon (list, build_tree_list (NULL_TREE, id));
5829       c_parser_consume_token (parser);
5830       if (c_parser_next_token_is (parser, CPP_COMMA))
5831         c_parser_consume_token (parser);
5832       else
5833         break;
5834     }
5835   c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
5836   objc_declare_class (list);
5837 }
5838
5839 /* Parse an objc-alias-declaration.
5840
5841    objc-alias-declaration:
5842      @compatibility_alias identifier identifier ;
5843 */
5844
5845 static void
5846 c_parser_objc_alias_declaration (c_parser *parser)
5847 {
5848   tree id1, id2;
5849   gcc_assert (c_parser_next_token_is_keyword (parser, RID_AT_ALIAS));
5850   c_parser_consume_token (parser);
5851   if (c_parser_next_token_is_not (parser, CPP_NAME))
5852     {
5853       c_parser_error (parser, "expected identifier");
5854       c_parser_skip_until_found (parser, CPP_SEMICOLON, NULL);
5855       return;
5856     }
5857   id1 = c_parser_peek_token (parser)->value;
5858   c_parser_consume_token (parser);
5859   if (c_parser_next_token_is_not (parser, CPP_NAME))
5860     {
5861       c_parser_error (parser, "expected identifier");
5862       c_parser_skip_until_found (parser, CPP_SEMICOLON, NULL);
5863       return;
5864     }
5865   id2 = c_parser_peek_token (parser)->value;
5866   c_parser_consume_token (parser);
5867   c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
5868   objc_declare_alias (id1, id2);
5869 }
5870
5871 /* Parse an objc-protocol-definition.
5872
5873    objc-protocol-definition:
5874      @protocol identifier objc-protocol-refs[opt] objc-methodprotolist @end
5875      @protocol identifier-list ;
5876
5877    "@protocol identifier ;" should be resolved as "@protocol
5878    identifier-list ;": objc-methodprotolist may not start with a
5879    semicolon in the first alternative if objc-protocol-refs are
5880    omitted.  */
5881
5882 static void
5883 c_parser_objc_protocol_definition (c_parser *parser)
5884 {
5885   gcc_assert (c_parser_next_token_is_keyword (parser, RID_AT_PROTOCOL));
5886   c_parser_consume_token (parser);
5887   if (c_parser_next_token_is_not (parser, CPP_NAME))
5888     {
5889       c_parser_error (parser, "expected identifier");
5890       return;
5891     }
5892   if (c_parser_peek_2nd_token (parser)->type == CPP_COMMA
5893       || c_parser_peek_2nd_token (parser)->type == CPP_SEMICOLON)
5894     {
5895       tree list = NULL_TREE;
5896       /* Any identifiers, including those declared as type names, are
5897          OK here.  */
5898       while (true)
5899         {
5900           tree id;
5901           if (c_parser_next_token_is_not (parser, CPP_NAME))
5902             {
5903               c_parser_error (parser, "expected identifier");
5904               break;
5905             }
5906           id = c_parser_peek_token (parser)->value;
5907           list = chainon (list, build_tree_list (NULL_TREE, id));
5908           c_parser_consume_token (parser);
5909           if (c_parser_next_token_is (parser, CPP_COMMA))
5910             c_parser_consume_token (parser);
5911           else
5912             break;
5913         }
5914       c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
5915       objc_declare_protocols (list);
5916     }
5917   else
5918     {
5919       tree id = c_parser_peek_token (parser)->value;
5920       tree proto = NULL_TREE;
5921       c_parser_consume_token (parser);
5922       if (c_parser_next_token_is (parser, CPP_LESS))
5923         proto = c_parser_objc_protocol_refs (parser);
5924       objc_pq_context = 1;
5925       objc_start_protocol (id, proto);
5926       c_parser_objc_methodprotolist (parser);
5927       c_parser_require_keyword (parser, RID_AT_END, "expected %<@end%>");
5928       objc_pq_context = 0;
5929       objc_finish_interface ();
5930     }
5931 }
5932
5933 /* Parse an objc-method-type.
5934
5935    objc-method-type:
5936      +
5937      -
5938 */
5939
5940 static enum tree_code
5941 c_parser_objc_method_type (c_parser *parser)
5942 {
5943   switch (c_parser_peek_token (parser)->type)
5944     {
5945     case CPP_PLUS:
5946       c_parser_consume_token (parser);
5947       return PLUS_EXPR;
5948     case CPP_MINUS:
5949       c_parser_consume_token (parser);
5950       return MINUS_EXPR;
5951     default:
5952       gcc_unreachable ();
5953     }
5954 }
5955
5956 /* Parse an objc-method-definition.
5957
5958    objc-method-definition:
5959      objc-method-type objc-method-decl ;[opt] compound-statement
5960 */
5961
5962 static void
5963 c_parser_objc_method_definition (c_parser *parser)
5964 {
5965   enum tree_code type = c_parser_objc_method_type (parser);
5966   tree decl;
5967   objc_set_method_type (type);
5968   objc_pq_context = 1;
5969   decl = c_parser_objc_method_decl (parser);
5970   if (c_parser_next_token_is (parser, CPP_SEMICOLON))
5971     {
5972       c_parser_consume_token (parser);
5973       if (pedantic)
5974         pedwarn ("extra semicolon in method definition specified");
5975     }
5976   if (!c_parser_next_token_is (parser, CPP_OPEN_BRACE))
5977     {
5978       c_parser_error (parser, "expected %<{%>");
5979       return;
5980     }
5981   objc_pq_context = 0;
5982   objc_start_method_definition (decl);
5983   add_stmt (c_parser_compound_statement (parser));
5984   objc_finish_method_definition (current_function_decl);
5985 }
5986
5987 /* Parse an objc-methodprotolist.
5988
5989    objc-methodprotolist:
5990      empty
5991      objc-methodprotolist objc-methodproto
5992      objc-methodprotolist declaration
5993      objc-methodprotolist ;
5994
5995    The declaration is a data definition, which may be missing
5996    declaration specifiers under the same rules and diagnostics as
5997    other data definitions outside functions, and the stray semicolon
5998    is diagnosed the same way as a stray semicolon outside a
5999    function.  */
6000
6001 static void
6002 c_parser_objc_methodprotolist (c_parser *parser)
6003 {
6004   while (true)
6005     {
6006       /* The list is terminated by @end.  */
6007       switch (c_parser_peek_token (parser)->type)
6008         {
6009         case CPP_SEMICOLON:
6010           if (pedantic)
6011             pedwarn ("ISO C does not allow extra %<;%> outside of a function");
6012           c_parser_consume_token (parser);
6013           break;
6014         case CPP_PLUS:
6015         case CPP_MINUS:
6016           c_parser_objc_methodproto (parser);
6017           break;
6018         case CPP_PRAGMA:
6019           c_parser_pragma (parser, pragma_external);
6020           break;
6021         case CPP_EOF:
6022           return;
6023         default:
6024           if (c_parser_next_token_is_keyword (parser, RID_AT_END))
6025             return;
6026           c_parser_declaration_or_fndef (parser, false, true, false, true);
6027           break;
6028         }
6029     }
6030 }
6031
6032 /* Parse an objc-methodproto.
6033
6034    objc-methodproto:
6035      objc-method-type objc-method-decl ;
6036 */
6037
6038 static void
6039 c_parser_objc_methodproto (c_parser *parser)
6040 {
6041   enum tree_code type = c_parser_objc_method_type (parser);
6042   tree decl;
6043   objc_set_method_type (type);
6044   /* Remember protocol qualifiers in prototypes.  */
6045   objc_pq_context = 1;
6046   decl = c_parser_objc_method_decl (parser);
6047   /* Forget protocol qualifiers here.  */
6048   objc_pq_context = 0;
6049   objc_add_method_declaration (decl);
6050   c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
6051 }
6052
6053 /* Parse an objc-method-decl.
6054
6055    objc-method-decl:
6056      ( objc-type-name ) objc-selector
6057      objc-selector
6058      ( objc-type-name ) objc-keyword-selector objc-optparmlist
6059      objc-keyword-selector objc-optparmlist
6060
6061    objc-keyword-selector:
6062      objc-keyword-decl
6063      objc-keyword-selector objc-keyword-decl
6064
6065    objc-keyword-decl:
6066      objc-selector : ( objc-type-name ) identifier
6067      objc-selector : identifier
6068      : ( objc-type-name ) identifier
6069      : identifier
6070
6071    objc-optparmlist:
6072      objc-optparms objc-optellipsis
6073
6074    objc-optparms:
6075      empty
6076      objc-opt-parms , parameter-declaration
6077
6078    objc-optellipsis:
6079      empty
6080      , ...
6081 */
6082
6083 static tree
6084 c_parser_objc_method_decl (c_parser *parser)
6085 {
6086   tree type = NULL_TREE;
6087   tree sel;
6088   tree parms = NULL_TREE;
6089   bool ellipsis = false;
6090
6091   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
6092     {
6093       c_parser_consume_token (parser);
6094       type = c_parser_objc_type_name (parser);
6095       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
6096     }
6097   sel = c_parser_objc_selector (parser);
6098   /* If there is no selector, or a colon follows, we have an
6099      objc-keyword-selector.  If there is a selector, and a colon does
6100      not follow, that selector ends the objc-method-decl.  */
6101   if (!sel || c_parser_next_token_is (parser, CPP_COLON))
6102     {
6103       tree tsel = sel;
6104       tree list = NULL_TREE;
6105       while (true)
6106         {
6107           tree atype = NULL_TREE, id, keyworddecl;
6108           if (!c_parser_require (parser, CPP_COLON, "expected %<:%>"))
6109             break;
6110           if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
6111             {
6112               c_parser_consume_token (parser);
6113               atype = c_parser_objc_type_name (parser);
6114               c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
6115                                          "expected %<)%>");
6116             }
6117           if (c_parser_next_token_is_not (parser, CPP_NAME))
6118             {
6119               c_parser_error (parser, "expected identifier");
6120               return error_mark_node;
6121             }
6122           id = c_parser_peek_token (parser)->value;
6123           c_parser_consume_token (parser);
6124           keyworddecl = objc_build_keyword_decl (tsel, atype, id);
6125           list = chainon (list, keyworddecl);
6126           tsel = c_parser_objc_selector (parser);
6127           if (!tsel && c_parser_next_token_is_not (parser, CPP_COLON))
6128             break;
6129         }
6130       /* Parse the optional parameter list.  Optional Objective-C
6131          method parameters follow the C syntax, and may include '...'
6132          to denote a variable number of arguments.  */
6133       parms = make_node (TREE_LIST);
6134       while (c_parser_next_token_is (parser, CPP_COMMA))
6135         {
6136           struct c_parm *parm;
6137           c_parser_consume_token (parser);
6138           if (c_parser_next_token_is (parser, CPP_ELLIPSIS))
6139             {
6140               ellipsis = true;
6141               c_parser_consume_token (parser);
6142               break;
6143             }
6144           parm = c_parser_parameter_declaration (parser, NULL_TREE);
6145           if (parm == NULL)
6146             break;
6147           parms = chainon (parms,
6148                            build_tree_list (NULL_TREE, grokparm (parm)));
6149         }
6150       sel = list;
6151     }
6152   return objc_build_method_signature (type, sel, parms, ellipsis);
6153 }
6154
6155 /* Parse an objc-type-name.
6156
6157    objc-type-name:
6158      objc-type-qualifiers[opt] type-name
6159      objc-type-qualifiers[opt]
6160
6161    objc-type-qualifiers:
6162      objc-type-qualifier
6163      objc-type-qualifiers objc-type-qualifier
6164
6165    objc-type-qualifier: one of
6166      in out inout bycopy byref oneway
6167 */
6168
6169 static tree
6170 c_parser_objc_type_name (c_parser *parser)
6171 {
6172   tree quals = NULL_TREE;
6173   struct c_type_name *typename = NULL;
6174   tree type = NULL_TREE;
6175   while (true)
6176     {
6177       c_token *token = c_parser_peek_token (parser);
6178       if (token->type == CPP_KEYWORD
6179           && (token->keyword == RID_IN
6180               || token->keyword == RID_OUT
6181               || token->keyword == RID_INOUT
6182               || token->keyword == RID_BYCOPY
6183               || token->keyword == RID_BYREF
6184               || token->keyword == RID_ONEWAY))
6185         {
6186           quals = chainon (quals, build_tree_list (NULL_TREE, token->value));
6187           c_parser_consume_token (parser);
6188         }
6189       else
6190         break;
6191     }
6192   if (c_parser_next_token_starts_typename (parser))
6193     typename = c_parser_type_name (parser);
6194   if (typename)
6195     type = groktypename (typename);
6196   return build_tree_list (quals, type);
6197 }
6198
6199 /* Parse objc-protocol-refs.
6200
6201    objc-protocol-refs:
6202      < identifier-list >
6203 */
6204
6205 static tree
6206 c_parser_objc_protocol_refs (c_parser *parser)
6207 {
6208   tree list = NULL_TREE;
6209   gcc_assert (c_parser_next_token_is (parser, CPP_LESS));
6210   c_parser_consume_token (parser);
6211   /* Any identifiers, including those declared as type names, are OK
6212      here.  */
6213   while (true)
6214     {
6215       tree id;
6216       if (c_parser_next_token_is_not (parser, CPP_NAME))
6217         {
6218           c_parser_error (parser, "expected identifier");
6219           break;
6220         }
6221       id = c_parser_peek_token (parser)->value;
6222       list = chainon (list, build_tree_list (NULL_TREE, id));
6223       c_parser_consume_token (parser);
6224       if (c_parser_next_token_is (parser, CPP_COMMA))
6225         c_parser_consume_token (parser);
6226       else
6227         break;
6228     }
6229   c_parser_require (parser, CPP_GREATER, "expected %<>%>");
6230   return list;
6231 }
6232
6233 /* Parse an objc-try-catch-statement.
6234
6235    objc-try-catch-statement:
6236      @try compound-statement objc-catch-list[opt]
6237      @try compound-statement objc-catch-list[opt] @finally compound-statement
6238
6239    objc-catch-list:
6240      @catch ( parameter-declaration ) compound-statement
6241      objc-catch-list @catch ( parameter-declaration ) compound-statement
6242 */
6243
6244 static void
6245 c_parser_objc_try_catch_statement (c_parser *parser)
6246 {
6247   location_t loc;
6248   tree stmt;
6249   gcc_assert (c_parser_next_token_is_keyword (parser, RID_AT_TRY));
6250   c_parser_consume_token (parser);
6251   loc = c_parser_peek_token (parser)->location;
6252   stmt = c_parser_compound_statement (parser);
6253   objc_begin_try_stmt (loc, stmt);
6254   while (c_parser_next_token_is_keyword (parser, RID_AT_CATCH))
6255     {
6256       struct c_parm *parm;
6257       c_parser_consume_token (parser);
6258       if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
6259         break;
6260       parm = c_parser_parameter_declaration (parser, NULL_TREE);
6261       if (parm == NULL)
6262         {
6263           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
6264           break;
6265         }
6266       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
6267       objc_begin_catch_clause (grokparm (parm));
6268       if (c_parser_require (parser, CPP_OPEN_BRACE, "expected %<{%>"))
6269         c_parser_compound_statement_nostart (parser);
6270       objc_finish_catch_clause ();
6271     }
6272   if (c_parser_next_token_is_keyword (parser, RID_AT_FINALLY))
6273     {
6274       location_t finloc;
6275       tree finstmt;
6276       c_parser_consume_token (parser);
6277       finloc = c_parser_peek_token (parser)->location;
6278       finstmt = c_parser_compound_statement (parser);
6279       objc_build_finally_clause (finloc, finstmt);
6280     }
6281   objc_finish_try_stmt ();
6282 }
6283
6284 /* Parse an objc-synchronized-statement.
6285
6286    objc-synchronized-statement:
6287      @synchronized ( expression ) compound-statement
6288 */
6289
6290 static void
6291 c_parser_objc_synchronized_statement (c_parser *parser)
6292 {
6293   location_t loc;
6294   tree expr, stmt;
6295   gcc_assert (c_parser_next_token_is_keyword (parser, RID_AT_SYNCHRONIZED));
6296   c_parser_consume_token (parser);
6297   loc = c_parser_peek_token (parser)->location;
6298   if (c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
6299     {
6300       expr = c_parser_expression (parser).value;
6301       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
6302     }
6303   else
6304     expr = error_mark_node;
6305   stmt = c_parser_compound_statement (parser);
6306   objc_build_synchronized (loc, expr, stmt);
6307 }
6308
6309 /* Parse an objc-selector; return NULL_TREE without an error if the
6310    next token is not an objc-selector.
6311
6312    objc-selector:
6313      identifier
6314      one of
6315        enum struct union if else while do for switch case default
6316        break continue return goto asm sizeof typeof __alignof
6317        unsigned long const short volatile signed restrict _Complex
6318        in out inout bycopy byref oneway int char float double void _Bool
6319
6320    ??? Why this selection of keywords but not, for example, storage
6321    class specifiers?  */
6322
6323 static tree
6324 c_parser_objc_selector (c_parser *parser)
6325 {
6326   c_token *token = c_parser_peek_token (parser);
6327   tree value = token->value;
6328   if (token->type == CPP_NAME)
6329     {
6330       c_parser_consume_token (parser);
6331       return value;
6332     }
6333   if (token->type != CPP_KEYWORD)
6334     return NULL_TREE;
6335   switch (token->keyword)
6336     {
6337     case RID_ENUM:
6338     case RID_STRUCT:
6339     case RID_UNION:
6340     case RID_IF:
6341     case RID_ELSE:
6342     case RID_WHILE:
6343     case RID_DO:
6344     case RID_FOR:
6345     case RID_SWITCH:
6346     case RID_CASE:
6347     case RID_DEFAULT:
6348     case RID_BREAK:
6349     case RID_CONTINUE:
6350     case RID_RETURN:
6351     case RID_GOTO:
6352     case RID_ASM:
6353     case RID_SIZEOF:
6354     case RID_TYPEOF:
6355     case RID_ALIGNOF:
6356     case RID_UNSIGNED:
6357     case RID_LONG:
6358     case RID_CONST:
6359     case RID_SHORT:
6360     case RID_VOLATILE:
6361     case RID_SIGNED:
6362     case RID_RESTRICT:
6363     case RID_COMPLEX:
6364     case RID_IN:
6365     case RID_OUT:
6366     case RID_INOUT:
6367     case RID_BYCOPY:
6368     case RID_BYREF:
6369     case RID_ONEWAY:
6370     case RID_INT:
6371     case RID_CHAR:
6372     case RID_FLOAT:
6373     case RID_DOUBLE:
6374     case RID_VOID:
6375     case RID_BOOL:
6376       c_parser_consume_token (parser);
6377       return value;
6378     default:
6379       return NULL_TREE;
6380     }
6381 }
6382
6383 /* Parse an objc-selector-arg.
6384
6385    objc-selector-arg:
6386      objc-selector
6387      objc-keywordname-list
6388
6389    objc-keywordname-list:
6390      objc-keywordname
6391      objc-keywordname-list objc-keywordname
6392
6393    objc-keywordname:
6394      objc-selector :
6395      :
6396 */
6397
6398 static tree
6399 c_parser_objc_selector_arg (c_parser *parser)
6400 {
6401   tree sel = c_parser_objc_selector (parser);
6402   tree list = NULL_TREE;
6403   if (sel && c_parser_next_token_is_not (parser, CPP_COLON))
6404     return sel;
6405   while (true)
6406     {
6407       if (!c_parser_require (parser, CPP_COLON, "expected %<:%>"))
6408         return list;
6409       list = chainon (list, build_tree_list (sel, NULL_TREE));
6410       sel = c_parser_objc_selector (parser);
6411       if (!sel && c_parser_next_token_is_not (parser, CPP_COLON))
6412         break;
6413     }
6414   return list;
6415 }
6416
6417 /* Parse an objc-receiver.
6418
6419    objc-receiver:
6420      expression
6421      class-name
6422      type-name
6423 */
6424
6425 static tree
6426 c_parser_objc_receiver (c_parser *parser)
6427 {
6428   if (c_parser_peek_token (parser)->type == CPP_NAME
6429       && (c_parser_peek_token (parser)->id_kind == C_ID_TYPENAME
6430           || c_parser_peek_token (parser)->id_kind == C_ID_CLASSNAME))
6431     {
6432       tree id = c_parser_peek_token (parser)->value;
6433       c_parser_consume_token (parser);
6434       return objc_get_class_reference (id);
6435     }
6436   return c_parser_expression (parser).value;
6437 }
6438
6439 /* Parse objc-message-args.
6440
6441    objc-message-args:
6442      objc-selector
6443      objc-keywordarg-list
6444
6445    objc-keywordarg-list:
6446      objc-keywordarg
6447      objc-keywordarg-list objc-keywordarg
6448
6449    objc-keywordarg:
6450      objc-selector : objc-keywordexpr
6451      : objc-keywordexpr
6452 */
6453
6454 static tree
6455 c_parser_objc_message_args (c_parser *parser)
6456 {
6457   tree sel = c_parser_objc_selector (parser);
6458   tree list = NULL_TREE;
6459   if (sel && c_parser_next_token_is_not (parser, CPP_COLON))
6460     return sel;
6461   while (true)
6462     {
6463       tree keywordexpr;
6464       if (!c_parser_require (parser, CPP_COLON, "expected %<:%>"))
6465         return list;
6466       keywordexpr = c_parser_objc_keywordexpr (parser);
6467       list = chainon (list, build_tree_list (sel, keywordexpr));
6468       sel = c_parser_objc_selector (parser);
6469       if (!sel && c_parser_next_token_is_not (parser, CPP_COLON))
6470         break;
6471     }
6472   return list;
6473 }
6474
6475 /* Parse an objc-keywordexpr.
6476
6477    objc-keywordexpr:
6478      nonempty-expr-list
6479 */
6480
6481 static tree
6482 c_parser_objc_keywordexpr (c_parser *parser)
6483 {
6484   tree list = c_parser_expr_list (parser, true);
6485   if (TREE_CHAIN (list) == NULL_TREE)
6486     {
6487       /* Just return the expression, remove a level of
6488          indirection.  */
6489       return TREE_VALUE (list);
6490     }
6491   else
6492     {
6493       /* We have a comma expression, we will collapse later.  */
6494       return list;
6495     }
6496 }
6497
6498 \f
6499 /* Handle pragmas.  Some OpenMP pragmas are associated with, and therefore
6500    should be considered, statements.  ALLOW_STMT is true if we're within
6501    the context of a function and such pragmas are to be allowed.  Returns
6502    true if we actually parsed such a pragma.  */
6503
6504 static bool
6505 c_parser_pragma (c_parser *parser, enum pragma_context context)
6506 {
6507   unsigned int id;
6508
6509   id = c_parser_peek_token (parser)->pragma_kind;
6510   gcc_assert (id != PRAGMA_NONE);
6511
6512   switch (id)
6513     {
6514     case PRAGMA_OMP_BARRIER:
6515       if (context != pragma_compound)
6516         {
6517           if (context == pragma_stmt)
6518             c_parser_error (parser, "%<#pragma omp barrier%> may only be "
6519                             "used in compound statements");
6520           goto bad_stmt;
6521         }
6522       c_parser_omp_barrier (parser);
6523       return false;
6524
6525     case PRAGMA_OMP_FLUSH:
6526       if (context != pragma_compound)
6527         {
6528           if (context == pragma_stmt)
6529             c_parser_error (parser, "%<#pragma omp flush%> may only be "
6530                             "used in compound statements");
6531           goto bad_stmt;
6532         }
6533       c_parser_omp_flush (parser);
6534       return false;
6535
6536     case PRAGMA_OMP_THREADPRIVATE:
6537       c_parser_omp_threadprivate (parser);
6538       return false;
6539
6540     case PRAGMA_OMP_SECTION:
6541       error ("%<#pragma omp section%> may only be used in "
6542              "%<#pragma omp sections%> construct");
6543       c_parser_skip_until_found (parser, CPP_PRAGMA_EOL, NULL);
6544       return false;
6545
6546     case PRAGMA_GCC_PCH_PREPROCESS:
6547       c_parser_error (parser, "%<#pragma GCC pch_preprocess%> must be first");
6548       c_parser_skip_until_found (parser, CPP_PRAGMA_EOL, NULL);
6549       return false;
6550
6551     default:
6552       if (id < PRAGMA_FIRST_EXTERNAL)
6553         {
6554           if (context == pragma_external)
6555             {
6556             bad_stmt:
6557               c_parser_error (parser, "expected declaration specifiers");
6558               c_parser_skip_until_found (parser, CPP_PRAGMA_EOL, NULL);
6559               return false;
6560             }
6561           c_parser_omp_construct (parser);
6562           return true;
6563         }
6564       break;
6565     }
6566
6567   c_parser_consume_pragma (parser);
6568   c_invoke_pragma_handler (id);
6569
6570   /* Skip to EOL, but suppress any error message.  Those will have been 
6571      generated by the handler routine through calling error, as opposed
6572      to calling c_parser_error.  */
6573   parser->error = true;
6574   c_parser_skip_to_pragma_eol (parser);
6575
6576   return false;
6577 }
6578
6579 /* The interface the pragma parsers have to the lexer.  */
6580
6581 enum cpp_ttype
6582 pragma_lex (tree *value)
6583 {
6584   c_token *tok = c_parser_peek_token (the_parser);
6585   enum cpp_ttype ret = tok->type;
6586
6587   *value = tok->value;
6588   if (ret == CPP_PRAGMA_EOL || ret == CPP_EOF)
6589     ret = CPP_EOF;
6590   else
6591     {
6592       if (ret == CPP_KEYWORD)
6593         ret = CPP_NAME;
6594       c_parser_consume_token (the_parser);
6595     }
6596
6597   return ret;
6598 }
6599
6600 static void
6601 c_parser_pragma_pch_preprocess (c_parser *parser)
6602 {
6603   tree name = NULL;
6604
6605   c_parser_consume_pragma (parser);
6606   if (c_parser_next_token_is (parser, CPP_STRING))
6607     {
6608       name = c_parser_peek_token (parser)->value;
6609       c_parser_consume_token (parser);
6610     }
6611   else
6612     c_parser_error (parser, "expected string literal");
6613   c_parser_skip_to_pragma_eol (parser);
6614
6615   if (name)
6616     c_common_pch_pragma (parse_in, TREE_STRING_POINTER (name));
6617 }
6618 \f
6619 /* OpenMP 2.5 parsing routines.  */
6620
6621 /* Returns name of the next clause.
6622    If the clause is not recognized PRAGMA_OMP_CLAUSE_NONE is returned and
6623    the token is not consumed.  Otherwise appropriate pragma_omp_clause is
6624    returned and the token is consumed.  */
6625
6626 static pragma_omp_clause
6627 c_parser_omp_clause_name (c_parser *parser)
6628 {
6629   pragma_omp_clause result = PRAGMA_OMP_CLAUSE_NONE;
6630
6631   if (c_parser_next_token_is_keyword (parser, RID_IF))
6632     result = PRAGMA_OMP_CLAUSE_IF;
6633   else if (c_parser_next_token_is_keyword (parser, RID_DEFAULT))
6634     result = PRAGMA_OMP_CLAUSE_DEFAULT;
6635   else if (c_parser_next_token_is (parser, CPP_NAME))
6636     {
6637       const char *p = IDENTIFIER_POINTER (c_parser_peek_token (parser)->value);
6638
6639       switch (p[0])
6640         {
6641         case 'c':
6642           if (!strcmp ("copyin", p))
6643             result = PRAGMA_OMP_CLAUSE_COPYIN;
6644           else if (!strcmp ("copyprivate", p))
6645             result = PRAGMA_OMP_CLAUSE_COPYPRIVATE;
6646           break;
6647         case 'f':
6648           if (!strcmp ("firstprivate", p))
6649             result = PRAGMA_OMP_CLAUSE_FIRSTPRIVATE;
6650           break;
6651         case 'l':
6652           if (!strcmp ("lastprivate", p))
6653             result = PRAGMA_OMP_CLAUSE_LASTPRIVATE;
6654           break;
6655         case 'n':
6656           if (!strcmp ("nowait", p))
6657             result = PRAGMA_OMP_CLAUSE_NOWAIT;
6658           else if (!strcmp ("num_threads", p))
6659             result = PRAGMA_OMP_CLAUSE_NUM_THREADS;
6660           break;
6661         case 'o':
6662           if (!strcmp ("ordered", p))
6663             result = PRAGMA_OMP_CLAUSE_ORDERED;
6664           break;
6665         case 'p':
6666           if (!strcmp ("private", p))
6667             result = PRAGMA_OMP_CLAUSE_PRIVATE;
6668           break;
6669         case 'r':
6670           if (!strcmp ("reduction", p))
6671             result = PRAGMA_OMP_CLAUSE_REDUCTION;
6672           break;
6673         case 's':
6674           if (!strcmp ("schedule", p))
6675             result = PRAGMA_OMP_CLAUSE_SCHEDULE;
6676           else if (!strcmp ("shared", p))
6677             result = PRAGMA_OMP_CLAUSE_SHARED;
6678           break;
6679         }
6680     }
6681
6682   if (result != PRAGMA_OMP_CLAUSE_NONE)
6683     c_parser_consume_token (parser);
6684
6685   return result;
6686 }
6687
6688 /* Validate that a clause of the given type does not already exist.  */
6689
6690 static void
6691 check_no_duplicate_clause (tree clauses, enum tree_code code, const char *name)
6692 {
6693   tree c;
6694
6695   for (c = clauses; c ; c = OMP_CLAUSE_CHAIN (c))
6696     if (OMP_CLAUSE_CODE (c) == code)
6697       {
6698         error ("too many %qs clauses", name);
6699         break;
6700       }
6701 }
6702
6703 /* OpenMP 2.5:
6704    variable-list:
6705      identifier
6706      variable-list , identifier
6707
6708    If KIND is nonzero, create the appropriate node and install the decl
6709    in OMP_CLAUSE_DECL and add the node to the head of the list.
6710
6711    If KIND is zero, create a TREE_LIST with the decl in TREE_PURPOSE;
6712    return the list created.  */
6713
6714 static tree
6715 c_parser_omp_variable_list (c_parser *parser, enum omp_clause_code kind,
6716                             tree list)
6717 {
6718   if (c_parser_next_token_is_not (parser, CPP_NAME)
6719       || c_parser_peek_token (parser)->id_kind != C_ID_ID)
6720     c_parser_error (parser, "expected identifier");
6721
6722   while (c_parser_next_token_is (parser, CPP_NAME)
6723          && c_parser_peek_token (parser)->id_kind == C_ID_ID)
6724     {
6725       tree t = lookup_name (c_parser_peek_token (parser)->value);
6726
6727       if (t == NULL_TREE)
6728         undeclared_variable (c_parser_peek_token (parser)->value,
6729                              c_parser_peek_token (parser)->location);
6730       else if (t == error_mark_node)
6731         ;
6732       else if (kind != 0)
6733         {
6734           tree u = build_omp_clause (kind);
6735           OMP_CLAUSE_DECL (u) = t;
6736           OMP_CLAUSE_CHAIN (u) = list;
6737           list = u;
6738         }
6739       else
6740         list = tree_cons (t, NULL_TREE, list);
6741
6742       c_parser_consume_token (parser);
6743
6744       if (c_parser_next_token_is_not (parser, CPP_COMMA))
6745         break;
6746
6747       c_parser_consume_token (parser);
6748     }
6749
6750   return list;
6751 }
6752
6753 /* Similarly, but expect leading and trailing parenthesis.  This is a very
6754    common case for omp clauses.  */
6755
6756 static tree
6757 c_parser_omp_var_list_parens (c_parser *parser, enum tree_code kind, tree list)
6758 {
6759   if (c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
6760     {
6761       list = c_parser_omp_variable_list (parser, kind, list);
6762       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
6763     }
6764   return list;
6765 }
6766
6767 /* OpenMP 2.5:
6768    copyin ( variable-list ) */
6769
6770 static tree
6771 c_parser_omp_clause_copyin (c_parser *parser, tree list)
6772 {
6773   return c_parser_omp_var_list_parens (parser, OMP_CLAUSE_COPYIN, list);
6774 }
6775
6776 /* OpenMP 2.5:
6777    copyprivate ( variable-list ) */
6778
6779 static tree
6780 c_parser_omp_clause_copyprivate (c_parser *parser, tree list)
6781 {
6782   return c_parser_omp_var_list_parens (parser, OMP_CLAUSE_COPYPRIVATE, list);
6783 }
6784
6785 /* OpenMP 2.5:
6786    default ( shared | none ) */
6787
6788 static tree
6789 c_parser_omp_clause_default (c_parser *parser, tree list)
6790 {
6791   enum omp_clause_default_kind kind = OMP_CLAUSE_DEFAULT_UNSPECIFIED;
6792   tree c;
6793
6794   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
6795     return list;
6796   if (c_parser_next_token_is (parser, CPP_NAME))
6797     {
6798       const char *p = IDENTIFIER_POINTER (c_parser_peek_token (parser)->value);
6799
6800       switch (p[0])
6801         {
6802         case 'n':
6803           if (strcmp ("none", p) != 0)
6804             goto invalid_kind;
6805           kind = OMP_CLAUSE_DEFAULT_NONE;
6806           break;
6807
6808         case 's':
6809           if (strcmp ("shared", p) != 0)
6810             goto invalid_kind;
6811           kind = OMP_CLAUSE_DEFAULT_SHARED;
6812           break;
6813
6814         default:
6815           goto invalid_kind;
6816         }
6817
6818       c_parser_consume_token (parser);
6819     }
6820   else
6821     {
6822     invalid_kind:
6823       c_parser_error (parser, "expected %<none%> or %<shared%>");
6824     }
6825   c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
6826
6827   if (kind == OMP_CLAUSE_DEFAULT_UNSPECIFIED)
6828     return list;
6829
6830   check_no_duplicate_clause (list, OMP_CLAUSE_DEFAULT, "default");
6831   c = build_omp_clause (OMP_CLAUSE_DEFAULT);
6832   OMP_CLAUSE_CHAIN (c) = list;
6833   OMP_CLAUSE_DEFAULT_KIND (c) = kind;
6834
6835   return c;
6836 }
6837
6838 /* OpenMP 2.5:
6839    firstprivate ( variable-list ) */
6840
6841 static tree
6842 c_parser_omp_clause_firstprivate (c_parser *parser, tree list)
6843 {
6844   return c_parser_omp_var_list_parens (parser, OMP_CLAUSE_FIRSTPRIVATE, list);
6845 }
6846
6847 /* OpenMP 2.5:
6848    if ( expression ) */
6849
6850 static tree
6851 c_parser_omp_clause_if (c_parser *parser, tree list)
6852 {
6853   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
6854     {
6855       tree t = c_parser_paren_condition (parser);
6856       tree c;
6857
6858       check_no_duplicate_clause (list, OMP_CLAUSE_IF, "if");
6859
6860       c = build_omp_clause (OMP_CLAUSE_IF);
6861       OMP_CLAUSE_IF_EXPR (c) = t;
6862       OMP_CLAUSE_CHAIN (c) = list;
6863       list = c;
6864     }
6865   else
6866     c_parser_error (parser, "expected %<(%>");
6867
6868   return list;
6869 }
6870
6871 /* OpenMP 2.5:
6872    lastprivate ( variable-list ) */
6873
6874 static tree
6875 c_parser_omp_clause_lastprivate (c_parser *parser, tree list)
6876 {
6877   return c_parser_omp_var_list_parens (parser, OMP_CLAUSE_LASTPRIVATE, list);
6878 }
6879
6880 /* OpenMP 2.5:
6881    nowait */
6882
6883 static tree
6884 c_parser_omp_clause_nowait (c_parser *parser ATTRIBUTE_UNUSED, tree list)
6885 {
6886   tree c;
6887
6888   check_no_duplicate_clause (list, OMP_CLAUSE_NOWAIT, "nowait");
6889
6890   c = build_omp_clause (OMP_CLAUSE_NOWAIT);
6891   OMP_CLAUSE_CHAIN (c) = list;
6892   return c;
6893 }
6894
6895 /* OpenMP 2.5:
6896    num_threads ( expression ) */
6897
6898 static tree
6899 c_parser_omp_clause_num_threads (c_parser *parser, tree list)
6900 {
6901   if (c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
6902     {
6903       tree c, t = c_parser_expression (parser).value;
6904
6905       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
6906
6907       if (!INTEGRAL_TYPE_P (TREE_TYPE (t)))
6908         {
6909           c_parser_error (parser, "expected integer expression");
6910           return list;
6911         }
6912
6913       /* Attempt to statically determine when the number isn't positive.  */
6914       c = fold_build2 (LE_EXPR, boolean_type_node, t,
6915                        build_int_cst (TREE_TYPE (t), 0));
6916       if (c == boolean_true_node)
6917         {
6918           warning (0, "%<num_threads%> value must be positive");
6919           t = integer_one_node;
6920         }
6921
6922       check_no_duplicate_clause (list, OMP_CLAUSE_NUM_THREADS, "num_threads");
6923
6924       c = build_omp_clause (OMP_CLAUSE_NUM_THREADS);
6925       OMP_CLAUSE_NUM_THREADS_EXPR (c) = t;
6926       OMP_CLAUSE_CHAIN (c) = list;
6927       list = c;
6928     }
6929
6930   return list;
6931 }
6932
6933 /* OpenMP 2.5:
6934    ordered */
6935
6936 static tree
6937 c_parser_omp_clause_ordered (c_parser *parser ATTRIBUTE_UNUSED, tree list)
6938 {
6939   tree c;
6940
6941   check_no_duplicate_clause (list, OMP_CLAUSE_ORDERED, "ordered");
6942
6943   c = build_omp_clause (OMP_CLAUSE_ORDERED);
6944   OMP_CLAUSE_CHAIN (c) = list;
6945   return c;
6946 }
6947
6948 /* OpenMP 2.5:
6949    private ( variable-list ) */
6950
6951 static tree
6952 c_parser_omp_clause_private (c_parser *parser, tree list)
6953 {
6954   return c_parser_omp_var_list_parens (parser, OMP_CLAUSE_PRIVATE, list);
6955 }
6956
6957 /* OpenMP 2.5:
6958    reduction ( reduction-operator : variable-list )
6959
6960    reduction-operator:
6961      One of: + * - & ^ | && || */
6962
6963 static tree
6964 c_parser_omp_clause_reduction (c_parser *parser, tree list)
6965 {
6966   if (c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
6967     {
6968       enum tree_code code;
6969
6970       switch (c_parser_peek_token (parser)->type)
6971         {
6972         case CPP_PLUS:
6973           code = PLUS_EXPR;
6974           break;
6975         case CPP_MULT:
6976           code = MULT_EXPR;
6977           break;
6978         case CPP_MINUS:
6979           code = MINUS_EXPR;
6980           break;
6981         case CPP_AND:
6982           code = BIT_AND_EXPR;
6983           break;
6984         case CPP_XOR:
6985           code = BIT_XOR_EXPR;
6986           break;
6987         case CPP_OR:
6988           code = BIT_IOR_EXPR;
6989           break;
6990         case CPP_AND_AND:
6991           code = TRUTH_ANDIF_EXPR;
6992           break;
6993         case CPP_OR_OR:
6994           code = TRUTH_ORIF_EXPR;
6995           break;
6996         default:
6997           c_parser_error (parser,
6998                           "expected %<+%>, %<*%>, %<-%>, %<&%>, "
6999                           "%<^%>, %<|%>, %<&&%>, or %<||%>");
7000           c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, 0);
7001           return list;
7002         }
7003       c_parser_consume_token (parser);
7004       if (c_parser_require (parser, CPP_COLON, "expected %<:%>"))
7005         {
7006           tree nl, c;
7007
7008           nl = c_parser_omp_variable_list (parser, OMP_CLAUSE_REDUCTION, list);
7009           for (c = nl; c != list; c = OMP_CLAUSE_CHAIN (c))
7010             OMP_CLAUSE_REDUCTION_CODE (c) = code;
7011
7012           list = nl;
7013         }
7014       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
7015     }
7016   return list;
7017 }
7018
7019 /* OpenMP 2.5:
7020    schedule ( schedule-kind )
7021    schedule ( schedule-kind , expression )
7022
7023    schedule-kind:
7024      static | dynamic | guided | runtime
7025 */
7026
7027 static tree
7028 c_parser_omp_clause_schedule (c_parser *parser, tree list)
7029 {
7030   tree c, t;
7031
7032   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
7033     return list;
7034
7035   c = build_omp_clause (OMP_CLAUSE_SCHEDULE);
7036
7037   if (c_parser_next_token_is (parser, CPP_NAME))
7038     {
7039       tree kind = c_parser_peek_token (parser)->value;
7040       const char *p = IDENTIFIER_POINTER (kind);
7041
7042       switch (p[0])
7043         {
7044         case 'd':
7045           if (strcmp ("dynamic", p) != 0)
7046             goto invalid_kind;
7047           OMP_CLAUSE_SCHEDULE_KIND (c) = OMP_CLAUSE_SCHEDULE_DYNAMIC;
7048           break;
7049
7050         case 'g':
7051           if (strcmp ("guided", p) != 0)
7052             goto invalid_kind;
7053           OMP_CLAUSE_SCHEDULE_KIND (c) = OMP_CLAUSE_SCHEDULE_GUIDED;
7054           break;
7055
7056         case 'r':
7057           if (strcmp ("runtime", p) != 0)
7058             goto invalid_kind;
7059           OMP_CLAUSE_SCHEDULE_KIND (c) = OMP_CLAUSE_SCHEDULE_RUNTIME;
7060           break;
7061
7062         default:
7063           goto invalid_kind;
7064         }
7065     }
7066   else if (c_parser_next_token_is_keyword (parser, RID_STATIC))
7067     OMP_CLAUSE_SCHEDULE_KIND (c) = OMP_CLAUSE_SCHEDULE_STATIC;
7068   else
7069     goto invalid_kind;
7070
7071   c_parser_consume_token (parser);
7072   if (c_parser_next_token_is (parser, CPP_COMMA))
7073     {
7074       c_parser_consume_token (parser);
7075
7076       t = c_parser_expr_no_commas (parser, NULL).value;
7077
7078       if (OMP_CLAUSE_SCHEDULE_KIND (c) == OMP_CLAUSE_SCHEDULE_RUNTIME)
7079         error ("schedule %<runtime%> does not take "
7080                "a %<chunk_size%> parameter");
7081       else if (TREE_CODE (TREE_TYPE (t)) == INTEGER_TYPE)
7082         OMP_CLAUSE_SCHEDULE_CHUNK_EXPR (c) = t;
7083       else
7084         c_parser_error (parser, "expected integer expression");
7085
7086       c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
7087     }
7088   else
7089     c_parser_skip_until_found (parser, CPP_CLOSE_PAREN,
7090                                "expected %<,%> or %<)%>");
7091
7092   check_no_duplicate_clause (list, OMP_CLAUSE_SCHEDULE, "schedule");
7093   OMP_CLAUSE_CHAIN (c) = list;
7094   return c;
7095
7096  invalid_kind:
7097   c_parser_error (parser, "invalid schedule kind");
7098   c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, 0);
7099   return list;
7100 }
7101
7102 /* OpenMP 2.5:
7103    shared ( variable-list ) */
7104
7105 static tree
7106 c_parser_omp_clause_shared (c_parser *parser, tree list)
7107 {
7108   return c_parser_omp_var_list_parens (parser, OMP_CLAUSE_SHARED, list);
7109 }
7110
7111 /* Parse all OpenMP clauses.  The set clauses allowed by the directive
7112    is a bitmask in MASK.  Return the list of clauses found; the result
7113    of clause default goes in *pdefault.  */
7114
7115 static tree
7116 c_parser_omp_all_clauses (c_parser *parser, unsigned int mask,
7117                           const char *where)
7118 {
7119   tree clauses = NULL;
7120
7121   while (c_parser_next_token_is_not (parser, CPP_PRAGMA_EOL))
7122     {
7123       const pragma_omp_clause c_kind = c_parser_omp_clause_name (parser);
7124       const char *c_name;
7125       tree prev = clauses;
7126
7127       switch (c_kind)
7128         {
7129         case PRAGMA_OMP_CLAUSE_COPYIN:
7130           clauses = c_parser_omp_clause_copyin (parser, clauses);
7131           c_name = "copyin";
7132           break;
7133         case PRAGMA_OMP_CLAUSE_COPYPRIVATE:
7134           clauses = c_parser_omp_clause_copyprivate (parser, clauses);
7135           c_name = "copyprivate";
7136           break;
7137         case PRAGMA_OMP_CLAUSE_DEFAULT:
7138           clauses = c_parser_omp_clause_default (parser, clauses);
7139           c_name = "default";
7140           break;
7141         case PRAGMA_OMP_CLAUSE_FIRSTPRIVATE:
7142           clauses = c_parser_omp_clause_firstprivate (parser, clauses);
7143           c_name = "firstprivate";
7144           break;
7145         case PRAGMA_OMP_CLAUSE_IF:
7146           clauses = c_parser_omp_clause_if (parser, clauses);
7147           c_name = "if";
7148           break;
7149         case PRAGMA_OMP_CLAUSE_LASTPRIVATE:
7150           clauses = c_parser_omp_clause_lastprivate (parser, clauses);
7151           c_name = "lastprivate";
7152           break;
7153         case PRAGMA_OMP_CLAUSE_NOWAIT:
7154           clauses = c_parser_omp_clause_nowait (parser, clauses);
7155           c_name = "nowait";
7156           break;
7157         case PRAGMA_OMP_CLAUSE_NUM_THREADS:
7158           clauses = c_parser_omp_clause_num_threads (parser, clauses);
7159           c_name = "num_threads";
7160           break;
7161         case PRAGMA_OMP_CLAUSE_ORDERED:
7162           clauses = c_parser_omp_clause_ordered (parser, clauses);
7163           c_name = "ordered";
7164           break;
7165         case PRAGMA_OMP_CLAUSE_PRIVATE:
7166           clauses = c_parser_omp_clause_private (parser, clauses);
7167           c_name = "private";
7168           break;
7169         case PRAGMA_OMP_CLAUSE_REDUCTION:
7170           clauses = c_parser_omp_clause_reduction (parser, clauses);
7171           c_name = "reduction";
7172           break;
7173         case PRAGMA_OMP_CLAUSE_SCHEDULE:
7174           clauses = c_parser_omp_clause_schedule (parser, clauses);
7175           c_name = "schedule";
7176           break;
7177         case PRAGMA_OMP_CLAUSE_SHARED:
7178           clauses = c_parser_omp_clause_shared (parser, clauses);
7179           c_name = "shared";
7180           break;
7181         default:
7182           c_parser_error (parser, "expected %<#pragma omp%> clause");
7183           goto saw_error;
7184         }
7185
7186       if (((mask >> c_kind) & 1) == 0 && !parser->error)
7187         {
7188           /* Remove the invalid clause(s) from the list to avoid
7189              confusing the rest of the compiler.  */
7190           clauses = prev;
7191           error ("%qs is not valid for %qs", c_name, where);
7192         }
7193     }
7194
7195  saw_error:
7196   c_parser_skip_to_pragma_eol (parser);
7197
7198   return c_finish_omp_clauses (clauses);
7199 }
7200
7201 /* OpenMP 2.5:
7202    structured-block:
7203      statement
7204
7205    In practice, we're also interested in adding the statement to an
7206    outer node.  So it is convenient if we work around the fact that
7207    c_parser_statement calls add_stmt.  */
7208
7209 static tree
7210 c_parser_omp_structured_block (c_parser *parser)
7211 {
7212   tree stmt = push_stmt_list ();
7213   c_parser_statement (parser);
7214   return pop_stmt_list (stmt);
7215 }
7216
7217 /* OpenMP 2.5:
7218    # pragma omp atomic new-line
7219      expression-stmt
7220
7221    expression-stmt:
7222      x binop= expr | x++ | ++x | x-- | --x
7223    binop:
7224      +, *, -, /, &, ^, |, <<, >>
7225
7226   where x is an lvalue expression with scalar type.  */
7227
7228 static void
7229 c_parser_omp_atomic (c_parser *parser)
7230 {
7231   tree lhs, rhs;
7232   tree stmt;
7233   enum tree_code code;
7234
7235   c_parser_skip_to_pragma_eol (parser);
7236
7237   lhs = c_parser_unary_expression (parser).value;
7238   switch (TREE_CODE (lhs))
7239     {
7240     case ERROR_MARK:
7241     saw_error:
7242       c_parser_skip_to_end_of_block_or_statement (parser);
7243       return;
7244
7245     case PREINCREMENT_EXPR:
7246     case POSTINCREMENT_EXPR:
7247       lhs = TREE_OPERAND (lhs, 0);
7248       code = PLUS_EXPR;
7249       rhs = integer_one_node;
7250       break;
7251
7252     case PREDECREMENT_EXPR:
7253     case POSTDECREMENT_EXPR:
7254       lhs = TREE_OPERAND (lhs, 0);
7255       code = MINUS_EXPR;
7256       rhs = integer_one_node;
7257       break;
7258
7259     default:
7260       switch (c_parser_peek_token (parser)->type)
7261         {
7262         case CPP_MULT_EQ:
7263           code = MULT_EXPR;
7264           break;
7265         case CPP_DIV_EQ:
7266           code = TRUNC_DIV_EXPR;
7267           break;
7268         case CPP_PLUS_EQ:
7269           code = PLUS_EXPR;
7270           break;
7271         case CPP_MINUS_EQ:
7272           code = MINUS_EXPR;
7273           break;
7274         case CPP_LSHIFT_EQ:
7275           code = LSHIFT_EXPR;
7276           break;
7277         case CPP_RSHIFT_EQ:
7278           code = RSHIFT_EXPR;
7279           break;
7280         case CPP_AND_EQ:
7281           code = BIT_AND_EXPR;
7282           break;
7283         case CPP_OR_EQ:
7284           code = BIT_IOR_EXPR;
7285           break;
7286         case CPP_XOR_EQ:
7287           code = BIT_XOR_EXPR;
7288           break;
7289         default:
7290           c_parser_error (parser,
7291                           "invalid operator for %<#pragma omp atomic%>");
7292           goto saw_error;
7293         }
7294
7295       c_parser_consume_token (parser);
7296       rhs = c_parser_expression (parser).value;
7297       break;
7298     }
7299   stmt = c_finish_omp_atomic (code, lhs, rhs);
7300   if (stmt != error_mark_node)
7301     add_stmt (stmt);
7302   c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
7303 }
7304
7305
7306 /* OpenMP 2.5:
7307    # pragma omp barrier new-line
7308 */
7309
7310 static void
7311 c_parser_omp_barrier (c_parser *parser)
7312 {
7313   c_parser_consume_pragma (parser);
7314   c_parser_skip_to_pragma_eol (parser);
7315
7316   c_finish_omp_barrier ();
7317 }
7318
7319 /* OpenMP 2.5:
7320    # pragma omp critical [(name)] new-line
7321      structured-block
7322 */
7323
7324 static tree
7325 c_parser_omp_critical (c_parser *parser)
7326 {
7327   tree stmt, name = NULL;
7328
7329   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
7330     {
7331       c_parser_consume_token (parser);
7332       if (c_parser_next_token_is (parser, CPP_NAME))
7333         {
7334           name = c_parser_peek_token (parser)->value;
7335           c_parser_consume_token (parser);
7336           c_parser_require (parser, CPP_CLOSE_PAREN, "expected %<)%>");
7337         }
7338       else
7339         c_parser_error (parser, "expected identifier");
7340     }
7341   else if (c_parser_next_token_is_not (parser, CPP_PRAGMA_EOL))
7342     c_parser_error (parser, "expected %<(%> or end of line");
7343   c_parser_skip_to_pragma_eol (parser);
7344
7345   stmt = c_parser_omp_structured_block (parser);
7346   return c_finish_omp_critical (stmt, name);
7347 }
7348
7349 /* OpenMP 2.5:
7350    # pragma omp flush flush-vars[opt] new-line
7351
7352    flush-vars:
7353      ( variable-list ) */
7354
7355 static void
7356 c_parser_omp_flush (c_parser *parser)
7357 {
7358   c_parser_consume_pragma (parser);
7359   if (c_parser_next_token_is (parser, CPP_OPEN_PAREN))
7360     c_parser_omp_var_list_parens (parser, 0, NULL);
7361   else if (c_parser_next_token_is_not (parser, CPP_PRAGMA_EOL))
7362     c_parser_error (parser, "expected %<(%> or end of line");
7363   c_parser_skip_to_pragma_eol (parser);
7364
7365   c_finish_omp_flush ();
7366 }
7367
7368 /* Parse the restricted form of the for statment allowed by OpenMP.
7369    The real trick here is to determine the loop control variable early
7370    so that we can push a new decl if necessary to make it private.  */
7371
7372 static tree
7373 c_parser_omp_for_loop (c_parser *parser)
7374 {
7375   tree decl, cond, incr, save_break, save_cont, body, init;
7376   location_t loc;
7377
7378   if (!c_parser_next_token_is_keyword (parser, RID_FOR))
7379     {
7380       c_parser_error (parser, "for statement expected");
7381       return NULL;
7382     }
7383   loc = c_parser_peek_token (parser)->location;
7384   c_parser_consume_token (parser);
7385
7386   if (!c_parser_require (parser, CPP_OPEN_PAREN, "expected %<(%>"))
7387     return NULL;
7388
7389   /* Parse the initialization declaration or expression.  */
7390   if (c_parser_next_token_starts_declspecs (parser))
7391     {
7392       c_parser_declaration_or_fndef (parser, true, true, true, true);
7393       decl = check_for_loop_decls ();
7394       if (decl == NULL)
7395         goto error_init;
7396       init = decl;
7397     }
7398   else if (c_parser_next_token_is (parser, CPP_NAME)
7399            && c_parser_peek_2nd_token (parser)->type == CPP_EQ)
7400     {
7401       decl = c_parser_postfix_expression (parser).value;
7402
7403       c_parser_require (parser, CPP_EQ, "expected %<=%>");
7404
7405       init = c_parser_expr_no_commas (parser, NULL).value;
7406       init = build_modify_expr (decl, NOP_EXPR, init);
7407       init = c_process_expr_stmt (init);
7408
7409       c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
7410     }
7411   else
7412     goto error_init;
7413
7414   /* Parse the loop condition.  */
7415   cond = NULL_TREE;
7416   if (c_parser_next_token_is_not (parser, CPP_SEMICOLON))
7417     {
7418       cond = c_parser_expression_conv (parser).value;
7419       cond = c_objc_common_truthvalue_conversion (cond);
7420       if (EXPR_P (cond))
7421         SET_EXPR_LOCATION (cond, input_location);
7422     }
7423   c_parser_skip_until_found (parser, CPP_SEMICOLON, "expected %<;%>");
7424
7425   /* Parse the increment expression.  */
7426   incr = NULL_TREE;
7427   if (c_parser_next_token_is_not (parser, CPP_CLOSE_PAREN))
7428     incr = c_process_expr_stmt (c_parser_expression (parser).value);
7429   c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
7430
7431  parse_body:
7432   save_break = c_break_label;
7433   c_break_label = size_one_node;
7434   save_cont = c_cont_label;
7435   c_cont_label = NULL_TREE;
7436   body = push_stmt_list ();
7437
7438   add_stmt (c_parser_c99_block_statement (parser));
7439   if (c_cont_label)
7440     add_stmt (build1 (LABEL_EXPR, void_type_node, c_cont_label));
7441
7442   body = pop_stmt_list (body);
7443   c_break_label = save_break;
7444   c_cont_label = save_cont;
7445
7446   /* Only bother calling c_finish_omp_for if we havn't already generated
7447      an error from the initialization parsing.  */
7448   if (decl != NULL && decl != error_mark_node && init != error_mark_node)
7449     return c_finish_omp_for (loc, decl, init, cond, incr, body, NULL);
7450   return NULL;
7451
7452  error_init:
7453   c_parser_error (parser, "expected iteration declaration or initialization");
7454   c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, "expected %<)%>");
7455   decl = init = cond = incr = NULL_TREE;
7456   goto parse_body;
7457 }
7458
7459 /* OpenMP 2.5:
7460    #pragma omp for for-clause[optseq] new-line
7461      for-loop
7462 */
7463
7464 #define OMP_FOR_CLAUSE_MASK                             \
7465         ( (1u << PRAGMA_OMP_CLAUSE_PRIVATE)             \
7466         | (1u << PRAGMA_OMP_CLAUSE_FIRSTPRIVATE)        \
7467         | (1u << PRAGMA_OMP_CLAUSE_LASTPRIVATE)         \
7468         | (1u << PRAGMA_OMP_CLAUSE_REDUCTION)           \
7469         | (1u << PRAGMA_OMP_CLAUSE_ORDERED)             \
7470         | (1u << PRAGMA_OMP_CLAUSE_SCHEDULE)            \
7471         | (1u << PRAGMA_OMP_CLAUSE_NOWAIT))
7472
7473 static tree
7474 c_parser_omp_for (c_parser *parser)
7475 {
7476   tree block, clauses, ret;
7477
7478   clauses = c_parser_omp_all_clauses (parser, OMP_FOR_CLAUSE_MASK,
7479                                       "#pragma omp for");
7480
7481   block = c_begin_compound_stmt (true);
7482   ret = c_parser_omp_for_loop (parser);
7483   if (ret)
7484     OMP_FOR_CLAUSES (ret) = clauses;
7485   block = c_end_compound_stmt (block, true);
7486   add_stmt (block);
7487
7488   return ret;
7489 }
7490
7491 /* OpenMP 2.5:
7492    # pragma omp master new-line
7493      structured-block
7494 */
7495
7496 static tree
7497 c_parser_omp_master (c_parser *parser)
7498 {
7499   c_parser_skip_to_pragma_eol (parser);
7500   return c_finish_omp_master (c_parser_omp_structured_block (parser));
7501 }
7502
7503 /* OpenMP 2.5:
7504    # pragma omp ordered new-line
7505      structured-block
7506 */
7507
7508 static tree
7509 c_parser_omp_ordered (c_parser *parser)
7510 {
7511   c_parser_skip_to_pragma_eol (parser);
7512   return c_finish_omp_ordered (c_parser_omp_structured_block (parser));
7513 }
7514
7515 /* OpenMP 2.5:
7516
7517    section-scope:
7518      { section-sequence }
7519
7520    section-sequence:
7521      section-directive[opt] structured-block
7522      section-sequence section-directive structured-block  */
7523
7524 static tree
7525 c_parser_omp_sections_scope (c_parser *parser)
7526 {
7527   tree stmt, substmt;
7528   bool error_suppress = false;
7529   location_t loc;
7530
7531   if (!c_parser_require (parser, CPP_OPEN_BRACE, "expected %<{%>"))
7532     {
7533       /* Avoid skipping until the end of the block.  */
7534       parser->error = false;
7535       return NULL_TREE;
7536     }
7537
7538   stmt = push_stmt_list ();
7539
7540   loc = c_parser_peek_token (parser)->location;
7541   if (c_parser_peek_token (parser)->pragma_kind != PRAGMA_OMP_SECTION)
7542     {
7543       substmt = push_stmt_list ();
7544
7545       while (1)
7546         {
7547           c_parser_statement (parser);
7548
7549           if (c_parser_peek_token (parser)->pragma_kind == PRAGMA_OMP_SECTION)
7550             break;
7551           if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
7552             break;
7553           if (c_parser_next_token_is (parser, CPP_EOF))
7554             break;
7555         }
7556
7557       substmt = pop_stmt_list (substmt);
7558       substmt = build1 (OMP_SECTION, void_type_node, substmt);
7559       SET_EXPR_LOCATION (substmt, loc);
7560       add_stmt (substmt);
7561     }
7562
7563   while (1)
7564     {
7565       if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE))
7566         break;
7567       if (c_parser_next_token_is (parser, CPP_EOF))
7568         break;
7569
7570       loc = c_parser_peek_token (parser)->location;
7571       if (c_parser_peek_token (parser)->pragma_kind == PRAGMA_OMP_SECTION)
7572         {
7573           c_parser_consume_pragma (parser);
7574           c_parser_skip_to_pragma_eol (parser);
7575           error_suppress = false;
7576         }
7577       else if (!error_suppress)
7578         {
7579           error ("expected %<#pragma omp section%> or %<}%>");
7580           error_suppress = true;
7581         }
7582
7583       substmt = c_parser_omp_structured_block (parser);
7584       substmt = build1 (OMP_SECTION, void_type_node, substmt);
7585       SET_EXPR_LOCATION (substmt, loc);
7586       add_stmt (substmt);
7587     }
7588   c_parser_skip_until_found (parser, CPP_CLOSE_BRACE,
7589                              "expected %<#pragma omp section%> or %<}%>");
7590
7591   substmt = pop_stmt_list (stmt);
7592
7593   stmt = make_node (OMP_SECTIONS);
7594   TREE_TYPE (stmt) = void_type_node;
7595   OMP_SECTIONS_BODY (stmt) = substmt;
7596
7597   return add_stmt (stmt);
7598 }
7599
7600 /* OpenMP 2.5:
7601    # pragma omp sections sections-clause[optseq] newline
7602      sections-scope
7603 */
7604
7605 #define OMP_SECTIONS_CLAUSE_MASK                        \
7606         ( (1u << PRAGMA_OMP_CLAUSE_PRIVATE)             \
7607         | (1u << PRAGMA_OMP_CLAUSE_FIRSTPRIVATE)        \
7608         | (1u << PRAGMA_OMP_CLAUSE_LASTPRIVATE)         \
7609         | (1u << PRAGMA_OMP_CLAUSE_REDUCTION)           \
7610         | (1u << PRAGMA_OMP_CLAUSE_NOWAIT))
7611
7612 static tree
7613 c_parser_omp_sections (c_parser *parser)
7614 {
7615   tree block, clauses, ret;
7616
7617   clauses = c_parser_omp_all_clauses (parser, OMP_SECTIONS_CLAUSE_MASK,
7618                                       "#pragma omp sections");
7619
7620   block = c_begin_compound_stmt (true);
7621   ret = c_parser_omp_sections_scope (parser);
7622   if (ret)
7623     OMP_SECTIONS_CLAUSES (ret) = clauses;
7624   block = c_end_compound_stmt (block, true);
7625   add_stmt (block);
7626
7627   return ret;
7628 }
7629
7630 /* OpenMP 2.5:
7631    # pragma parallel parallel-clause new-line
7632    # pragma parallel for parallel-for-clause new-line
7633    # pragma parallel sections parallel-sections-clause new-line
7634 */
7635
7636 #define OMP_PARALLEL_CLAUSE_MASK                        \
7637         ( (1u << PRAGMA_OMP_CLAUSE_IF)                  \
7638         | (1u << PRAGMA_OMP_CLAUSE_PRIVATE)             \
7639         | (1u << PRAGMA_OMP_CLAUSE_FIRSTPRIVATE)        \
7640         | (1u << PRAGMA_OMP_CLAUSE_DEFAULT)             \
7641         | (1u << PRAGMA_OMP_CLAUSE_SHARED)              \
7642         | (1u << PRAGMA_OMP_CLAUSE_COPYIN)              \
7643         | (1u << PRAGMA_OMP_CLAUSE_REDUCTION)           \
7644         | (1u << PRAGMA_OMP_CLAUSE_NUM_THREADS))
7645
7646 static tree
7647 c_parser_omp_parallel (c_parser *parser)
7648 {
7649   enum pragma_kind p_kind = PRAGMA_OMP_PARALLEL;
7650   const char *p_name = "#pragma omp parallel";
7651   tree stmt, clauses, par_clause, ws_clause, block;
7652   unsigned int mask = OMP_PARALLEL_CLAUSE_MASK;
7653
7654   if (c_parser_next_token_is_keyword (parser, RID_FOR))
7655     {
7656       c_parser_consume_token (parser);
7657       p_kind = PRAGMA_OMP_PARALLEL_FOR;
7658       p_name = "#pragma omp parallel for";
7659       mask |= OMP_FOR_CLAUSE_MASK;
7660       mask &= ~(1u << PRAGMA_OMP_CLAUSE_NOWAIT);
7661     }
7662   else if (c_parser_next_token_is (parser, CPP_NAME))
7663     {
7664       const char *p = IDENTIFIER_POINTER (c_parser_peek_token (parser)->value);
7665       if (strcmp (p, "sections") == 0)
7666         {
7667           c_parser_consume_token (parser);
7668           p_kind = PRAGMA_OMP_PARALLEL_SECTIONS;
7669           p_name = "#pragma omp parallel sections";
7670           mask |= OMP_SECTIONS_CLAUSE_MASK;
7671           mask &= ~(1u << PRAGMA_OMP_CLAUSE_NOWAIT);
7672         }
7673     }
7674
7675   clauses = c_parser_omp_all_clauses (parser, mask, p_name);
7676
7677   switch (p_kind)
7678     {
7679     case PRAGMA_OMP_PARALLEL:
7680       block = c_begin_omp_parallel ();
7681       c_parser_statement (parser);
7682       stmt = c_finish_omp_parallel (clauses, block);
7683       break;
7684
7685     case PRAGMA_OMP_PARALLEL_FOR:
7686       block = c_begin_omp_parallel ();
7687       c_split_parallel_clauses (clauses, &par_clause, &ws_clause);
7688       stmt = c_parser_omp_for_loop (parser);
7689       if (stmt)
7690         OMP_FOR_CLAUSES (stmt) = ws_clause;
7691       stmt = c_finish_omp_parallel (par_clause, block);
7692       OMP_PARALLEL_COMBINED (stmt) = 1;
7693       break;
7694
7695     case PRAGMA_OMP_PARALLEL_SECTIONS:
7696       block = c_begin_omp_parallel ();
7697       c_split_parallel_clauses (clauses, &par_clause, &ws_clause);
7698       stmt = c_parser_omp_sections_scope (parser);
7699       if (stmt)
7700         OMP_SECTIONS_CLAUSES (stmt) = ws_clause;
7701       stmt = c_finish_omp_parallel (par_clause, block);
7702       OMP_PARALLEL_COMBINED (stmt) = 1;
7703       break;
7704
7705     default:
7706       gcc_unreachable ();
7707     }
7708
7709   return stmt;
7710 }
7711
7712 /* OpenMP 2.5:
7713    # pragma omp single single-clause[optseq] new-line
7714      structured-block
7715 */
7716
7717 #define OMP_SINGLE_CLAUSE_MASK                          \
7718         ( (1u << PRAGMA_OMP_CLAUSE_PRIVATE)             \
7719         | (1u << PRAGMA_OMP_CLAUSE_FIRSTPRIVATE)        \
7720         | (1u << PRAGMA_OMP_CLAUSE_COPYPRIVATE)         \
7721         | (1u << PRAGMA_OMP_CLAUSE_NOWAIT))
7722
7723 static tree
7724 c_parser_omp_single (c_parser *parser)
7725 {
7726   tree stmt = make_node (OMP_SINGLE);
7727   TREE_TYPE (stmt) = void_type_node;
7728
7729   OMP_SINGLE_CLAUSES (stmt)
7730     = c_parser_omp_all_clauses (parser, OMP_SINGLE_CLAUSE_MASK,
7731                                 "#pragma omp single");
7732   OMP_SINGLE_BODY (stmt) = c_parser_omp_structured_block (parser);
7733
7734   return add_stmt (stmt);
7735 }
7736
7737
7738 /* Main entry point to parsing most OpenMP pragmas.  */
7739
7740 static void
7741 c_parser_omp_construct (c_parser *parser)
7742 {
7743   enum pragma_kind p_kind;
7744   location_t loc;
7745   tree stmt;
7746
7747   loc = c_parser_peek_token (parser)->location;
7748   p_kind = c_parser_peek_token (parser)->pragma_kind;
7749   c_parser_consume_pragma (parser);
7750
7751   switch (p_kind)
7752     {
7753     case PRAGMA_OMP_ATOMIC:
7754       c_parser_omp_atomic (parser);
7755       return;
7756     case PRAGMA_OMP_CRITICAL:
7757       stmt = c_parser_omp_critical (parser);
7758       break;
7759     case PRAGMA_OMP_FOR:
7760       stmt = c_parser_omp_for (parser);
7761       break;
7762     case PRAGMA_OMP_MASTER:
7763       stmt = c_parser_omp_master (parser);
7764       break;
7765     case PRAGMA_OMP_ORDERED:
7766       stmt = c_parser_omp_ordered (parser);
7767       break;
7768     case PRAGMA_OMP_PARALLEL:
7769       stmt = c_parser_omp_parallel (parser);
7770       break;
7771     case PRAGMA_OMP_SECTIONS:
7772       stmt = c_parser_omp_sections (parser);
7773       break;
7774     case PRAGMA_OMP_SINGLE:
7775       stmt = c_parser_omp_single (parser);
7776       break;
7777     default:
7778       gcc_unreachable ();
7779     }
7780
7781   if (stmt)
7782     SET_EXPR_LOCATION (stmt, loc);
7783 }
7784
7785
7786 /* OpenMP 2.5:
7787    # pragma omp threadprivate (variable-list) */
7788
7789 static void
7790 c_parser_omp_threadprivate (c_parser *parser)
7791 {
7792   tree vars, t;
7793
7794   c_parser_consume_pragma (parser);
7795   vars = c_parser_omp_var_list_parens (parser, 0, NULL);
7796
7797   if (!targetm.have_tls)
7798     sorry ("threadprivate variables not supported in this target");
7799
7800   /* Mark every variable in VARS to be assigned thread local storage.  */
7801   for (t = vars; t; t = TREE_CHAIN (t))
7802     {
7803       tree v = TREE_PURPOSE (t);
7804
7805       /* If V had already been marked threadprivate, it doesn't matter
7806          whether it had been used prior to this point.  */
7807       if (TREE_USED (v) && !C_DECL_THREADPRIVATE_P (v))
7808         error ("%qE declared %<threadprivate%> after first use", v);
7809       else if (! TREE_STATIC (v) && ! DECL_EXTERNAL (v))
7810         error ("automatic variable %qE cannot be %<threadprivate%>", v);
7811       else if (! COMPLETE_TYPE_P (TREE_TYPE (v)))
7812         error ("%<threadprivate%> %qE has incomplete type", v);
7813       else
7814         {
7815           if (! DECL_THREAD_LOCAL_P (v))
7816             {
7817               DECL_TLS_MODEL (v) = decl_default_tls_model (v);
7818               /* If rtl has been already set for this var, call
7819                  make_decl_rtl once again, so that encode_section_info
7820                  has a chance to look at the new decl flags.  */
7821               if (DECL_RTL_SET_P (v))
7822                 make_decl_rtl (v);
7823             }
7824           C_DECL_THREADPRIVATE_P (v) = 1;
7825         }
7826     }
7827
7828   c_parser_skip_to_pragma_eol (parser);
7829 }
7830
7831 \f
7832 /* Parse a single source file.  */
7833
7834 void
7835 c_parse_file (void)
7836 {
7837   /* Use local storage to begin.  If the first token is a pragma, parse it.
7838      If it is #pragma GCC pch_preprocess, then this will load a PCH file
7839      which will cause garbage collection.  */
7840   c_parser tparser;
7841
7842   memset (&tparser, 0, sizeof tparser);
7843   the_parser = &tparser;
7844
7845   if (c_parser_peek_token (&tparser)->pragma_kind == PRAGMA_GCC_PCH_PREPROCESS)
7846     c_parser_pragma_pch_preprocess (&tparser);
7847
7848   the_parser = GGC_NEW (c_parser);
7849   *the_parser = tparser;
7850
7851   c_parser_translation_unit (the_parser);
7852   the_parser = NULL;
7853 }
7854
7855 #include "gt-c-parser.h"