Fix type.
[official-gcc.git] / gcc / cppinit.c
blob82b3056b704974c2a838dff0c7234c70e36cc0df
1 /* CPP Library.
2 Copyright (C) 1986, 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
4 Contributed by Per Bothner, 1994-95.
5 Based on CCCP program by Paul Rubin, June 1986
6 Adapted to ANSI C, Richard Stallman, Jan 1987
8 This program is free software; you can redistribute it and/or modify it
9 under the terms of the GNU General Public License as published by the
10 Free Software Foundation; either version 2, or (at your option) any
11 later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
22 #include "config.h"
23 #include "system.h"
24 #include "cpplib.h"
25 #include "cpphash.h"
26 #include "prefix.h"
27 #include "intl.h"
28 #include "mkdeps.h"
29 #include "cppdefault.h"
31 /* Windows does not natively support inodes, and neither does MSDOS.
32 Cygwin's emulation can generate non-unique inodes, so don't use it.
33 VMS has non-numeric inodes. */
34 #ifdef VMS
35 # define INO_T_EQ(A, B) (!memcmp (&(A), &(B), sizeof (A)))
36 # define INO_T_COPY(DEST, SRC) memcpy(&(DEST), &(SRC), sizeof (SRC))
37 #else
38 # if (defined _WIN32 && ! defined (_UWIN)) || defined __MSDOS__
39 # define INO_T_EQ(A, B) 0
40 # else
41 # define INO_T_EQ(A, B) ((A) == (B))
42 # endif
43 # define INO_T_COPY(DEST, SRC) (DEST) = (SRC)
44 #endif
46 /* Internal structures and prototypes. */
48 /* A `struct pending_option' remembers one -D, -A, -U, -include, or
49 -imacros switch. */
50 typedef void (* cl_directive_handler) PARAMS ((cpp_reader *, const char *));
51 struct pending_option
53 struct pending_option *next;
54 const char *arg;
55 cl_directive_handler handler;
58 /* The `pending' structure accumulates all the options that are not
59 actually processed until we hit cpp_read_main_file. It consists of
60 several lists, one for each type of option. We keep both head and
61 tail pointers for quick insertion. */
62 struct cpp_pending
64 struct pending_option *directive_head, *directive_tail;
66 struct search_path *quote_head, *quote_tail;
67 struct search_path *brack_head, *brack_tail;
68 struct search_path *systm_head, *systm_tail;
69 struct search_path *after_head, *after_tail;
71 struct pending_option *imacros_head, *imacros_tail;
72 struct pending_option *include_head, *include_tail;
75 #ifdef __STDC__
76 #define APPEND(pend, list, elt) \
77 do { if (!(pend)->list##_head) (pend)->list##_head = (elt); \
78 else (pend)->list##_tail->next = (elt); \
79 (pend)->list##_tail = (elt); \
80 } while (0)
81 #else
82 #define APPEND(pend, list, elt) \
83 do { if (!(pend)->list/**/_head) (pend)->list/**/_head = (elt); \
84 else (pend)->list/**/_tail->next = (elt); \
85 (pend)->list/**/_tail = (elt); \
86 } while (0)
87 #endif
89 static void path_include PARAMS ((cpp_reader *,
90 char *, int));
91 static void init_library PARAMS ((void));
92 static void init_builtins PARAMS ((cpp_reader *));
93 static void mark_named_operators PARAMS ((cpp_reader *));
94 static void append_include_chain PARAMS ((cpp_reader *,
95 char *, int, int));
96 static struct search_path * remove_dup_dir PARAMS ((cpp_reader *,
97 struct search_path *,
98 struct search_path **));
99 static struct search_path * remove_dup_nonsys_dirs PARAMS ((cpp_reader *,
100 struct search_path **,
101 struct search_path *));
102 static struct search_path * remove_dup_dirs PARAMS ((cpp_reader *,
103 struct search_path **));
104 static void merge_include_chains PARAMS ((cpp_reader *));
105 static bool push_include PARAMS ((cpp_reader *,
106 struct pending_option *));
107 static void free_chain PARAMS ((struct pending_option *));
108 static void init_standard_includes PARAMS ((cpp_reader *));
109 static void read_original_filename PARAMS ((cpp_reader *));
110 static void new_pending_directive PARAMS ((struct cpp_pending *,
111 const char *,
112 cl_directive_handler));
113 static int parse_option PARAMS ((const char *));
114 static void post_options PARAMS ((cpp_reader *));
116 /* Fourth argument to append_include_chain: chain to use.
117 Note it's never asked to append to the quote chain. */
118 enum { BRACKET = 0, SYSTEM, AFTER };
120 /* If we have designated initializers (GCC >2.7) these tables can be
121 initialized, constant data. Otherwise, they have to be filled in at
122 runtime. */
123 #if HAVE_DESIGNATED_INITIALIZERS
125 #define init_trigraph_map() /* Nothing. */
126 #define TRIGRAPH_MAP \
127 __extension__ const uchar _cpp_trigraph_map[UCHAR_MAX + 1] = {
129 #define END };
130 #define s(p, v) [p] = v,
132 #else
134 #define TRIGRAPH_MAP uchar _cpp_trigraph_map[UCHAR_MAX + 1] = { 0 }; \
135 static void init_trigraph_map PARAMS ((void)) { \
136 unsigned char *x = _cpp_trigraph_map;
138 #define END }
139 #define s(p, v) x[p] = v;
141 #endif
143 TRIGRAPH_MAP
144 s('=', '#') s(')', ']') s('!', '|')
145 s('(', '[') s('\'', '^') s('>', '}')
146 s('/', '\\') s('<', '{') s('-', '~')
149 #undef s
150 #undef END
151 #undef TRIGRAPH_MAP
153 /* Given a colon-separated list of file names PATH,
154 add all the names to the search path for include files. */
155 static void
156 path_include (pfile, list, path)
157 cpp_reader *pfile;
158 char *list;
159 int path;
161 char *p, *q, *name;
163 p = list;
167 /* Find the end of this name. */
168 q = p;
169 while (*q != 0 && *q != PATH_SEPARATOR) q++;
170 if (q == p)
172 /* An empty name in the path stands for the current directory. */
173 name = (char *) xmalloc (2);
174 name[0] = '.';
175 name[1] = 0;
177 else
179 /* Otherwise use the directory that is named. */
180 name = (char *) xmalloc (q - p + 1);
181 memcpy (name, p, q - p);
182 name[q - p] = 0;
185 append_include_chain (pfile, name, path, path == SYSTEM);
187 /* Advance past this name. */
188 if (*q == 0)
189 break;
190 p = q + 1;
192 while (1);
195 /* Append DIR to include path PATH. DIR must be allocated on the
196 heap; this routine takes responsibility for freeing it. CXX_AWARE
197 is nonzero if the header contains extern "C" guards for C++,
198 otherwise it is zero. */
199 static void
200 append_include_chain (pfile, dir, path, cxx_aware)
201 cpp_reader *pfile;
202 char *dir;
203 int path;
204 int cxx_aware;
206 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
207 struct search_path *new;
208 struct stat st;
209 unsigned int len;
211 if (*dir == '\0')
213 free (dir);
214 dir = xstrdup (".");
216 _cpp_simplify_pathname (dir);
218 if (stat (dir, &st))
220 /* Dirs that don't exist are silently ignored. */
221 if (errno != ENOENT)
222 cpp_errno (pfile, DL_ERROR, dir);
223 else if (CPP_OPTION (pfile, verbose))
224 fprintf (stderr, _("ignoring nonexistent directory \"%s\"\n"), dir);
225 free (dir);
226 return;
229 if (!S_ISDIR (st.st_mode))
231 cpp_error_with_line (pfile, DL_ERROR, 0, 0, "%s: Not a directory", dir);
232 free (dir);
233 return;
236 len = strlen (dir);
237 if (len > pfile->max_include_len)
238 pfile->max_include_len = len;
240 new = (struct search_path *) xmalloc (sizeof (struct search_path));
241 new->name = dir;
242 new->len = len;
243 INO_T_COPY (new->ino, st.st_ino);
244 new->dev = st.st_dev;
245 /* Both systm and after include file lists should be treated as system
246 include files since these two lists are really just a concatenation
247 of one "system" list. */
248 if (path == SYSTEM || path == AFTER)
249 new->sysp = cxx_aware ? 1 : 2;
250 else
251 new->sysp = 0;
252 new->name_map = NULL;
253 new->next = NULL;
255 switch (path)
257 case BRACKET: APPEND (pend, brack, new); break;
258 case SYSTEM: APPEND (pend, systm, new); break;
259 case AFTER: APPEND (pend, after, new); break;
263 /* Handle a duplicated include path. PREV is the link in the chain
264 before the duplicate, or NULL if the duplicate is at the head of
265 the chain. The duplicate is removed from the chain and freed.
266 Returns PREV. */
267 static struct search_path *
268 remove_dup_dir (pfile, prev, head_ptr)
269 cpp_reader *pfile;
270 struct search_path *prev;
271 struct search_path **head_ptr;
273 struct search_path *cur;
275 if (prev != NULL)
277 cur = prev->next;
278 prev->next = cur->next;
280 else
282 cur = *head_ptr;
283 *head_ptr = cur->next;
286 if (CPP_OPTION (pfile, verbose))
287 fprintf (stderr, _("ignoring duplicate directory \"%s\"\n"), cur->name);
289 free ((PTR) cur->name);
290 free (cur);
292 return prev;
295 /* Remove duplicate non-system directories for which there is an equivalent
296 system directory latter in the chain. The range for removal is between
297 *HEAD_PTR and END. Returns the directory before END, or NULL if none.
298 This algorithm is quadratic in the number system directories, which is
299 acceptable since there aren't usually that many of them. */
300 static struct search_path *
301 remove_dup_nonsys_dirs (pfile, head_ptr, end)
302 cpp_reader *pfile;
303 struct search_path **head_ptr;
304 struct search_path *end;
306 int sysdir = 0;
307 struct search_path *prev = NULL, *cur, *other;
309 for (cur = *head_ptr; cur; cur = cur->next)
311 if (cur->sysp)
313 sysdir = 1;
314 for (other = *head_ptr, prev = NULL;
315 other != end;
316 other = other ? other->next : *head_ptr)
318 if (!other->sysp
319 && INO_T_EQ (cur->ino, other->ino)
320 && cur->dev == other->dev)
322 other = remove_dup_dir (pfile, prev, head_ptr);
323 if (CPP_OPTION (pfile, verbose))
324 fprintf (stderr,
325 _(" as it is a non-system directory that duplicates a system directory\n"));
327 prev = other;
332 if (!sysdir)
333 for (cur = *head_ptr; cur != end; cur = cur->next)
334 prev = cur;
336 return prev;
339 /* Remove duplicate directories from a chain. Returns the tail of the
340 chain, or NULL if the chain is empty. This algorithm is quadratic
341 in the number of -I switches, which is acceptable since there
342 aren't usually that many of them. */
343 static struct search_path *
344 remove_dup_dirs (pfile, head_ptr)
345 cpp_reader *pfile;
346 struct search_path **head_ptr;
348 struct search_path *prev = NULL, *cur, *other;
350 for (cur = *head_ptr; cur; cur = cur->next)
352 for (other = *head_ptr; other != cur; other = other->next)
353 if (INO_T_EQ (cur->ino, other->ino) && cur->dev == other->dev)
355 cur = remove_dup_dir (pfile, prev, head_ptr);
356 break;
358 prev = cur;
361 return prev;
364 /* Merge the four include chains together in the order quote, bracket,
365 system, after. Remove duplicate dirs (as determined by
366 INO_T_EQ()). The system_include and after_include chains are never
367 referred to again after this function; all access is through the
368 bracket_include path. */
369 static void
370 merge_include_chains (pfile)
371 cpp_reader *pfile;
373 struct search_path *quote, *brack, *systm, *qtail;
375 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
377 quote = pend->quote_head;
378 brack = pend->brack_head;
379 systm = pend->systm_head;
380 qtail = pend->quote_tail;
382 /* Paste together bracket, system, and after include chains. */
383 if (systm)
384 pend->systm_tail->next = pend->after_head;
385 else
386 systm = pend->after_head;
388 if (brack)
389 pend->brack_tail->next = systm;
390 else
391 brack = systm;
393 /* This is a bit tricky. First we drop non-system dupes of system
394 directories from the merged bracket-include list. Next we drop
395 dupes from the bracket and quote include lists. Then we drop
396 non-system dupes from the merged quote-include list. Finally,
397 if qtail and brack are the same directory, we cut out brack and
398 move brack up to point to qtail.
400 We can't just merge the lists and then uniquify them because
401 then we may lose directories from the <> search path that should
402 be there; consider -Ifoo -Ibar -I- -Ifoo -Iquux. It is however
403 safe to treat -Ibar -Ifoo -I- -Ifoo -Iquux as if written
404 -Ibar -I- -Ifoo -Iquux. */
406 remove_dup_nonsys_dirs (pfile, &brack, systm);
407 remove_dup_dirs (pfile, &brack);
409 if (quote)
411 qtail = remove_dup_dirs (pfile, &quote);
412 qtail->next = brack;
414 qtail = remove_dup_nonsys_dirs (pfile, &quote, brack);
416 /* If brack == qtail, remove brack as it's simpler. */
417 if (qtail && brack && INO_T_EQ (qtail->ino, brack->ino)
418 && qtail->dev == brack->dev)
419 brack = remove_dup_dir (pfile, qtail, &quote);
421 else
422 quote = brack;
424 CPP_OPTION (pfile, quote_include) = quote;
425 CPP_OPTION (pfile, bracket_include) = brack;
428 /* A set of booleans indicating what CPP features each source language
429 requires. */
430 struct lang_flags
432 char c99;
433 char cplusplus;
434 char extended_numbers;
435 char std;
436 char dollars_in_ident;
437 char cplusplus_comments;
438 char digraphs;
441 /* ??? Enable $ in identifiers in assembly? */
442 static const struct lang_flags lang_defaults[] =
443 { /* c99 c++ xnum std dollar c++comm digr */
444 /* GNUC89 */ { 0, 0, 1, 0, 1, 1, 1 },
445 /* GNUC99 */ { 1, 0, 1, 0, 1, 1, 1 },
446 /* STDC89 */ { 0, 0, 0, 1, 0, 0, 0 },
447 /* STDC94 */ { 0, 0, 0, 1, 0, 0, 1 },
448 /* STDC99 */ { 1, 0, 1, 1, 0, 1, 1 },
449 /* GNUCXX */ { 0, 1, 1, 0, 1, 1, 1 },
450 /* CXX98 */ { 0, 1, 1, 1, 0, 1, 1 },
451 /* ASM */ { 0, 0, 1, 0, 0, 1, 0 }
454 /* Sets internal flags correctly for a given language. */
455 void
456 cpp_set_lang (pfile, lang)
457 cpp_reader *pfile;
458 enum c_lang lang;
460 const struct lang_flags *l = &lang_defaults[(int) lang];
462 CPP_OPTION (pfile, lang) = lang;
464 CPP_OPTION (pfile, c99) = l->c99;
465 CPP_OPTION (pfile, cplusplus) = l->cplusplus;
466 CPP_OPTION (pfile, extended_numbers) = l->extended_numbers;
467 CPP_OPTION (pfile, std) = l->std;
468 CPP_OPTION (pfile, trigraphs) = l->std;
469 CPP_OPTION (pfile, dollars_in_ident) = l->dollars_in_ident;
470 CPP_OPTION (pfile, cplusplus_comments) = l->cplusplus_comments;
471 CPP_OPTION (pfile, digraphs) = l->digraphs;
474 #ifdef HOST_EBCDIC
475 static int opt_comp PARAMS ((const void *, const void *));
477 /* Run-time sorting of options array. */
478 static int
479 opt_comp (p1, p2)
480 const void *p1, *p2;
482 return strcmp (((struct cl_option *) p1)->opt_text,
483 ((struct cl_option *) p2)->opt_text);
485 #endif
487 /* init initializes library global state. It might not need to
488 do anything depending on the platform and compiler. */
489 static void
490 init_library ()
492 static int initialized = 0;
494 if (! initialized)
496 initialized = 1;
498 #ifdef HOST_EBCDIC
499 /* For non-ASCII hosts, the cl_options array needs to be sorted at
500 runtime. */
501 qsort (cl_options, N_OPTS, sizeof (struct cl_option), opt_comp);
502 #endif
504 /* Set up the trigraph map. This doesn't need to do anything if
505 we were compiled with a compiler that supports C99 designated
506 initializers. */
507 init_trigraph_map ();
511 /* Initialize a cpp_reader structure. */
512 cpp_reader *
513 cpp_create_reader (lang)
514 enum c_lang lang;
516 cpp_reader *pfile;
518 /* Initialize this instance of the library if it hasn't been already. */
519 init_library ();
521 pfile = (cpp_reader *) xcalloc (1, sizeof (cpp_reader));
523 cpp_set_lang (pfile, lang);
524 CPP_OPTION (pfile, warn_import) = 1;
525 CPP_OPTION (pfile, warn_multichar) = 1;
526 CPP_OPTION (pfile, discard_comments) = 1;
527 CPP_OPTION (pfile, discard_comments_in_macro_exp) = 1;
528 CPP_OPTION (pfile, show_column) = 1;
529 CPP_OPTION (pfile, tabstop) = 8;
530 CPP_OPTION (pfile, operator_names) = 1;
531 CPP_OPTION (pfile, warn_endif_labels) = 1;
532 CPP_OPTION (pfile, warn_long_long) = !CPP_OPTION (pfile, c99);
534 CPP_OPTION (pfile, pending) =
535 (struct cpp_pending *) xcalloc (1, sizeof (struct cpp_pending));
537 /* Default CPP arithmetic to something sensible for the host for the
538 benefit of dumb users like fix-header. */
539 CPP_OPTION (pfile, precision) = CHAR_BIT * sizeof (long);
540 CPP_OPTION (pfile, char_precision) = CHAR_BIT;
541 CPP_OPTION (pfile, wchar_precision) = CHAR_BIT * sizeof (int);
542 CPP_OPTION (pfile, int_precision) = CHAR_BIT * sizeof (int);
543 CPP_OPTION (pfile, unsigned_char) = 0;
544 CPP_OPTION (pfile, unsigned_wchar) = 1;
546 /* Initialize the line map. Start at logical line 1, so we can use
547 a line number of zero for special states. */
548 init_line_maps (&pfile->line_maps);
549 pfile->line = 1;
551 /* Initialize lexer state. */
552 pfile->state.save_comments = ! CPP_OPTION (pfile, discard_comments);
554 /* Set up static tokens. */
555 pfile->avoid_paste.type = CPP_PADDING;
556 pfile->avoid_paste.val.source = NULL;
557 pfile->eof.type = CPP_EOF;
558 pfile->eof.flags = 0;
560 /* Create a token buffer for the lexer. */
561 _cpp_init_tokenrun (&pfile->base_run, 250);
562 pfile->cur_run = &pfile->base_run;
563 pfile->cur_token = pfile->base_run.base;
565 /* Initialize the base context. */
566 pfile->context = &pfile->base_context;
567 pfile->base_context.macro = 0;
568 pfile->base_context.prev = pfile->base_context.next = 0;
570 /* Aligned and unaligned storage. */
571 pfile->a_buff = _cpp_get_buff (pfile, 0);
572 pfile->u_buff = _cpp_get_buff (pfile, 0);
574 /* The expression parser stack. */
575 _cpp_expand_op_stack (pfile);
577 /* Initialize the buffer obstack. */
578 gcc_obstack_init (&pfile->buffer_ob);
580 _cpp_init_includes (pfile);
582 return pfile;
585 /* Free resources used by PFILE. Accessing PFILE after this function
586 returns leads to undefined behavior. Returns the error count. */
587 void
588 cpp_destroy (pfile)
589 cpp_reader *pfile;
591 struct search_path *dir, *dirn;
592 cpp_context *context, *contextn;
593 tokenrun *run, *runn;
595 free_chain (CPP_OPTION (pfile, pending)->include_head);
596 free (CPP_OPTION (pfile, pending));
597 free (pfile->op_stack);
599 while (CPP_BUFFER (pfile) != NULL)
600 _cpp_pop_buffer (pfile);
602 if (pfile->out.base)
603 free (pfile->out.base);
605 if (pfile->macro_buffer)
607 free ((PTR) pfile->macro_buffer);
608 pfile->macro_buffer = NULL;
609 pfile->macro_buffer_len = 0;
612 if (pfile->deps)
613 deps_free (pfile->deps);
614 obstack_free (&pfile->buffer_ob, 0);
616 _cpp_destroy_hashtable (pfile);
617 _cpp_cleanup_includes (pfile);
619 _cpp_free_buff (pfile->a_buff);
620 _cpp_free_buff (pfile->u_buff);
621 _cpp_free_buff (pfile->free_buffs);
623 for (run = &pfile->base_run; run; run = runn)
625 runn = run->next;
626 free (run->base);
627 if (run != &pfile->base_run)
628 free (run);
631 for (dir = CPP_OPTION (pfile, quote_include); dir; dir = dirn)
633 dirn = dir->next;
634 free ((PTR) dir->name);
635 free (dir);
638 for (context = pfile->base_context.next; context; context = contextn)
640 contextn = context->next;
641 free (context);
644 free_line_maps (&pfile->line_maps);
645 free (pfile);
648 /* This structure defines one built-in identifier. A node will be
649 entered in the hash table under the name NAME, with value VALUE.
651 There are two tables of these. builtin_array holds all the
652 "builtin" macros: these are handled by builtin_macro() in
653 cppmacro.c. Builtin is somewhat of a misnomer -- the property of
654 interest is that these macros require special code to compute their
655 expansions. The value is a "builtin_type" enumerator.
657 operator_array holds the C++ named operators. These are keywords
658 which act as aliases for punctuators. In C++, they cannot be
659 altered through #define, and #if recognizes them as operators. In
660 C, these are not entered into the hash table at all (but see
661 <iso646.h>). The value is a token-type enumerator. */
662 struct builtin
664 const uchar *name;
665 unsigned short len;
666 unsigned short value;
669 #define B(n, t) { DSC(n), t }
670 static const struct builtin builtin_array[] =
672 B("__TIME__", BT_TIME),
673 B("__DATE__", BT_DATE),
674 B("__FILE__", BT_FILE),
675 B("__BASE_FILE__", BT_BASE_FILE),
676 B("__LINE__", BT_SPECLINE),
677 B("__INCLUDE_LEVEL__", BT_INCLUDE_LEVEL),
678 /* Keep builtins not used for -traditional-cpp at the end, and
679 update init_builtins() if any more are added. */
680 B("_Pragma", BT_PRAGMA),
681 B("__STDC__", BT_STDC),
684 static const struct builtin operator_array[] =
686 B("and", CPP_AND_AND),
687 B("and_eq", CPP_AND_EQ),
688 B("bitand", CPP_AND),
689 B("bitor", CPP_OR),
690 B("compl", CPP_COMPL),
691 B("not", CPP_NOT),
692 B("not_eq", CPP_NOT_EQ),
693 B("or", CPP_OR_OR),
694 B("or_eq", CPP_OR_EQ),
695 B("xor", CPP_XOR),
696 B("xor_eq", CPP_XOR_EQ)
698 #undef B
700 /* Mark the C++ named operators in the hash table. */
701 static void
702 mark_named_operators (pfile)
703 cpp_reader *pfile;
705 const struct builtin *b;
707 for (b = operator_array;
708 b < (operator_array + ARRAY_SIZE (operator_array));
709 b++)
711 cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len);
712 hp->flags |= NODE_OPERATOR;
713 hp->value.operator = b->value;
717 /* Subroutine of cpp_read_main_file; reads the builtins table above and
718 enters them, and language-specific macros, into the hash table. */
719 static void
720 init_builtins (pfile)
721 cpp_reader *pfile;
723 const struct builtin *b;
724 size_t n = ARRAY_SIZE (builtin_array);
726 if (CPP_OPTION (pfile, traditional))
727 n -= 2;
729 for(b = builtin_array; b < builtin_array + n; b++)
731 cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len);
732 hp->type = NT_MACRO;
733 hp->flags |= NODE_BUILTIN | NODE_WARN;
734 hp->value.builtin = b->value;
737 if (CPP_OPTION (pfile, cplusplus))
738 _cpp_define_builtin (pfile, "__cplusplus 1");
739 else if (CPP_OPTION (pfile, lang) == CLK_ASM)
740 _cpp_define_builtin (pfile, "__ASSEMBLER__ 1");
741 else if (CPP_OPTION (pfile, lang) == CLK_STDC94)
742 _cpp_define_builtin (pfile, "__STDC_VERSION__ 199409L");
743 else if (CPP_OPTION (pfile, c99))
744 _cpp_define_builtin (pfile, "__STDC_VERSION__ 199901L");
746 if (CPP_OPTION (pfile, objc))
747 _cpp_define_builtin (pfile, "__OBJC__ 1");
749 if (pfile->cb.register_builtins)
750 (*pfile->cb.register_builtins) (pfile);
753 /* And another subroutine. This one sets up the standard include path. */
754 static void
755 init_standard_includes (pfile)
756 cpp_reader *pfile;
758 char *path;
759 const struct default_include *p;
760 const char *specd_prefix = CPP_OPTION (pfile, include_prefix);
762 /* Several environment variables may add to the include search path.
763 CPATH specifies an additional list of directories to be searched
764 as if specified with -I, while C_INCLUDE_PATH, CPLUS_INCLUDE_PATH,
765 etc. specify an additional list of directories to be searched as
766 if specified with -isystem, for the language indicated. */
768 GET_ENVIRONMENT (path, "CPATH");
769 if (path != 0 && *path != 0)
770 path_include (pfile, path, BRACKET);
772 switch ((CPP_OPTION (pfile, objc) << 1) + CPP_OPTION (pfile, cplusplus))
774 case 0:
775 GET_ENVIRONMENT (path, "C_INCLUDE_PATH");
776 break;
777 case 1:
778 GET_ENVIRONMENT (path, "CPLUS_INCLUDE_PATH");
779 break;
780 case 2:
781 GET_ENVIRONMENT (path, "OBJC_INCLUDE_PATH");
782 break;
783 case 3:
784 GET_ENVIRONMENT (path, "OBJCPLUS_INCLUDE_PATH");
785 break;
787 if (path != 0 && *path != 0)
788 path_include (pfile, path, SYSTEM);
790 /* Search "translated" versions of GNU directories.
791 These have /usr/local/lib/gcc... replaced by specd_prefix. */
792 if (specd_prefix != 0 && cpp_GCC_INCLUDE_DIR_len)
794 /* Remove the `include' from /usr/local/lib/gcc.../include.
795 GCC_INCLUDE_DIR will always end in /include. */
796 int default_len = cpp_GCC_INCLUDE_DIR_len;
797 char *default_prefix = (char *) alloca (default_len + 1);
798 int specd_len = strlen (specd_prefix);
800 memcpy (default_prefix, cpp_GCC_INCLUDE_DIR, default_len);
801 default_prefix[default_len] = '\0';
803 for (p = cpp_include_defaults; p->fname; p++)
805 /* Some standard dirs are only for C++. */
806 if (!p->cplusplus
807 || (CPP_OPTION (pfile, cplusplus)
808 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
810 /* Does this dir start with the prefix? */
811 if (!strncmp (p->fname, default_prefix, default_len))
813 /* Yes; change prefix and add to search list. */
814 int flen = strlen (p->fname);
815 int this_len = specd_len + flen - default_len;
816 char *str = (char *) xmalloc (this_len + 1);
817 memcpy (str, specd_prefix, specd_len);
818 memcpy (str + specd_len,
819 p->fname + default_len,
820 flen - default_len + 1);
822 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
828 /* Search ordinary names for GNU include directories. */
829 for (p = cpp_include_defaults; p->fname; p++)
831 /* Some standard dirs are only for C++. */
832 if (!p->cplusplus
833 || (CPP_OPTION (pfile, cplusplus)
834 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
836 char *str = update_path (p->fname, p->component);
837 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
842 /* Pushes a command line -imacro and -include file indicated by P onto
843 the buffer stack. Returns nonzero if successful. */
844 static bool
845 push_include (pfile, p)
846 cpp_reader *pfile;
847 struct pending_option *p;
849 cpp_token header;
851 /* Later: maybe update this to use the #include "" search path
852 if cpp_read_file fails. */
853 header.type = CPP_STRING;
854 header.val.str.text = (const unsigned char *) p->arg;
855 header.val.str.len = strlen (p->arg);
856 /* Make the command line directive take up a line. */
857 pfile->line++;
859 return _cpp_execute_include (pfile, &header, IT_CMDLINE);
862 /* Frees a pending_option chain. */
863 static void
864 free_chain (head)
865 struct pending_option *head;
867 struct pending_option *next;
869 while (head)
871 next = head->next;
872 free (head);
873 head = next;
877 /* Sanity-checks are dependent on command-line options, so it is
878 called as a subroutine of cpp_read_main_file (). */
879 #if ENABLE_CHECKING
880 static void sanity_checks PARAMS ((cpp_reader *));
881 static void sanity_checks (pfile)
882 cpp_reader *pfile;
884 cppchar_t test = 0;
885 size_t max_precision = 2 * CHAR_BIT * sizeof (cpp_num_part);
887 /* Sanity checks for assumptions about CPP arithmetic and target
888 type precisions made by cpplib. */
889 test--;
890 if (test < 1)
891 cpp_error (pfile, DL_ICE, "cppchar_t must be an unsigned type");
893 if (CPP_OPTION (pfile, precision) > max_precision)
894 cpp_error (pfile, DL_ICE,
895 "preprocessor arithmetic has maximum precision of %lu bits; target requires %lu bits",
896 (unsigned long) max_precision,
897 (unsigned long) CPP_OPTION (pfile, precision));
899 if (CPP_OPTION (pfile, precision) < CPP_OPTION (pfile, int_precision))
900 cpp_error (pfile, DL_ICE,
901 "CPP arithmetic must be at least as precise as a target int");
903 if (CPP_OPTION (pfile, char_precision) < 8)
904 cpp_error (pfile, DL_ICE, "target char is less than 8 bits wide");
906 if (CPP_OPTION (pfile, wchar_precision) < CPP_OPTION (pfile, char_precision))
907 cpp_error (pfile, DL_ICE,
908 "target wchar_t is narrower than target char");
910 if (CPP_OPTION (pfile, int_precision) < CPP_OPTION (pfile, char_precision))
911 cpp_error (pfile, DL_ICE,
912 "target int is narrower than target char");
914 /* This is assumed in eval_token() and could be fixed if necessary. */
915 if (sizeof (cppchar_t) > sizeof (cpp_num_part))
916 cpp_error (pfile, DL_ICE, "CPP half-integer narrower than CPP character");
918 if (CPP_OPTION (pfile, wchar_precision) > BITS_PER_CPPCHAR_T)
919 cpp_error (pfile, DL_ICE,
920 "CPP on this host cannot handle wide character constants over %lu bits, but the target requires %lu bits",
921 (unsigned long) BITS_PER_CPPCHAR_T,
922 (unsigned long) CPP_OPTION (pfile, wchar_precision));
924 #else
925 # define sanity_checks(PFILE)
926 #endif
928 /* Add a dependency target. Can be called any number of times before
929 cpp_read_main_file(). If no targets have been added before
930 cpp_read_main_file(), then the default target is used. */
931 void
932 cpp_add_dependency_target (pfile, target, quote)
933 cpp_reader *pfile;
934 const char *target;
935 int quote;
937 if (!pfile->deps)
938 pfile->deps = deps_init ();
940 deps_add_target (pfile->deps, target, quote);
943 /* This is called after options have been parsed, and partially
944 processed. Setup for processing input from the file named FNAME,
945 or stdin if it is the empty string. Return the original filename
946 on success (e.g. foo.i->foo.c), or NULL on failure. */
947 const char *
948 cpp_read_main_file (pfile, fname, table)
949 cpp_reader *pfile;
950 const char *fname;
951 hash_table *table;
953 sanity_checks (pfile);
955 post_options (pfile);
957 /* The front ends don't set up the hash table until they have
958 finished processing the command line options, so initializing the
959 hashtable is deferred until now. */
960 _cpp_init_hashtable (pfile, table);
962 /* Set up the include search path now. */
963 if (! CPP_OPTION (pfile, no_standard_includes))
964 init_standard_includes (pfile);
966 merge_include_chains (pfile);
968 /* With -v, print the list of dirs to search. */
969 if (CPP_OPTION (pfile, verbose))
971 struct search_path *l;
972 fprintf (stderr, _("#include \"...\" search starts here:\n"));
973 for (l = CPP_OPTION (pfile, quote_include); l; l = l->next)
975 if (l == CPP_OPTION (pfile, bracket_include))
976 fprintf (stderr, _("#include <...> search starts here:\n"));
977 fprintf (stderr, " %s\n", l->name);
979 fprintf (stderr, _("End of search list.\n"));
982 if (CPP_OPTION (pfile, deps.style) != DEPS_NONE)
984 if (!pfile->deps)
985 pfile->deps = deps_init ();
987 /* Set the default target (if there is none already). */
988 deps_add_default_target (pfile->deps, fname);
991 /* Open the main input file. */
992 if (!_cpp_read_file (pfile, fname))
993 return NULL;
995 /* Set this here so the client can change the option if it wishes,
996 and after stacking the main file so we don't trace the main
997 file. */
998 pfile->line_maps.trace_includes = CPP_OPTION (pfile, print_include_names);
1000 /* For foo.i, read the original filename foo.c now, for the benefit
1001 of the front ends. */
1002 if (CPP_OPTION (pfile, preprocessed))
1003 read_original_filename (pfile);
1005 return pfile->map->to_file;
1008 /* For preprocessed files, if the first tokens are of the form # NUM.
1009 handle the directive so we know the original file name. This will
1010 generate file_change callbacks, which the front ends must handle
1011 appropriately given their state of initialization. */
1012 static void
1013 read_original_filename (pfile)
1014 cpp_reader *pfile;
1016 const cpp_token *token, *token1;
1018 /* Lex ahead; if the first tokens are of the form # NUM, then
1019 process the directive, otherwise back up. */
1020 token = _cpp_lex_direct (pfile);
1021 if (token->type == CPP_HASH)
1023 token1 = _cpp_lex_direct (pfile);
1024 _cpp_backup_tokens (pfile, 1);
1026 /* If it's a #line directive, handle it. */
1027 if (token1->type == CPP_NUMBER)
1029 _cpp_handle_directive (pfile, token->flags & PREV_WHITE);
1030 return;
1034 /* Backup as if nothing happened. */
1035 _cpp_backup_tokens (pfile, 1);
1038 /* Handle pending command line options: -D, -U, -A, -imacros and
1039 -include. This should be called after debugging has been properly
1040 set up in the front ends. */
1041 void
1042 cpp_finish_options (pfile)
1043 cpp_reader *pfile;
1045 /* Mark named operators before handling command line macros. */
1046 if (CPP_OPTION (pfile, cplusplus) && CPP_OPTION (pfile, operator_names))
1047 mark_named_operators (pfile);
1049 /* Install builtins and process command line macros etc. in the order
1050 they appeared, but only if not already preprocessed. */
1051 if (! CPP_OPTION (pfile, preprocessed))
1053 struct pending_option *p;
1055 _cpp_do_file_change (pfile, LC_RENAME, _("<built-in>"), 1, 0);
1056 init_builtins (pfile);
1057 _cpp_do_file_change (pfile, LC_RENAME, _("<command line>"), 1, 0);
1058 for (p = CPP_OPTION (pfile, pending)->directive_head; p; p = p->next)
1059 (*p->handler) (pfile, p->arg);
1061 /* Scan -imacros files after -D, -U, but before -include.
1062 pfile->next_include_file is NULL, so _cpp_pop_buffer does not
1063 push -include files. */
1064 for (p = CPP_OPTION (pfile, pending)->imacros_head; p; p = p->next)
1065 if (push_include (pfile, p))
1066 cpp_scan_nooutput (pfile);
1068 pfile->next_include_file = &CPP_OPTION (pfile, pending)->include_head;
1069 _cpp_maybe_push_include_file (pfile);
1072 pfile->first_unused_line = pfile->line;
1074 free_chain (CPP_OPTION (pfile, pending)->imacros_head);
1075 free_chain (CPP_OPTION (pfile, pending)->directive_head);
1078 /* Push the next buffer on the stack given by -include, if any. */
1079 void
1080 _cpp_maybe_push_include_file (pfile)
1081 cpp_reader *pfile;
1083 if (pfile->next_include_file)
1085 struct pending_option *head = *pfile->next_include_file;
1087 while (head && !push_include (pfile, head))
1088 head = head->next;
1090 if (head)
1091 pfile->next_include_file = &head->next;
1092 else
1094 /* All done; restore the line map from <command line>. */
1095 _cpp_do_file_change (pfile, LC_RENAME,
1096 pfile->line_maps.maps[0].to_file, 1, 0);
1097 /* Don't come back here again. */
1098 pfile->next_include_file = NULL;
1103 /* This is called at the end of preprocessing. It pops the last
1104 buffer and writes dependency output, and returns the number of
1105 errors.
1107 Maybe it should also reset state, such that you could call
1108 cpp_start_read with a new filename to restart processing. */
1110 cpp_finish (pfile, deps_stream)
1111 cpp_reader *pfile;
1112 FILE *deps_stream;
1114 /* Warn about unused macros before popping the final buffer. */
1115 if (CPP_OPTION (pfile, warn_unused_macros))
1116 cpp_forall_identifiers (pfile, _cpp_warn_if_unused_macro, NULL);
1118 /* cpplex.c leaves the final buffer on the stack. This it so that
1119 it returns an unending stream of CPP_EOFs to the client. If we
1120 popped the buffer, we'd dereference a NULL buffer pointer and
1121 segfault. It's nice to allow the client to do worry-free excess
1122 cpp_get_token calls. */
1123 while (pfile->buffer)
1124 _cpp_pop_buffer (pfile);
1126 /* Don't write the deps file if there are errors. */
1127 if (CPP_OPTION (pfile, deps.style) != DEPS_NONE
1128 && deps_stream && pfile->errors == 0)
1130 deps_write (pfile->deps, deps_stream, 72);
1132 if (CPP_OPTION (pfile, deps.phony_targets))
1133 deps_phony_targets (pfile->deps, deps_stream);
1136 /* Report on headers that could use multiple include guards. */
1137 if (CPP_OPTION (pfile, print_include_names))
1138 _cpp_report_missing_guards (pfile);
1140 return pfile->errors;
1143 /* Add a directive to be handled later in the initialization phase. */
1144 static void
1145 new_pending_directive (pend, text, handler)
1146 struct cpp_pending *pend;
1147 const char *text;
1148 cl_directive_handler handler;
1150 struct pending_option *o = (struct pending_option *)
1151 xmalloc (sizeof (struct pending_option));
1153 o->arg = text;
1154 o->next = NULL;
1155 o->handler = handler;
1156 APPEND (pend, directive, o);
1159 /* Irix6 "cc -n32" and OSF4 cc have problems with char foo[] = ("string");
1160 I.e. a const string initializer with parens around it. That is
1161 what N_("string") resolves to, so we make no_* be macros instead. */
1162 #define no_ass N_("assertion missing after %s")
1163 #define no_dir N_("directory name missing after %s")
1164 #define no_fil N_("file name missing after %s")
1165 #define no_mac N_("macro name missing after %s")
1166 #define no_pth N_("path name missing after %s")
1168 /* This is the list of all command line options, with the leading
1169 "-" removed. It must be sorted in ASCII collating order. */
1170 #define COMMAND_LINE_OPTIONS \
1171 DEF_OPT("A", no_ass, OPT_A) \
1172 DEF_OPT("D", no_mac, OPT_D) \
1173 DEF_OPT("I", no_dir, OPT_I) \
1174 DEF_OPT("U", no_mac, OPT_U) \
1175 DEF_OPT("idirafter", no_dir, OPT_idirafter) \
1176 DEF_OPT("imacros", no_fil, OPT_imacros) \
1177 DEF_OPT("include", no_fil, OPT_include) \
1178 DEF_OPT("iprefix", no_pth, OPT_iprefix) \
1179 DEF_OPT("isystem", no_dir, OPT_isystem) \
1180 DEF_OPT("iwithprefix", no_dir, OPT_iwithprefix) \
1181 DEF_OPT("iwithprefixbefore", no_dir, OPT_iwithprefixbefore)
1183 #define DEF_OPT(text, msg, code) code,
1184 enum opt_code
1186 COMMAND_LINE_OPTIONS
1187 N_OPTS
1189 #undef DEF_OPT
1191 struct cl_option
1193 const char *opt_text;
1194 const char *msg;
1195 size_t opt_len;
1196 enum opt_code opt_code;
1199 #define DEF_OPT(text, msg, code) { text, msg, sizeof(text) - 1, code },
1200 #ifdef HOST_EBCDIC
1201 static struct cl_option cl_options[] =
1202 #else
1203 static const struct cl_option cl_options[] =
1204 #endif
1206 COMMAND_LINE_OPTIONS
1208 #undef DEF_OPT
1209 #undef COMMAND_LINE_OPTIONS
1211 /* Perform a binary search to find which, if any, option the given
1212 command-line matches. Returns its index in the option array,
1213 negative on failure. Complications arise since some options can be
1214 suffixed with an argument, and multiple complete matches can occur,
1215 e.g. -pedantic and -pedantic-errors. */
1216 static int
1217 parse_option (input)
1218 const char *input;
1220 unsigned int md, mn, mx;
1221 size_t opt_len;
1222 int comp;
1224 mn = 0;
1225 mx = N_OPTS;
1227 while (mx > mn)
1229 md = (mn + mx) / 2;
1231 opt_len = cl_options[md].opt_len;
1232 comp = strncmp (input, cl_options[md].opt_text, opt_len);
1234 if (comp > 0)
1235 mn = md + 1;
1236 else if (comp < 0)
1237 mx = md;
1238 else
1240 if (input[opt_len] == '\0')
1241 return md;
1242 /* We were passed more text. If the option takes an argument,
1243 we may match a later option or we may have been passed the
1244 argument. The longest possible option match succeeds.
1245 If the option takes no arguments we have not matched and
1246 continue the search (e.g. input="stdc++" match was "stdc"). */
1247 mn = md + 1;
1248 if (cl_options[md].msg)
1250 /* Scan forwards. If we get an exact match, return it.
1251 Otherwise, return the longest option-accepting match.
1252 This loops no more than twice with current options. */
1253 mx = md;
1254 for (; mn < (unsigned int) N_OPTS; mn++)
1256 opt_len = cl_options[mn].opt_len;
1257 if (strncmp (input, cl_options[mn].opt_text, opt_len))
1258 break;
1259 if (input[opt_len] == '\0')
1260 return mn;
1261 if (cl_options[mn].msg)
1262 mx = mn;
1264 return mx;
1269 return -1;
1272 /* Handle one command-line option in (argc, argv).
1273 Can be called multiple times, to handle multiple sets of options.
1274 Returns number of strings consumed. */
1276 cpp_handle_option (pfile, argc, argv)
1277 cpp_reader *pfile;
1278 int argc;
1279 char **argv;
1281 int i = 0;
1282 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
1285 enum opt_code opt_code;
1286 int opt_index;
1287 const char *arg = 0;
1289 /* Skip over '-'. */
1290 opt_index = parse_option (&argv[i][1]);
1291 if (opt_index < 0)
1292 return i;
1294 opt_code = cl_options[opt_index].opt_code;
1295 if (cl_options[opt_index].msg)
1297 arg = &argv[i][cl_options[opt_index].opt_len + 1];
1298 if (arg[0] == '\0')
1300 arg = argv[++i];
1301 if (!arg)
1303 cpp_error (pfile, DL_ERROR,
1304 cl_options[opt_index].msg, argv[i - 1]);
1305 return argc;
1310 switch (opt_code)
1312 case N_OPTS: /* Shut GCC up. */
1313 break;
1315 case OPT_D:
1316 new_pending_directive (pend, arg, cpp_define);
1317 break;
1318 case OPT_iprefix:
1319 CPP_OPTION (pfile, include_prefix) = arg;
1320 CPP_OPTION (pfile, include_prefix_len) = strlen (arg);
1321 break;
1323 case OPT_A:
1324 if (arg[0] == '-')
1326 /* -A with an argument beginning with '-' acts as
1327 #unassert on whatever immediately follows the '-'.
1328 If "-" is the whole argument, we eliminate all
1329 predefined macros and assertions, including those
1330 that were specified earlier on the command line.
1331 That way we can get rid of any that were passed
1332 automatically in from GCC. */
1334 if (arg[1] == '\0')
1336 free_chain (pend->directive_head);
1337 pend->directive_head = NULL;
1338 pend->directive_tail = NULL;
1340 else
1341 new_pending_directive (pend, arg + 1, cpp_unassert);
1343 else
1344 new_pending_directive (pend, arg, cpp_assert);
1345 break;
1346 case OPT_U:
1347 new_pending_directive (pend, arg, cpp_undef);
1348 break;
1349 case OPT_I: /* Add directory to path for includes. */
1350 if (!strcmp (arg, "-"))
1352 /* -I- means:
1353 Use the preceding -I directories for #include "..."
1354 but not #include <...>.
1355 Don't search the directory of the present file
1356 for #include "...". (Note that -I. -I- is not the same as
1357 the default setup; -I. uses the compiler's working dir.) */
1358 if (! CPP_OPTION (pfile, ignore_srcdir))
1360 pend->quote_head = pend->brack_head;
1361 pend->quote_tail = pend->brack_tail;
1362 pend->brack_head = 0;
1363 pend->brack_tail = 0;
1364 CPP_OPTION (pfile, ignore_srcdir) = 1;
1366 else
1368 cpp_error (pfile, DL_ERROR, "-I- specified twice");
1369 return argc;
1372 else
1373 append_include_chain (pfile, xstrdup (arg), BRACKET, 0);
1374 break;
1375 case OPT_isystem:
1376 /* Add directory to beginning of system include path, as a system
1377 include directory. */
1378 append_include_chain (pfile, xstrdup (arg), SYSTEM, 0);
1379 break;
1380 case OPT_include:
1381 case OPT_imacros:
1383 struct pending_option *o = (struct pending_option *)
1384 xmalloc (sizeof (struct pending_option));
1385 o->arg = arg;
1386 o->next = NULL;
1388 if (opt_code == OPT_include)
1389 APPEND (pend, include, o);
1390 else
1391 APPEND (pend, imacros, o);
1393 break;
1394 case OPT_iwithprefix:
1395 /* Add directory to end of path for includes,
1396 with the default prefix at the front of its name. */
1397 /* fall through */
1398 case OPT_iwithprefixbefore:
1399 /* Add directory to main path for includes,
1400 with the default prefix at the front of its name. */
1402 char *fname;
1403 int len;
1405 len = strlen (arg);
1407 if (CPP_OPTION (pfile, include_prefix) != 0)
1409 size_t ipl = CPP_OPTION (pfile, include_prefix_len);
1410 fname = xmalloc (ipl + len + 1);
1411 memcpy (fname, CPP_OPTION (pfile, include_prefix), ipl);
1412 memcpy (fname + ipl, arg, len + 1);
1414 else if (cpp_GCC_INCLUDE_DIR_len)
1416 fname = xmalloc (cpp_GCC_INCLUDE_DIR_len + len + 1);
1417 memcpy (fname, cpp_GCC_INCLUDE_DIR, cpp_GCC_INCLUDE_DIR_len);
1418 memcpy (fname + cpp_GCC_INCLUDE_DIR_len, arg, len + 1);
1420 else
1421 fname = xstrdup (arg);
1423 append_include_chain (pfile, fname,
1424 opt_code == OPT_iwithprefix ? SYSTEM: BRACKET, 0);
1426 break;
1427 case OPT_idirafter:
1428 /* Add directory to end of path for includes. */
1429 append_include_chain (pfile, xstrdup (arg), AFTER, 0);
1430 break;
1433 return i + 1;
1436 /* Handle command-line options in (argc, argv).
1437 Can be called multiple times, to handle multiple sets of options.
1438 Returns if an unrecognized option is seen.
1439 Returns number of strings consumed. */
1441 cpp_handle_options (pfile, argc, argv)
1442 cpp_reader *pfile;
1443 int argc;
1444 char **argv;
1446 int i;
1447 int strings_processed;
1449 for (i = 0; i < argc; i += strings_processed)
1451 strings_processed = cpp_handle_option (pfile, argc - i, argv + i);
1452 if (strings_processed == 0)
1453 break;
1456 return i;
1459 static void
1460 post_options (pfile)
1461 cpp_reader *pfile;
1463 /* -Wtraditional is not useful in C++ mode. */
1464 if (CPP_OPTION (pfile, cplusplus))
1465 CPP_OPTION (pfile, warn_traditional) = 0;
1467 /* Permanently disable macro expansion if we are rescanning
1468 preprocessed text. Read preprocesed source in ISO mode. */
1469 if (CPP_OPTION (pfile, preprocessed))
1471 pfile->state.prevent_expansion = 1;
1472 CPP_OPTION (pfile, traditional) = 0;
1475 /* Traditional CPP does not accurately track column information. */
1476 if (CPP_OPTION (pfile, traditional))
1477 CPP_OPTION (pfile, show_column) = 0;