2000-12-21 Benjamin Kosnik <bkoz@redhat.com>
[official-gcc.git] / gcc / cppinit.c
blobea4bc6bc5192fdab7e71cbdc0511c665be139bc2
1 /* CPP Library.
2 Copyright (C) 1986, 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000 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 "output.h"
27 #include "prefix.h"
28 #include "intl.h"
29 #include "version.h"
30 #include "mkdeps.h"
31 #include "cppdefault.h"
33 /* Predefined symbols, built-in macros, and the default include path. */
35 #ifndef GET_ENV_PATH_LIST
36 #define GET_ENV_PATH_LIST(VAR,NAME) do { (VAR) = getenv (NAME); } while (0)
37 #endif
39 /* Windows does not natively support inodes, and neither does MSDOS.
40 Cygwin's emulation can generate non-unique inodes, so don't use it.
41 VMS has non-numeric inodes. */
42 #ifdef VMS
43 #define INO_T_EQ(a, b) (!memcmp (&(a), &(b), sizeof (a)))
44 #elif (defined _WIN32 && ! defined (_UWIN)) || defined __MSDOS__
45 #define INO_T_EQ(a, b) 0
46 #else
47 #define INO_T_EQ(a, b) ((a) == (b))
48 #endif
50 /* Internal structures and prototypes. */
52 /* A `struct pending_option' remembers one -D, -A, -U, -include, or
53 -imacros switch. */
55 typedef void (* cl_directive_handler) PARAMS ((cpp_reader *, const char *));
56 struct pending_option
58 struct pending_option *next;
59 const char *arg;
60 cl_directive_handler handler;
63 /* The `pending' structure accumulates all the options that are not
64 actually processed until we hit cpp_start_read. It consists of
65 several lists, one for each type of option. We keep both head and
66 tail pointers for quick insertion. */
67 struct cpp_pending
69 struct pending_option *directive_head, *directive_tail;
71 struct file_name_list *quote_head, *quote_tail;
72 struct file_name_list *brack_head, *brack_tail;
73 struct file_name_list *systm_head, *systm_tail;
74 struct file_name_list *after_head, *after_tail;
76 struct pending_option *imacros_head, *imacros_tail;
77 struct pending_option *include_head, *include_tail;
80 #ifdef __STDC__
81 #define APPEND(pend, list, elt) \
82 do { if (!(pend)->list##_head) (pend)->list##_head = (elt); \
83 else (pend)->list##_tail->next = (elt); \
84 (pend)->list##_tail = (elt); \
85 } while (0)
86 #else
87 #define APPEND(pend, list, elt) \
88 do { if (!(pend)->list/**/_head) (pend)->list/**/_head = (elt); \
89 else (pend)->list/**/_tail->next = (elt); \
90 (pend)->list/**/_tail = (elt); \
91 } while (0)
92 #endif
94 static void print_help PARAMS ((void));
95 static void path_include PARAMS ((cpp_reader *,
96 char *, int));
97 static void initialize PARAMS ((void));
98 static void initialize_builtins PARAMS ((cpp_reader *));
99 static void append_include_chain PARAMS ((cpp_reader *,
100 char *, int, int));
101 struct file_name_list * remove_dup_dir PARAMS ((cpp_reader *,
102 struct file_name_list *));
103 struct file_name_list * remove_dup_dirs PARAMS ((cpp_reader *,
104 struct file_name_list *));
105 static void merge_include_chains PARAMS ((cpp_reader *));
106 static void do_includes PARAMS ((cpp_reader *,
107 struct pending_option *,
108 int));
109 static void set_lang PARAMS ((cpp_reader *, enum c_lang));
110 static void initialize_dependency_output PARAMS ((cpp_reader *));
111 static void initialize_standard_includes PARAMS ((cpp_reader *));
112 static void new_pending_directive PARAMS ((struct cpp_pending *,
113 const char *,
114 cl_directive_handler));
115 #ifdef HOST_EBCDIC
116 static int opt_comp PARAMS ((const void *, const void *));
117 #endif
118 static int parse_option PARAMS ((const char *));
120 /* Fourth argument to append_include_chain: chain to use. */
121 enum { QUOTE = 0, BRACKET, SYSTEM, AFTER };
123 /* If we have designated initializers (GCC >2.7) these tables can be
124 initialized, constant data. Otherwise, they have to be filled in at
125 runtime. */
126 #if HAVE_DESIGNATED_INITIALIZERS
128 #define init_trigraph_map() /* Nothing. */
129 #define TRIGRAPH_MAP \
130 __extension__ const U_CHAR _cpp_trigraph_map[UCHAR_MAX + 1] = {
132 #define END };
133 #define s(p, v) [p] = v,
135 #else
137 #define TRIGRAPH_MAP U_CHAR _cpp_trigraph_map[UCHAR_MAX + 1] = { 0 }; \
138 static void init_trigraph_map PARAMS ((void)) { \
139 unsigned char *x = _cpp_trigraph_map;
141 #define END }
142 #define s(p, v) x[p] = v;
144 #endif
146 TRIGRAPH_MAP
147 s('=', '#') s(')', ']') s('!', '|')
148 s('(', '[') s('\'', '^') s('>', '}')
149 s('/', '\\') s('<', '{') s('-', '~')
152 #undef s
153 #undef END
154 #undef TRIGRAPH_MAP
156 /* Given a colon-separated list of file names PATH,
157 add all the names to the search path for include files. */
159 static void
160 path_include (pfile, list, path)
161 cpp_reader *pfile;
162 char *list;
163 int path;
165 char *p, *q, *name;
167 p = list;
171 /* Find the end of this name. */
172 q = p;
173 while (*q != 0 && *q != PATH_SEPARATOR) q++;
174 if (q == p)
176 /* An empty name in the path stands for the current directory. */
177 name = (char *) xmalloc (2);
178 name[0] = '.';
179 name[1] = 0;
181 else
183 /* Otherwise use the directory that is named. */
184 name = (char *) xmalloc (q - p + 1);
185 memcpy (name, p, q - p);
186 name[q - p] = 0;
189 append_include_chain (pfile, name, path, 0);
191 /* Advance past this name. */
192 if (*q == 0)
193 break;
194 p = q + 1;
196 while (1);
199 /* Append DIR to include path PATH. DIR must be permanently allocated
200 and writable. */
201 static void
202 append_include_chain (pfile, dir, path, cxx_aware)
203 cpp_reader *pfile;
204 char *dir;
205 int path;
206 int cxx_aware;
208 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
209 struct file_name_list *new;
210 struct stat st;
211 unsigned int len;
213 _cpp_simplify_pathname (dir);
214 if (stat (dir, &st))
216 /* Dirs that don't exist are silently ignored. */
217 if (errno != ENOENT)
218 cpp_notice_from_errno (pfile, dir);
219 else if (CPP_OPTION (pfile, verbose))
220 fprintf (stderr, _("ignoring nonexistent directory \"%s\"\n"), dir);
221 return;
224 if (!S_ISDIR (st.st_mode))
226 cpp_notice (pfile, "%s: Not a directory", dir);
227 return;
230 len = strlen (dir);
231 if (len > pfile->max_include_len)
232 pfile->max_include_len = len;
234 new = (struct file_name_list *) xmalloc (sizeof (struct file_name_list));
235 new->name = dir;
236 new->nlen = len;
237 new->ino = st.st_ino;
238 new->dev = st.st_dev;
239 if (path == SYSTEM)
240 new->sysp = cxx_aware ? 1 : 2;
241 else
242 new->sysp = 0;
243 new->name_map = NULL;
244 new->next = NULL;
245 new->alloc = NULL;
247 switch (path)
249 case QUOTE: APPEND (pend, quote, new); break;
250 case BRACKET: APPEND (pend, brack, new); break;
251 case SYSTEM: APPEND (pend, systm, new); break;
252 case AFTER: APPEND (pend, after, new); break;
256 /* Handle a duplicated include path. PREV is the link in the chain
257 before the duplicate. The duplicate is removed from the chain and
258 freed. Returns PREV. */
259 struct file_name_list *
260 remove_dup_dir (pfile, prev)
261 cpp_reader *pfile;
262 struct file_name_list *prev;
264 struct file_name_list *cur = prev->next;
266 if (CPP_OPTION (pfile, verbose))
267 fprintf (stderr, _("ignoring duplicate directory \"%s\"\n"), cur->name);
269 prev->next = cur->next;
270 free (cur->name);
271 free (cur);
273 return prev;
276 /* Remove duplicate directories from a chain. Returns the tail of the
277 chain, or NULL if the chain is empty. This algorithm is quadratic
278 in the number of -I switches, which is acceptable since there
279 aren't usually that many of them. */
280 struct file_name_list *
281 remove_dup_dirs (pfile, head)
282 cpp_reader *pfile;
283 struct file_name_list *head;
285 struct file_name_list *prev = NULL, *cur, *other;
287 for (cur = head; cur; cur = cur->next)
289 for (other = head; other != cur; other = other->next)
290 if (INO_T_EQ (cur->ino, other->ino) && cur->dev == other->dev)
292 cur = remove_dup_dir (pfile, prev);
293 break;
295 prev = cur;
298 return prev;
301 /* Merge the four include chains together in the order quote, bracket,
302 system, after. Remove duplicate dirs (as determined by
303 INO_T_EQ()). The system_include and after_include chains are never
304 referred to again after this function; all access is through the
305 bracket_include path.
307 For the future: Check if the directory is empty (but
308 how?) and possibly preload the include hash. */
310 static void
311 merge_include_chains (pfile)
312 cpp_reader *pfile;
314 struct file_name_list *quote, *brack, *systm, *qtail;
316 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
318 quote = pend->quote_head;
319 brack = pend->brack_head;
320 systm = pend->systm_head;
321 qtail = pend->quote_tail;
323 /* Paste together bracket, system, and after include chains. */
324 if (systm)
325 pend->systm_tail->next = pend->after_head;
326 else
327 systm = pend->after_head;
329 if (brack)
330 pend->brack_tail->next = systm;
331 else
332 brack = systm;
334 /* This is a bit tricky. First we drop dupes from the quote-include
335 list. Then we drop dupes from the bracket-include list.
336 Finally, if qtail and brack are the same directory, we cut out
337 brack.
339 We can't just merge the lists and then uniquify them because
340 then we may lose directories from the <> search path that should
341 be there; consider -Ifoo -Ibar -I- -Ifoo -Iquux. It is however
342 safe to treat -Ibar -Ifoo -I- -Ifoo -Iquux as if written
343 -Ibar -I- -Ifoo -Iquux. */
345 remove_dup_dirs (pfile, brack);
346 qtail = remove_dup_dirs (pfile, quote);
348 if (quote)
350 qtail->next = brack;
352 /* If brack == qtail, remove brack as it's simpler. */
353 if (INO_T_EQ (qtail->ino, brack->ino) && qtail->dev == brack->dev)
354 brack = remove_dup_dir (pfile, qtail);
356 else
357 quote = brack;
359 CPP_OPTION (pfile, quote_include) = quote;
360 CPP_OPTION (pfile, bracket_include) = brack;
363 /* Sets internal flags correctly for a given language, and defines
364 macros if necessary. */
365 static void
366 set_lang (pfile, lang)
367 cpp_reader *pfile;
368 enum c_lang lang;
370 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
372 /* Defaults. */
373 CPP_OPTION (pfile, lang) = lang;
374 CPP_OPTION (pfile, objc) = 0;
375 CPP_OPTION (pfile, cplusplus) = 0;
376 CPP_OPTION (pfile, extended_numbers) = 1; /* Allowed in GNU C and C99. */
378 switch (lang)
380 /* GNU C. */
381 case CLK_GNUC99:
382 CPP_OPTION (pfile, trigraphs) = 0;
383 CPP_OPTION (pfile, dollars_in_ident) = 1;
384 CPP_OPTION (pfile, cplusplus_comments) = 1;
385 CPP_OPTION (pfile, digraphs) = 1;
386 CPP_OPTION (pfile, c99) = 1;
387 new_pending_directive (pend, "__STDC_VERSION__=199901L", cpp_define);
388 break;
389 case CLK_GNUC89:
390 CPP_OPTION (pfile, trigraphs) = 0;
391 CPP_OPTION (pfile, dollars_in_ident) = 1;
392 CPP_OPTION (pfile, cplusplus_comments) = 1;
393 CPP_OPTION (pfile, digraphs) = 1;
394 CPP_OPTION (pfile, c99) = 0;
395 break;
397 /* ISO C. */
398 case CLK_STDC94:
399 new_pending_directive (pend, "__STDC_VERSION__=199409L", cpp_define);
400 case CLK_STDC89:
401 CPP_OPTION (pfile, trigraphs) = 1;
402 CPP_OPTION (pfile, dollars_in_ident) = 0;
403 CPP_OPTION (pfile, cplusplus_comments) = 0;
404 CPP_OPTION (pfile, digraphs) = lang == CLK_STDC94;
405 CPP_OPTION (pfile, c99) = 0;
406 CPP_OPTION (pfile, extended_numbers) = 0;
407 new_pending_directive (pend, "__STRICT_ANSI__", cpp_define);
408 break;
409 case CLK_STDC99:
410 CPP_OPTION (pfile, trigraphs) = 1;
411 CPP_OPTION (pfile, dollars_in_ident) = 0;
412 CPP_OPTION (pfile, cplusplus_comments) = 1;
413 CPP_OPTION (pfile, digraphs) = 1;
414 CPP_OPTION (pfile, c99) = 1;
415 new_pending_directive (pend, "__STRICT_ANSI__", cpp_define);
416 new_pending_directive (pend, "__STDC_VERSION__=199901L", cpp_define);
417 break;
419 /* Objective C. */
420 case CLK_OBJCXX:
421 new_pending_directive (pend, "__cplusplus", cpp_define);
422 CPP_OPTION (pfile, cplusplus) = 1;
423 case CLK_OBJC:
424 CPP_OPTION (pfile, trigraphs) = 0;
425 CPP_OPTION (pfile, dollars_in_ident) = 1;
426 CPP_OPTION (pfile, cplusplus_comments) = 1;
427 CPP_OPTION (pfile, digraphs) = 1;
428 CPP_OPTION (pfile, c99) = 0;
429 CPP_OPTION (pfile, objc) = 1;
430 new_pending_directive (pend, "__OBJC__", cpp_define);
431 break;
433 /* C++. */
434 case CLK_GNUCXX:
435 case CLK_CXX98:
436 CPP_OPTION (pfile, cplusplus) = 1;
437 CPP_OPTION (pfile, trigraphs) = lang == CLK_CXX98;
438 CPP_OPTION (pfile, dollars_in_ident) = lang == CLK_GNUCXX;
439 CPP_OPTION (pfile, cplusplus_comments) = 1;
440 CPP_OPTION (pfile, digraphs) = 1;
441 CPP_OPTION (pfile, c99) = 0;
442 new_pending_directive (pend, "__cplusplus", cpp_define);
443 break;
445 /* Assembler. */
446 case CLK_ASM:
447 CPP_OPTION (pfile, trigraphs) = 0;
448 CPP_OPTION (pfile, dollars_in_ident) = 0; /* Maybe not? */
449 CPP_OPTION (pfile, cplusplus_comments) = 1;
450 CPP_OPTION (pfile, digraphs) = 0;
451 CPP_OPTION (pfile, c99) = 0;
452 new_pending_directive (pend, "__ASSEMBLER__", cpp_define);
453 break;
457 /* initialize initializes library global state. It might not need to
458 do anything depending on the platform and compiler. */
460 static int initialized = 0;
462 static void
463 initialize ()
465 #ifdef HOST_EBCDIC
466 /* For non-ASCII hosts, the cl_options array needs to be sorted at
467 runtime. */
468 qsort (cl_options, N_OPTS, sizeof (struct cl_option), opt_comp);
469 #endif
471 /* Set up the trigraph map. This doesn't need to do anything if we were
472 compiled with a compiler that supports C99 designated initializers. */
473 init_trigraph_map ();
475 initialized = 1;
478 /* Initialize a cpp_reader structure. */
479 cpp_reader *
480 cpp_create_reader (lang)
481 enum c_lang lang;
483 struct spec_nodes *s;
484 cpp_reader *pfile = (cpp_reader *) xcalloc (1, sizeof (cpp_reader));
486 /* Initialise this instance of the library if it hasn't been already. */
487 if (! initialized)
488 initialize ();
490 CPP_OPTION (pfile, warn_import) = 1;
491 CPP_OPTION (pfile, discard_comments) = 1;
492 CPP_OPTION (pfile, show_column) = 1;
493 CPP_OPTION (pfile, tabstop) = 8;
494 CPP_OPTION (pfile, operator_names) = 1;
496 CPP_OPTION (pfile, pending) =
497 (struct cpp_pending *) xcalloc (1, sizeof (struct cpp_pending));
499 /* After creating pfile->pending. */
500 set_lang (pfile, lang);
502 /* Initialize lexer state. */
503 pfile->state.save_comments = ! CPP_OPTION (pfile, discard_comments);
505 /* Indicate date and time not yet calculated. */
506 pfile->date.type = CPP_EOF;
508 /* Initialise the base context. */
509 pfile->context = &pfile->base_context;
510 pfile->base_context.macro = 0;
511 pfile->base_context.prev = pfile->base_context.next = 0;
513 /* Identifier pool initially 8K. Unaligned, permanent pool. */
514 _cpp_init_pool (&pfile->ident_pool, 8 * 1024, 1, 0);
516 /* Argument pool initially 8K. Aligned, temporary pool. */
517 _cpp_init_pool (&pfile->argument_pool, 8 * 1024, 0, 1);
519 /* Macro pool initially 8K. Aligned, permanent pool. */
520 _cpp_init_pool (&pfile->macro_pool, 8 * 1024, 0, 0);
522 _cpp_init_hashtable (pfile);
523 _cpp_init_stacks (pfile);
524 _cpp_init_includes (pfile);
525 _cpp_init_internal_pragmas (pfile);
527 /* Initialize the special nodes. */
528 s = &pfile->spec_nodes;
529 s->n_L = cpp_lookup (pfile, DSC("L"));
530 s->n_defined = cpp_lookup (pfile, DSC("defined"));
531 s->n__Pragma = cpp_lookup (pfile, DSC("_Pragma"));
532 s->n__STRICT_ANSI__ = cpp_lookup (pfile, DSC("__STRICT_ANSI__"));
533 s->n__CHAR_UNSIGNED__ = cpp_lookup (pfile, DSC("__CHAR_UNSIGNED__"));
534 s->n__VA_ARGS__ = cpp_lookup (pfile, DSC("__VA_ARGS__"));
535 s->n__VA_ARGS__->flags |= NODE_DIAGNOSTIC;
537 return pfile;
540 /* Free resources used by PFILE.
541 This is the cpp_reader 'finalizer' or 'destructor' (in C++ terminology). */
542 void
543 cpp_cleanup (pfile)
544 cpp_reader *pfile;
546 struct file_name_list *dir, *dirn;
547 cpp_context *context, *contextn;
549 while (CPP_BUFFER (pfile) != NULL)
550 cpp_pop_buffer (pfile);
552 if (pfile->macro_buffer)
553 free ((PTR) pfile->macro_buffer);
555 if (pfile->deps)
556 deps_free (pfile->deps);
558 _cpp_cleanup_includes (pfile);
559 _cpp_cleanup_stacks (pfile);
560 _cpp_cleanup_hashtable (pfile);
562 _cpp_free_lookaheads (pfile);
564 _cpp_free_pool (&pfile->ident_pool);
565 _cpp_free_pool (&pfile->macro_pool);
566 _cpp_free_pool (&pfile->argument_pool);
568 for (dir = CPP_OPTION (pfile, quote_include); dir; dir = dirn)
570 dirn = dir->next;
571 free (dir->name);
572 free (dir);
575 for (context = pfile->base_context.next; context; context = contextn)
577 contextn = context->next;
578 free (context);
583 /* This structure defines one built-in identifier. A node will be
584 entered in the hash table under the name NAME, with value VALUE (if
585 any). If flags has OPERATOR, the node's operator field is used; if
586 flags has BUILTIN the node's builtin field is used.
588 Two values are not compile time constants, so we tag
589 them in the FLAGS field instead:
590 VERS value is the global version_string, quoted
591 ULP value is the global user_label_prefix
593 Also, macros with CPLUS set in the flags field are entered only for C++. */
595 struct builtin
597 const U_CHAR *name;
598 const char *value;
599 unsigned char builtin;
600 unsigned char operator;
601 unsigned short flags;
602 unsigned short len;
604 #define VERS 0x01
605 #define ULP 0x02
606 #define CPLUS 0x04
607 #define BUILTIN 0x08
608 #define OPERATOR 0x10
610 #define B(n, t) { U n, 0, t, 0, BUILTIN, sizeof n - 1 }
611 #define C(n, v) { U n, v, 0, 0, 0, sizeof n - 1 }
612 #define X(n, f) { U n, 0, 0, 0, f, sizeof n - 1 }
613 #define O(n, c, f) { U n, 0, 0, c, OPERATOR | f, sizeof n - 1 }
614 static const struct builtin builtin_array[] =
616 B("__TIME__", BT_TIME),
617 B("__DATE__", BT_DATE),
618 B("__FILE__", BT_FILE),
619 B("__BASE_FILE__", BT_BASE_FILE),
620 B("__LINE__", BT_SPECLINE),
621 B("__INCLUDE_LEVEL__", BT_INCLUDE_LEVEL),
622 B("__STDC__", BT_STDC),
624 X("__VERSION__", VERS),
625 X("__USER_LABEL_PREFIX__", ULP),
626 C("__REGISTER_PREFIX__", REGISTER_PREFIX),
627 C("__HAVE_BUILTIN_SETJMP__", "1"),
628 #ifndef NO_BUILTIN_SIZE_TYPE
629 C("__SIZE_TYPE__", SIZE_TYPE),
630 #endif
631 #ifndef NO_BUILTIN_PTRDIFF_TYPE
632 C("__PTRDIFF_TYPE__", PTRDIFF_TYPE),
633 #endif
634 #ifndef NO_BUILTIN_WCHAR_TYPE
635 C("__WCHAR_TYPE__", WCHAR_TYPE),
636 #endif
637 #ifndef NO_BUILTIN_WINT_TYPE
638 C("__WINT_TYPE__", WINT_TYPE),
639 #endif
641 /* Named operators known to the preprocessor. These cannot be #defined
642 and always have their stated meaning. They are treated like normal
643 identifiers except for the type code and the meaning. Most of them
644 are only for C++ (but see iso646.h). */
645 O("and", CPP_AND_AND, CPLUS),
646 O("and_eq", CPP_AND_EQ, CPLUS),
647 O("bitand", CPP_AND, CPLUS),
648 O("bitor", CPP_OR, CPLUS),
649 O("compl", CPP_COMPL, CPLUS),
650 O("not", CPP_NOT, CPLUS),
651 O("not_eq", CPP_NOT_EQ, CPLUS),
652 O("or", CPP_OR_OR, CPLUS),
653 O("or_eq", CPP_OR_EQ, CPLUS),
654 O("xor", CPP_XOR, CPLUS),
655 O("xor_eq", CPP_XOR_EQ, CPLUS)
657 #undef B
658 #undef C
659 #undef X
660 #undef O
661 #define builtin_array_end \
662 builtin_array + sizeof(builtin_array)/sizeof(struct builtin)
664 /* Subroutine of cpp_start_read; reads the builtins table above and
665 enters the macros into the hash table. */
666 static void
667 initialize_builtins (pfile)
668 cpp_reader *pfile;
670 const struct builtin *b;
672 for(b = builtin_array; b < builtin_array_end; b++)
674 if ((b->flags & CPLUS) && ! CPP_OPTION (pfile, cplusplus))
675 continue;
677 if ((b->flags & OPERATOR) && ! CPP_OPTION (pfile, operator_names))
678 continue;
680 if (b->flags & (OPERATOR | BUILTIN))
682 cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len);
683 if (b->flags & OPERATOR)
685 hp->flags |= NODE_OPERATOR;
686 hp->value.operator = b->operator;
688 else
690 hp->type = NT_MACRO;
691 hp->flags |= NODE_BUILTIN;
692 hp->value.builtin = b->builtin;
695 else /* A standard macro of some kind. */
697 const char *val;
698 char *str;
700 if (b->flags & VERS)
702 /* Allocate enough space for 'name "value"\n\0'. */
703 str = alloca (b->len + strlen (version_string) + 5);
704 sprintf (str, "%s \"%s\"\n", b->name, version_string);
706 else
708 if (b->flags & ULP)
709 val = CPP_OPTION (pfile, user_label_prefix);
710 else
711 val = b->value;
713 /* Allocate enough space for "name value\n\0". */
714 str = alloca (b->len + strlen (val) + 3);
715 sprintf(str, "%s %s\n", b->name, val);
718 _cpp_define_builtin (pfile, str);
722 #undef BUILTIN
723 #undef OPERATOR
724 #undef VERS
725 #undef ULP
726 #undef CPLUS
727 #undef builtin_array_end
729 /* Another subroutine of cpp_start_read. This one sets up to do
730 dependency-file output. */
731 static void
732 initialize_dependency_output (pfile)
733 cpp_reader *pfile;
735 char *spec, *s, *output_file;
737 /* Either of two environment variables can specify output of deps.
738 Its value is either "OUTPUT_FILE" or "OUTPUT_FILE DEPS_TARGET",
739 where OUTPUT_FILE is the file to write deps info to
740 and DEPS_TARGET is the target to mention in the deps. */
742 if (CPP_OPTION (pfile, print_deps) == 0)
744 spec = getenv ("DEPENDENCIES_OUTPUT");
745 if (spec)
746 CPP_OPTION (pfile, print_deps) = 1;
747 else
749 spec = getenv ("SUNPRO_DEPENDENCIES");
750 if (spec)
751 CPP_OPTION (pfile, print_deps) = 2;
752 else
753 return;
756 /* Find the space before the DEPS_TARGET, if there is one. */
757 s = strchr (spec, ' ');
758 if (s)
760 CPP_OPTION (pfile, deps_target) = s + 1;
761 output_file = (char *) xmalloc (s - spec + 1);
762 memcpy (output_file, spec, s - spec);
763 output_file[s - spec] = 0;
765 else
767 CPP_OPTION (pfile, deps_target) = 0;
768 output_file = spec;
771 CPP_OPTION (pfile, deps_file) = output_file;
772 CPP_OPTION (pfile, print_deps_append) = 1;
775 pfile->deps = deps_init ();
777 /* Print the expected object file name as the target of this Make-rule. */
778 if (CPP_OPTION (pfile, deps_target))
779 deps_add_target (pfile->deps, CPP_OPTION (pfile, deps_target));
780 else if (*CPP_OPTION (pfile, in_fname) == 0)
781 deps_add_target (pfile->deps, "-");
782 else
783 deps_calc_target (pfile->deps, CPP_OPTION (pfile, in_fname));
785 if (CPP_OPTION (pfile, in_fname))
786 deps_add_dep (pfile->deps, CPP_OPTION (pfile, in_fname));
789 /* And another subroutine. This one sets up the standard include path. */
790 static void
791 initialize_standard_includes (pfile)
792 cpp_reader *pfile;
794 char *path;
795 const struct default_include *p;
796 const char *specd_prefix = CPP_OPTION (pfile, include_prefix);
798 /* Several environment variables may add to the include search path.
799 CPATH specifies an additional list of directories to be searched
800 as if specified with -I, while C_INCLUDE_PATH, CPLUS_INCLUDE_PATH,
801 etc. specify an additional list of directories to be searched as
802 if specified with -isystem, for the language indicated. */
804 GET_ENV_PATH_LIST (path, "CPATH");
805 if (path != 0 && *path != 0)
806 path_include (pfile, path, BRACKET);
808 switch ((CPP_OPTION (pfile, objc) << 1) + CPP_OPTION (pfile, cplusplus))
810 case 0:
811 GET_ENV_PATH_LIST (path, "C_INCLUDE_PATH");
812 break;
813 case 1:
814 GET_ENV_PATH_LIST (path, "CPLUS_INCLUDE_PATH");
815 break;
816 case 2:
817 GET_ENV_PATH_LIST (path, "OBJC_INCLUDE_PATH");
818 break;
819 case 3:
820 GET_ENV_PATH_LIST (path, "OBJCPLUS_INCLUDE_PATH");
821 break;
823 if (path != 0 && *path != 0)
824 path_include (pfile, path, SYSTEM);
826 /* Search "translated" versions of GNU directories.
827 These have /usr/local/lib/gcc... replaced by specd_prefix. */
828 if (specd_prefix != 0 && cpp_GCC_INCLUDE_DIR_len)
830 /* Remove the `include' from /usr/local/lib/gcc.../include.
831 GCC_INCLUDE_DIR will always end in /include. */
832 int default_len = cpp_GCC_INCLUDE_DIR_len;
833 char *default_prefix = (char *) alloca (default_len + 1);
834 int specd_len = strlen (specd_prefix);
836 memcpy (default_prefix, cpp_GCC_INCLUDE_DIR, default_len);
837 default_prefix[default_len] = '\0';
839 for (p = cpp_include_defaults; p->fname; p++)
841 /* Some standard dirs are only for C++. */
842 if (!p->cplusplus
843 || (CPP_OPTION (pfile, cplusplus)
844 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
846 /* Does this dir start with the prefix? */
847 if (!memcmp (p->fname, default_prefix, default_len))
849 /* Yes; change prefix and add to search list. */
850 int flen = strlen (p->fname);
851 int this_len = specd_len + flen - default_len;
852 char *str = (char *) xmalloc (this_len + 1);
853 memcpy (str, specd_prefix, specd_len);
854 memcpy (str + specd_len,
855 p->fname + default_len,
856 flen - default_len + 1);
858 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
864 /* Search ordinary names for GNU include directories. */
865 for (p = cpp_include_defaults; p->fname; p++)
867 /* Some standard dirs are only for C++. */
868 if (!p->cplusplus
869 || (CPP_OPTION (pfile, cplusplus)
870 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
872 char *str = xstrdup (update_path (p->fname, p->component));
873 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
878 /* Handles -imacro and -include from the command line. */
879 static void
880 do_includes (pfile, p, scan)
881 cpp_reader *pfile;
882 struct pending_option *p;
883 int scan;
885 while (p)
887 struct pending_option *q;
889 /* Later: maybe update this to use the #include "" search path
890 if cpp_read_file fails. */
891 if (_cpp_read_file (pfile, p->arg) && scan)
892 cpp_scan_buffer_nooutput (pfile, 0);
893 q = p->next;
894 free (p);
895 p = q;
899 /* This is called after options have been processed. Check options
900 for consistency, and setup for processing input from the file named
901 FNAME. (Use standard input if FNAME == NULL.) Return 1 on success,
902 0 on failure. */
905 cpp_start_read (pfile, fname)
906 cpp_reader *pfile;
907 const char *fname;
909 struct pending_option *p, *q;
911 /* -MG doesn't select the form of output and must be specified with one of
912 -M or -MM. -MG doesn't make sense with -MD or -MMD since they don't
913 inhibit compilation. */
914 if (CPP_OPTION (pfile, print_deps_missing_files)
915 && (CPP_OPTION (pfile, print_deps) == 0
916 || !CPP_OPTION (pfile, no_output)))
918 cpp_fatal (pfile, "-MG must be specified with one of -M or -MM");
919 return 0;
922 /* -Wtraditional is not useful in C++ mode. */
923 if (CPP_OPTION (pfile, cplusplus))
924 CPP_OPTION (pfile, warn_traditional) = 0;
926 /* Set this if it hasn't been set already. */
927 if (CPP_OPTION (pfile, user_label_prefix) == NULL)
928 CPP_OPTION (pfile, user_label_prefix) = USER_LABEL_PREFIX;
930 /* Set up the include search path now. */
931 if (! CPP_OPTION (pfile, no_standard_includes))
932 initialize_standard_includes (pfile);
934 merge_include_chains (pfile);
936 /* With -v, print the list of dirs to search. */
937 if (CPP_OPTION (pfile, verbose))
939 struct file_name_list *l;
940 fprintf (stderr, _("#include \"...\" search starts here:\n"));
941 for (l = CPP_OPTION (pfile, quote_include); l; l = l->next)
943 if (l == CPP_OPTION (pfile, bracket_include))
944 fprintf (stderr, _("#include <...> search starts here:\n"));
945 fprintf (stderr, " %s\n", l->name);
947 fprintf (stderr, _("End of search list.\n"));
950 /* Open the main input file. This must be done early, so we have a
951 buffer to stand on. */
952 if (CPP_OPTION (pfile, in_fname) == NULL
953 || *CPP_OPTION (pfile, in_fname) == 0)
955 CPP_OPTION (pfile, in_fname) = fname;
956 if (CPP_OPTION (pfile, in_fname) == NULL)
957 CPP_OPTION (pfile, in_fname) = "";
959 if (CPP_OPTION (pfile, out_fname) == NULL)
960 CPP_OPTION (pfile, out_fname) = "";
962 if (!_cpp_read_file (pfile, fname))
963 return 0;
965 initialize_dependency_output (pfile);
967 /* Install __LINE__, etc. */
968 initialize_builtins (pfile);
970 /* Do -U's, -D's and -A's in the order they were seen. */
971 p = CPP_OPTION (pfile, pending)->directive_head;
972 while (p)
974 (*p->handler) (pfile, p->arg);
975 q = p->next;
976 free (p);
977 p = q;
979 pfile->done_initializing = 1;
981 /* The -imacros files can be scanned now, but the -include files
982 have to be pushed onto the buffer stack and processed later,
983 otherwise cppmain.c won't see the tokens. include_head was built
984 up as a stack, and popping this stack onto the buffer stack means
985 we preserve the order of the command line. */
986 do_includes (pfile, CPP_OPTION (pfile, pending)->imacros_head, 1);
987 do_includes (pfile, CPP_OPTION (pfile, pending)->include_head, 0);
989 free (CPP_OPTION (pfile, pending));
990 CPP_OPTION (pfile, pending) = NULL;
992 return 1;
995 /* This is called at the end of preprocessing. It pops the
996 last buffer and writes dependency output. It should also
997 clear macro definitions, such that you could call cpp_start_read
998 with a new filename to restart processing. */
999 void
1000 cpp_finish (pfile)
1001 cpp_reader *pfile;
1003 if (CPP_BUFFER (pfile))
1005 cpp_ice (pfile, "buffers still stacked in cpp_finish");
1006 while (CPP_BUFFER (pfile))
1007 cpp_pop_buffer (pfile);
1010 /* Don't write the deps file if preprocessing has failed. */
1011 if (CPP_OPTION (pfile, print_deps) && pfile->errors == 0)
1013 /* Stream on which to print the dependency information. */
1014 FILE *deps_stream = 0;
1015 const char *deps_mode
1016 = CPP_OPTION (pfile, print_deps_append) ? "a" : "w";
1017 if (CPP_OPTION (pfile, deps_file) == 0)
1018 deps_stream = stdout;
1019 else
1021 deps_stream = fopen (CPP_OPTION (pfile, deps_file), deps_mode);
1022 if (deps_stream == 0)
1023 cpp_notice_from_errno (pfile, CPP_OPTION (pfile, deps_file));
1025 if (deps_stream)
1027 deps_write (pfile->deps, deps_stream, 72);
1028 if (CPP_OPTION (pfile, deps_file))
1030 if (ferror (deps_stream) || fclose (deps_stream) != 0)
1031 cpp_fatal (pfile, "I/O error on output");
1036 /* Report on headers that could use multiple include guards. */
1037 if (CPP_OPTION (pfile, print_include_names))
1038 _cpp_report_missing_guards (pfile);
1041 static void
1042 new_pending_directive (pend, text, handler)
1043 struct cpp_pending *pend;
1044 const char *text;
1045 cl_directive_handler handler;
1047 struct pending_option *o = (struct pending_option *)
1048 xmalloc (sizeof (struct pending_option));
1050 o->arg = text;
1051 o->next = NULL;
1052 o->handler = handler;
1053 APPEND (pend, directive, o);
1056 /* Irix6 "cc -n32" and OSF4 cc have problems with char foo[] = ("string");
1057 I.e. a const string initializer with parens around it. That is
1058 what N_("string") resolves to, so we make no_* be macros instead. */
1059 #define no_arg N_("Argument missing after %s")
1060 #define no_ass N_("Assertion missing after %s")
1061 #define no_dir N_("Directory name missing after %s")
1062 #define no_fil N_("File name missing after %s")
1063 #define no_mac N_("Macro name missing after %s")
1064 #define no_pth N_("Path name missing after %s")
1065 #define no_num N_("Number missing after %s")
1067 /* This is the list of all command line options, with the leading
1068 "-" removed. It must be sorted in ASCII collating order. */
1069 #define COMMAND_LINE_OPTIONS \
1070 DEF_OPT("", 0, OPT_stdin_stdout) \
1071 DEF_OPT("$", 0, OPT_dollar) \
1072 DEF_OPT("+", 0, OPT_plus) \
1073 DEF_OPT("-help", 0, OPT__help) \
1074 DEF_OPT("-target-help", 0, OPT_target__help) \
1075 DEF_OPT("-version", 0, OPT__version) \
1076 DEF_OPT("A", no_ass, OPT_A) \
1077 DEF_OPT("C", 0, OPT_C) \
1078 DEF_OPT("D", no_mac, OPT_D) \
1079 DEF_OPT("H", 0, OPT_H) \
1080 DEF_OPT("I", no_dir, OPT_I) \
1081 DEF_OPT("M", 0, OPT_M) \
1082 DEF_OPT("MD", no_fil, OPT_MD) \
1083 DEF_OPT("MG", 0, OPT_MG) \
1084 DEF_OPT("MM", 0, OPT_MM) \
1085 DEF_OPT("MMD", no_fil, OPT_MMD) \
1086 DEF_OPT("P", 0, OPT_P) \
1087 DEF_OPT("U", no_mac, OPT_U) \
1088 DEF_OPT("W", no_arg, OPT_W) /* arg optional */ \
1089 DEF_OPT("d", no_arg, OPT_d) \
1090 DEF_OPT("fleading-underscore", 0, OPT_fleading_underscore) \
1091 DEF_OPT("fno-leading-underscore", 0, OPT_fno_leading_underscore) \
1092 DEF_OPT("fno-operator-names", 0, OPT_fno_operator_names) \
1093 DEF_OPT("fno-preprocessed", 0, OPT_fno_preprocessed) \
1094 DEF_OPT("fno-show-column", 0, OPT_fno_show_column) \
1095 DEF_OPT("fpreprocessed", 0, OPT_fpreprocessed) \
1096 DEF_OPT("fshow-column", 0, OPT_fshow_column) \
1097 DEF_OPT("ftabstop=", no_num, OPT_ftabstop) \
1098 DEF_OPT("g", no_arg, OPT_g) /* arg optional */ \
1099 DEF_OPT("h", 0, OPT_h) \
1100 DEF_OPT("idirafter", no_dir, OPT_idirafter) \
1101 DEF_OPT("imacros", no_fil, OPT_imacros) \
1102 DEF_OPT("include", no_fil, OPT_include) \
1103 DEF_OPT("iprefix", no_pth, OPT_iprefix) \
1104 DEF_OPT("isystem", no_dir, OPT_isystem) \
1105 DEF_OPT("iwithprefix", no_dir, OPT_iwithprefix) \
1106 DEF_OPT("iwithprefixbefore", no_dir, OPT_iwithprefixbefore) \
1107 DEF_OPT("lang-asm", 0, OPT_lang_asm) \
1108 DEF_OPT("lang-c", 0, OPT_lang_c) \
1109 DEF_OPT("lang-c++", 0, OPT_lang_cplusplus) \
1110 DEF_OPT("lang-c89", 0, OPT_lang_c89) \
1111 DEF_OPT("lang-objc", 0, OPT_lang_objc) \
1112 DEF_OPT("lang-objc++", 0, OPT_lang_objcplusplus) \
1113 DEF_OPT("nostdinc", 0, OPT_nostdinc) \
1114 DEF_OPT("nostdinc++", 0, OPT_nostdincplusplus) \
1115 DEF_OPT("o", no_fil, OPT_o) \
1116 DEF_OPT("pedantic", 0, OPT_pedantic) \
1117 DEF_OPT("pedantic-errors", 0, OPT_pedantic_errors) \
1118 DEF_OPT("remap", 0, OPT_remap) \
1119 DEF_OPT("std=c++98", 0, OPT_std_cplusplus98) \
1120 DEF_OPT("std=c89", 0, OPT_std_c89) \
1121 DEF_OPT("std=c99", 0, OPT_std_c99) \
1122 DEF_OPT("std=c9x", 0, OPT_std_c9x) \
1123 DEF_OPT("std=gnu89", 0, OPT_std_gnu89) \
1124 DEF_OPT("std=gnu99", 0, OPT_std_gnu99) \
1125 DEF_OPT("std=gnu9x", 0, OPT_std_gnu9x) \
1126 DEF_OPT("std=iso9899:1990", 0, OPT_std_iso9899_1990) \
1127 DEF_OPT("std=iso9899:199409", 0, OPT_std_iso9899_199409) \
1128 DEF_OPT("std=iso9899:1999", 0, OPT_std_iso9899_1999) \
1129 DEF_OPT("std=iso9899:199x", 0, OPT_std_iso9899_199x) \
1130 DEF_OPT("trigraphs", 0, OPT_trigraphs) \
1131 DEF_OPT("v", 0, OPT_v) \
1132 DEF_OPT("w", 0, OPT_w)
1134 #define DEF_OPT(text, msg, code) code,
1135 enum opt_code
1137 COMMAND_LINE_OPTIONS
1138 N_OPTS
1140 #undef DEF_OPT
1142 struct cl_option
1144 const char *opt_text;
1145 const char *msg;
1146 size_t opt_len;
1147 enum opt_code opt_code;
1150 #define DEF_OPT(text, msg, code) { text, msg, sizeof(text) - 1, code },
1151 #ifdef HOST_EBCDIC
1152 static struct cl_option cl_options[] =
1153 #else
1154 static const struct cl_option cl_options[] =
1155 #endif
1157 COMMAND_LINE_OPTIONS
1159 #undef DEF_OPT
1160 #undef COMMAND_LINE_OPTIONS
1162 /* Perform a binary search to find which, if any, option the given
1163 command-line matches. Returns its index in the option array,
1164 negative on failure. Complications arise since some options can be
1165 suffixed with an argument, and multiple complete matches can occur,
1166 e.g. -iwithprefix and -iwithprefixbefore. Moreover, we want to
1167 accept options beginning with -g and -W that we do not recognise,
1168 but not to swallow any subsequent command line argument; these are
1169 handled as special cases in cpp_handle_option. */
1170 static int
1171 parse_option (input)
1172 const char *input;
1174 unsigned int md, mn, mx;
1175 size_t opt_len;
1176 int comp;
1178 mn = 0;
1179 mx = N_OPTS;
1181 while (mx > mn)
1183 md = (mn + mx) / 2;
1185 opt_len = cl_options[md].opt_len;
1186 comp = memcmp (input, cl_options[md].opt_text, opt_len);
1188 if (comp > 0)
1189 mn = md + 1;
1190 else if (comp < 0)
1191 mx = md;
1192 else
1194 if (input[opt_len] == '\0')
1195 return md;
1196 /* We were passed more text. If the option takes an argument,
1197 we may match a later option or we may have been passed the
1198 argument. The longest possible option match succeeds.
1199 If the option takes no arguments we have not matched and
1200 continue the search (e.g. input="stdc++" match was "stdc"). */
1201 mn = md + 1;
1202 if (cl_options[md].msg)
1204 /* Scan forwards. If we get an exact match, return it.
1205 Otherwise, return the longest option-accepting match.
1206 This loops no more than twice with current options. */
1207 mx = md;
1208 for (; mn < N_OPTS; mn++)
1210 opt_len = cl_options[mn].opt_len;
1211 if (memcmp (input, cl_options[mn].opt_text, opt_len))
1212 break;
1213 if (input[opt_len] == '\0')
1214 return mn;
1215 if (cl_options[mn].msg)
1216 mx = mn;
1218 return mx;
1223 return -1;
1226 /* Handle one command-line option in (argc, argv).
1227 Can be called multiple times, to handle multiple sets of options.
1228 Returns number of strings consumed. */
1231 cpp_handle_option (pfile, argc, argv)
1232 cpp_reader *pfile;
1233 int argc;
1234 char **argv;
1236 int i = 0;
1237 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
1239 if (argv[i][0] != '-')
1241 if (CPP_OPTION (pfile, out_fname) != NULL)
1242 cpp_fatal (pfile, "Too many arguments. Type %s --help for usage info",
1243 progname);
1244 else if (CPP_OPTION (pfile, in_fname) != NULL)
1245 CPP_OPTION (pfile, out_fname) = argv[i];
1246 else
1247 CPP_OPTION (pfile, in_fname) = argv[i];
1249 else
1251 enum opt_code opt_code;
1252 int opt_index;
1253 const char *arg = 0;
1255 /* Skip over '-'. */
1256 opt_index = parse_option (&argv[i][1]);
1257 if (opt_index < 0)
1258 return i;
1260 opt_code = cl_options[opt_index].opt_code;
1261 if (cl_options[opt_index].msg)
1263 arg = &argv[i][cl_options[opt_index].opt_len + 1];
1265 /* Yuk. Special case for -g and -W as they must not swallow
1266 up any following argument. If this becomes common, add
1267 another field to the cl_options table. */
1268 if (arg[0] == '\0' && !(opt_code == OPT_g || opt_code == OPT_W))
1270 arg = argv[++i];
1271 if (!arg)
1273 cpp_fatal (pfile, cl_options[opt_index].msg, argv[i - 1]);
1274 return argc;
1279 switch (opt_code)
1281 case N_OPTS: /* Shut GCC up. */
1282 break;
1283 case OPT_fleading_underscore:
1284 CPP_OPTION (pfile, user_label_prefix) = "_";
1285 break;
1286 case OPT_fno_leading_underscore:
1287 CPP_OPTION (pfile, user_label_prefix) = "";
1288 break;
1289 case OPT_fno_operator_names:
1290 CPP_OPTION (pfile, operator_names) = 0;
1291 break;
1292 case OPT_fpreprocessed:
1293 CPP_OPTION (pfile, preprocessed) = 1;
1294 break;
1295 case OPT_fno_preprocessed:
1296 CPP_OPTION (pfile, preprocessed) = 0;
1297 break;
1298 case OPT_fshow_column:
1299 CPP_OPTION (pfile, show_column) = 1;
1300 break;
1301 case OPT_fno_show_column:
1302 CPP_OPTION (pfile, show_column) = 0;
1303 break;
1304 case OPT_ftabstop:
1305 /* Silently ignore empty string, non-longs and silly values. */
1306 if (arg[0] != '\0')
1308 char *endptr;
1309 long tabstop = strtol (arg, &endptr, 10);
1310 if (*endptr == '\0' && tabstop >= 1 && tabstop <= 100)
1311 CPP_OPTION (pfile, tabstop) = tabstop;
1313 break;
1314 case OPT_w:
1315 CPP_OPTION (pfile, inhibit_warnings) = 1;
1316 break;
1317 case OPT_g: /* Silently ignore anything but -g3. */
1318 if (!strcmp(&argv[i][2], "3"))
1319 CPP_OPTION (pfile, debug_output) = 1;
1320 break;
1321 case OPT_h:
1322 case OPT__help:
1323 print_help ();
1324 exit (0); /* XXX */
1325 break;
1326 case OPT_target__help:
1327 /* Print if any target specific options. */
1328 exit (0);
1329 break;
1330 case OPT__version:
1331 fprintf (stderr, _("GNU CPP version %s (cpplib)\n"), version_string);
1332 exit (0); /* XXX */
1333 break;
1334 case OPT_C:
1335 CPP_OPTION (pfile, discard_comments) = 0;
1336 break;
1337 case OPT_P:
1338 CPP_OPTION (pfile, no_line_commands) = 1;
1339 break;
1340 case OPT_dollar: /* Don't include $ in identifiers. */
1341 CPP_OPTION (pfile, dollars_in_ident) = 0;
1342 break;
1343 case OPT_H:
1344 CPP_OPTION (pfile, print_include_names) = 1;
1345 break;
1346 case OPT_D:
1347 new_pending_directive (pend, arg, cpp_define);
1348 break;
1349 case OPT_pedantic_errors:
1350 CPP_OPTION (pfile, pedantic_errors) = 1;
1351 /* fall through */
1352 case OPT_pedantic:
1353 CPP_OPTION (pfile, pedantic) = 1;
1354 break;
1355 case OPT_trigraphs:
1356 CPP_OPTION (pfile, trigraphs) = 1;
1357 break;
1358 case OPT_plus:
1359 CPP_OPTION (pfile, cplusplus) = 1;
1360 CPP_OPTION (pfile, cplusplus_comments) = 1;
1361 break;
1362 case OPT_remap:
1363 CPP_OPTION (pfile, remap) = 1;
1364 break;
1365 case OPT_iprefix:
1366 CPP_OPTION (pfile, include_prefix) = arg;
1367 CPP_OPTION (pfile, include_prefix_len) = strlen (arg);
1368 break;
1369 case OPT_lang_c:
1370 set_lang (pfile, CLK_GNUC89);
1371 break;
1372 case OPT_lang_cplusplus:
1373 set_lang (pfile, CLK_GNUCXX);
1374 break;
1375 case OPT_lang_objc:
1376 set_lang (pfile, CLK_OBJC);
1377 break;
1378 case OPT_lang_objcplusplus:
1379 set_lang (pfile, CLK_OBJCXX);
1380 break;
1381 case OPT_lang_asm:
1382 set_lang (pfile, CLK_ASM);
1383 break;
1384 case OPT_std_cplusplus98:
1385 set_lang (pfile, CLK_CXX98);
1386 break;
1387 case OPT_std_gnu89:
1388 set_lang (pfile, CLK_GNUC89);
1389 break;
1390 case OPT_std_gnu9x:
1391 case OPT_std_gnu99:
1392 set_lang (pfile, CLK_GNUC99);
1393 break;
1394 case OPT_std_iso9899_199409:
1395 set_lang (pfile, CLK_STDC94);
1396 break;
1397 case OPT_std_iso9899_1990:
1398 case OPT_std_c89:
1399 case OPT_lang_c89:
1400 set_lang (pfile, CLK_STDC89);
1401 break;
1402 case OPT_std_iso9899_199x:
1403 case OPT_std_iso9899_1999:
1404 case OPT_std_c9x:
1405 case OPT_std_c99:
1406 set_lang (pfile, CLK_STDC99);
1407 break;
1408 case OPT_nostdinc:
1409 /* -nostdinc causes no default include directories.
1410 You must specify all include-file directories with -I. */
1411 CPP_OPTION (pfile, no_standard_includes) = 1;
1412 break;
1413 case OPT_nostdincplusplus:
1414 /* -nostdinc++ causes no default C++-specific include directories. */
1415 CPP_OPTION (pfile, no_standard_cplusplus_includes) = 1;
1416 break;
1417 case OPT_o:
1418 if (CPP_OPTION (pfile, out_fname) != NULL)
1420 cpp_fatal (pfile, "Output filename specified twice");
1421 return argc;
1423 CPP_OPTION (pfile, out_fname) = arg;
1424 if (!strcmp (CPP_OPTION (pfile, out_fname), "-"))
1425 CPP_OPTION (pfile, out_fname) = "";
1426 break;
1427 case OPT_v:
1428 fprintf (stderr, _("GNU CPP version %s (cpplib)"), version_string);
1429 #ifdef TARGET_VERSION
1430 TARGET_VERSION;
1431 #endif
1432 fputc ('\n', stderr);
1433 CPP_OPTION (pfile, verbose) = 1;
1434 break;
1435 case OPT_stdin_stdout:
1436 /* JF handle '-' as file name meaning stdin or stdout. */
1437 if (CPP_OPTION (pfile, in_fname) == NULL)
1438 CPP_OPTION (pfile, in_fname) = "";
1439 else if (CPP_OPTION (pfile, out_fname) == NULL)
1440 CPP_OPTION (pfile, out_fname) = "";
1441 break;
1442 case OPT_d:
1443 /* Args to -d specify what parts of macros to dump.
1444 Silently ignore unrecognised options; they may
1445 be aimed at the compiler proper. */
1447 char c;
1449 while ((c = *arg++) != '\0')
1450 switch (c)
1452 case 'M':
1453 CPP_OPTION (pfile, dump_macros) = dump_only;
1454 CPP_OPTION (pfile, no_output) = 1;
1455 break;
1456 case 'N':
1457 CPP_OPTION (pfile, dump_macros) = dump_names;
1458 break;
1459 case 'D':
1460 CPP_OPTION (pfile, dump_macros) = dump_definitions;
1461 break;
1462 case 'I':
1463 CPP_OPTION (pfile, dump_includes) = 1;
1464 break;
1467 break;
1468 /* The style of the choices here is a bit mixed.
1469 The chosen scheme is a hybrid of keeping all options in one string
1470 and specifying each option in a separate argument:
1471 -M|-MM|-MD file|-MMD file [-MG]. An alternative is:
1472 -M|-MM|-MD file|-MMD file|-MG|-MMG; or more concisely:
1473 -M[M][G][D file]. This is awkward to handle in specs, and is not
1474 as extensible. */
1475 /* ??? -MG must be specified in addition to one of -M or -MM.
1476 This can be relaxed in the future without breaking anything.
1477 The converse isn't true. */
1479 /* -MG isn't valid with -MD or -MMD. This is checked for later. */
1480 case OPT_MG:
1481 CPP_OPTION (pfile, print_deps_missing_files) = 1;
1482 break;
1483 case OPT_M:
1484 case OPT_MD:
1485 case OPT_MM:
1486 case OPT_MMD:
1487 if (opt_code == OPT_M || opt_code == OPT_MD)
1488 CPP_OPTION (pfile, print_deps) = 2;
1489 else
1490 CPP_OPTION (pfile, print_deps) = 1;
1492 /* For -MD and -MMD, write deps on file named by next arg. */
1493 /* For -M and -MM, write deps on standard output and
1494 suppress the usual output. */
1495 if (opt_code == OPT_MD || opt_code == OPT_MMD)
1496 CPP_OPTION (pfile, deps_file) = arg;
1497 else
1498 CPP_OPTION (pfile, no_output) = 1;
1499 break;
1500 case OPT_A:
1501 if (arg[0] == '-')
1503 /* -A with an argument beginning with '-' acts as
1504 #unassert on whatever immediately follows the '-'.
1505 If "-" is the whole argument, we eliminate all
1506 predefined macros and assertions, including those
1507 that were specified earlier on the command line.
1508 That way we can get rid of any that were passed
1509 automatically in from GCC. */
1511 if (arg[1] == '\0')
1513 struct pending_option *o1, *o2;
1515 o1 = pend->directive_head;
1516 while (o1)
1518 o2 = o1->next;
1519 free (o1);
1520 o1 = o2;
1522 pend->directive_head = NULL;
1523 pend->directive_tail = NULL;
1525 else
1526 new_pending_directive (pend, arg + 1, cpp_unassert);
1528 else
1529 new_pending_directive (pend, arg, cpp_assert);
1530 break;
1531 case OPT_U:
1532 new_pending_directive (pend, arg, cpp_undef);
1533 break;
1534 case OPT_I: /* Add directory to path for includes. */
1535 if (!strcmp (arg, "-"))
1537 /* -I- means:
1538 Use the preceding -I directories for #include "..."
1539 but not #include <...>.
1540 Don't search the directory of the present file
1541 for #include "...". (Note that -I. -I- is not the same as
1542 the default setup; -I. uses the compiler's working dir.) */
1543 if (! CPP_OPTION (pfile, ignore_srcdir))
1545 pend->quote_head = pend->brack_head;
1546 pend->quote_tail = pend->brack_tail;
1547 pend->brack_head = 0;
1548 pend->brack_tail = 0;
1549 CPP_OPTION (pfile, ignore_srcdir) = 1;
1551 else
1553 cpp_fatal (pfile, "-I- specified twice");
1554 return argc;
1557 else
1558 append_include_chain (pfile, xstrdup (arg), BRACKET, 0);
1559 break;
1560 case OPT_isystem:
1561 /* Add directory to beginning of system include path, as a system
1562 include directory. */
1563 append_include_chain (pfile, xstrdup (arg), SYSTEM, 0);
1564 break;
1565 case OPT_include:
1567 struct pending_option *o = (struct pending_option *)
1568 xmalloc (sizeof (struct pending_option));
1569 o->arg = arg;
1571 /* This list has to be built in reverse order so that
1572 when cpp_start_read pushes all the -include files onto
1573 the buffer stack, they will be scanned in forward order. */
1574 o->next = pend->include_head;
1575 pend->include_head = o;
1577 break;
1578 case OPT_imacros:
1580 struct pending_option *o = (struct pending_option *)
1581 xmalloc (sizeof (struct pending_option));
1582 o->arg = arg;
1583 o->next = NULL;
1585 APPEND (pend, imacros, o);
1587 break;
1588 case OPT_iwithprefix:
1589 /* Add directory to end of path for includes,
1590 with the default prefix at the front of its name. */
1591 /* fall through */
1592 case OPT_iwithprefixbefore:
1593 /* Add directory to main path for includes,
1594 with the default prefix at the front of its name. */
1596 char *fname;
1597 int len;
1599 len = strlen (arg);
1601 if (CPP_OPTION (pfile, include_prefix) != 0)
1603 size_t ipl = CPP_OPTION (pfile, include_prefix_len);
1604 fname = xmalloc (ipl + len + 1);
1605 memcpy (fname, CPP_OPTION (pfile, include_prefix), ipl);
1606 memcpy (fname + ipl, arg, len + 1);
1608 else if (cpp_GCC_INCLUDE_DIR_len)
1610 fname = xmalloc (cpp_GCC_INCLUDE_DIR_len + len + 1);
1611 memcpy (fname, cpp_GCC_INCLUDE_DIR, cpp_GCC_INCLUDE_DIR_len);
1612 memcpy (fname + cpp_GCC_INCLUDE_DIR_len, arg, len + 1);
1614 else
1615 fname = xstrdup (arg);
1617 append_include_chain (pfile, fname,
1618 opt_code == OPT_iwithprefix ? SYSTEM: BRACKET, 0);
1620 break;
1621 case OPT_idirafter:
1622 /* Add directory to end of path for includes. */
1623 append_include_chain (pfile, xstrdup (arg), AFTER, 0);
1624 break;
1625 case OPT_W:
1626 /* Silently ignore unrecognised options. */
1627 if (!strcmp (argv[i], "-Wall"))
1629 CPP_OPTION (pfile, warn_trigraphs) = 1;
1630 CPP_OPTION (pfile, warn_comments) = 1;
1632 else if (!strcmp (argv[i], "-Wtraditional"))
1633 CPP_OPTION (pfile, warn_traditional) = 1;
1634 else if (!strcmp (argv[i], "-Wtrigraphs"))
1635 CPP_OPTION (pfile, warn_trigraphs) = 1;
1636 else if (!strcmp (argv[i], "-Wcomment"))
1637 CPP_OPTION (pfile, warn_comments) = 1;
1638 else if (!strcmp (argv[i], "-Wcomments"))
1639 CPP_OPTION (pfile, warn_comments) = 1;
1640 else if (!strcmp (argv[i], "-Wundef"))
1641 CPP_OPTION (pfile, warn_undef) = 1;
1642 else if (!strcmp (argv[i], "-Wimport"))
1643 CPP_OPTION (pfile, warn_import) = 1;
1644 else if (!strcmp (argv[i], "-Werror"))
1645 CPP_OPTION (pfile, warnings_are_errors) = 1;
1646 else if (!strcmp (argv[i], "-Wsystem-headers"))
1647 CPP_OPTION (pfile, warn_system_headers) = 1;
1648 else if (!strcmp (argv[i], "-Wno-traditional"))
1649 CPP_OPTION (pfile, warn_traditional) = 0;
1650 else if (!strcmp (argv[i], "-Wno-trigraphs"))
1651 CPP_OPTION (pfile, warn_trigraphs) = 0;
1652 else if (!strcmp (argv[i], "-Wno-comment"))
1653 CPP_OPTION (pfile, warn_comments) = 0;
1654 else if (!strcmp (argv[i], "-Wno-comments"))
1655 CPP_OPTION (pfile, warn_comments) = 0;
1656 else if (!strcmp (argv[i], "-Wno-undef"))
1657 CPP_OPTION (pfile, warn_undef) = 0;
1658 else if (!strcmp (argv[i], "-Wno-import"))
1659 CPP_OPTION (pfile, warn_import) = 0;
1660 else if (!strcmp (argv[i], "-Wno-error"))
1661 CPP_OPTION (pfile, warnings_are_errors) = 0;
1662 else if (!strcmp (argv[i], "-Wno-system-headers"))
1663 CPP_OPTION (pfile, warn_system_headers) = 0;
1664 break;
1667 return i + 1;
1670 #ifdef HOST_EBCDIC
1671 static int
1672 opt_comp (const void *p1, const void *p2)
1674 return strcmp (((struct cl_option *)p1)->opt_text,
1675 ((struct cl_option *)p2)->opt_text);
1677 #endif
1679 /* Handle command-line options in (argc, argv).
1680 Can be called multiple times, to handle multiple sets of options.
1681 Returns if an unrecognized option is seen.
1682 Returns number of strings consumed. */
1684 cpp_handle_options (pfile, argc, argv)
1685 cpp_reader *pfile;
1686 int argc;
1687 char **argv;
1689 int i;
1690 int strings_processed;
1692 for (i = 0; i < argc; i += strings_processed)
1694 strings_processed = cpp_handle_option (pfile, argc - i, argv + i);
1695 if (strings_processed == 0)
1696 break;
1698 return i;
1701 static void
1702 print_help ()
1704 fprintf (stderr, _("Usage: %s [switches] input output\n"), progname);
1705 /* To keep the lines from getting too long for some compilers, limit
1706 to about 500 characters (6 lines) per chunk. */
1707 fputs (_("\
1708 Switches:\n\
1709 -include <file> Include the contents of <file> before other files\n\
1710 -imacros <file> Accept definition of macros in <file>\n\
1711 -iprefix <path> Specify <path> as a prefix for next two options\n\
1712 -iwithprefix <dir> Add <dir> to the end of the system include path\n\
1713 -iwithprefixbefore <dir> Add <dir> to the end of the main include path\n\
1714 -isystem <dir> Add <dir> to the start of the system include path\n\
1715 "), stdout);
1716 fputs (_("\
1717 -idirafter <dir> Add <dir> to the end of the system include path\n\
1718 -I <dir> Add <dir> to the end of the main include path\n\
1719 -I- Fine-grained include path control; see info docs\n\
1720 -nostdinc Do not search system include directories\n\
1721 (dirs specified with -isystem will still be used)\n\
1722 -nostdinc++ Do not search system include directories for C++\n\
1723 -o <file> Put output into <file>\n\
1724 "), stdout);
1725 fputs (_("\
1726 -pedantic Issue all warnings demanded by strict ISO C\n\
1727 -pedantic-errors Issue -pedantic warnings as errors instead\n\
1728 -trigraphs Support ISO C trigraphs\n\
1729 -lang-c Assume that the input sources are in C\n\
1730 -lang-c89 Assume that the input sources are in C89\n\
1731 "), stdout);
1732 fputs (_("\
1733 -lang-c++ Assume that the input sources are in C++\n\
1734 -lang-objc Assume that the input sources are in ObjectiveC\n\
1735 -lang-objc++ Assume that the input sources are in ObjectiveC++\n\
1736 -lang-asm Assume that the input sources are in assembler\n\
1737 "), stdout);
1738 fputs (_("\
1739 -std=<std name> Specify the conformance standard; one of:\n\
1740 gnu89, gnu99, c89, c99, iso9899:1990,\n\
1741 iso9899:199409, iso9899:1999\n\
1742 -+ Allow parsing of C++ style features\n\
1743 -w Inhibit warning messages\n\
1744 -Wtrigraphs Warn if trigraphs are encountered\n\
1745 -Wno-trigraphs Do not warn about trigraphs\n\
1746 -Wcomment{s} Warn if one comment starts inside another\n\
1747 "), stdout);
1748 fputs (_("\
1749 -Wno-comment{s} Do not warn about comments\n\
1750 -Wtraditional Warn about features not present in traditional C\n\
1751 -Wno-traditional Do not warn about traditional C\n\
1752 -Wundef Warn if an undefined macro is used by #if\n\
1753 -Wno-undef Do not warn about testing undefined macros\n\
1754 -Wimport Warn about the use of the #import directive\n\
1755 "), stdout);
1756 fputs (_("\
1757 -Wno-import Do not warn about the use of #import\n\
1758 -Werror Treat all warnings as errors\n\
1759 -Wno-error Do not treat warnings as errors\n\
1760 -Wsystem-headers Do not suppress warnings from system headers\n\
1761 -Wno-system-headers Suppress warnings from system headers\n\
1762 -Wall Enable all preprocessor warnings\n\
1763 "), stdout);
1764 fputs (_("\
1765 -M Generate make dependencies\n\
1766 -MM As -M, but ignore system header files\n\
1767 -MD As -M, but put output in a .d file\n\
1768 -MMD As -MD, but ignore system header files\n\
1769 -MG Treat missing header file as generated files\n\
1770 -g3 Include #define and #undef directives in the output\n\
1771 "), stdout);
1772 fputs (_("\
1773 -D<macro> Define a <macro> with string '1' as its value\n\
1774 -D<macro>=<val> Define a <macro> with <val> as its value\n\
1775 -A<question> (<answer>) Assert the <answer> to <question>\n\
1776 -A-<question> (<answer>) Disable the <answer> to <question>\n\
1777 -U<macro> Undefine <macro> \n\
1778 -v Display the version number\n\
1779 "), stdout);
1780 fputs (_("\
1781 -H Print the name of header files as they are used\n\
1782 -C Do not discard comments\n\
1783 -dM Display a list of macro definitions active at end\n\
1784 -dD Preserve macro definitions in output\n\
1785 -dN As -dD except that only the names are preserved\n\
1786 -dI Include #include directives in the output\n\
1787 "), stdout);
1788 fputs (_("\
1789 -ftabstop=<number> Distance between tab stops for column reporting\n\
1790 -P Do not generate #line directives\n\
1791 -$ Do not allow '$' in identifiers\n\
1792 -remap Remap file names when including files.\n\
1793 --version Display version information\n\
1794 -h or --help Display this information\n\
1795 "), stdout);