2001-01-23 Alexandre Petit-Bianco <apbianco@cygnus.com>
[official-gcc.git] / gcc / cppinit.c
blob93568f4b1fccca336502b8d184b5f63c3e33850f
1 /* CPP Library.
2 Copyright (C) 1986, 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001 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 #else
45 # if (defined _WIN32 && ! defined (_UWIN)) || defined __MSDOS__
46 # define INO_T_EQ(a, b) 0
47 # else
48 # define INO_T_EQ(a, b) ((a) == (b))
49 # endif
50 #endif
52 /* Internal structures and prototypes. */
54 /* A `struct pending_option' remembers one -D, -A, -U, -include, or
55 -imacros switch. */
57 typedef void (* cl_directive_handler) PARAMS ((cpp_reader *, const char *));
58 struct pending_option
60 struct pending_option *next;
61 const char *arg;
62 cl_directive_handler handler;
65 /* The `pending' structure accumulates all the options that are not
66 actually processed until we hit cpp_start_read. It consists of
67 several lists, one for each type of option. We keep both head and
68 tail pointers for quick insertion. */
69 struct cpp_pending
71 struct pending_option *directive_head, *directive_tail;
73 struct file_name_list *quote_head, *quote_tail;
74 struct file_name_list *brack_head, *brack_tail;
75 struct file_name_list *systm_head, *systm_tail;
76 struct file_name_list *after_head, *after_tail;
78 struct pending_option *imacros_head, *imacros_tail;
79 struct pending_option *include_head, *include_tail;
82 #ifdef __STDC__
83 #define APPEND(pend, list, elt) \
84 do { if (!(pend)->list##_head) (pend)->list##_head = (elt); \
85 else (pend)->list##_tail->next = (elt); \
86 (pend)->list##_tail = (elt); \
87 } while (0)
88 #else
89 #define APPEND(pend, list, elt) \
90 do { if (!(pend)->list/**/_head) (pend)->list/**/_head = (elt); \
91 else (pend)->list/**/_tail->next = (elt); \
92 (pend)->list/**/_tail = (elt); \
93 } while (0)
94 #endif
96 static void print_help PARAMS ((void));
97 static void path_include PARAMS ((cpp_reader *,
98 char *, int));
99 static void init_library PARAMS ((void));
100 static void init_builtins PARAMS ((cpp_reader *));
101 static void append_include_chain PARAMS ((cpp_reader *,
102 char *, int, int));
103 struct file_name_list * remove_dup_dir PARAMS ((cpp_reader *,
104 struct file_name_list *));
105 struct file_name_list * remove_dup_dirs PARAMS ((cpp_reader *,
106 struct file_name_list *));
107 static void merge_include_chains PARAMS ((cpp_reader *));
108 static void do_includes PARAMS ((cpp_reader *,
109 struct pending_option *,
110 int));
111 static void set_lang PARAMS ((cpp_reader *, enum c_lang));
112 static void init_dependency_output PARAMS ((cpp_reader *));
113 static void init_standard_includes PARAMS ((cpp_reader *));
114 static void new_pending_directive PARAMS ((struct cpp_pending *,
115 const char *,
116 cl_directive_handler));
117 static void output_deps PARAMS ((cpp_reader *));
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 #ifdef HOST_EBCDIC
458 static int opt_comp PARAMS ((const void *, const void *));
460 /* Run-time sorting of options array. */
461 static int
462 opt_comp (p1, p2)
463 const void *p1, *p2;
465 return strcmp (((struct cl_option *) p1)->opt_text,
466 ((struct cl_option *) p2)->opt_text);
468 #endif
470 /* init initializes library global state. It might not need to
471 do anything depending on the platform and compiler. */
473 static void
474 init_library ()
476 static int initialized = 0;
478 if (! initialized)
480 initialized = 1;
482 #ifdef HOST_EBCDIC
483 /* For non-ASCII hosts, the cl_options array needs to be sorted at
484 runtime. */
485 qsort (cl_options, N_OPTS, sizeof (struct cl_option), opt_comp);
486 #endif
488 /* Set up the trigraph map. This doesn't need to do anything if
489 we were compiled with a compiler that supports C99 designated
490 initializers. */
491 init_trigraph_map ();
495 /* Initialize a cpp_reader structure. */
496 cpp_reader *
497 cpp_create_reader (lang)
498 enum c_lang lang;
500 struct spec_nodes *s;
501 cpp_reader *pfile;
503 /* Initialise this instance of the library if it hasn't been already. */
504 init_library ();
506 pfile = (cpp_reader *) xcalloc (1, sizeof (cpp_reader));
508 CPP_OPTION (pfile, warn_import) = 1;
509 CPP_OPTION (pfile, discard_comments) = 1;
510 CPP_OPTION (pfile, show_column) = 1;
511 CPP_OPTION (pfile, tabstop) = 8;
512 CPP_OPTION (pfile, operator_names) = 1;
514 CPP_OPTION (pfile, pending) =
515 (struct cpp_pending *) xcalloc (1, sizeof (struct cpp_pending));
517 /* After creating pfile->pending. */
518 set_lang (pfile, lang);
520 /* It's simplest to just create this struct whether or not it will
521 be needed. */
522 pfile->deps = deps_init ();
524 /* Initialize lexer state. */
525 pfile->state.save_comments = ! CPP_OPTION (pfile, discard_comments);
527 /* Indicate date and time not yet calculated. */
528 pfile->date.type = CPP_EOF;
530 /* Initialise the base context. */
531 pfile->context = &pfile->base_context;
532 pfile->base_context.macro = 0;
533 pfile->base_context.prev = pfile->base_context.next = 0;
535 /* Identifier pool initially 8K. Unaligned, permanent pool. */
536 _cpp_init_pool (&pfile->ident_pool, 8 * 1024, 1, 0);
538 /* Argument pool initially 8K. Aligned, temporary pool. */
539 _cpp_init_pool (&pfile->argument_pool, 8 * 1024, 0, 1);
541 /* Macro pool initially 8K. Aligned, permanent pool. */
542 _cpp_init_pool (&pfile->macro_pool, 8 * 1024, 0, 0);
544 _cpp_init_hashtable (pfile);
545 _cpp_init_stacks (pfile);
546 _cpp_init_includes (pfile);
547 _cpp_init_internal_pragmas (pfile);
549 /* Initialize the special nodes. */
550 s = &pfile->spec_nodes;
551 s->n_L = cpp_lookup (pfile, DSC("L"));
552 s->n_defined = cpp_lookup (pfile, DSC("defined"));
553 s->n__Pragma = cpp_lookup (pfile, DSC("_Pragma"));
554 s->n__STRICT_ANSI__ = cpp_lookup (pfile, DSC("__STRICT_ANSI__"));
555 s->n__CHAR_UNSIGNED__ = cpp_lookup (pfile, DSC("__CHAR_UNSIGNED__"));
556 s->n__VA_ARGS__ = cpp_lookup (pfile, DSC("__VA_ARGS__"));
557 s->n__VA_ARGS__->flags |= NODE_DIAGNOSTIC;
559 return pfile;
562 /* Free resources used by PFILE. Accessing PFILE after this function
563 returns leads to undefined behaviour. */
565 cpp_destroy (pfile)
566 cpp_reader *pfile;
568 int result;
569 struct file_name_list *dir, *dirn;
570 cpp_context *context, *contextn;
572 while (CPP_BUFFER (pfile) != NULL)
573 cpp_pop_buffer (pfile);
575 if (pfile->macro_buffer)
577 free ((PTR) pfile->macro_buffer);
578 pfile->macro_buffer = NULL;
579 pfile->macro_buffer_len = 0;
582 deps_free (pfile->deps);
584 _cpp_cleanup_includes (pfile);
585 _cpp_cleanup_stacks (pfile);
586 _cpp_cleanup_hashtable (pfile);
588 _cpp_free_lookaheads (pfile);
590 _cpp_free_pool (&pfile->ident_pool);
591 _cpp_free_pool (&pfile->macro_pool);
592 _cpp_free_pool (&pfile->argument_pool);
594 for (dir = CPP_OPTION (pfile, quote_include); dir; dir = dirn)
596 dirn = dir->next;
597 free (dir->name);
598 free (dir);
601 for (context = pfile->base_context.next; context; context = contextn)
603 contextn = context->next;
604 free (context);
607 result = pfile->errors;
608 free (pfile);
610 return result;
614 /* This structure defines one built-in identifier. A node will be
615 entered in the hash table under the name NAME, with value VALUE (if
616 any). If flags has OPERATOR, the node's operator field is used; if
617 flags has BUILTIN the node's builtin field is used.
619 Two values are not compile time constants, so we tag
620 them in the FLAGS field instead:
621 VERS value is the global version_string, quoted
622 ULP value is the global user_label_prefix
624 Also, macros with CPLUS set in the flags field are entered only for C++. */
626 struct builtin
628 const U_CHAR *name;
629 const char *value;
630 unsigned char builtin;
631 unsigned char operator;
632 unsigned short flags;
633 unsigned short len;
635 #define VERS 0x01
636 #define ULP 0x02
637 #define CPLUS 0x04
638 #define BUILTIN 0x08
639 #define OPERATOR 0x10
641 #define B(n, t) { U n, 0, t, 0, BUILTIN, sizeof n - 1 }
642 #define C(n, v) { U n, v, 0, 0, 0, sizeof n - 1 }
643 #define X(n, f) { U n, 0, 0, 0, f, sizeof n - 1 }
644 #define O(n, c, f) { U n, 0, 0, c, OPERATOR | f, sizeof n - 1 }
645 static const struct builtin builtin_array[] =
647 B("__TIME__", BT_TIME),
648 B("__DATE__", BT_DATE),
649 B("__FILE__", BT_FILE),
650 B("__BASE_FILE__", BT_BASE_FILE),
651 B("__LINE__", BT_SPECLINE),
652 B("__INCLUDE_LEVEL__", BT_INCLUDE_LEVEL),
653 B("__STDC__", BT_STDC),
655 X("__VERSION__", VERS),
656 X("__USER_LABEL_PREFIX__", ULP),
657 C("__REGISTER_PREFIX__", REGISTER_PREFIX),
658 C("__HAVE_BUILTIN_SETJMP__", "1"),
659 #ifndef NO_BUILTIN_SIZE_TYPE
660 C("__SIZE_TYPE__", SIZE_TYPE),
661 #endif
662 #ifndef NO_BUILTIN_PTRDIFF_TYPE
663 C("__PTRDIFF_TYPE__", PTRDIFF_TYPE),
664 #endif
665 #ifndef NO_BUILTIN_WCHAR_TYPE
666 C("__WCHAR_TYPE__", WCHAR_TYPE),
667 #endif
668 #ifndef NO_BUILTIN_WINT_TYPE
669 C("__WINT_TYPE__", WINT_TYPE),
670 #endif
672 /* Named operators known to the preprocessor. These cannot be #defined
673 and always have their stated meaning. They are treated like normal
674 identifiers except for the type code and the meaning. Most of them
675 are only for C++ (but see iso646.h). */
676 O("and", CPP_AND_AND, CPLUS),
677 O("and_eq", CPP_AND_EQ, CPLUS),
678 O("bitand", CPP_AND, CPLUS),
679 O("bitor", CPP_OR, CPLUS),
680 O("compl", CPP_COMPL, CPLUS),
681 O("not", CPP_NOT, CPLUS),
682 O("not_eq", CPP_NOT_EQ, CPLUS),
683 O("or", CPP_OR_OR, CPLUS),
684 O("or_eq", CPP_OR_EQ, CPLUS),
685 O("xor", CPP_XOR, CPLUS),
686 O("xor_eq", CPP_XOR_EQ, CPLUS)
688 #undef B
689 #undef C
690 #undef X
691 #undef O
692 #define builtin_array_end \
693 builtin_array + sizeof(builtin_array)/sizeof(struct builtin)
695 /* Subroutine of cpp_start_read; reads the builtins table above and
696 enters the macros into the hash table. */
697 static void
698 init_builtins (pfile)
699 cpp_reader *pfile;
701 const struct builtin *b;
703 for(b = builtin_array; b < builtin_array_end; b++)
705 if ((b->flags & CPLUS) && ! CPP_OPTION (pfile, cplusplus))
706 continue;
708 if ((b->flags & OPERATOR) && ! CPP_OPTION (pfile, operator_names))
709 continue;
711 if (b->flags & (OPERATOR | BUILTIN))
713 cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len);
714 if (b->flags & OPERATOR)
716 hp->flags |= NODE_OPERATOR;
717 hp->value.operator = b->operator;
719 else
721 hp->type = NT_MACRO;
722 hp->flags |= NODE_BUILTIN;
723 hp->value.builtin = b->builtin;
726 else /* A standard macro of some kind. */
728 const char *val;
729 char *str;
731 if (b->flags & VERS)
733 /* Allocate enough space for 'name "value"\n\0'. */
734 str = alloca (b->len + strlen (version_string) + 5);
735 sprintf (str, "%s \"%s\"\n", b->name, version_string);
737 else
739 if (b->flags & ULP)
740 val = CPP_OPTION (pfile, user_label_prefix);
741 else
742 val = b->value;
744 /* Allocate enough space for "name value\n\0". */
745 str = alloca (b->len + strlen (val) + 3);
746 sprintf(str, "%s %s\n", b->name, val);
749 _cpp_define_builtin (pfile, str);
753 #undef BUILTIN
754 #undef OPERATOR
755 #undef VERS
756 #undef ULP
757 #undef CPLUS
758 #undef builtin_array_end
760 /* And another subroutine. This one sets up the standard include path. */
761 static void
762 init_standard_includes (pfile)
763 cpp_reader *pfile;
765 char *path;
766 const struct default_include *p;
767 const char *specd_prefix = CPP_OPTION (pfile, include_prefix);
769 /* Several environment variables may add to the include search path.
770 CPATH specifies an additional list of directories to be searched
771 as if specified with -I, while C_INCLUDE_PATH, CPLUS_INCLUDE_PATH,
772 etc. specify an additional list of directories to be searched as
773 if specified with -isystem, for the language indicated. */
775 GET_ENV_PATH_LIST (path, "CPATH");
776 if (path != 0 && *path != 0)
777 path_include (pfile, path, BRACKET);
779 switch ((CPP_OPTION (pfile, objc) << 1) + CPP_OPTION (pfile, cplusplus))
781 case 0:
782 GET_ENV_PATH_LIST (path, "C_INCLUDE_PATH");
783 break;
784 case 1:
785 GET_ENV_PATH_LIST (path, "CPLUS_INCLUDE_PATH");
786 break;
787 case 2:
788 GET_ENV_PATH_LIST (path, "OBJC_INCLUDE_PATH");
789 break;
790 case 3:
791 GET_ENV_PATH_LIST (path, "OBJCPLUS_INCLUDE_PATH");
792 break;
794 if (path != 0 && *path != 0)
795 path_include (pfile, path, SYSTEM);
797 /* Search "translated" versions of GNU directories.
798 These have /usr/local/lib/gcc... replaced by specd_prefix. */
799 if (specd_prefix != 0 && cpp_GCC_INCLUDE_DIR_len)
801 /* Remove the `include' from /usr/local/lib/gcc.../include.
802 GCC_INCLUDE_DIR will always end in /include. */
803 int default_len = cpp_GCC_INCLUDE_DIR_len;
804 char *default_prefix = (char *) alloca (default_len + 1);
805 int specd_len = strlen (specd_prefix);
807 memcpy (default_prefix, cpp_GCC_INCLUDE_DIR, default_len);
808 default_prefix[default_len] = '\0';
810 for (p = cpp_include_defaults; p->fname; p++)
812 /* Some standard dirs are only for C++. */
813 if (!p->cplusplus
814 || (CPP_OPTION (pfile, cplusplus)
815 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
817 /* Does this dir start with the prefix? */
818 if (!memcmp (p->fname, default_prefix, default_len))
820 /* Yes; change prefix and add to search list. */
821 int flen = strlen (p->fname);
822 int this_len = specd_len + flen - default_len;
823 char *str = (char *) xmalloc (this_len + 1);
824 memcpy (str, specd_prefix, specd_len);
825 memcpy (str + specd_len,
826 p->fname + default_len,
827 flen - default_len + 1);
829 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
835 /* Search ordinary names for GNU include directories. */
836 for (p = cpp_include_defaults; p->fname; p++)
838 /* Some standard dirs are only for C++. */
839 if (!p->cplusplus
840 || (CPP_OPTION (pfile, cplusplus)
841 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
843 char *str = xstrdup (update_path (p->fname, p->component));
844 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
849 /* Handles -imacro and -include from the command line. */
850 static void
851 do_includes (pfile, p, scan)
852 cpp_reader *pfile;
853 struct pending_option *p;
854 int scan;
856 while (p)
858 struct pending_option *q;
860 /* Don't handle if -fpreprocessed. Later: maybe update this to
861 use the #include "" search path if cpp_read_file fails. */
862 if (CPP_OPTION (pfile, preprocessed))
863 cpp_error (pfile, "-include and -imacros cannot be used with -fpreprocessed");
864 else if (_cpp_read_file (pfile, p->arg) && scan)
865 cpp_scan_buffer_nooutput (pfile, 0);
866 q = p->next;
867 free (p);
868 p = q;
872 /* This is called after options have been processed. Setup for
873 processing input from the file named FNAME. (Use standard input if
874 FNAME == NULL.) Return 1 on success, 0 on failure. */
877 cpp_start_read (pfile, fname)
878 cpp_reader *pfile;
879 const char *fname;
881 struct pending_option *p, *q;
883 /* Set up the include search path now. */
884 if (! CPP_OPTION (pfile, no_standard_includes))
885 init_standard_includes (pfile);
887 merge_include_chains (pfile);
889 /* With -v, print the list of dirs to search. */
890 if (CPP_OPTION (pfile, verbose))
892 struct file_name_list *l;
893 fprintf (stderr, _("#include \"...\" search starts here:\n"));
894 for (l = CPP_OPTION (pfile, quote_include); l; l = l->next)
896 if (l == CPP_OPTION (pfile, bracket_include))
897 fprintf (stderr, _("#include <...> search starts here:\n"));
898 fprintf (stderr, " %s\n", l->name);
900 fprintf (stderr, _("End of search list.\n"));
903 if (CPP_OPTION (pfile, in_fname) == NULL
904 || *CPP_OPTION (pfile, in_fname) == 0)
906 CPP_OPTION (pfile, in_fname) = fname;
907 if (CPP_OPTION (pfile, in_fname) == NULL)
908 CPP_OPTION (pfile, in_fname) = "";
910 if (CPP_OPTION (pfile, out_fname) == NULL)
911 CPP_OPTION (pfile, out_fname) = "";
913 if (CPP_OPTION (pfile, print_deps))
915 /* Set the default target (if there is none already), and
916 the dependency on the main file. */
917 deps_add_default_target (pfile->deps, CPP_OPTION (pfile, in_fname));
919 deps_add_dep (pfile->deps, CPP_OPTION (pfile, in_fname));
922 /* Open the main input file. This must be done early, so we have a
923 buffer to stand on. */
924 if (!_cpp_read_file (pfile, fname))
925 return 0;
927 /* If already preprocessed, don't install __LINE__, etc., and ignore
928 command line definitions and assertions. Handle -U's, -D's and
929 -A's in the order they were seen. */
930 if (! CPP_OPTION (pfile, preprocessed))
931 init_builtins (pfile);
933 p = CPP_OPTION (pfile, pending)->directive_head;
934 while (p)
936 if (! CPP_OPTION (pfile, preprocessed))
937 (*p->handler) (pfile, p->arg);
938 q = p->next;
939 free (p);
940 p = q;
943 pfile->done_initializing = 1;
945 /* The -imacros files can be scanned now, but the -include files
946 have to be pushed onto the buffer stack and processed later,
947 otherwise cppmain.c won't see the tokens. include_head was built
948 up as a stack, and popping this stack onto the buffer stack means
949 we preserve the order of the command line. */
950 do_includes (pfile, CPP_OPTION (pfile, pending)->imacros_head, 1);
951 do_includes (pfile, CPP_OPTION (pfile, pending)->include_head, 0);
953 free (CPP_OPTION (pfile, pending));
954 CPP_OPTION (pfile, pending) = NULL;
956 return 1;
959 /* Use mkdeps.c to output dependency information. */
960 static void
961 output_deps (pfile)
962 cpp_reader *pfile;
964 /* Stream on which to print the dependency information. */
965 FILE *deps_stream = 0;
966 const char *deps_mode = CPP_OPTION (pfile, print_deps_append) ? "a" : "w";
968 if (CPP_OPTION (pfile, deps_file) == 0)
969 deps_stream = stdout;
970 else
972 deps_stream = fopen (CPP_OPTION (pfile, deps_file), deps_mode);
973 if (deps_stream == 0)
975 cpp_notice_from_errno (pfile, CPP_OPTION (pfile, deps_file));
976 return;
980 deps_write (pfile->deps, deps_stream, 72);
982 if (CPP_OPTION (pfile, deps_phony_targets))
983 deps_phony_targets (pfile->deps, deps_stream);
985 /* Don't close stdout. */
986 if (CPP_OPTION (pfile, deps_file))
988 if (ferror (deps_stream) || fclose (deps_stream) != 0)
989 cpp_fatal (pfile, "I/O error on output");
993 /* This is called at the end of preprocessing. It pops the
994 last buffer and writes dependency output. It should also
995 clear macro definitions, such that you could call cpp_start_read
996 with a new filename to restart processing. */
997 void
998 cpp_finish (pfile)
999 cpp_reader *pfile;
1001 if (CPP_BUFFER (pfile))
1003 cpp_ice (pfile, "buffers still stacked in cpp_finish");
1004 while (CPP_BUFFER (pfile))
1005 cpp_pop_buffer (pfile);
1008 /* Don't write the deps file if preprocessing has failed. */
1009 if (CPP_OPTION (pfile, print_deps) && pfile->errors == 0)
1010 output_deps (pfile);
1012 /* Report on headers that could use multiple include guards. */
1013 if (CPP_OPTION (pfile, print_include_names))
1014 _cpp_report_missing_guards (pfile);
1017 static void
1018 new_pending_directive (pend, text, handler)
1019 struct cpp_pending *pend;
1020 const char *text;
1021 cl_directive_handler handler;
1023 struct pending_option *o = (struct pending_option *)
1024 xmalloc (sizeof (struct pending_option));
1026 o->arg = text;
1027 o->next = NULL;
1028 o->handler = handler;
1029 APPEND (pend, directive, o);
1032 /* Irix6 "cc -n32" and OSF4 cc have problems with char foo[] = ("string");
1033 I.e. a const string initializer with parens around it. That is
1034 what N_("string") resolves to, so we make no_* be macros instead. */
1035 #define no_arg N_("Argument missing after %s")
1036 #define no_ass N_("Assertion missing after %s")
1037 #define no_dir N_("Directory name missing after %s")
1038 #define no_fil N_("File name missing after %s")
1039 #define no_mac N_("Macro name missing after %s")
1040 #define no_pth N_("Path name missing after %s")
1041 #define no_num N_("Number missing after %s")
1042 #define no_tgt N_("Target missing after %s")
1044 /* This is the list of all command line options, with the leading
1045 "-" removed. It must be sorted in ASCII collating order. */
1046 #define COMMAND_LINE_OPTIONS \
1047 DEF_OPT("", 0, OPT_stdin_stdout) \
1048 DEF_OPT("$", 0, OPT_dollar) \
1049 DEF_OPT("+", 0, OPT_plus) \
1050 DEF_OPT("-help", 0, OPT__help) \
1051 DEF_OPT("-target-help", 0, OPT_target__help) \
1052 DEF_OPT("-version", 0, OPT__version) \
1053 DEF_OPT("A", no_ass, OPT_A) \
1054 DEF_OPT("C", 0, OPT_C) \
1055 DEF_OPT("D", no_mac, OPT_D) \
1056 DEF_OPT("H", 0, OPT_H) \
1057 DEF_OPT("I", no_dir, OPT_I) \
1058 DEF_OPT("M", 0, OPT_M) \
1059 DEF_OPT("MD", no_fil, OPT_MD) \
1060 DEF_OPT("MF", no_fil, OPT_MF) \
1061 DEF_OPT("MG", 0, OPT_MG) \
1062 DEF_OPT("MM", 0, OPT_MM) \
1063 DEF_OPT("MMD", no_fil, OPT_MMD) \
1064 DEF_OPT("MP", 0, OPT_MP) \
1065 DEF_OPT("MQ", no_tgt, OPT_MQ) \
1066 DEF_OPT("MT", no_tgt, OPT_MT) \
1067 DEF_OPT("P", 0, OPT_P) \
1068 DEF_OPT("U", no_mac, OPT_U) \
1069 DEF_OPT("W", no_arg, OPT_W) /* arg optional */ \
1070 DEF_OPT("d", no_arg, OPT_d) \
1071 DEF_OPT("fleading-underscore", 0, OPT_fleading_underscore) \
1072 DEF_OPT("fno-leading-underscore", 0, OPT_fno_leading_underscore) \
1073 DEF_OPT("fno-operator-names", 0, OPT_fno_operator_names) \
1074 DEF_OPT("fno-preprocessed", 0, OPT_fno_preprocessed) \
1075 DEF_OPT("fno-show-column", 0, OPT_fno_show_column) \
1076 DEF_OPT("fpreprocessed", 0, OPT_fpreprocessed) \
1077 DEF_OPT("fshow-column", 0, OPT_fshow_column) \
1078 DEF_OPT("ftabstop=", no_num, OPT_ftabstop) \
1079 DEF_OPT("h", 0, OPT_h) \
1080 DEF_OPT("idirafter", no_dir, OPT_idirafter) \
1081 DEF_OPT("imacros", no_fil, OPT_imacros) \
1082 DEF_OPT("include", no_fil, OPT_include) \
1083 DEF_OPT("iprefix", no_pth, OPT_iprefix) \
1084 DEF_OPT("isystem", no_dir, OPT_isystem) \
1085 DEF_OPT("iwithprefix", no_dir, OPT_iwithprefix) \
1086 DEF_OPT("iwithprefixbefore", no_dir, OPT_iwithprefixbefore) \
1087 DEF_OPT("lang-asm", 0, OPT_lang_asm) \
1088 DEF_OPT("lang-c", 0, OPT_lang_c) \
1089 DEF_OPT("lang-c++", 0, OPT_lang_cplusplus) \
1090 DEF_OPT("lang-c89", 0, OPT_lang_c89) \
1091 DEF_OPT("lang-objc", 0, OPT_lang_objc) \
1092 DEF_OPT("lang-objc++", 0, OPT_lang_objcplusplus) \
1093 DEF_OPT("nostdinc", 0, OPT_nostdinc) \
1094 DEF_OPT("nostdinc++", 0, OPT_nostdincplusplus) \
1095 DEF_OPT("o", no_fil, OPT_o) \
1096 DEF_OPT("pedantic", 0, OPT_pedantic) \
1097 DEF_OPT("pedantic-errors", 0, OPT_pedantic_errors) \
1098 DEF_OPT("remap", 0, OPT_remap) \
1099 DEF_OPT("std=c++98", 0, OPT_std_cplusplus98) \
1100 DEF_OPT("std=c89", 0, OPT_std_c89) \
1101 DEF_OPT("std=c99", 0, OPT_std_c99) \
1102 DEF_OPT("std=c9x", 0, OPT_std_c9x) \
1103 DEF_OPT("std=gnu89", 0, OPT_std_gnu89) \
1104 DEF_OPT("std=gnu99", 0, OPT_std_gnu99) \
1105 DEF_OPT("std=gnu9x", 0, OPT_std_gnu9x) \
1106 DEF_OPT("std=iso9899:1990", 0, OPT_std_iso9899_1990) \
1107 DEF_OPT("std=iso9899:199409", 0, OPT_std_iso9899_199409) \
1108 DEF_OPT("std=iso9899:1999", 0, OPT_std_iso9899_1999) \
1109 DEF_OPT("std=iso9899:199x", 0, OPT_std_iso9899_199x) \
1110 DEF_OPT("trigraphs", 0, OPT_trigraphs) \
1111 DEF_OPT("v", 0, OPT_v) \
1112 DEF_OPT("version", 0, OPT_version) \
1113 DEF_OPT("w", 0, OPT_w)
1115 #define DEF_OPT(text, msg, code) code,
1116 enum opt_code
1118 COMMAND_LINE_OPTIONS
1119 N_OPTS
1121 #undef DEF_OPT
1123 struct cl_option
1125 const char *opt_text;
1126 const char *msg;
1127 size_t opt_len;
1128 enum opt_code opt_code;
1131 #define DEF_OPT(text, msg, code) { text, msg, sizeof(text) - 1, code },
1132 #ifdef HOST_EBCDIC
1133 static struct cl_option cl_options[] =
1134 #else
1135 static const struct cl_option cl_options[] =
1136 #endif
1138 COMMAND_LINE_OPTIONS
1140 #undef DEF_OPT
1141 #undef COMMAND_LINE_OPTIONS
1143 /* Perform a binary search to find which, if any, option the given
1144 command-line matches. Returns its index in the option array,
1145 negative on failure. Complications arise since some options can be
1146 suffixed with an argument, and multiple complete matches can occur,
1147 e.g. -iwithprefix and -iwithprefixbefore. Moreover, we need to
1148 accept options beginning with -W that we do not recognise, but not
1149 to swallow any subsequent command line argument; this is handled as
1150 special cases in cpp_handle_option. */
1151 static int
1152 parse_option (input)
1153 const char *input;
1155 unsigned int md, mn, mx;
1156 size_t opt_len;
1157 int comp;
1159 mn = 0;
1160 mx = N_OPTS;
1162 while (mx > mn)
1164 md = (mn + mx) / 2;
1166 opt_len = cl_options[md].opt_len;
1167 comp = memcmp (input, cl_options[md].opt_text, opt_len);
1169 if (comp > 0)
1170 mn = md + 1;
1171 else if (comp < 0)
1172 mx = md;
1173 else
1175 if (input[opt_len] == '\0')
1176 return md;
1177 /* We were passed more text. If the option takes an argument,
1178 we may match a later option or we may have been passed the
1179 argument. The longest possible option match succeeds.
1180 If the option takes no arguments we have not matched and
1181 continue the search (e.g. input="stdc++" match was "stdc"). */
1182 mn = md + 1;
1183 if (cl_options[md].msg)
1185 /* Scan forwards. If we get an exact match, return it.
1186 Otherwise, return the longest option-accepting match.
1187 This loops no more than twice with current options. */
1188 mx = md;
1189 for (; mn < N_OPTS; mn++)
1191 opt_len = cl_options[mn].opt_len;
1192 if (memcmp (input, cl_options[mn].opt_text, opt_len))
1193 break;
1194 if (input[opt_len] == '\0')
1195 return mn;
1196 if (cl_options[mn].msg)
1197 mx = mn;
1199 return mx;
1204 return -1;
1207 /* Handle one command-line option in (argc, argv).
1208 Can be called multiple times, to handle multiple sets of options.
1209 Returns number of strings consumed. */
1212 cpp_handle_option (pfile, argc, argv)
1213 cpp_reader *pfile;
1214 int argc;
1215 char **argv;
1217 int i = 0;
1218 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
1220 if (argv[i][0] != '-')
1222 if (CPP_OPTION (pfile, out_fname) != NULL)
1223 cpp_fatal (pfile, "Too many arguments. Type %s --help for usage info",
1224 progname);
1225 else if (CPP_OPTION (pfile, in_fname) != NULL)
1226 CPP_OPTION (pfile, out_fname) = argv[i];
1227 else
1228 CPP_OPTION (pfile, in_fname) = argv[i];
1230 else
1232 enum opt_code opt_code;
1233 int opt_index;
1234 const char *arg = 0;
1236 /* Skip over '-'. */
1237 opt_index = parse_option (&argv[i][1]);
1238 if (opt_index < 0)
1239 return i;
1241 opt_code = cl_options[opt_index].opt_code;
1242 if (cl_options[opt_index].msg)
1244 arg = &argv[i][cl_options[opt_index].opt_len + 1];
1246 /* Yuk. Special case for -W as it must not swallow
1247 up any following argument. If this becomes common, add
1248 another field to the cl_options table. */
1249 if (arg[0] == '\0' && opt_code != OPT_W)
1251 arg = argv[++i];
1252 if (!arg)
1254 cpp_fatal (pfile, cl_options[opt_index].msg, argv[i - 1]);
1255 return argc;
1260 switch (opt_code)
1262 case N_OPTS: /* Shut GCC up. */
1263 break;
1264 case OPT_fleading_underscore:
1265 CPP_OPTION (pfile, user_label_prefix) = "_";
1266 break;
1267 case OPT_fno_leading_underscore:
1268 CPP_OPTION (pfile, user_label_prefix) = "";
1269 break;
1270 case OPT_fno_operator_names:
1271 CPP_OPTION (pfile, operator_names) = 0;
1272 break;
1273 case OPT_fpreprocessed:
1274 CPP_OPTION (pfile, preprocessed) = 1;
1275 break;
1276 case OPT_fno_preprocessed:
1277 CPP_OPTION (pfile, preprocessed) = 0;
1278 break;
1279 case OPT_fshow_column:
1280 CPP_OPTION (pfile, show_column) = 1;
1281 break;
1282 case OPT_fno_show_column:
1283 CPP_OPTION (pfile, show_column) = 0;
1284 break;
1285 case OPT_ftabstop:
1286 /* Silently ignore empty string, non-longs and silly values. */
1287 if (arg[0] != '\0')
1289 char *endptr;
1290 long tabstop = strtol (arg, &endptr, 10);
1291 if (*endptr == '\0' && tabstop >= 1 && tabstop <= 100)
1292 CPP_OPTION (pfile, tabstop) = tabstop;
1294 break;
1295 case OPT_w:
1296 CPP_OPTION (pfile, inhibit_warnings) = 1;
1297 break;
1298 case OPT_h:
1299 case OPT__help:
1300 print_help ();
1301 CPP_OPTION (pfile, help_only) = 1;
1302 break;
1303 case OPT_target__help:
1304 /* Print if any target specific options. cpplib has none, but
1305 make sure help_only gets set. */
1306 CPP_OPTION (pfile, help_only) = 1;
1307 break;
1309 /* --version inhibits compilation, -version doesn't. -v means
1310 verbose and -version. Historical reasons, don't ask. */
1311 case OPT__version:
1312 CPP_OPTION (pfile, help_only) = 1;
1313 goto version;
1314 case OPT_v:
1315 CPP_OPTION (pfile, verbose) = 1;
1316 goto version;
1318 case OPT_version:
1319 version:
1320 fprintf (stderr, _("GNU CPP version %s (cpplib)"), version_string);
1321 #ifdef TARGET_VERSION
1322 TARGET_VERSION;
1323 #endif
1324 fputc ('\n', stderr);
1325 break;
1327 case OPT_C:
1328 CPP_OPTION (pfile, discard_comments) = 0;
1329 break;
1330 case OPT_P:
1331 CPP_OPTION (pfile, no_line_commands) = 1;
1332 break;
1333 case OPT_dollar: /* Don't include $ in identifiers. */
1334 CPP_OPTION (pfile, dollars_in_ident) = 0;
1335 break;
1336 case OPT_H:
1337 CPP_OPTION (pfile, print_include_names) = 1;
1338 break;
1339 case OPT_D:
1340 new_pending_directive (pend, arg, cpp_define);
1341 break;
1342 case OPT_pedantic_errors:
1343 CPP_OPTION (pfile, pedantic_errors) = 1;
1344 /* fall through */
1345 case OPT_pedantic:
1346 CPP_OPTION (pfile, pedantic) = 1;
1347 break;
1348 case OPT_trigraphs:
1349 CPP_OPTION (pfile, trigraphs) = 1;
1350 break;
1351 case OPT_plus:
1352 CPP_OPTION (pfile, cplusplus) = 1;
1353 CPP_OPTION (pfile, cplusplus_comments) = 1;
1354 break;
1355 case OPT_remap:
1356 CPP_OPTION (pfile, remap) = 1;
1357 break;
1358 case OPT_iprefix:
1359 CPP_OPTION (pfile, include_prefix) = arg;
1360 CPP_OPTION (pfile, include_prefix_len) = strlen (arg);
1361 break;
1362 case OPT_lang_c:
1363 set_lang (pfile, CLK_GNUC89);
1364 break;
1365 case OPT_lang_cplusplus:
1366 set_lang (pfile, CLK_GNUCXX);
1367 break;
1368 case OPT_lang_objc:
1369 set_lang (pfile, CLK_OBJC);
1370 break;
1371 case OPT_lang_objcplusplus:
1372 set_lang (pfile, CLK_OBJCXX);
1373 break;
1374 case OPT_lang_asm:
1375 set_lang (pfile, CLK_ASM);
1376 break;
1377 case OPT_std_cplusplus98:
1378 set_lang (pfile, CLK_CXX98);
1379 break;
1380 case OPT_std_gnu89:
1381 set_lang (pfile, CLK_GNUC89);
1382 break;
1383 case OPT_std_gnu9x:
1384 case OPT_std_gnu99:
1385 set_lang (pfile, CLK_GNUC99);
1386 break;
1387 case OPT_std_iso9899_199409:
1388 set_lang (pfile, CLK_STDC94);
1389 break;
1390 case OPT_std_iso9899_1990:
1391 case OPT_std_c89:
1392 case OPT_lang_c89:
1393 set_lang (pfile, CLK_STDC89);
1394 break;
1395 case OPT_std_iso9899_199x:
1396 case OPT_std_iso9899_1999:
1397 case OPT_std_c9x:
1398 case OPT_std_c99:
1399 set_lang (pfile, CLK_STDC99);
1400 break;
1401 case OPT_nostdinc:
1402 /* -nostdinc causes no default include directories.
1403 You must specify all include-file directories with -I. */
1404 CPP_OPTION (pfile, no_standard_includes) = 1;
1405 break;
1406 case OPT_nostdincplusplus:
1407 /* -nostdinc++ causes no default C++-specific include directories. */
1408 CPP_OPTION (pfile, no_standard_cplusplus_includes) = 1;
1409 break;
1410 case OPT_o:
1411 if (CPP_OPTION (pfile, out_fname) != NULL)
1413 cpp_fatal (pfile, "Output filename specified twice");
1414 return argc;
1416 CPP_OPTION (pfile, out_fname) = arg;
1417 if (!strcmp (CPP_OPTION (pfile, out_fname), "-"))
1418 CPP_OPTION (pfile, out_fname) = "";
1419 break;
1420 case OPT_stdin_stdout:
1421 /* JF handle '-' as file name meaning stdin or stdout. */
1422 if (CPP_OPTION (pfile, in_fname) == NULL)
1423 CPP_OPTION (pfile, in_fname) = "";
1424 else if (CPP_OPTION (pfile, out_fname) == NULL)
1425 CPP_OPTION (pfile, out_fname) = "";
1426 break;
1427 case OPT_d:
1428 /* Args to -d specify what parts of macros to dump.
1429 Silently ignore unrecognised options; they may
1430 be aimed at the compiler proper. */
1432 char c;
1434 while ((c = *arg++) != '\0')
1435 switch (c)
1437 case 'M':
1438 CPP_OPTION (pfile, dump_macros) = dump_only;
1439 CPP_OPTION (pfile, no_output) = 1;
1440 break;
1441 case 'N':
1442 CPP_OPTION (pfile, dump_macros) = dump_names;
1443 break;
1444 case 'D':
1445 CPP_OPTION (pfile, dump_macros) = dump_definitions;
1446 break;
1447 case 'I':
1448 CPP_OPTION (pfile, dump_includes) = 1;
1449 break;
1452 break;
1454 case OPT_MG:
1455 CPP_OPTION (pfile, print_deps_missing_files) = 1;
1456 break;
1457 case OPT_M:
1458 CPP_OPTION (pfile, print_deps) = 2;
1459 break;
1460 case OPT_MM:
1461 CPP_OPTION (pfile, print_deps) = 1;
1462 break;
1463 case OPT_MF:
1464 CPP_OPTION (pfile, deps_file) = arg;
1465 break;
1466 case OPT_MP:
1467 CPP_OPTION (pfile, deps_phony_targets) = 1;
1468 break;
1469 case OPT_MQ:
1470 case OPT_MT:
1471 /* Add a target. -MQ quotes for Make. */
1472 deps_add_target (pfile->deps, arg, opt_code == OPT_MQ);
1473 break;
1475 /* -MD and -MMD for cpp0 are deprecated and undocumented
1476 (use -M or -MM with -MF instead), and probably should be
1477 removed with the next major GCC version. For the moment
1478 we allow these for the benefit of Automake 1.4, which
1479 uses these when dependency tracking is enabled. Automake
1480 1.5 will fix this. */
1481 case OPT_MD:
1482 CPP_OPTION (pfile, print_deps) = 2;
1483 CPP_OPTION (pfile, deps_file) = arg;
1484 break;
1485 case OPT_MMD:
1486 CPP_OPTION (pfile, print_deps) = 1;
1487 CPP_OPTION (pfile, deps_file) = arg;
1488 break;
1490 case OPT_A:
1491 if (arg[0] == '-')
1493 /* -A with an argument beginning with '-' acts as
1494 #unassert on whatever immediately follows the '-'.
1495 If "-" is the whole argument, we eliminate all
1496 predefined macros and assertions, including those
1497 that were specified earlier on the command line.
1498 That way we can get rid of any that were passed
1499 automatically in from GCC. */
1501 if (arg[1] == '\0')
1503 struct pending_option *o1, *o2;
1505 o1 = pend->directive_head;
1506 while (o1)
1508 o2 = o1->next;
1509 free (o1);
1510 o1 = o2;
1512 pend->directive_head = NULL;
1513 pend->directive_tail = NULL;
1515 else
1516 new_pending_directive (pend, arg + 1, cpp_unassert);
1518 else
1519 new_pending_directive (pend, arg, cpp_assert);
1520 break;
1521 case OPT_U:
1522 new_pending_directive (pend, arg, cpp_undef);
1523 break;
1524 case OPT_I: /* Add directory to path for includes. */
1525 if (!strcmp (arg, "-"))
1527 /* -I- means:
1528 Use the preceding -I directories for #include "..."
1529 but not #include <...>.
1530 Don't search the directory of the present file
1531 for #include "...". (Note that -I. -I- is not the same as
1532 the default setup; -I. uses the compiler's working dir.) */
1533 if (! CPP_OPTION (pfile, ignore_srcdir))
1535 pend->quote_head = pend->brack_head;
1536 pend->quote_tail = pend->brack_tail;
1537 pend->brack_head = 0;
1538 pend->brack_tail = 0;
1539 CPP_OPTION (pfile, ignore_srcdir) = 1;
1541 else
1543 cpp_fatal (pfile, "-I- specified twice");
1544 return argc;
1547 else
1548 append_include_chain (pfile, xstrdup (arg), BRACKET, 0);
1549 break;
1550 case OPT_isystem:
1551 /* Add directory to beginning of system include path, as a system
1552 include directory. */
1553 append_include_chain (pfile, xstrdup (arg), SYSTEM, 0);
1554 break;
1555 case OPT_include:
1557 struct pending_option *o = (struct pending_option *)
1558 xmalloc (sizeof (struct pending_option));
1559 o->arg = arg;
1561 /* This list has to be built in reverse order so that
1562 when cpp_start_read pushes all the -include files onto
1563 the buffer stack, they will be scanned in forward order. */
1564 o->next = pend->include_head;
1565 pend->include_head = o;
1567 break;
1568 case OPT_imacros:
1570 struct pending_option *o = (struct pending_option *)
1571 xmalloc (sizeof (struct pending_option));
1572 o->arg = arg;
1573 o->next = NULL;
1575 APPEND (pend, imacros, o);
1577 break;
1578 case OPT_iwithprefix:
1579 /* Add directory to end of path for includes,
1580 with the default prefix at the front of its name. */
1581 /* fall through */
1582 case OPT_iwithprefixbefore:
1583 /* Add directory to main path for includes,
1584 with the default prefix at the front of its name. */
1586 char *fname;
1587 int len;
1589 len = strlen (arg);
1591 if (CPP_OPTION (pfile, include_prefix) != 0)
1593 size_t ipl = CPP_OPTION (pfile, include_prefix_len);
1594 fname = xmalloc (ipl + len + 1);
1595 memcpy (fname, CPP_OPTION (pfile, include_prefix), ipl);
1596 memcpy (fname + ipl, arg, len + 1);
1598 else if (cpp_GCC_INCLUDE_DIR_len)
1600 fname = xmalloc (cpp_GCC_INCLUDE_DIR_len + len + 1);
1601 memcpy (fname, cpp_GCC_INCLUDE_DIR, cpp_GCC_INCLUDE_DIR_len);
1602 memcpy (fname + cpp_GCC_INCLUDE_DIR_len, arg, len + 1);
1604 else
1605 fname = xstrdup (arg);
1607 append_include_chain (pfile, fname,
1608 opt_code == OPT_iwithprefix ? SYSTEM: BRACKET, 0);
1610 break;
1611 case OPT_idirafter:
1612 /* Add directory to end of path for includes. */
1613 append_include_chain (pfile, xstrdup (arg), AFTER, 0);
1614 break;
1615 case OPT_W:
1616 /* Silently ignore unrecognised options. */
1617 if (!strcmp (argv[i], "-Wall"))
1619 CPP_OPTION (pfile, warn_trigraphs) = 1;
1620 CPP_OPTION (pfile, warn_comments) = 1;
1622 else if (!strcmp (argv[i], "-Wtraditional"))
1623 CPP_OPTION (pfile, warn_traditional) = 1;
1624 else if (!strcmp (argv[i], "-Wtrigraphs"))
1625 CPP_OPTION (pfile, warn_trigraphs) = 1;
1626 else if (!strcmp (argv[i], "-Wcomment"))
1627 CPP_OPTION (pfile, warn_comments) = 1;
1628 else if (!strcmp (argv[i], "-Wcomments"))
1629 CPP_OPTION (pfile, warn_comments) = 1;
1630 else if (!strcmp (argv[i], "-Wundef"))
1631 CPP_OPTION (pfile, warn_undef) = 1;
1632 else if (!strcmp (argv[i], "-Wimport"))
1633 CPP_OPTION (pfile, warn_import) = 1;
1634 else if (!strcmp (argv[i], "-Werror"))
1635 CPP_OPTION (pfile, warnings_are_errors) = 1;
1636 else if (!strcmp (argv[i], "-Wsystem-headers"))
1637 CPP_OPTION (pfile, warn_system_headers) = 1;
1638 else if (!strcmp (argv[i], "-Wno-traditional"))
1639 CPP_OPTION (pfile, warn_traditional) = 0;
1640 else if (!strcmp (argv[i], "-Wno-trigraphs"))
1641 CPP_OPTION (pfile, warn_trigraphs) = 0;
1642 else if (!strcmp (argv[i], "-Wno-comment"))
1643 CPP_OPTION (pfile, warn_comments) = 0;
1644 else if (!strcmp (argv[i], "-Wno-comments"))
1645 CPP_OPTION (pfile, warn_comments) = 0;
1646 else if (!strcmp (argv[i], "-Wno-undef"))
1647 CPP_OPTION (pfile, warn_undef) = 0;
1648 else if (!strcmp (argv[i], "-Wno-import"))
1649 CPP_OPTION (pfile, warn_import) = 0;
1650 else if (!strcmp (argv[i], "-Wno-error"))
1651 CPP_OPTION (pfile, warnings_are_errors) = 0;
1652 else if (!strcmp (argv[i], "-Wno-system-headers"))
1653 CPP_OPTION (pfile, warn_system_headers) = 0;
1654 break;
1657 return i + 1;
1660 /* Handle command-line options in (argc, argv).
1661 Can be called multiple times, to handle multiple sets of options.
1662 Returns if an unrecognized option is seen.
1663 Returns number of strings consumed. */
1665 cpp_handle_options (pfile, argc, argv)
1666 cpp_reader *pfile;
1667 int argc;
1668 char **argv;
1670 int i;
1671 int strings_processed;
1673 for (i = 0; i < argc; i += strings_processed)
1675 strings_processed = cpp_handle_option (pfile, argc - i, argv + i);
1676 if (strings_processed == 0)
1677 break;
1680 return i;
1683 /* Extra processing when all options are parsed, after all calls to
1684 cpp_handle_option[s]. Consistency checks etc. */
1685 void
1686 cpp_post_options (pfile)
1687 cpp_reader *pfile;
1689 /* -Wtraditional is not useful in C++ mode. */
1690 if (CPP_OPTION (pfile, cplusplus))
1691 CPP_OPTION (pfile, warn_traditional) = 0;
1693 /* Set this if it hasn't been set already. */
1694 if (CPP_OPTION (pfile, user_label_prefix) == NULL)
1695 CPP_OPTION (pfile, user_label_prefix) = USER_LABEL_PREFIX;
1697 /* We need to do this after option processing and before
1698 cpp_start_read, as cppmain.c relies on the options->no_output to
1699 set its callbacks correctly before calling cpp_start_read. */
1700 init_dependency_output (pfile);
1702 /* After checking the environment variables, check if -M or -MM has
1703 not been specified, but other -M options have. */
1704 if (CPP_OPTION (pfile, print_deps) == 0 &&
1705 (CPP_OPTION (pfile, print_deps_missing_files)
1706 || CPP_OPTION (pfile, deps_file)
1707 || CPP_OPTION (pfile, deps_phony_targets)))
1708 cpp_fatal (pfile, "you must additionally specify either -M or -MM");
1711 /* Set up dependency-file output. */
1712 static void
1713 init_dependency_output (pfile)
1714 cpp_reader *pfile;
1716 char *spec, *s, *output_file;
1718 /* Either of two environment variables can specify output of deps.
1719 Its value is either "OUTPUT_FILE" or "OUTPUT_FILE DEPS_TARGET",
1720 where OUTPUT_FILE is the file to write deps info to
1721 and DEPS_TARGET is the target to mention in the deps. */
1723 if (CPP_OPTION (pfile, print_deps) == 0)
1725 spec = getenv ("DEPENDENCIES_OUTPUT");
1726 if (spec)
1727 CPP_OPTION (pfile, print_deps) = 1;
1728 else
1730 spec = getenv ("SUNPRO_DEPENDENCIES");
1731 if (spec)
1732 CPP_OPTION (pfile, print_deps) = 2;
1733 else
1734 return;
1737 /* Find the space before the DEPS_TARGET, if there is one. */
1738 s = strchr (spec, ' ');
1739 if (s)
1741 /* Let the caller perform MAKE quoting. */
1742 deps_add_target (pfile->deps, s + 1, 0);
1743 output_file = (char *) xmalloc (s - spec + 1);
1744 memcpy (output_file, spec, s - spec);
1745 output_file[s - spec] = 0;
1747 else
1748 output_file = spec;
1750 /* Command line overrides environment variables. */
1751 if (CPP_OPTION (pfile, deps_file) == 0)
1752 CPP_OPTION (pfile, deps_file) = output_file;
1753 CPP_OPTION (pfile, print_deps_append) = 1;
1756 /* If dependencies go to standard output, or -MG is used, we should
1757 suppress output. The user may be requesting other stuff to
1758 stdout, with -dM, -v etc. We let them shoot themselves in the
1759 foot. */
1760 if (CPP_OPTION (pfile, deps_file) == 0
1761 || CPP_OPTION (pfile, print_deps_missing_files))
1762 CPP_OPTION (pfile, no_output) = 1;
1765 static void
1766 print_help ()
1768 fprintf (stderr, _("Usage: %s [switches] input output\n"), progname);
1769 /* To keep the lines from getting too long for some compilers, limit
1770 to about 500 characters (6 lines) per chunk. */
1771 fputs (_("\
1772 Switches:\n\
1773 -include <file> Include the contents of <file> before other files\n\
1774 -imacros <file> Accept definition of macros in <file>\n\
1775 -iprefix <path> Specify <path> as a prefix for next two options\n\
1776 -iwithprefix <dir> Add <dir> to the end of the system include path\n\
1777 -iwithprefixbefore <dir> Add <dir> to the end of the main include path\n\
1778 -isystem <dir> Add <dir> to the start of the system include path\n\
1779 "), stdout);
1780 fputs (_("\
1781 -idirafter <dir> Add <dir> to the end of the system include path\n\
1782 -I <dir> Add <dir> to the end of the main include path\n\
1783 -I- Fine-grained include path control; see info docs\n\
1784 -nostdinc Do not search system include directories\n\
1785 (dirs specified with -isystem will still be used)\n\
1786 -nostdinc++ Do not search system include directories for C++\n\
1787 -o <file> Put output into <file>\n\
1788 "), stdout);
1789 fputs (_("\
1790 -pedantic Issue all warnings demanded by strict ISO C\n\
1791 -pedantic-errors Issue -pedantic warnings as errors instead\n\
1792 -trigraphs Support ISO C trigraphs\n\
1793 -lang-c Assume that the input sources are in C\n\
1794 -lang-c89 Assume that the input sources are in C89\n\
1795 "), stdout);
1796 fputs (_("\
1797 -lang-c++ Assume that the input sources are in C++\n\
1798 -lang-objc Assume that the input sources are in ObjectiveC\n\
1799 -lang-objc++ Assume that the input sources are in ObjectiveC++\n\
1800 -lang-asm Assume that the input sources are in assembler\n\
1801 "), stdout);
1802 fputs (_("\
1803 -std=<std name> Specify the conformance standard; one of:\n\
1804 gnu89, gnu99, c89, c99, iso9899:1990,\n\
1805 iso9899:199409, iso9899:1999\n\
1806 -+ Allow parsing of C++ style features\n\
1807 -w Inhibit warning messages\n\
1808 -Wtrigraphs Warn if trigraphs are encountered\n\
1809 -Wno-trigraphs Do not warn about trigraphs\n\
1810 -Wcomment{s} Warn if one comment starts inside another\n\
1811 "), stdout);
1812 fputs (_("\
1813 -Wno-comment{s} Do not warn about comments\n\
1814 -Wtraditional Warn about features not present in traditional C\n\
1815 -Wno-traditional Do not warn about traditional C\n\
1816 -Wundef Warn if an undefined macro is used by #if\n\
1817 -Wno-undef Do not warn about testing undefined macros\n\
1818 -Wimport Warn about the use of the #import directive\n\
1819 "), stdout);
1820 fputs (_("\
1821 -Wno-import Do not warn about the use of #import\n\
1822 -Werror Treat all warnings as errors\n\
1823 -Wno-error Do not treat warnings as errors\n\
1824 -Wsystem-headers Do not suppress warnings from system headers\n\
1825 -Wno-system-headers Suppress warnings from system headers\n\
1826 -Wall Enable all preprocessor warnings\n\
1827 "), stdout);
1828 fputs (_("\
1829 -M Generate make dependencies\n\
1830 -MM As -M, but ignore system header files\n\
1831 -MF <file> Write dependency output to the given file\n\
1832 -MG Treat missing header file as generated files\n\
1833 "), stdout);
1834 fputs (_("\
1835 -MP Generate phony targets for all headers\n\
1836 -MQ <target> Add a MAKE-quoted target\n\
1837 -MT <target> Add an unquoted target\n\
1838 "), stdout);
1839 fputs (_("\
1840 -D<macro> Define a <macro> with string '1' as its value\n\
1841 -D<macro>=<val> Define a <macro> with <val> as its value\n\
1842 -A<question> (<answer>) Assert the <answer> to <question>\n\
1843 -A-<question> (<answer>) Disable the <answer> to <question>\n\
1844 -U<macro> Undefine <macro> \n\
1845 -v Display the version number\n\
1846 "), stdout);
1847 fputs (_("\
1848 -H Print the name of header files as they are used\n\
1849 -C Do not discard comments\n\
1850 -dM Display a list of macro definitions active at end\n\
1851 -dD Preserve macro definitions in output\n\
1852 -dN As -dD except that only the names are preserved\n\
1853 -dI Include #include directives in the output\n\
1854 "), stdout);
1855 fputs (_("\
1856 -ftabstop=<number> Distance between tab stops for column reporting\n\
1857 -P Do not generate #line directives\n\
1858 -$ Do not allow '$' in identifiers\n\
1859 -remap Remap file names when including files.\n\
1860 --version Display version information\n\
1861 -h or --help Display this information\n\
1862 "), stdout);