]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/cppinit.c
* toplev.c (output_quoted_string): Write unprintable
[thirdparty/gcc.git] / gcc / cppinit.c
CommitLineData
a852e3b1 1/* CPP Library.
00059bc7 2 Copyright (C) 1986, 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
355a19c4 3 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
a852e3b1 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
7
8This program is free software; you can redistribute it and/or modify it
9under the terms of the GNU General Public License as published by the
10Free Software Foundation; either version 2, or (at your option) any
11later version.
12
13This program is distributed in the hope that it will be useful,
14but WITHOUT ANY WARRANTY; without even the implied warranty of
15MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16GNU General Public License for more details.
17
18You should have received a copy of the GNU General Public License
19along with this program; if not, write to the Free Software
20Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21
a852e3b1 22#include "config.h"
23#include "system.h"
6d71dc85 24#include "cpplib.h"
25#include "cpphash.h"
6d71dc85 26#include "prefix.h"
27#include "intl.h"
56fc5f02 28#include "version.h"
62adb1fe 29#include "mkdeps.h"
472679ed 30#include "cppdefault.h"
a1a7e9d5 31#include "except.h" /* for USING_SJLJ_EXCEPTIONS */
6d71dc85 32
8d1752de 33/* Predefined symbols, built-in macros, and the default include path. */
6d71dc85 34
35#ifndef GET_ENV_PATH_LIST
36#define GET_ENV_PATH_LIST(VAR,NAME) do { (VAR) = getenv (NAME); } while (0)
37#endif
38
1e8b9746 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.
2c0e001b 41 VMS has non-numeric inodes. */
1e8b9746 42#ifdef VMS
5ec90c2e 43# define INO_T_EQ(A, B) (!memcmp (&(A), &(B), sizeof (A)))
44# define INO_T_COPY(DEST, SRC) memcpy(&(DEST), &(SRC), sizeof (SRC))
1e8b9746 45#else
ca68aa59 46# if (defined _WIN32 && ! defined (_UWIN)) || defined __MSDOS__
5ec90c2e 47# define INO_T_EQ(A, B) 0
ca68aa59 48# else
5ec90c2e 49# define INO_T_EQ(A, B) ((A) == (B))
ca68aa59 50# endif
5ec90c2e 51# define INO_T_COPY(DEST, SRC) (DEST) = (SRC)
1e8b9746 52#endif
53
8d1752de 54/* Internal structures and prototypes. */
6d71dc85 55
8d1752de 56/* A `struct pending_option' remembers one -D, -A, -U, -include, or
57 -imacros switch. */
078aa0ff 58typedef void (* cl_directive_handler) PARAMS ((cpp_reader *, const char *));
9fa36617 59struct pending_option
6d71dc85 60{
9fa36617 61 struct pending_option *next;
8d7a2585 62 const char *arg;
d73269b6 63 cl_directive_handler handler;
6d71dc85 64};
9fa36617 65
1e8b9746 66/* The `pending' structure accumulates all the options that are not
9ceb1c29 67 actually processed until we hit cpp_read_main_file. It consists of
1e8b9746 68 several lists, one for each type of option. We keep both head and
8d1752de 69 tail pointers for quick insertion. */
1e8b9746 70struct cpp_pending
71{
d73269b6 72 struct pending_option *directive_head, *directive_tail;
1e8b9746 73
3ec84a0b 74 struct search_path *quote_head, *quote_tail;
75 struct search_path *brack_head, *brack_tail;
76 struct search_path *systm_head, *systm_tail;
77 struct search_path *after_head, *after_tail;
1e8b9746 78
79 struct pending_option *imacros_head, *imacros_tail;
80 struct pending_option *include_head, *include_tail;
81};
82
9fa36617 83#ifdef __STDC__
84#define APPEND(pend, list, elt) \
85 do { if (!(pend)->list##_head) (pend)->list##_head = (elt); \
86 else (pend)->list##_tail->next = (elt); \
87 (pend)->list##_tail = (elt); \
88 } while (0)
89#else
90#define APPEND(pend, list, elt) \
91 do { if (!(pend)->list/**/_head) (pend)->list/**/_head = (elt); \
92 else (pend)->list/**/_tail->next = (elt); \
93 (pend)->list/**/_tail = (elt); \
94 } while (0)
95#endif
6d71dc85 96
6d71dc85 97static void print_help PARAMS ((void));
9fa36617 98static void path_include PARAMS ((cpp_reader *,
9fa36617 99 char *, int));
c77d825d 100static void init_library PARAMS ((void));
b3a8144e 101static void init_builtins PARAMS ((cpp_reader *));
9fa36617 102static void append_include_chain PARAMS ((cpp_reader *,
d2e850c1 103 char *, int, int));
72ac7d9a 104static struct search_path * remove_dup_dir PARAMS ((cpp_reader *,
3ec84a0b 105 struct search_path *));
72ac7d9a 106static struct search_path * remove_dup_dirs PARAMS ((cpp_reader *,
3ec84a0b 107 struct search_path *));
2ff3ad1d 108static void merge_include_chains PARAMS ((cpp_reader *));
fe560637 109static bool push_include PARAMS ((cpp_reader *,
110 struct pending_option *));
111static void free_chain PARAMS ((struct pending_option *));
fad0ffbb 112static void set_lang PARAMS ((cpp_reader *, enum c_lang));
b3a8144e 113static void init_dependency_output PARAMS ((cpp_reader *));
114static void init_standard_includes PARAMS ((cpp_reader *));
9ceb1c29 115static void read_original_filename PARAMS ((cpp_reader *));
dfa5c7fa 116static void new_pending_directive PARAMS ((struct cpp_pending *,
d73269b6 117 const char *,
118 cl_directive_handler));
b3a8144e 119static void output_deps PARAMS ((cpp_reader *));
bcc40c63 120static int parse_option PARAMS ((const char *));
6d71dc85 121
a19b9668 122/* Fourth argument to append_include_chain: chain to use.
123 Note it's never asked to append to the quote chain. */
124enum { BRACKET = 0, SYSTEM, AFTER };
6d71dc85 125
b3954366 126/* If we have designated initializers (GCC >2.7) these tables can be
127 initialized, constant data. Otherwise, they have to be filled in at
e057cf7c 128 runtime. */
b3954366 129#if HAVE_DESIGNATED_INITIALIZERS
5ba37007 130
8d1752de 131#define init_trigraph_map() /* Nothing. */
b3954366 132#define TRIGRAPH_MAP \
133__extension__ const U_CHAR _cpp_trigraph_map[UCHAR_MAX + 1] = {
134
5ba37007 135#define END };
4f98874d 136#define s(p, v) [p] = v,
b3954366 137
5ba37007 138#else
b3954366 139
b3954366 140#define TRIGRAPH_MAP U_CHAR _cpp_trigraph_map[UCHAR_MAX + 1] = { 0 }; \
141 static void init_trigraph_map PARAMS ((void)) { \
142 unsigned char *x = _cpp_trigraph_map;
143
2ff3ad1d 144#define END }
4f98874d 145#define s(p, v) x[p] = v;
b3954366 146
5ba37007 147#endif
6d71dc85 148
b3954366 149TRIGRAPH_MAP
150 s('=', '#') s(')', ']') s('!', '|')
151 s('(', '[') s('\'', '^') s('>', '}')
152 s('/', '\\') s('<', '{') s('-', '~')
153END
154
5ba37007 155#undef s
4f98874d 156#undef END
b3954366 157#undef TRIGRAPH_MAP
6d71dc85 158
159/* Given a colon-separated list of file names PATH,
160 add all the names to the search path for include files. */
6d71dc85 161static void
466b3f58 162path_include (pfile, list, path)
6d71dc85 163 cpp_reader *pfile;
9fa36617 164 char *list;
165 int path;
6d71dc85 166{
9fa36617 167 char *p, *q, *name;
6d71dc85 168
9fa36617 169 p = list;
6d71dc85 170
9fa36617 171 do
172 {
6d71dc85 173 /* Find the end of this name. */
9fa36617 174 q = p;
6d71dc85 175 while (*q != 0 && *q != PATH_SEPARATOR) q++;
9fa36617 176 if (q == p)
177 {
178 /* An empty name in the path stands for the current directory. */
179 name = (char *) xmalloc (2);
180 name[0] = '.';
181 name[1] = 0;
182 }
183 else
184 {
185 /* Otherwise use the directory that is named. */
186 name = (char *) xmalloc (q - p + 1);
187 memcpy (name, p, q - p);
188 name[q - p] = 0;
189 }
6d71dc85 190
466b3f58 191 append_include_chain (pfile, name, path, 0);
6d71dc85 192
193 /* Advance past this name. */
9fa36617 194 if (*q == 0)
6d71dc85 195 break;
9fa36617 196 p = q + 1;
197 }
198 while (1);
199}
200
162cee98 201/* Append DIR to include path PATH. DIR must be allocated on the
e484a1cc 202 heap; this routine takes responsibility for freeing it. CXX_AWARE
203 is non-zero if the header contains extern "C" guards for C++,
204 otherwise it is zero. */
9fa36617 205static void
466b3f58 206append_include_chain (pfile, dir, path, cxx_aware)
9fa36617 207 cpp_reader *pfile;
9fa36617 208 char *dir;
209 int path;
2376a7f7 210 int cxx_aware ATTRIBUTE_UNUSED;
9fa36617 211{
466b3f58 212 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
3ec84a0b 213 struct search_path *new;
9fa36617 214 struct stat st;
215 unsigned int len;
216
7eda354a 217 if (*dir == '\0')
162cee98 218 {
219 free (dir);
220 dir = xstrdup (".");
221 }
94221a92 222 _cpp_simplify_pathname (dir);
162cee98 223
9fa36617 224 if (stat (dir, &st))
225 {
7eda354a 226 /* Dirs that don't exist are silently ignored. */
9fa36617 227 if (errno != ENOENT)
9e87fa80 228 cpp_notice_from_errno (pfile, dir);
2ff3ad1d 229 else if (CPP_OPTION (pfile, verbose))
f80e83a9 230 fprintf (stderr, _("ignoring nonexistent directory \"%s\"\n"), dir);
162cee98 231 free (dir);
9fa36617 232 return;
233 }
234
235 if (!S_ISDIR (st.st_mode))
236 {
9e87fa80 237 cpp_notice (pfile, "%s: Not a directory", dir);
162cee98 238 free (dir);
9fa36617 239 return;
240 }
241
242 len = strlen (dir);
243 if (len > pfile->max_include_len)
244 pfile->max_include_len = len;
2ff3ad1d 245
3ec84a0b 246 new = (struct search_path *) xmalloc (sizeof (struct search_path));
9fa36617 247 new->name = dir;
3ec84a0b 248 new->len = len;
5ec90c2e 249 INO_T_COPY (new->ino, st.st_ino);
9fa36617 250 new->dev = st.st_dev;
4dac543a 251 /* Both systm and after include file lists should be treated as system
252 include files since these two lists are really just a concatenation
2c0e001b 253 of one "system" list. */
4dac543a 254 if (path == SYSTEM || path == AFTER)
3b44c686 255#ifdef NO_IMPLICIT_EXTERN_C
256 new->sysp = 1;
257#else
d2e850c1 258 new->sysp = cxx_aware ? 1 : 2;
3b44c686 259#endif
d2e850c1 260 else
261 new->sysp = 0;
9fa36617 262 new->name_map = NULL;
48f3f15c 263 new->next = NULL;
9fa36617 264
265 switch (path)
266 {
9fa36617 267 case BRACKET: APPEND (pend, brack, new); break;
268 case SYSTEM: APPEND (pend, systm, new); break;
269 case AFTER: APPEND (pend, after, new); break;
6d71dc85 270 }
271}
272
d1ad3794 273/* Handle a duplicated include path. PREV is the link in the chain
274 before the duplicate. The duplicate is removed from the chain and
275 freed. Returns PREV. */
72ac7d9a 276static struct search_path *
d1ad3794 277remove_dup_dir (pfile, prev)
278 cpp_reader *pfile;
3ec84a0b 279 struct search_path *prev;
d1ad3794 280{
3ec84a0b 281 struct search_path *cur = prev->next;
d1ad3794 282
283 if (CPP_OPTION (pfile, verbose))
284 fprintf (stderr, _("ignoring duplicate directory \"%s\"\n"), cur->name);
285
286 prev->next = cur->next;
3ec84a0b 287 free ((PTR) cur->name);
d1ad3794 288 free (cur);
289
290 return prev;
291}
292
293/* Remove duplicate directories from a chain. Returns the tail of the
294 chain, or NULL if the chain is empty. This algorithm is quadratic
295 in the number of -I switches, which is acceptable since there
296 aren't usually that many of them. */
72ac7d9a 297static struct search_path *
d1ad3794 298remove_dup_dirs (pfile, head)
299 cpp_reader *pfile;
3ec84a0b 300 struct search_path *head;
d1ad3794 301{
3ec84a0b 302 struct search_path *prev = NULL, *cur, *other;
d1ad3794 303
304 for (cur = head; cur; cur = cur->next)
305 {
306 for (other = head; other != cur; other = other->next)
307 if (INO_T_EQ (cur->ino, other->ino) && cur->dev == other->dev)
308 {
72ac7d9a 309 if (cur->sysp && !other->sysp)
83e21af4 310 {
311 cpp_warning (pfile,
312 "changing search order for system directory \"%s\"",
313 cur->name);
314 if (strcmp (cur->name, other->name))
72ac7d9a 315 cpp_warning (pfile,
316 " as it is the same as non-system directory \"%s\"",
83e21af4 317 other->name);
318 else
72ac7d9a 319 cpp_warning (pfile,
320 " as it has already been specified as a non-system directory");
83e21af4 321 }
d1ad3794 322 cur = remove_dup_dir (pfile, prev);
323 break;
324 }
325 prev = cur;
326 }
327
328 return prev;
329}
330
1e8b9746 331/* Merge the four include chains together in the order quote, bracket,
332 system, after. Remove duplicate dirs (as determined by
333 INO_T_EQ()). The system_include and after_include chains are never
334 referred to again after this function; all access is through the
e484a1cc 335 bracket_include path. */
1e8b9746 336static void
2ff3ad1d 337merge_include_chains (pfile)
338 cpp_reader *pfile;
1e8b9746 339{
3ec84a0b 340 struct search_path *quote, *brack, *systm, *qtail;
1e8b9746 341
2ff3ad1d 342 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
1e8b9746 343
2ff3ad1d 344 quote = pend->quote_head;
345 brack = pend->brack_head;
346 systm = pend->systm_head;
d1ad3794 347 qtail = pend->quote_tail;
1e8b9746 348
d1ad3794 349 /* Paste together bracket, system, and after include chains. */
350 if (systm)
351 pend->systm_tail->next = pend->after_head;
1e8b9746 352 else
d1ad3794 353 systm = pend->after_head;
354
355 if (brack)
356 pend->brack_tail->next = systm;
1e8b9746 357 else
358 brack = systm;
359
d1ad3794 360 /* This is a bit tricky. First we drop dupes from the quote-include
361 list. Then we drop dupes from the bracket-include list.
362 Finally, if qtail and brack are the same directory, we cut out
a19b9668 363 brack and move brack up to point to qtail.
1e8b9746 364
365 We can't just merge the lists and then uniquify them because
366 then we may lose directories from the <> search path that should
367 be there; consider -Ifoo -Ibar -I- -Ifoo -Iquux. It is however
368 safe to treat -Ibar -Ifoo -I- -Ifoo -Iquux as if written
d1ad3794 369 -Ibar -I- -Ifoo -Iquux. */
1e8b9746 370
d1ad3794 371 remove_dup_dirs (pfile, brack);
372 qtail = remove_dup_dirs (pfile, quote);
1e8b9746 373
374 if (quote)
375 {
d1ad3794 376 qtail->next = brack;
377
378 /* If brack == qtail, remove brack as it's simpler. */
f7ee0e54 379 if (brack && INO_T_EQ (qtail->ino, brack->ino)
380 && qtail->dev == brack->dev)
d1ad3794 381 brack = remove_dup_dir (pfile, qtail);
1e8b9746 382 }
383 else
162cee98 384 quote = brack;
1e8b9746 385
2ff3ad1d 386 CPP_OPTION (pfile, quote_include) = quote;
387 CPP_OPTION (pfile, bracket_include) = brack;
1e8b9746 388}
389
e484a1cc 390/* A set of booleans indicating what CPP features each source language
391 requires. */
f48efcc3 392struct lang_flags
393{
394 char c99;
395 char objc;
396 char cplusplus;
397 char extended_numbers;
398 char trigraphs;
399 char dollars_in_ident;
400 char cplusplus_comments;
401 char digraphs;
402};
403
404/* ??? Enable $ in identifiers in assembly? */
405static const struct lang_flags lang_defaults[] =
406{ /* c99 objc c++ xnum trig dollar c++comm digr */
407 /* GNUC89 */ { 0, 0, 0, 1, 0, 1, 1, 1 },
408 /* GNUC99 */ { 1, 0, 0, 1, 0, 1, 1, 1 },
409 /* STDC89 */ { 0, 0, 0, 0, 1, 0, 0, 0 },
410 /* STDC94 */ { 0, 0, 0, 0, 1, 0, 0, 1 },
411 /* STDC99 */ { 1, 0, 0, 1, 1, 0, 1, 1 },
412 /* GNUCXX */ { 0, 0, 1, 1, 0, 1, 1, 1 },
413 /* CXX98 */ { 0, 0, 1, 1, 1, 0, 1, 1 },
414 /* OBJC */ { 0, 1, 0, 1, 0, 1, 1, 1 },
415 /* OBJCXX */ { 0, 1, 1, 1, 0, 1, 1, 1 },
416 /* ASM */ { 0, 0, 0, 1, 0, 0, 1, 0 }
417};
418
e484a1cc 419/* Sets internal flags correctly for a given language. */
fad0ffbb 420static void
421set_lang (pfile, lang)
422 cpp_reader *pfile;
423 enum c_lang lang;
424{
f48efcc3 425 const struct lang_flags *l = &lang_defaults[(int) lang];
426
5db5d057 427 CPP_OPTION (pfile, lang) = lang;
fad0ffbb 428
f48efcc3 429 CPP_OPTION (pfile, c99) = l->c99;
430 CPP_OPTION (pfile, objc) = l->objc;
431 CPP_OPTION (pfile, cplusplus) = l->cplusplus;
432 CPP_OPTION (pfile, extended_numbers) = l->extended_numbers;
433 CPP_OPTION (pfile, trigraphs) = l->trigraphs;
434 CPP_OPTION (pfile, dollars_in_ident) = l->dollars_in_ident;
435 CPP_OPTION (pfile, cplusplus_comments) = l->cplusplus_comments;
436 CPP_OPTION (pfile, digraphs) = l->digraphs;
fad0ffbb 437}
438
b3a8144e 439#ifdef HOST_EBCDIC
440static int opt_comp PARAMS ((const void *, const void *));
441
442/* Run-time sorting of options array. */
443static int
444opt_comp (p1, p2)
445 const void *p1, *p2;
446{
447 return strcmp (((struct cl_option *) p1)->opt_text,
448 ((struct cl_option *) p2)->opt_text);
449}
450#endif
9751c00e 451
b3a8144e 452/* init initializes library global state. It might not need to
453 do anything depending on the platform and compiler. */
9751c00e 454static void
c77d825d 455init_library ()
9751c00e 456{
b3a8144e 457 static int initialized = 0;
458
459 if (! initialized)
460 {
461 initialized = 1;
462
9751c00e 463#ifdef HOST_EBCDIC
b3a8144e 464 /* For non-ASCII hosts, the cl_options array needs to be sorted at
465 runtime. */
466 qsort (cl_options, N_OPTS, sizeof (struct cl_option), opt_comp);
9751c00e 467#endif
468
b3a8144e 469 /* Set up the trigraph map. This doesn't need to do anything if
470 we were compiled with a compiler that supports C99 designated
471 initializers. */
472 init_trigraph_map ();
473 }
9751c00e 474}
475
2c0e001b 476/* Initialize a cpp_reader structure. */
9751c00e 477cpp_reader *
9ceb1c29 478cpp_create_reader (lang)
fad0ffbb 479 enum c_lang lang;
6d71dc85 480{
b3a8144e 481 cpp_reader *pfile;
79bd622b 482
9751c00e 483 /* Initialise this instance of the library if it hasn't been already. */
c77d825d 484 init_library ();
b3a8144e 485
486 pfile = (cpp_reader *) xcalloc (1, sizeof (cpp_reader));
79bd622b 487
eef6c20f 488 set_lang (pfile, lang);
2ff3ad1d 489 CPP_OPTION (pfile, warn_import) = 1;
490 CPP_OPTION (pfile, discard_comments) = 1;
491 CPP_OPTION (pfile, show_column) = 1;
3b304865 492 CPP_OPTION (pfile, tabstop) = 8;
624a7570 493 CPP_OPTION (pfile, operator_names) = 1;
537c4bc6 494#if DEFAULT_SIGNED_CHAR
495 CPP_OPTION (pfile, signed_char) = 1;
496#else
497 CPP_OPTION (pfile, signed_char) = 0;
498#endif
2ff3ad1d 499
500 CPP_OPTION (pfile, pending) =
501 (struct cpp_pending *) xcalloc (1, sizeof (struct cpp_pending));
502
7b4b68f2 503 /* It's simplest to just create this struct whether or not it will
504 be needed. */
505 pfile->deps = deps_init ();
506
729d2022 507 /* Initialise the line map. Start at logical line 1, so we can use
508 a line number of zero for special states. */
38692459 509 init_line_maps (&pfile->line_maps);
729d2022 510 pfile->line = 1;
38692459 511
8d1752de 512 /* Initialize lexer state. */
79bd622b 513 pfile->state.save_comments = ! CPP_OPTION (pfile, discard_comments);
514
f9b5f742 515 /* Set up static tokens. */
79bd622b 516 pfile->date.type = CPP_EOF;
f9b5f742 517 pfile->avoid_paste.type = CPP_PADDING;
518 pfile->avoid_paste.val.source = NULL;
519 pfile->eof.type = CPP_EOF;
520 pfile->eof.flags = 0;
79bd622b 521
83dcbb5c 522 /* Create a token buffer for the lexer. */
523 _cpp_init_tokenrun (&pfile->base_run, 250);
524 pfile->cur_run = &pfile->base_run;
525 pfile->cur_token = pfile->base_run.base;
83dcbb5c 526
79bd622b 527 /* Initialise the base context. */
528 pfile->context = &pfile->base_context;
529 pfile->base_context.macro = 0;
530 pfile->base_context.prev = pfile->base_context.next = 0;
531
e6a5f963 532 /* Aligned and unaligned storage. */
533 pfile->a_buff = _cpp_get_buff (pfile, 0);
1fdf6039 534 pfile->u_buff = _cpp_get_buff (pfile, 0);
79bd622b 535
0d086e18 536 /* Initialise the buffer obstack. */
537 gcc_obstack_init (&pfile->buffer_ob);
538
f51c2148 539 _cpp_init_includes (pfile);
9751c00e 540
541 return pfile;
e2f9a79f 542}
543
9bd97637 544/* Free resources used by PFILE. Accessing PFILE after this function
e484a1cc 545 returns leads to undefined behaviour. Returns the error count. */
9bd97637 546int
547cpp_destroy (pfile)
6d71dc85 548 cpp_reader *pfile;
549{
9bd97637 550 int result;
3ec84a0b 551 struct search_path *dir, *dirn;
79bd622b 552 cpp_context *context, *contextn;
729d2022 553 tokenrun *run, *runn;
11d10d3f 554
5b201908 555 while (CPP_BUFFER (pfile) != NULL)
4dfe8b74 556 _cpp_pop_buffer (pfile);
6d71dc85 557
79bd622b 558 if (pfile->macro_buffer)
8744fb7e 559 {
560 free ((PTR) pfile->macro_buffer);
561 pfile->macro_buffer = NULL;
562 pfile->macro_buffer_len = 0;
563 }
79bd622b 564
7b4b68f2 565 deps_free (pfile->deps);
0d086e18 566 obstack_free (&pfile->buffer_ob, 0);
62adb1fe 567
0d086e18 568 _cpp_destroy_hashtable (pfile);
76faa4c0 569 _cpp_cleanup_includes (pfile);
11d10d3f 570
e6a5f963 571 _cpp_free_buff (pfile->a_buff);
1fdf6039 572 _cpp_free_buff (pfile->u_buff);
06c92cbc 573 _cpp_free_buff (pfile->free_buffs);
79bd622b 574
729d2022 575 for (run = &pfile->base_run; run; run = runn)
576 {
577 runn = run->next;
578 free (run->base);
579 if (run != &pfile->base_run)
580 free (run);
581 }
582
79bd622b 583 for (dir = CPP_OPTION (pfile, quote_include); dir; dir = dirn)
11d10d3f 584 {
79bd622b 585 dirn = dir->next;
3ec84a0b 586 free ((PTR) dir->name);
11d10d3f 587 free (dir);
588 }
79bd622b 589
590 for (context = pfile->base_context.next; context; context = contextn)
591 {
592 contextn = context->next;
593 free (context);
594 }
9bd97637 595
38692459 596 free_line_maps (&pfile->line_maps);
597
9bd97637 598 result = pfile->errors;
599 free (pfile);
600
601 return result;
6d71dc85 602}
603
604
79bd622b 605/* This structure defines one built-in identifier. A node will be
606 entered in the hash table under the name NAME, with value VALUE (if
607 any). If flags has OPERATOR, the node's operator field is used; if
31ca26b1 608 flags has BUILTIN the node's builtin field is used. Macros that are
609 known at build time should not be flagged BUILTIN, as then they do
610 not appear in macro dumps with e.g. -dM or -dD.
31674461 611
612 Two values are not compile time constants, so we tag
f80e83a9 613 them in the FLAGS field instead:
1e67c2e8 614 VERS value is the global version_string, quoted
615 ULP value is the global user_label_prefix
31674461 616
79bd622b 617 Also, macros with CPLUS set in the flags field are entered only for C++. */
5ba37007 618struct builtin
619{
e057cf7c 620 const U_CHAR *name;
f80e83a9 621 const char *value;
79bd622b 622 unsigned char builtin;
623 unsigned char operator;
5ba37007 624 unsigned short flags;
79bd622b 625 unsigned short len;
5ba37007 626};
79bd622b 627#define VERS 0x01
628#define ULP 0x02
629#define CPLUS 0x04
630#define BUILTIN 0x08
631#define OPERATOR 0x10
632
633#define B(n, t) { U n, 0, t, 0, BUILTIN, sizeof n - 1 }
634#define C(n, v) { U n, v, 0, 0, 0, sizeof n - 1 }
635#define X(n, f) { U n, 0, 0, 0, f, sizeof n - 1 }
636#define O(n, c, f) { U n, 0, 0, c, OPERATOR | f, sizeof n - 1 }
5ba37007 637static const struct builtin builtin_array[] =
6d71dc85 638{
79bd622b 639 B("__TIME__", BT_TIME),
640 B("__DATE__", BT_DATE),
641 B("__FILE__", BT_FILE),
642 B("__BASE_FILE__", BT_BASE_FILE),
643 B("__LINE__", BT_SPECLINE),
644 B("__INCLUDE_LEVEL__", BT_INCLUDE_LEVEL),
c7e5d924 645 B("_Pragma", BT_PRAGMA),
e057cf7c 646
f80e83a9 647 X("__VERSION__", VERS),
648 X("__USER_LABEL_PREFIX__", ULP),
e057cf7c 649 C("__REGISTER_PREFIX__", REGISTER_PREFIX),
650 C("__HAVE_BUILTIN_SETJMP__", "1"),
a1a7e9d5 651#if USING_SJLJ_EXCEPTIONS
652 /* libgcc needs to know this. */
653 C("__USING_SJLJ_EXCEPTIONS__","1"),
654#endif
6d71dc85 655#ifndef NO_BUILTIN_SIZE_TYPE
e057cf7c 656 C("__SIZE_TYPE__", SIZE_TYPE),
6d71dc85 657#endif
658#ifndef NO_BUILTIN_PTRDIFF_TYPE
e057cf7c 659 C("__PTRDIFF_TYPE__", PTRDIFF_TYPE),
6d71dc85 660#endif
7347d500 661#ifndef NO_BUILTIN_WCHAR_TYPE
e057cf7c 662 C("__WCHAR_TYPE__", WCHAR_TYPE),
7347d500 663#endif
1d3cade7 664#ifndef NO_BUILTIN_WINT_TYPE
665 C("__WINT_TYPE__", WINT_TYPE),
666#endif
31ca26b1 667#ifdef STDC_0_IN_SYSTEM_HEADERS
668 B("__STDC__", BT_STDC),
669#else
670 C("__STDC__", "1"),
671#endif
31674461 672
673 /* Named operators known to the preprocessor. These cannot be #defined
674 and always have their stated meaning. They are treated like normal
79bd622b 675 identifiers except for the type code and the meaning. Most of them
31674461 676 are only for C++ (but see iso646.h). */
31674461 677 O("and", CPP_AND_AND, CPLUS),
678 O("and_eq", CPP_AND_EQ, CPLUS),
679 O("bitand", CPP_AND, CPLUS),
680 O("bitor", CPP_OR, CPLUS),
681 O("compl", CPP_COMPL, CPLUS),
682 O("not", CPP_NOT, CPLUS),
683 O("not_eq", CPP_NOT_EQ, CPLUS),
684 O("or", CPP_OR_OR, CPLUS),
685 O("or_eq", CPP_OR_EQ, CPLUS),
686 O("xor", CPP_XOR, CPLUS),
79bd622b 687 O("xor_eq", CPP_XOR_EQ, CPLUS)
5ba37007 688};
e057cf7c 689#undef B
690#undef C
691#undef X
624a7570 692#undef O
1e67c2e8 693#define builtin_array_end \
694 builtin_array + sizeof(builtin_array)/sizeof(struct builtin)
5ba37007 695
9ceb1c29 696/* Subroutine of cpp_read_main_file; reads the builtins table above and
e484a1cc 697 enters them, and language-specific macros, into the hash table. */
5ba37007 698static void
b3a8144e 699init_builtins (pfile)
5ba37007 700 cpp_reader *pfile;
701{
5ba37007 702 const struct builtin *b;
4e464091 703
1e67c2e8 704 for(b = builtin_array; b < builtin_array_end; b++)
6d71dc85 705 {
79bd622b 706 if ((b->flags & CPLUS) && ! CPP_OPTION (pfile, cplusplus))
31674461 707 continue;
708
624a7570 709 if ((b->flags & OPERATOR) && ! CPP_OPTION (pfile, operator_names))
710 continue;
711
79bd622b 712 if (b->flags & (OPERATOR | BUILTIN))
713 {
714 cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len);
715 if (b->flags & OPERATOR)
716 {
717 hp->flags |= NODE_OPERATOR;
718 hp->value.operator = b->operator;
719 }
720 else
721 {
722 hp->type = NT_MACRO;
31ca26b1 723 hp->flags |= NODE_BUILTIN | NODE_WARN;
79bd622b 724 hp->value.builtin = b->builtin;
725 }
726 }
727 else /* A standard macro of some kind. */
1e67c2e8 728 {
f80e83a9 729 const char *val;
730 char *str;
731
732 if (b->flags & VERS)
733 {
a336277c 734 /* Allocate enough space for 'name "value"\n\0'. */
735 str = alloca (b->len + strlen (version_string) + 5);
736 sprintf (str, "%s \"%s\"\n", b->name, version_string);
f80e83a9 737 }
738 else
739 {
740 if (b->flags & ULP)
4e464091 741 val = CPP_OPTION (pfile, user_label_prefix);
f80e83a9 742 else
743 val = b->value;
744
a336277c 745 /* Allocate enough space for "name value\n\0". */
746 str = alloca (b->len + strlen (val) + 3);
747 sprintf(str, "%s %s\n", b->name, val);
f80e83a9 748 }
a622c29d 749
a336277c 750 _cpp_define_builtin (pfile, str);
1e67c2e8 751 }
6d71dc85 752 }
eef6c20f 753
754 if (CPP_OPTION (pfile, cplusplus))
31ca26b1 755 {
756 _cpp_define_builtin (pfile, "__cplusplus 1");
757 if (SUPPORTS_ONE_ONLY)
758 _cpp_define_builtin (pfile, "__GXX_WEAK__ 1");
759 else
760 _cpp_define_builtin (pfile, "__GXX_WEAK__ 0");
761 }
eef6c20f 762 if (CPP_OPTION (pfile, objc))
763 _cpp_define_builtin (pfile, "__OBJC__ 1");
764
765 if (CPP_OPTION (pfile, lang) == CLK_STDC94)
766 _cpp_define_builtin (pfile, "__STDC_VERSION__ 199409L");
767 else if (CPP_OPTION (pfile, c99))
768 _cpp_define_builtin (pfile, "__STDC_VERSION__ 199901L");
769
537c4bc6 770 if (CPP_OPTION (pfile, signed_char) == 0)
771 _cpp_define_builtin (pfile, "__CHAR_UNSIGNED__ 1");
772
eef6c20f 773 if (CPP_OPTION (pfile, lang) == CLK_STDC89
774 || CPP_OPTION (pfile, lang) == CLK_STDC94
775 || CPP_OPTION (pfile, lang) == CLK_STDC99)
776 _cpp_define_builtin (pfile, "__STRICT_ANSI__ 1");
777 else if (CPP_OPTION (pfile, lang) == CLK_ASM)
778 _cpp_define_builtin (pfile, "__ASSEMBLER__ 1");
6d71dc85 779}
79bd622b 780#undef BUILTIN
781#undef OPERATOR
608a2132 782#undef VERS
5ba37007 783#undef ULP
79bd622b 784#undef CPLUS
f80e83a9 785#undef builtin_array_end
6d71dc85 786
d2e850c1 787/* And another subroutine. This one sets up the standard include path. */
788static void
b3a8144e 789init_standard_includes (pfile)
d2e850c1 790 cpp_reader *pfile;
791{
d2e850c1 792 char *path;
4f98874d 793 const struct default_include *p;
2ff3ad1d 794 const char *specd_prefix = CPP_OPTION (pfile, include_prefix);
d2e850c1 795
796 /* Several environment variables may add to the include search path.
797 CPATH specifies an additional list of directories to be searched
798 as if specified with -I, while C_INCLUDE_PATH, CPLUS_INCLUDE_PATH,
799 etc. specify an additional list of directories to be searched as
800 if specified with -isystem, for the language indicated. */
801
802 GET_ENV_PATH_LIST (path, "CPATH");
803 if (path != 0 && *path != 0)
466b3f58 804 path_include (pfile, path, BRACKET);
d2e850c1 805
2ff3ad1d 806 switch ((CPP_OPTION (pfile, objc) << 1) + CPP_OPTION (pfile, cplusplus))
d2e850c1 807 {
808 case 0:
809 GET_ENV_PATH_LIST (path, "C_INCLUDE_PATH");
810 break;
811 case 1:
812 GET_ENV_PATH_LIST (path, "CPLUS_INCLUDE_PATH");
813 break;
814 case 2:
815 GET_ENV_PATH_LIST (path, "OBJC_INCLUDE_PATH");
816 break;
817 case 3:
818 GET_ENV_PATH_LIST (path, "OBJCPLUS_INCLUDE_PATH");
819 break;
820 }
821 if (path != 0 && *path != 0)
466b3f58 822 path_include (pfile, path, SYSTEM);
d2e850c1 823
824 /* Search "translated" versions of GNU directories.
825 These have /usr/local/lib/gcc... replaced by specd_prefix. */
472679ed 826 if (specd_prefix != 0 && cpp_GCC_INCLUDE_DIR_len)
d2e850c1 827 {
d2e850c1 828 /* Remove the `include' from /usr/local/lib/gcc.../include.
2c0e001b 829 GCC_INCLUDE_DIR will always end in /include. */
472679ed 830 int default_len = cpp_GCC_INCLUDE_DIR_len;
831 char *default_prefix = (char *) alloca (default_len + 1);
d2e850c1 832 int specd_len = strlen (specd_prefix);
833
472679ed 834 memcpy (default_prefix, cpp_GCC_INCLUDE_DIR, default_len);
d2e850c1 835 default_prefix[default_len] = '\0';
836
472679ed 837 for (p = cpp_include_defaults; p->fname; p++)
d2e850c1 838 {
839 /* Some standard dirs are only for C++. */
840 if (!p->cplusplus
2ff3ad1d 841 || (CPP_OPTION (pfile, cplusplus)
842 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
d2e850c1 843 {
844 /* Does this dir start with the prefix? */
b3954366 845 if (!memcmp (p->fname, default_prefix, default_len))
d2e850c1 846 {
847 /* Yes; change prefix and add to search list. */
848 int flen = strlen (p->fname);
849 int this_len = specd_len + flen - default_len;
850 char *str = (char *) xmalloc (this_len + 1);
851 memcpy (str, specd_prefix, specd_len);
852 memcpy (str + specd_len,
853 p->fname + default_len,
854 flen - default_len + 1);
855
466b3f58 856 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
d2e850c1 857 }
858 }
859 }
860 }
861
862 /* Search ordinary names for GNU include directories. */
472679ed 863 for (p = cpp_include_defaults; p->fname; p++)
d2e850c1 864 {
865 /* Some standard dirs are only for C++. */
866 if (!p->cplusplus
2ff3ad1d 867 || (CPP_OPTION (pfile, cplusplus)
868 && !CPP_OPTION (pfile, no_standard_cplusplus_includes)))
d2e850c1 869 {
17b80c08 870 char *str = update_path (p->fname, p->component);
466b3f58 871 append_include_chain (pfile, str, SYSTEM, p->cxx_aware);
d2e850c1 872 }
873 }
874}
875
e484a1cc 876/* Pushes a command line -imacro and -include file indicated by P onto
fe560637 877 the buffer stack. Returns non-zero if successful. */
878static bool
879push_include (pfile, p)
8d1752de 880 cpp_reader *pfile;
881 struct pending_option *p;
8d1752de 882{
fe560637 883 cpp_token header;
8d1752de 884
fe560637 885 /* Later: maybe update this to use the #include "" search path
886 if cpp_read_file fails. */
887 header.type = CPP_STRING;
888 header.val.str.text = (const unsigned char *) p->arg;
889 header.val.str.len = strlen (p->arg);
890 /* Make the command line directive take up a line. */
729d2022 891 pfile->line++;
fe560637 892
893 return _cpp_execute_include (pfile, &header, IT_CMDLINE);
894}
895
896/* Frees a pending_option chain. */
897static void
898free_chain (head)
899 struct pending_option *head;
900{
901 struct pending_option *next;
902
903 while (head)
904 {
905 next = head->next;
906 free (head);
907 head = next;
8d1752de 908 }
909}
910
9ceb1c29 911/* This is called after options have been parsed, and partially
912 processed. Setup for processing input from the file named FNAME,
913 or stdin if it is the empty string. Return the original filename
914 on success (e.g. foo.i->foo.c), or NULL on failure. */
915const char *
916cpp_read_main_file (pfile, fname, table)
6d71dc85 917 cpp_reader *pfile;
8d7a2585 918 const char *fname;
9ceb1c29 919 hash_table *table;
6d71dc85 920{
9ceb1c29 921 /* The front ends don't set up the hash table until they have
922 finished processing the command line options, so initializing the
923 hashtable is deferred until now. */
924 _cpp_init_hashtable (pfile, table);
925
d2e850c1 926 /* Set up the include search path now. */
2ff3ad1d 927 if (! CPP_OPTION (pfile, no_standard_includes))
b3a8144e 928 init_standard_includes (pfile);
d2e850c1 929
2ff3ad1d 930 merge_include_chains (pfile);
d2e850c1 931
932 /* With -v, print the list of dirs to search. */
2ff3ad1d 933 if (CPP_OPTION (pfile, verbose))
d2e850c1 934 {
3ec84a0b 935 struct search_path *l;
d2e850c1 936 fprintf (stderr, _("#include \"...\" search starts here:\n"));
2ff3ad1d 937 for (l = CPP_OPTION (pfile, quote_include); l; l = l->next)
d2e850c1 938 {
2ff3ad1d 939 if (l == CPP_OPTION (pfile, bracket_include))
d2e850c1 940 fprintf (stderr, _("#include <...> search starts here:\n"));
941 fprintf (stderr, " %s\n", l->name);
942 }
943 fprintf (stderr, _("End of search list.\n"));
944 }
945
af808d7d 946 if (CPP_OPTION (pfile, print_deps))
162804c0 947 /* Set the default target (if there is none already). */
7e555f5f 948 deps_add_default_target (pfile->deps, fname);
af808d7d 949
9ceb1c29 950 /* Open the main input file. */
fd944c82 951 if (!_cpp_read_file (pfile, fname))
9ceb1c29 952 return NULL;
d2e850c1 953
438ac94c 954 /* Set this after cpp_post_options so the client can change the
955 option if it wishes, and after stacking the main file so we don't
956 trace the main file. */
957 pfile->line_maps.trace_includes = CPP_OPTION (pfile, print_include_names);
958
9ceb1c29 959 /* For foo.i, read the original filename foo.c now, for the benefit
960 of the front ends. */
961 if (CPP_OPTION (pfile, preprocessed))
962 read_original_filename (pfile);
963
964 return pfile->map->to_file;
965}
966
967/* For preprocessed files, if the first tokens are of the form # NUM.
968 handle the directive so we know the original file name. This will
969 generate file_change callbacks, which the front ends must handle
970 appropriately given their state of initialization. */
971static void
972read_original_filename (pfile)
973 cpp_reader *pfile;
974{
975 const cpp_token *token, *token1;
976
977 /* Lex ahead; if the first tokens are of the form # NUM, then
978 process the directive, otherwise back up. */
979 token = _cpp_lex_direct (pfile);
980 if (token->type == CPP_HASH)
981 {
982 token1 = _cpp_lex_direct (pfile);
983 _cpp_backup_tokens (pfile, 1);
984
985 /* If it's a #line directive, handle it. */
986 if (token1->type == CPP_NUMBER)
987 {
988 _cpp_handle_directive (pfile, token->flags & PREV_WHITE);
989 return;
990 }
991 }
992
993 /* Backup as if nothing happened. */
994 _cpp_backup_tokens (pfile, 1);
995}
996
997/* Handle pending command line options: -D, -U, -A, -imacros and
998 -include. This should be called after debugging has been properly
999 set up in the front ends. */
1000void
1001cpp_finish_options (pfile)
1002 cpp_reader *pfile;
1003{
fe560637 1004 /* Install builtins and process command line macros etc. in the order
1005 they appeared, but only if not already preprocessed. */
c2acbd5a 1006 if (! CPP_OPTION (pfile, preprocessed))
6d71dc85 1007 {
fe560637 1008 struct pending_option *p;
1009
f4ec69cb 1010 _cpp_do_file_change (pfile, LC_RENAME, _("<built-in>"), 1, 0);
fe560637 1011 init_builtins (pfile);
1012 _cpp_do_file_change (pfile, LC_RENAME, _("<command line>"), 1, 0);
1013 for (p = CPP_OPTION (pfile, pending)->directive_head; p; p = p->next)
c2acbd5a 1014 (*p->handler) (pfile, p->arg);
fe560637 1015
1016 /* Scan -imacros files after command line defines, but before
1017 files given with -include. */
155b5da1 1018 while ((p = CPP_OPTION (pfile, pending)->imacros_head) != NULL)
fe560637 1019 {
1020 if (push_include (pfile, p))
1021 {
1022 pfile->buffer->return_at_eof = true;
1023 cpp_scan_nooutput (pfile);
1024 }
155b5da1 1025 CPP_OPTION (pfile, pending)->imacros_head = p->next;
1026 free (p);
fe560637 1027 }
6d71dc85 1028 }
c2acbd5a 1029
fe560637 1030 free_chain (CPP_OPTION (pfile, pending)->directive_head);
fe560637 1031 _cpp_push_next_buffer (pfile);
fe560637 1032}
6d71dc85 1033
fe560637 1034/* Called to push the next buffer on the stack given by -include. If
1035 there are none, free the pending structure and restore the line map
1036 for the main file. */
1037bool
1038_cpp_push_next_buffer (pfile)
1039 cpp_reader *pfile;
1040{
1041 bool pushed = false;
6d71dc85 1042
155b5da1 1043 /* This is't pretty; we'd rather not be relying on this as a boolean
1044 for reverting the line map. Further, we only free the chains in
1045 this conditional, so an early call to cpp_finish / cpp_destroy
1046 will leak that memory. */
1047 if (CPP_OPTION (pfile, pending)
1048 && CPP_OPTION (pfile, pending)->imacros_head == NULL)
fe560637 1049 {
1050 while (!pushed)
1051 {
1052 struct pending_option *p = CPP_OPTION (pfile, pending)->include_head;
1053
1054 if (p == NULL)
1055 break;
1056 if (! CPP_OPTION (pfile, preprocessed))
1057 pushed = push_include (pfile, p);
1058 CPP_OPTION (pfile, pending)->include_head = p->next;
1059 free (p);
1060 }
1061
1062 if (!pushed)
1063 {
1064 free (CPP_OPTION (pfile, pending));
1065 CPP_OPTION (pfile, pending) = NULL;
1066
1067 /* Restore the line map for the main file. */
1068 if (! CPP_OPTION (pfile, preprocessed))
1069 _cpp_do_file_change (pfile, LC_RENAME,
1070 pfile->line_maps.maps[0].to_file, 1, 0);
1071 }
1072 }
1073
1074 return pushed;
6d71dc85 1075}
1076
de2873b7 1077/* Use mkdeps.c to output dependency information. */
b3a8144e 1078static void
1079output_deps (pfile)
1080 cpp_reader *pfile;
1081{
1082 /* Stream on which to print the dependency information. */
1083 FILE *deps_stream = 0;
35823b64 1084 const char *const deps_mode =
1085 CPP_OPTION (pfile, print_deps_append) ? "a" : "w";
b3a8144e 1086
1087 if (CPP_OPTION (pfile, deps_file) == 0)
1088 deps_stream = stdout;
1089 else
1090 {
1091 deps_stream = fopen (CPP_OPTION (pfile, deps_file), deps_mode);
1092 if (deps_stream == 0)
1093 {
1094 cpp_notice_from_errno (pfile, CPP_OPTION (pfile, deps_file));
1095 return;
1096 }
1097 }
1098
1099 deps_write (pfile->deps, deps_stream, 72);
1100
1101 if (CPP_OPTION (pfile, deps_phony_targets))
1102 deps_phony_targets (pfile->deps, deps_stream);
1103
1104 /* Don't close stdout. */
1105 if (CPP_OPTION (pfile, deps_file))
1106 {
1107 if (ferror (deps_stream) || fclose (deps_stream) != 0)
1108 cpp_fatal (pfile, "I/O error on output");
1109 }
1110}
1111
6d71dc85 1112/* This is called at the end of preprocessing. It pops the
1113 last buffer and writes dependency output. It should also
1114 clear macro definitions, such that you could call cpp_start_read
8d1752de 1115 with a new filename to restart processing. */
6d71dc85 1116void
79bd622b 1117cpp_finish (pfile)
6d71dc85 1118 cpp_reader *pfile;
1119{
5475a165 1120 /* cpplex.c leaves the final buffer on the stack. This it so that
1121 it returns an unending stream of CPP_EOFs to the client. If we
3fb1e43b 1122 popped the buffer, we'd dereference a NULL buffer pointer and
5475a165 1123 segfault. It's nice to allow the client to do worry-free excess
1124 cpp_get_token calls. */
1125 while (pfile->buffer)
1126 _cpp_pop_buffer (pfile);
9e87fa80 1127
62adb1fe 1128 /* Don't write the deps file if preprocessing has failed. */
2ff3ad1d 1129 if (CPP_OPTION (pfile, print_deps) && pfile->errors == 0)
b3a8144e 1130 output_deps (pfile);
d453a374 1131
34627970 1132 /* Report on headers that could use multiple include guards. */
1133 if (CPP_OPTION (pfile, print_include_names))
f51c2148 1134 _cpp_report_missing_guards (pfile);
6d71dc85 1135}
1136
e484a1cc 1137/* Add a directive to be handled later in the initialization phase. */
dd48bf24 1138static void
2ff3ad1d 1139new_pending_directive (pend, text, handler)
1140 struct cpp_pending *pend;
dd48bf24 1141 const char *text;
d73269b6 1142 cl_directive_handler handler;
dd48bf24 1143{
1144 struct pending_option *o = (struct pending_option *)
1145 xmalloc (sizeof (struct pending_option));
1146
8d7a2585 1147 o->arg = text;
dd48bf24 1148 o->next = NULL;
d73269b6 1149 o->handler = handler;
2ff3ad1d 1150 APPEND (pend, directive, o);
dd48bf24 1151}
1152
2ff3ad1d 1153/* Irix6 "cc -n32" and OSF4 cc have problems with char foo[] = ("string");
1154 I.e. a const string initializer with parens around it. That is
1155 what N_("string") resolves to, so we make no_* be macros instead. */
68435912 1156#define no_arg N_("argument missing after %s")
1157#define no_ass N_("assertion missing after %s")
1158#define no_dir N_("directory name missing after %s")
1159#define no_fil N_("file name missing after %s")
1160#define no_mac N_("macro name missing after %s")
1161#define no_pth N_("path name missing after %s")
1162#define no_num N_("number missing after %s")
1163#define no_tgt N_("target missing after %s")
2ff3ad1d 1164
1165/* This is the list of all command line options, with the leading
1166 "-" removed. It must be sorted in ASCII collating order. */
1167#define COMMAND_LINE_OPTIONS \
2ff3ad1d 1168 DEF_OPT("$", 0, OPT_dollar) \
1169 DEF_OPT("+", 0, OPT_plus) \
1170 DEF_OPT("-help", 0, OPT__help) \
7a6882ca 1171 DEF_OPT("-target-help", 0, OPT_target__help) \
2ff3ad1d 1172 DEF_OPT("-version", 0, OPT__version) \
1173 DEF_OPT("A", no_ass, OPT_A) \
1174 DEF_OPT("C", 0, OPT_C) \
1175 DEF_OPT("D", no_mac, OPT_D) \
1176 DEF_OPT("H", 0, OPT_H) \
1177 DEF_OPT("I", no_dir, OPT_I) \
1178 DEF_OPT("M", 0, OPT_M) \
308f302c 1179 DEF_OPT("MD", no_fil, OPT_MD) \
af808d7d 1180 DEF_OPT("MF", no_fil, OPT_MF) \
2ff3ad1d 1181 DEF_OPT("MG", 0, OPT_MG) \
1182 DEF_OPT("MM", 0, OPT_MM) \
308f302c 1183 DEF_OPT("MMD", no_fil, OPT_MMD) \
2e399de6 1184 DEF_OPT("MP", 0, OPT_MP) \
7b4b68f2 1185 DEF_OPT("MQ", no_tgt, OPT_MQ) \
3d7dca39 1186 DEF_OPT("MT", no_tgt, OPT_MT) \
2ff3ad1d 1187 DEF_OPT("P", 0, OPT_P) \
1188 DEF_OPT("U", no_mac, OPT_U) \
1189 DEF_OPT("W", no_arg, OPT_W) /* arg optional */ \
1190 DEF_OPT("d", no_arg, OPT_d) \
1191 DEF_OPT("fleading-underscore", 0, OPT_fleading_underscore) \
1192 DEF_OPT("fno-leading-underscore", 0, OPT_fno_leading_underscore) \
624a7570 1193 DEF_OPT("fno-operator-names", 0, OPT_fno_operator_names) \
2ff3ad1d 1194 DEF_OPT("fno-preprocessed", 0, OPT_fno_preprocessed) \
1195 DEF_OPT("fno-show-column", 0, OPT_fno_show_column) \
1196 DEF_OPT("fpreprocessed", 0, OPT_fpreprocessed) \
1197 DEF_OPT("fshow-column", 0, OPT_fshow_column) \
537c4bc6 1198 DEF_OPT("fsigned-char", 0, OPT_fsigned_char) \
3b304865 1199 DEF_OPT("ftabstop=", no_num, OPT_ftabstop) \
537c4bc6 1200 DEF_OPT("funsigned-char", 0, OPT_funsigned_char) \
2ff3ad1d 1201 DEF_OPT("h", 0, OPT_h) \
1202 DEF_OPT("idirafter", no_dir, OPT_idirafter) \
1203 DEF_OPT("imacros", no_fil, OPT_imacros) \
1204 DEF_OPT("include", no_fil, OPT_include) \
1205 DEF_OPT("iprefix", no_pth, OPT_iprefix) \
1206 DEF_OPT("isystem", no_dir, OPT_isystem) \
1207 DEF_OPT("iwithprefix", no_dir, OPT_iwithprefix) \
1208 DEF_OPT("iwithprefixbefore", no_dir, OPT_iwithprefixbefore) \
1209 DEF_OPT("lang-asm", 0, OPT_lang_asm) \
1210 DEF_OPT("lang-c", 0, OPT_lang_c) \
1211 DEF_OPT("lang-c++", 0, OPT_lang_cplusplus) \
1212 DEF_OPT("lang-c89", 0, OPT_lang_c89) \
2ff3ad1d 1213 DEF_OPT("lang-objc", 0, OPT_lang_objc) \
1214 DEF_OPT("lang-objc++", 0, OPT_lang_objcplusplus) \
1215 DEF_OPT("nostdinc", 0, OPT_nostdinc) \
1216 DEF_OPT("nostdinc++", 0, OPT_nostdincplusplus) \
1217 DEF_OPT("o", no_fil, OPT_o) \
1218 DEF_OPT("pedantic", 0, OPT_pedantic) \
1219 DEF_OPT("pedantic-errors", 0, OPT_pedantic_errors) \
1220 DEF_OPT("remap", 0, OPT_remap) \
fad0ffbb 1221 DEF_OPT("std=c++98", 0, OPT_std_cplusplus98) \
2ff3ad1d 1222 DEF_OPT("std=c89", 0, OPT_std_c89) \
1223 DEF_OPT("std=c99", 0, OPT_std_c99) \
1224 DEF_OPT("std=c9x", 0, OPT_std_c9x) \
1225 DEF_OPT("std=gnu89", 0, OPT_std_gnu89) \
1226 DEF_OPT("std=gnu99", 0, OPT_std_gnu99) \
1227 DEF_OPT("std=gnu9x", 0, OPT_std_gnu9x) \
1228 DEF_OPT("std=iso9899:1990", 0, OPT_std_iso9899_1990) \
1229 DEF_OPT("std=iso9899:199409", 0, OPT_std_iso9899_199409) \
1230 DEF_OPT("std=iso9899:1999", 0, OPT_std_iso9899_1999) \
1231 DEF_OPT("std=iso9899:199x", 0, OPT_std_iso9899_199x) \
2ff3ad1d 1232 DEF_OPT("trigraphs", 0, OPT_trigraphs) \
1233 DEF_OPT("v", 0, OPT_v) \
1353d9f7 1234 DEF_OPT("version", 0, OPT_version) \
2ff3ad1d 1235 DEF_OPT("w", 0, OPT_w)
1236
1237#define DEF_OPT(text, msg, code) code,
bcc40c63 1238enum opt_code
1239{
2ff3ad1d 1240 COMMAND_LINE_OPTIONS
bcc40c63 1241 N_OPTS
1242};
2ff3ad1d 1243#undef DEF_OPT
bcc40c63 1244
1245struct cl_option
1246{
1247 const char *opt_text;
1248 const char *msg;
1249 size_t opt_len;
1250 enum opt_code opt_code;
1251};
1252
2ff3ad1d 1253#define DEF_OPT(text, msg, code) { text, msg, sizeof(text) - 1, code },
bcc40c63 1254#ifdef HOST_EBCDIC
1255static struct cl_option cl_options[] =
1256#else
1257static const struct cl_option cl_options[] =
1258#endif
1259{
2ff3ad1d 1260 COMMAND_LINE_OPTIONS
bcc40c63 1261};
1262#undef DEF_OPT
2ff3ad1d 1263#undef COMMAND_LINE_OPTIONS
bcc40c63 1264
1265/* Perform a binary search to find which, if any, option the given
1266 command-line matches. Returns its index in the option array,
1267 negative on failure. Complications arise since some options can be
1268 suffixed with an argument, and multiple complete matches can occur,
c2acbd5a 1269 e.g. -iwithprefix and -iwithprefixbefore. Moreover, we need to
1270 accept options beginning with -W that we do not recognise, but not
1271 to swallow any subsequent command line argument; this is handled as
1272 special cases in cpp_handle_option. */
bcc40c63 1273static int
1274parse_option (input)
1275 const char *input;
1276{
1277 unsigned int md, mn, mx;
1278 size_t opt_len;
1279 int comp;
1280
1281 mn = 0;
1282 mx = N_OPTS;
1283
1284 while (mx > mn)
1285 {
1286 md = (mn + mx) / 2;
2ff3ad1d 1287
bcc40c63 1288 opt_len = cl_options[md].opt_len;
b3954366 1289 comp = memcmp (input, cl_options[md].opt_text, opt_len);
2ff3ad1d 1290
bcc40c63 1291 if (comp > 0)
1292 mn = md + 1;
1293 else if (comp < 0)
1294 mx = md;
1295 else
1296 {
1297 if (input[opt_len] == '\0')
1298 return md;
1299 /* We were passed more text. If the option takes an argument,
1300 we may match a later option or we may have been passed the
1301 argument. The longest possible option match succeeds.
1302 If the option takes no arguments we have not matched and
8d1752de 1303 continue the search (e.g. input="stdc++" match was "stdc"). */
bcc40c63 1304 mn = md + 1;
1305 if (cl_options[md].msg)
1306 {
1307 /* Scan forwards. If we get an exact match, return it.
1308 Otherwise, return the longest option-accepting match.
8d1752de 1309 This loops no more than twice with current options. */
bcc40c63 1310 mx = md;
ee6c4e4b 1311 for (; mn < (unsigned int) N_OPTS; mn++)
bcc40c63 1312 {
1313 opt_len = cl_options[mn].opt_len;
b3954366 1314 if (memcmp (input, cl_options[mn].opt_text, opt_len))
bcc40c63 1315 break;
1316 if (input[opt_len] == '\0')
1317 return mn;
1318 if (cl_options[mn].msg)
1319 mx = mn;
1320 }
1321 return mx;
1322 }
1323 }
1324 }
1325
1326 return -1;
1327}
1328
6d71dc85 1329/* Handle one command-line option in (argc, argv).
1330 Can be called multiple times, to handle multiple sets of options.
a182c763 1331 If ignore is non-zero, this will ignore unrecognized -W* options.
6d71dc85 1332 Returns number of strings consumed. */
dfa5c7fa 1333int
a182c763 1334cpp_handle_option (pfile, argc, argv, ignore)
6d71dc85 1335 cpp_reader *pfile;
1336 int argc;
1337 char **argv;
a182c763 1338 int ignore;
6d71dc85 1339{
6d71dc85 1340 int i = 0;
c4abf88d 1341 struct cpp_pending *pend = CPP_OPTION (pfile, pending);
6d71dc85 1342
7e555f5f 1343 /* Interpret "-" or a non-option as a file name. */
1344 if (argv[i][0] != '-' || argv[i][1] == '\0')
9fa36617 1345 {
7e555f5f 1346 if (CPP_OPTION (pfile, in_fname) == NULL)
1347 CPP_OPTION (pfile, in_fname) = argv[i];
1348 else if (CPP_OPTION (pfile, out_fname) == NULL)
2ff3ad1d 1349 CPP_OPTION (pfile, out_fname) = argv[i];
9fa36617 1350 else
68435912 1351 cpp_fatal (pfile, "too many filenames. Type %s --help for usage info",
7e555f5f 1352 progname);
9fa36617 1353 }
1354 else
bcc40c63 1355 {
1356 enum opt_code opt_code;
1357 int opt_index;
8d7a2585 1358 const char *arg = 0;
bcc40c63 1359
8d1752de 1360 /* Skip over '-'. */
bcc40c63 1361 opt_index = parse_option (&argv[i][1]);
1362 if (opt_index < 0)
1363 return i;
1364
1365 opt_code = cl_options[opt_index].opt_code;
1366 if (cl_options[opt_index].msg)
1367 {
1368 arg = &argv[i][cl_options[opt_index].opt_len + 1];
1369
b60b3a91 1370 /* Yuk. Special case for -W as it must not swallow
bcc40c63 1371 up any following argument. If this becomes common, add
8d1752de 1372 another field to the cl_options table. */
b60b3a91 1373 if (arg[0] == '\0' && opt_code != OPT_W)
bcc40c63 1374 {
1375 arg = argv[++i];
1376 if (!arg)
1377 {
780662e7 1378 cpp_fatal (pfile, cl_options[opt_index].msg, argv[i - 1]);
bcc40c63 1379 return argc;
1380 }
1381 }
1382 }
2ff3ad1d 1383
bcc40c63 1384 switch (opt_code)
1385 {
8d1752de 1386 case N_OPTS: /* Shut GCC up. */
bcc40c63 1387 break;
1388 case OPT_fleading_underscore:
4e464091 1389 CPP_OPTION (pfile, user_label_prefix) = "_";
bcc40c63 1390 break;
1391 case OPT_fno_leading_underscore:
4e464091 1392 CPP_OPTION (pfile, user_label_prefix) = "";
bcc40c63 1393 break;
624a7570 1394 case OPT_fno_operator_names:
1395 CPP_OPTION (pfile, operator_names) = 0;
1396 break;
bcc40c63 1397 case OPT_fpreprocessed:
2ff3ad1d 1398 CPP_OPTION (pfile, preprocessed) = 1;
bcc40c63 1399 break;
1400 case OPT_fno_preprocessed:
2ff3ad1d 1401 CPP_OPTION (pfile, preprocessed) = 0;
1402 break;
1403 case OPT_fshow_column:
1404 CPP_OPTION (pfile, show_column) = 1;
1405 break;
1406 case OPT_fno_show_column:
1407 CPP_OPTION (pfile, show_column) = 0;
bcc40c63 1408 break;
537c4bc6 1409 case OPT_fsigned_char:
1410 CPP_OPTION (pfile, signed_char) = 1;
1411 break;
1412 case OPT_funsigned_char:
1413 CPP_OPTION (pfile, signed_char) = 0;
1414 break;
3b304865 1415 case OPT_ftabstop:
1416 /* Silently ignore empty string, non-longs and silly values. */
1417 if (arg[0] != '\0')
1418 {
1419 char *endptr;
1420 long tabstop = strtol (arg, &endptr, 10);
1421 if (*endptr == '\0' && tabstop >= 1 && tabstop <= 100)
1422 CPP_OPTION (pfile, tabstop) = tabstop;
1423 }
1424 break;
bcc40c63 1425 case OPT_w:
2ff3ad1d 1426 CPP_OPTION (pfile, inhibit_warnings) = 1;
bcc40c63 1427 break;
bcc40c63 1428 case OPT_h:
1429 case OPT__help:
1430 print_help ();
72b04ca4 1431 CPP_OPTION (pfile, help_only) = 1;
bcc40c63 1432 break;
7a6882ca 1433 case OPT_target__help:
1353d9f7 1434 /* Print if any target specific options. cpplib has none, but
1435 make sure help_only gets set. */
72b04ca4 1436 CPP_OPTION (pfile, help_only) = 1;
7a6882ca 1437 break;
1353d9f7 1438
1439 /* --version inhibits compilation, -version doesn't. -v means
1440 verbose and -version. Historical reasons, don't ask. */
bcc40c63 1441 case OPT__version:
72b04ca4 1442 CPP_OPTION (pfile, help_only) = 1;
a19b9668 1443 pfile->print_version = 1;
1444 break;
1353d9f7 1445 case OPT_v:
1446 CPP_OPTION (pfile, verbose) = 1;
a19b9668 1447 pfile->print_version = 1;
1448 break;
1353d9f7 1449 case OPT_version:
a19b9668 1450 pfile->print_version = 1;
bcc40c63 1451 break;
1353d9f7 1452
bcc40c63 1453 case OPT_C:
2ff3ad1d 1454 CPP_OPTION (pfile, discard_comments) = 0;
bcc40c63 1455 break;
1456 case OPT_P:
2ff3ad1d 1457 CPP_OPTION (pfile, no_line_commands) = 1;
bcc40c63 1458 break;
8d1752de 1459 case OPT_dollar: /* Don't include $ in identifiers. */
2ff3ad1d 1460 CPP_OPTION (pfile, dollars_in_ident) = 0;
bcc40c63 1461 break;
1462 case OPT_H:
2ff3ad1d 1463 CPP_OPTION (pfile, print_include_names) = 1;
bcc40c63 1464 break;
1465 case OPT_D:
c4abf88d 1466 new_pending_directive (pend, arg, cpp_define);
bcc40c63 1467 break;
1468 case OPT_pedantic_errors:
2ff3ad1d 1469 CPP_OPTION (pfile, pedantic_errors) = 1;
bcc40c63 1470 /* fall through */
1471 case OPT_pedantic:
2ff3ad1d 1472 CPP_OPTION (pfile, pedantic) = 1;
bcc40c63 1473 break;
bcc40c63 1474 case OPT_trigraphs:
2ff3ad1d 1475 CPP_OPTION (pfile, trigraphs) = 1;
bcc40c63 1476 break;
1477 case OPT_plus:
2ff3ad1d 1478 CPP_OPTION (pfile, cplusplus) = 1;
1479 CPP_OPTION (pfile, cplusplus_comments) = 1;
bcc40c63 1480 break;
1481 case OPT_remap:
2ff3ad1d 1482 CPP_OPTION (pfile, remap) = 1;
bcc40c63 1483 break;
1484 case OPT_iprefix:
2ff3ad1d 1485 CPP_OPTION (pfile, include_prefix) = arg;
1486 CPP_OPTION (pfile, include_prefix_len) = strlen (arg);
bcc40c63 1487 break;
1488 case OPT_lang_c:
fad0ffbb 1489 set_lang (pfile, CLK_GNUC89);
bcc40c63 1490 break;
bcc40c63 1491 case OPT_lang_cplusplus:
fad0ffbb 1492 set_lang (pfile, CLK_GNUCXX);
bcc40c63 1493 break;
c4abf88d 1494 case OPT_lang_objc:
fad0ffbb 1495 set_lang (pfile, CLK_OBJC);
bcc40c63 1496 break;
fad0ffbb 1497 case OPT_lang_objcplusplus:
1498 set_lang (pfile, CLK_OBJCXX);
bcc40c63 1499 break;
fad0ffbb 1500 case OPT_lang_asm:
1501 set_lang (pfile, CLK_ASM);
bcc40c63 1502 break;
fad0ffbb 1503 case OPT_std_cplusplus98:
1504 set_lang (pfile, CLK_CXX98);
bcc40c63 1505 break;
1506 case OPT_std_gnu89:
fad0ffbb 1507 set_lang (pfile, CLK_GNUC89);
bcc40c63 1508 break;
1509 case OPT_std_gnu9x:
1510 case OPT_std_gnu99:
fad0ffbb 1511 set_lang (pfile, CLK_GNUC99);
bcc40c63 1512 break;
1513 case OPT_std_iso9899_199409:
fad0ffbb 1514 set_lang (pfile, CLK_STDC94);
1515 break;
bcc40c63 1516 case OPT_std_iso9899_1990:
1517 case OPT_std_c89:
27fdc0b6 1518 case OPT_lang_c89:
fad0ffbb 1519 set_lang (pfile, CLK_STDC89);
bcc40c63 1520 break;
1521 case OPT_std_iso9899_199x:
1522 case OPT_std_iso9899_1999:
1523 case OPT_std_c9x:
1524 case OPT_std_c99:
fad0ffbb 1525 set_lang (pfile, CLK_STDC99);
1526 break;
1527 case OPT_nostdinc:
1528 /* -nostdinc causes no default include directories.
1529 You must specify all include-file directories with -I. */
1530 CPP_OPTION (pfile, no_standard_includes) = 1;
1531 break;
1532 case OPT_nostdincplusplus:
2c0e001b 1533 /* -nostdinc++ causes no default C++-specific include directories. */
fad0ffbb 1534 CPP_OPTION (pfile, no_standard_cplusplus_includes) = 1;
bcc40c63 1535 break;
1536 case OPT_o:
7e555f5f 1537 if (CPP_OPTION (pfile, out_fname) == NULL)
1538 CPP_OPTION (pfile, out_fname) = arg;
1539 else
9fa36617 1540 {
cb8bacb6 1541 cpp_fatal (pfile, "output filename specified twice");
bcc40c63 1542 return argc;
1543 }
bcc40c63 1544 break;
1545 case OPT_d:
1546 /* Args to -d specify what parts of macros to dump.
1547 Silently ignore unrecognised options; they may
8d1752de 1548 be aimed at the compiler proper. */
bcc40c63 1549 {
1550 char c;
2ff3ad1d 1551
bcc40c63 1552 while ((c = *arg++) != '\0')
1553 switch (c)
1554 {
1555 case 'M':
2ff3ad1d 1556 CPP_OPTION (pfile, dump_macros) = dump_only;
1557 CPP_OPTION (pfile, no_output) = 1;
9fa36617 1558 break;
1559 case 'N':
2ff3ad1d 1560 CPP_OPTION (pfile, dump_macros) = dump_names;
9fa36617 1561 break;
1562 case 'D':
2ff3ad1d 1563 CPP_OPTION (pfile, dump_macros) = dump_definitions;
9fa36617 1564 break;
1565 case 'I':
2ff3ad1d 1566 CPP_OPTION (pfile, dump_includes) = 1;
9fa36617 1567 break;
1568 }
bcc40c63 1569 }
1570 break;
af808d7d 1571
bcc40c63 1572 case OPT_MG:
2ff3ad1d 1573 CPP_OPTION (pfile, print_deps_missing_files) = 1;
bcc40c63 1574 break;
1575 case OPT_M:
af808d7d 1576 CPP_OPTION (pfile, print_deps) = 2;
1577 break;
bcc40c63 1578 case OPT_MM:
af808d7d 1579 CPP_OPTION (pfile, print_deps) = 1;
bcc40c63 1580 break;
af808d7d 1581 case OPT_MF:
1582 CPP_OPTION (pfile, deps_file) = arg;
1583 break;
1584 case OPT_MP:
2e399de6 1585 CPP_OPTION (pfile, deps_phony_targets) = 1;
1586 break;
7b4b68f2 1587 case OPT_MQ:
3d7dca39 1588 case OPT_MT:
7b4b68f2 1589 /* Add a target. -MQ quotes for Make. */
1590 deps_add_target (pfile->deps, arg, opt_code == OPT_MQ);
3d7dca39 1591 break;
1592
308f302c 1593 /* -MD and -MMD for cpp0 are deprecated and undocumented
1594 (use -M or -MM with -MF instead), and probably should be
1595 removed with the next major GCC version. For the moment
1596 we allow these for the benefit of Automake 1.4, which
1597 uses these when dependency tracking is enabled. Automake
1598 1.5 will fix this. */
1599 case OPT_MD:
1600 CPP_OPTION (pfile, print_deps) = 2;
1601 CPP_OPTION (pfile, deps_file) = arg;
1602 break;
1603 case OPT_MMD:
1604 CPP_OPTION (pfile, print_deps) = 1;
1605 CPP_OPTION (pfile, deps_file) = arg;
1606 break;
1607
bcc40c63 1608 case OPT_A:
77ee202d 1609 if (arg[0] == '-')
9fa36617 1610 {
77ee202d 1611 /* -A with an argument beginning with '-' acts as
1612 #unassert on whatever immediately follows the '-'.
1613 If "-" is the whole argument, we eliminate all
1614 predefined macros and assertions, including those
1615 that were specified earlier on the command line.
1616 That way we can get rid of any that were passed
1617 automatically in from GCC. */
1618
1619 if (arg[1] == '\0')
9fa36617 1620 {
c808d026 1621 free_chain (pend->directive_head);
466b3f58 1622 pend->directive_head = NULL;
1623 pend->directive_tail = NULL;
9fa36617 1624 }
77ee202d 1625 else
466b3f58 1626 new_pending_directive (pend, arg + 1, cpp_unassert);
6d71dc85 1627 }
77ee202d 1628 else
466b3f58 1629 new_pending_directive (pend, arg, cpp_assert);
bcc40c63 1630 break;
1631 case OPT_U:
466b3f58 1632 new_pending_directive (pend, arg, cpp_undef);
bcc40c63 1633 break;
1634 case OPT_I: /* Add directory to path for includes. */
1635 if (!strcmp (arg, "-"))
1636 {
1637 /* -I- means:
1638 Use the preceding -I directories for #include "..."
1639 but not #include <...>.
1640 Don't search the directory of the present file
1641 for #include "...". (Note that -I. -I- is not the same as
1642 the default setup; -I. uses the compiler's working dir.) */
2ff3ad1d 1643 if (! CPP_OPTION (pfile, ignore_srcdir))
bcc40c63 1644 {
2ff3ad1d 1645 pend->quote_head = pend->brack_head;
1646 pend->quote_tail = pend->brack_tail;
1647 pend->brack_head = 0;
1648 pend->brack_tail = 0;
1649 CPP_OPTION (pfile, ignore_srcdir) = 1;
bcc40c63 1650 }
1651 else
1652 {
1653 cpp_fatal (pfile, "-I- specified twice");
1654 return argc;
1655 }
1656 }
1657 else
466b3f58 1658 append_include_chain (pfile, xstrdup (arg), BRACKET, 0);
bcc40c63 1659 break;
1660 case OPT_isystem:
1661 /* Add directory to beginning of system include path, as a system
8d1752de 1662 include directory. */
466b3f58 1663 append_include_chain (pfile, xstrdup (arg), SYSTEM, 0);
bcc40c63 1664 break;
1665 case OPT_include:
bcc40c63 1666 case OPT_imacros:
1667 {
1668 struct pending_option *o = (struct pending_option *)
1669 xmalloc (sizeof (struct pending_option));
1670 o->arg = arg;
1671 o->next = NULL;
2ff3ad1d 1672
fe560637 1673 if (opt_code == OPT_include)
1674 APPEND (pend, include, o);
1675 else
1676 APPEND (pend, imacros, o);
bcc40c63 1677 }
1678 break;
1679 case OPT_iwithprefix:
1680 /* Add directory to end of path for includes,
1681 with the default prefix at the front of its name. */
1682 /* fall through */
1683 case OPT_iwithprefixbefore:
1684 /* Add directory to main path for includes,
1685 with the default prefix at the front of its name. */
1686 {
1687 char *fname;
1688 int len;
2ff3ad1d 1689
bcc40c63 1690 len = strlen (arg);
2ff3ad1d 1691
1692 if (CPP_OPTION (pfile, include_prefix) != 0)
bcc40c63 1693 {
2ff3ad1d 1694 size_t ipl = CPP_OPTION (pfile, include_prefix_len);
1695 fname = xmalloc (ipl + len + 1);
1696 memcpy (fname, CPP_OPTION (pfile, include_prefix), ipl);
1697 memcpy (fname + ipl, arg, len + 1);
bcc40c63 1698 }
472679ed 1699 else if (cpp_GCC_INCLUDE_DIR_len)
bcc40c63 1700 {
472679ed 1701 fname = xmalloc (cpp_GCC_INCLUDE_DIR_len + len + 1);
1702 memcpy (fname, cpp_GCC_INCLUDE_DIR, cpp_GCC_INCLUDE_DIR_len);
1703 memcpy (fname + cpp_GCC_INCLUDE_DIR_len, arg, len + 1);
bcc40c63 1704 }
472679ed 1705 else
1706 fname = xstrdup (arg);
2ff3ad1d 1707
466b3f58 1708 append_include_chain (pfile, fname,
bcc40c63 1709 opt_code == OPT_iwithprefix ? SYSTEM: BRACKET, 0);
1710 }
1711 break;
1712 case OPT_idirafter:
1713 /* Add directory to end of path for includes. */
466b3f58 1714 append_include_chain (pfile, xstrdup (arg), AFTER, 0);
bcc40c63 1715 break;
1716 case OPT_W:
8d1752de 1717 /* Silently ignore unrecognised options. */
bcc40c63 1718 if (!strcmp (argv[i], "-Wall"))
9fa36617 1719 {
2ff3ad1d 1720 CPP_OPTION (pfile, warn_trigraphs) = 1;
1721 CPP_OPTION (pfile, warn_comments) = 1;
9fa36617 1722 }
bcc40c63 1723 else if (!strcmp (argv[i], "-Wtraditional"))
ef33b55c 1724 CPP_OPTION (pfile, warn_traditional) = 1;
bcc40c63 1725 else if (!strcmp (argv[i], "-Wtrigraphs"))
2ff3ad1d 1726 CPP_OPTION (pfile, warn_trigraphs) = 1;
bcc40c63 1727 else if (!strcmp (argv[i], "-Wcomment"))
2ff3ad1d 1728 CPP_OPTION (pfile, warn_comments) = 1;
bcc40c63 1729 else if (!strcmp (argv[i], "-Wcomments"))
2ff3ad1d 1730 CPP_OPTION (pfile, warn_comments) = 1;
bcc40c63 1731 else if (!strcmp (argv[i], "-Wundef"))
2ff3ad1d 1732 CPP_OPTION (pfile, warn_undef) = 1;
bcc40c63 1733 else if (!strcmp (argv[i], "-Wimport"))
2ff3ad1d 1734 CPP_OPTION (pfile, warn_import) = 1;
bcc40c63 1735 else if (!strcmp (argv[i], "-Werror"))
2ff3ad1d 1736 CPP_OPTION (pfile, warnings_are_errors) = 1;
02c09dab 1737 else if (!strcmp (argv[i], "-Wsystem-headers"))
1738 CPP_OPTION (pfile, warn_system_headers) = 1;
bcc40c63 1739 else if (!strcmp (argv[i], "-Wno-traditional"))
ef33b55c 1740 CPP_OPTION (pfile, warn_traditional) = 0;
bcc40c63 1741 else if (!strcmp (argv[i], "-Wno-trigraphs"))
2ff3ad1d 1742 CPP_OPTION (pfile, warn_trigraphs) = 0;
bcc40c63 1743 else if (!strcmp (argv[i], "-Wno-comment"))
2ff3ad1d 1744 CPP_OPTION (pfile, warn_comments) = 0;
bcc40c63 1745 else if (!strcmp (argv[i], "-Wno-comments"))
2ff3ad1d 1746 CPP_OPTION (pfile, warn_comments) = 0;
bcc40c63 1747 else if (!strcmp (argv[i], "-Wno-undef"))
2ff3ad1d 1748 CPP_OPTION (pfile, warn_undef) = 0;
bcc40c63 1749 else if (!strcmp (argv[i], "-Wno-import"))
2ff3ad1d 1750 CPP_OPTION (pfile, warn_import) = 0;
bcc40c63 1751 else if (!strcmp (argv[i], "-Wno-error"))
2ff3ad1d 1752 CPP_OPTION (pfile, warnings_are_errors) = 0;
02c09dab 1753 else if (!strcmp (argv[i], "-Wno-system-headers"))
1754 CPP_OPTION (pfile, warn_system_headers) = 0;
a182c763 1755 else if (! ignore)
1756 return i;
bcc40c63 1757 break;
1758 }
1759 }
6d71dc85 1760 return i + 1;
bcc40c63 1761}
9fa36617 1762
6d71dc85 1763/* Handle command-line options in (argc, argv).
1764 Can be called multiple times, to handle multiple sets of options.
1765 Returns if an unrecognized option is seen.
1766 Returns number of strings consumed. */
6d71dc85 1767int
1768cpp_handle_options (pfile, argc, argv)
1769 cpp_reader *pfile;
1770 int argc;
1771 char **argv;
1772{
1773 int i;
1774 int strings_processed;
bcc40c63 1775
6d71dc85 1776 for (i = 0; i < argc; i += strings_processed)
1777 {
a182c763 1778 strings_processed = cpp_handle_option (pfile, argc - i, argv + i, 1);
6d71dc85 1779 if (strings_processed == 0)
1780 break;
1781 }
af808d7d 1782
6d71dc85 1783 return i;
1784}
1785
af808d7d 1786/* Extra processing when all options are parsed, after all calls to
1787 cpp_handle_option[s]. Consistency checks etc. */
1788void
1789cpp_post_options (pfile)
1790 cpp_reader *pfile;
1791{
a19b9668 1792 if (pfile->print_version)
1793 {
1794 fprintf (stderr, _("GNU CPP version %s (cpplib)"), version_string);
1795#ifdef TARGET_VERSION
1796 TARGET_VERSION;
1797#endif
1798 fputc ('\n', stderr);
1799 }
1800
7e555f5f 1801 /* Canonicalize in_fname and out_fname. We guarantee they are not
1802 NULL, and that the empty string represents stdin / stdout. */
1803 if (CPP_OPTION (pfile, in_fname) == NULL
1804 || !strcmp (CPP_OPTION (pfile, in_fname), "-"))
1805 CPP_OPTION (pfile, in_fname) = "";
1806
1807 if (CPP_OPTION (pfile, out_fname) == NULL
1808 || !strcmp (CPP_OPTION (pfile, out_fname), "-"))
1809 CPP_OPTION (pfile, out_fname) = "";
1810
af808d7d 1811 /* -Wtraditional is not useful in C++ mode. */
1812 if (CPP_OPTION (pfile, cplusplus))
1813 CPP_OPTION (pfile, warn_traditional) = 0;
1814
2c0e001b 1815 /* Set this if it hasn't been set already. */
af808d7d 1816 if (CPP_OPTION (pfile, user_label_prefix) == NULL)
1817 CPP_OPTION (pfile, user_label_prefix) = USER_LABEL_PREFIX;
1818
946ce1b7 1819 /* Permanently disable macro expansion if we are rescanning
1820 preprocessed text. */
1821 if (CPP_OPTION (pfile, preprocessed))
1822 pfile->state.prevent_expansion = 1;
1823
af808d7d 1824 /* We need to do this after option processing and before
1825 cpp_start_read, as cppmain.c relies on the options->no_output to
1826 set its callbacks correctly before calling cpp_start_read. */
1827 init_dependency_output (pfile);
1828
308f302c 1829 /* After checking the environment variables, check if -M or -MM has
1830 not been specified, but other -M options have. */
1831 if (CPP_OPTION (pfile, print_deps) == 0 &&
1832 (CPP_OPTION (pfile, print_deps_missing_files)
1833 || CPP_OPTION (pfile, deps_file)
1834 || CPP_OPTION (pfile, deps_phony_targets)))
1835 cpp_fatal (pfile, "you must additionally specify either -M or -MM");
af808d7d 1836}
1837
b3a8144e 1838/* Set up dependency-file output. */
1839static void
1840init_dependency_output (pfile)
1841 cpp_reader *pfile;
1842{
1843 char *spec, *s, *output_file;
1844
1845 /* Either of two environment variables can specify output of deps.
1846 Its value is either "OUTPUT_FILE" or "OUTPUT_FILE DEPS_TARGET",
1847 where OUTPUT_FILE is the file to write deps info to
1848 and DEPS_TARGET is the target to mention in the deps. */
1849
1850 if (CPP_OPTION (pfile, print_deps) == 0)
1851 {
1852 spec = getenv ("DEPENDENCIES_OUTPUT");
1853 if (spec)
1854 CPP_OPTION (pfile, print_deps) = 1;
1855 else
1856 {
1857 spec = getenv ("SUNPRO_DEPENDENCIES");
1858 if (spec)
1859 CPP_OPTION (pfile, print_deps) = 2;
1860 else
1861 return;
1862 }
1863
1864 /* Find the space before the DEPS_TARGET, if there is one. */
1865 s = strchr (spec, ' ');
1866 if (s)
1867 {
1868 /* Let the caller perform MAKE quoting. */
1869 deps_add_target (pfile->deps, s + 1, 0);
1870 output_file = (char *) xmalloc (s - spec + 1);
1871 memcpy (output_file, spec, s - spec);
1872 output_file[s - spec] = 0;
1873 }
1874 else
1875 output_file = spec;
1876
af808d7d 1877 /* Command line overrides environment variables. */
1878 if (CPP_OPTION (pfile, deps_file) == 0)
1879 CPP_OPTION (pfile, deps_file) = output_file;
b3a8144e 1880 CPP_OPTION (pfile, print_deps_append) = 1;
1881 }
1882
308f302c 1883 /* If dependencies go to standard output, or -MG is used, we should
32713c6a 1884 suppress output, including -dM, -dI etc. */
308f302c 1885 if (CPP_OPTION (pfile, deps_file) == 0
1886 || CPP_OPTION (pfile, print_deps_missing_files))
32713c6a 1887 {
1888 CPP_OPTION (pfile, no_output) = 1;
1889 CPP_OPTION (pfile, dump_macros) = 0;
1890 CPP_OPTION (pfile, dump_includes) = 0;
1891 }
b3a8144e 1892}
1893
e484a1cc 1894/* Handle --help output. */
6d71dc85 1895static void
1896print_help ()
1897{
9e87fa80 1898 fprintf (stderr, _("Usage: %s [switches] input output\n"), progname);
6219c3ed 1899 /* To keep the lines from getting too long for some compilers, limit
2c0e001b 1900 to about 500 characters (6 lines) per chunk. */
6d71dc85 1901 fputs (_("\
1902Switches:\n\
1903 -include <file> Include the contents of <file> before other files\n\
1904 -imacros <file> Accept definition of macros in <file>\n\
1905 -iprefix <path> Specify <path> as a prefix for next two options\n\
1906 -iwithprefix <dir> Add <dir> to the end of the system include path\n\
1907 -iwithprefixbefore <dir> Add <dir> to the end of the main include path\n\
1908 -isystem <dir> Add <dir> to the start of the system include path\n\
6219c3ed 1909"), stdout);
1910 fputs (_("\
6d71dc85 1911 -idirafter <dir> Add <dir> to the end of the system include path\n\
1912 -I <dir> Add <dir> to the end of the main include path\n\
bcc40c63 1913 -I- Fine-grained include path control; see info docs\n\
6d71dc85 1914 -nostdinc Do not search system include directories\n\
1915 (dirs specified with -isystem will still be used)\n\
1916 -nostdinc++ Do not search system include directories for C++\n\
1917 -o <file> Put output into <file>\n\
6219c3ed 1918"), stdout);
1919 fputs (_("\
f80e83a9 1920 -pedantic Issue all warnings demanded by strict ISO C\n\
bcc40c63 1921 -pedantic-errors Issue -pedantic warnings as errors instead\n\
f80e83a9 1922 -trigraphs Support ISO C trigraphs\n\
6d71dc85 1923 -lang-c Assume that the input sources are in C\n\
1924 -lang-c89 Assume that the input sources are in C89\n\
6219c3ed 1925"), stdout);
1926 fputs (_("\
241e762e 1927 -lang-c++ Assume that the input sources are in C++\n\
6d71dc85 1928 -lang-objc Assume that the input sources are in ObjectiveC\n\
1929 -lang-objc++ Assume that the input sources are in ObjectiveC++\n\
1930 -lang-asm Assume that the input sources are in assembler\n\
6219c3ed 1931"), stdout);
1932 fputs (_("\
6d71dc85 1933 -std=<std name> Specify the conformance standard; one of:\n\
4960a83f 1934 gnu89, gnu99, c89, c99, iso9899:1990,\n\
1935 iso9899:199409, iso9899:1999\n\
6d71dc85 1936 -+ Allow parsing of C++ style features\n\
1937 -w Inhibit warning messages\n\
1938 -Wtrigraphs Warn if trigraphs are encountered\n\
1939 -Wno-trigraphs Do not warn about trigraphs\n\
1940 -Wcomment{s} Warn if one comment starts inside another\n\
6219c3ed 1941"), stdout);
1942 fputs (_("\
6d71dc85 1943 -Wno-comment{s} Do not warn about comments\n\
241e762e 1944 -Wtraditional Warn about features not present in traditional C\n\
1945 -Wno-traditional Do not warn about traditional C\n\
6d71dc85 1946 -Wundef Warn if an undefined macro is used by #if\n\
1947 -Wno-undef Do not warn about testing undefined macros\n\
1948 -Wimport Warn about the use of the #import directive\n\
6219c3ed 1949"), stdout);
1950 fputs (_("\
6d71dc85 1951 -Wno-import Do not warn about the use of #import\n\
1952 -Werror Treat all warnings as errors\n\
1953 -Wno-error Do not treat warnings as errors\n\
02c09dab 1954 -Wsystem-headers Do not suppress warnings from system headers\n\
1955 -Wno-system-headers Suppress warnings from system headers\n\
6d71dc85 1956 -Wall Enable all preprocessor warnings\n\
6219c3ed 1957"), stdout);
1958 fputs (_("\
02c09dab 1959 -M Generate make dependencies\n\
1960 -MM As -M, but ignore system header files\n\
af808d7d 1961 -MF <file> Write dependency output to the given file\n\
6d71dc85 1962 -MG Treat missing header file as generated files\n\
af808d7d 1963"), stdout);
1964 fputs (_("\
1965 -MP Generate phony targets for all headers\n\
1966 -MQ <target> Add a MAKE-quoted target\n\
1967 -MT <target> Add an unquoted target\n\
6219c3ed 1968"), stdout);
1969 fputs (_("\
02c09dab 1970 -D<macro> Define a <macro> with string '1' as its value\n\
1971 -D<macro>=<val> Define a <macro> with <val> as its value\n\
6d71dc85 1972 -A<question> (<answer>) Assert the <answer> to <question>\n\
77ee202d 1973 -A-<question> (<answer>) Disable the <answer> to <question>\n\
6d71dc85 1974 -U<macro> Undefine <macro> \n\
6d71dc85 1975 -v Display the version number\n\
6219c3ed 1976"), stdout);
1977 fputs (_("\
02c09dab 1978 -H Print the name of header files as they are used\n\
1979 -C Do not discard comments\n\
6d71dc85 1980 -dM Display a list of macro definitions active at end\n\
1981 -dD Preserve macro definitions in output\n\
1982 -dN As -dD except that only the names are preserved\n\
1983 -dI Include #include directives in the output\n\
02c09dab 1984"), stdout);
1985 fputs (_("\
f95f1608 1986 -fpreprocessed Treat the input file as already preprocessed\n\
3b304865 1987 -ftabstop=<number> Distance between tab stops for column reporting\n\
6d71dc85 1988 -P Do not generate #line directives\n\
1989 -$ Do not allow '$' in identifiers\n\
1990 -remap Remap file names when including files.\n\
bcc40c63 1991 --version Display version information\n\
6d71dc85 1992 -h or --help Display this information\n\
1993"), stdout);
1994}