OSDN Git Service

* gcc.c (default_compilers, cpp-output): Pass -fpreprocessed.
[pf3gnuchains/gcc-fork.git] / gcc / cppinit.c
1 /* CPP Library.
2    Copyright (C) 1986, 87, 89, 92-98, 1999 Free Software Foundation, Inc.
3    Contributed by Per Bothner, 1994-95.
4    Based on CCCP program by Paul Rubin, June 1986
5    Adapted to ANSI C, Richard Stallman, Jan 1987
6
7 This program is free software; you can redistribute it and/or modify it
8 under the terms of the GNU General Public License as published by the
9 Free Software Foundation; either version 2, or (at your option) any
10 later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 #include "config.h"
22 #include "system.h"
23
24 #define FAKE_CONST
25 #include "cpplib.h"
26 #include "cpphash.h"
27 #include "output.h"
28 #include "prefix.h"
29 #include "intl.h"
30
31 /* XXX Should be in a header file. */
32 extern char *version_string;
33
34 /* Predefined symbols, built-in macros, and the default include path. */
35
36 #ifndef GET_ENV_PATH_LIST
37 #define GET_ENV_PATH_LIST(VAR,NAME)     do { (VAR) = getenv (NAME); } while (0)
38 #endif
39
40 /* By default, colon separates directories in a path.  */
41 #ifndef PATH_SEPARATOR
42 #define PATH_SEPARATOR ':'
43 #endif
44
45 #ifndef STANDARD_INCLUDE_DIR
46 #define STANDARD_INCLUDE_DIR "/usr/include"
47 #endif
48
49 /* We let tm.h override the types used here, to handle trivial differences
50    such as the choice of unsigned int or long unsigned int for size_t.
51    When machines start needing nontrivial differences in the size type,
52    it would be best to do something here to figure out automatically
53    from other information what type to use.  */
54
55 /* The string value for __SIZE_TYPE__.  */
56
57 #ifndef SIZE_TYPE
58 #define SIZE_TYPE "long unsigned int"
59 #endif
60
61 /* The string value for __PTRDIFF_TYPE__.  */
62
63 #ifndef PTRDIFF_TYPE
64 #define PTRDIFF_TYPE "long int"
65 #endif
66
67 /* The string value for __WCHAR_TYPE__.  */
68
69 #ifndef WCHAR_TYPE
70 #define WCHAR_TYPE "int"
71 #endif
72 #define CPP_WCHAR_TYPE(PFILE) \
73         (CPP_OPTIONS (PFILE)->cplusplus ? "__wchar_t" : WCHAR_TYPE)
74
75 /* The string value for __USER_LABEL_PREFIX__ */
76
77 #ifndef USER_LABEL_PREFIX
78 #define USER_LABEL_PREFIX ""
79 #endif
80
81 /* The string value for __REGISTER_PREFIX__ */
82
83 #ifndef REGISTER_PREFIX
84 #define REGISTER_PREFIX ""
85 #endif
86
87 /* Suffix for object files, and known input-file extensions. */
88 static char *known_suffixes[] =
89 {
90   ".c",  ".C",   ".s",   ".S",   ".m",
91   ".cc", ".cxx", ".cpp", ".cp",  ".c++",
92   NULL
93 };
94
95 #ifndef OBJECT_SUFFIX
96 # ifdef VMS
97 #  define OBJECT_SUFFIX ".obj"
98 # else
99 #  define OBJECT_SUFFIX ".o"
100 # endif
101 #endif
102
103
104 /* This is the default list of directories to search for include files.
105    It may be overridden by the various -I and -ixxx options.
106
107    #include "file" looks in the same directory as the current file,
108    then this list. 
109    #include <file> just looks in this list.
110
111    All these directories are treated as `system' include directories
112    (they are not subject to pedantic warnings in some cases).  */
113
114 static struct default_include
115 {
116   char *fname;                  /* The name of the directory.  */
117   char *component;              /* The component containing the directory
118                                    (see update_path in prefix.c) */
119   int cplusplus;                /* Only look here if we're compiling C++.  */
120   int cxx_aware;                /* Includes in this directory don't need to
121                                    be wrapped in extern "C" when compiling
122                                    C++.  This is not used anymore.  */
123 }
124 include_defaults_array[]
125 #ifdef INCLUDE_DEFAULTS
126 = INCLUDE_DEFAULTS;
127 #else
128 = {
129     /* Pick up GNU C++ specific include files.  */
130     { GPLUSPLUS_INCLUDE_DIR, "G++", 1, 1 },
131 #ifdef CROSS_COMPILE
132     /* This is the dir for fixincludes.  Put it just before
133        the files that we fix.  */
134     { GCC_INCLUDE_DIR, "GCC", 0, 0 },
135     /* For cross-compilation, this dir name is generated
136        automatically in Makefile.in.  */
137     { CROSS_INCLUDE_DIR, "GCC", 0, 0 },
138 #ifdef TOOL_INCLUDE_DIR
139     /* This is another place that the target system's headers might be.  */
140     { TOOL_INCLUDE_DIR, "BINUTILS", 0, 1 },
141 #endif
142 #else /* not CROSS_COMPILE */
143 #ifdef LOCAL_INCLUDE_DIR
144     /* This should be /usr/local/include and should come before
145        the fixincludes-fixed header files.  */
146     { LOCAL_INCLUDE_DIR, 0, 0, 1 },
147 #endif
148 #ifdef TOOL_INCLUDE_DIR
149     /* This is here ahead of GCC_INCLUDE_DIR because assert.h goes here.
150        Likewise, behind LOCAL_INCLUDE_DIR, where glibc puts its assert.h.  */
151     { TOOL_INCLUDE_DIR, "BINUTILS", 0, 1 },
152 #endif
153     /* This is the dir for fixincludes.  Put it just before
154        the files that we fix.  */
155     { GCC_INCLUDE_DIR, "GCC", 0, 0 },
156     /* Some systems have an extra dir of include files.  */
157 #ifdef SYSTEM_INCLUDE_DIR
158     { SYSTEM_INCLUDE_DIR, 0, 0, 0 },
159 #endif
160 #ifndef STANDARD_INCLUDE_COMPONENT
161 #define STANDARD_INCLUDE_COMPONENT 0
162 #endif
163     { STANDARD_INCLUDE_DIR, STANDARD_INCLUDE_COMPONENT, 0, 0 },
164 #endif /* not CROSS_COMPILE */
165     { 0, 0, 0, 0 }
166   };
167 #endif /* no INCLUDE_DEFAULTS */
168
169 /* Internal structures and prototypes. */
170
171 /* A `struct pending_option' remembers one -D, -A, -U, -include, or -imacros
172    switch.  There are four lists: one for -D and -U, one for -A, one
173    for -include, one for -imacros.  `undef' is set for -U, clear for
174    -D, ignored for the others.
175    (Future: add an equivalent of -U for -A) */
176 struct pending_option
177 {
178   struct pending_option *next;
179   char *arg;
180   int undef;
181 };
182
183 #ifdef __STDC__
184 #define APPEND(pend, list, elt) \
185   do {  if (!(pend)->list##_head) (pend)->list##_head = (elt); \
186         else (pend)->list##_tail->next = (elt); \
187         (pend)->list##_tail = (elt); \
188   } while (0)
189 #else
190 #define APPEND(pend, list, elt) \
191   do {  if (!(pend)->list/**/_head) (pend)->list/**/_head = (elt); \
192         else (pend)->list/**/_tail->next = (elt); \
193         (pend)->list/**/_tail = (elt); \
194   } while (0)
195 #endif
196
197 static void initialize_char_syntax      PARAMS ((int));
198 static void print_help                  PARAMS ((void));
199 static void path_include                PARAMS ((cpp_reader *,
200                                                  struct cpp_pending *,
201                                                  char *, int));
202 static void initialize_builtins         PARAMS ((cpp_reader *));
203 static void append_include_chain        PARAMS ((cpp_reader *,
204                                                  struct cpp_pending *,
205                                                  char *, int));
206
207 /* Last argument to append_include_chain: chain to use */
208 enum { QUOTE = 0, BRACKET, SYSTEM, AFTER };
209
210 /* If gcc is in use (stage2/stage3) we can make these tables initialized
211    data. */
212 #if defined __GNUC__ && __GNUC__ >= 2
213 /* Table to tell if a character is legal as the second or later character
214    of a C identifier. */
215 U_CHAR is_idchar[256] =
216 {
217   ['a'] = 1, ['b'] = 1, ['c'] = 1,  ['d'] = 1, ['e'] = 1, ['f'] = 1,
218   ['g'] = 1, ['h'] = 1, ['i'] = 1,  ['j'] = 1, ['k'] = 1, ['l'] = 1,
219   ['m'] = 1, ['n'] = 1, ['o'] = 1,  ['p'] = 1, ['q'] = 1, ['r'] = 1,
220   ['s'] = 1, ['t'] = 1, ['u'] = 1,  ['v'] = 1, ['w'] = 1, ['x'] = 1,
221   ['y'] = 1, ['z'] = 1,
222
223   ['A'] = 1, ['B'] = 1, ['C'] = 1,  ['D'] = 1, ['E'] = 1, ['F'] = 1,
224   ['G'] = 1, ['H'] = 1, ['I'] = 1,  ['J'] = 1, ['K'] = 1, ['L'] = 1,
225   ['M'] = 1, ['N'] = 1, ['O'] = 1,  ['P'] = 1, ['Q'] = 1, ['R'] = 1,
226   ['S'] = 1, ['T'] = 1, ['U'] = 1,  ['V'] = 1, ['W'] = 1, ['X'] = 1,
227   ['Y'] = 1, ['Z'] = 1,
228
229   ['1'] = 1, ['2'] = 1, ['3'] = 1,  ['4'] = 1, ['5'] = 1, ['6'] = 1,
230   ['7'] = 1, ['8'] = 1, ['9'] = 1,  ['0'] = 1,
231
232   ['_']  = 1,
233 };
234
235 /* Table to tell if a character is legal as the first character of
236    a C identifier. */
237 U_CHAR is_idstart[256] =
238 {
239   ['a'] = 1, ['b'] = 1, ['c'] = 1,  ['d'] = 1, ['e'] = 1, ['f'] = 1,
240   ['g'] = 1, ['h'] = 1, ['i'] = 1,  ['j'] = 1, ['k'] = 1, ['l'] = 1,
241   ['m'] = 1, ['n'] = 1, ['o'] = 1,  ['p'] = 1, ['q'] = 1, ['r'] = 1,
242   ['s'] = 1, ['t'] = 1, ['u'] = 1,  ['v'] = 1, ['w'] = 1, ['x'] = 1,
243   ['y'] = 1, ['z'] = 1,
244
245   ['A'] = 1, ['B'] = 1, ['C'] = 1,  ['D'] = 1, ['E'] = 1, ['F'] = 1,
246   ['G'] = 1, ['H'] = 1, ['I'] = 1,  ['J'] = 1, ['K'] = 1, ['L'] = 1,
247   ['M'] = 1, ['N'] = 1, ['O'] = 1,  ['P'] = 1, ['Q'] = 1, ['R'] = 1,
248   ['S'] = 1, ['T'] = 1, ['U'] = 1,  ['V'] = 1, ['W'] = 1, ['X'] = 1,
249   ['Y'] = 1, ['Z'] = 1,
250
251   ['_']  = 1,
252 };
253
254 /* Table to tell if a character is horizontal space.
255    \r is magical, so it is not in here.  */
256 U_CHAR is_hor_space[256] =
257 {
258   [' '] = 1, ['\t'] = 1, ['\v'] = 1, ['\f'] = 1,
259 };
260 /* table to tell if a character is horizontal or vertical space.  */
261 U_CHAR is_space[256] =
262 {
263   [' '] = 1, ['\t'] = 1, ['\v'] = 1, ['\f'] = 1, ['\n'] = 1,
264 };
265 /* Table to handle trigraph conversion, which occurs before all other
266    processing, everywhere in the file.  (This is necessary since one
267    of the trigraphs encodes backslash.)  Note it's off by default.
268
269         from    to      from    to      from    to
270         ?? =    #       ?? )    ]       ?? !    |
271         ?? (    [       ?? '    ^       ?? >    }
272         ?? /    \       ?? <    {       ?? -    ~
273
274    There is not a space between the ?? and the third char.  I put spaces
275    there to avoid warnings when compiling this file. */
276 U_CHAR trigraph_table[256] =
277 {
278   ['='] = '#',  [')'] = ']',  ['!'] = '|',
279   ['('] = '[',  ['\''] = '^', ['>'] = '}',
280   ['/'] = '\\', ['<'] = '{',  ['-'] = '~',
281 };
282
283 /* This function will be entirely removed soon. */
284 static inline void
285 initialize_char_syntax (dollar_in_ident)
286      int dollar_in_ident;
287 {
288   is_idchar['$'] = dollar_in_ident;
289   is_idstart['$'] = dollar_in_ident;
290 }
291
292 #else /* Not GCC. */
293
294 U_CHAR is_idchar[256] = { 0 };
295 U_CHAR is_idstart[256] = { 0 };
296 U_CHAR is_hor_space[256] = { 0 };
297 U_CHAR is_space[256] = { 0 };
298 U_CHAR trigraph_table[256] = { 0 };
299
300 /* Initialize syntactic classifications of characters. */
301 static void
302 initialize_char_syntax (dollar_in_ident)
303      int dollar_in_ident;
304 {
305   is_idstart['a'] = 1; is_idstart['b'] = 1; is_idstart['c'] = 1;
306   is_idstart['d'] = 1; is_idstart['e'] = 1; is_idstart['f'] = 1;
307   is_idstart['g'] = 1; is_idstart['h'] = 1; is_idstart['i'] = 1;
308   is_idstart['j'] = 1; is_idstart['k'] = 1; is_idstart['l'] = 1;
309   is_idstart['m'] = 1; is_idstart['n'] = 1; is_idstart['o'] = 1;
310   is_idstart['p'] = 1; is_idstart['q'] = 1; is_idstart['r'] = 1;
311   is_idstart['s'] = 1; is_idstart['t'] = 1; is_idstart['u'] = 1;
312   is_idstart['v'] = 1; is_idstart['w'] = 1; is_idstart['x'] = 1;
313   is_idstart['y'] = 1; is_idstart['z'] = 1;
314
315   is_idstart['A'] = 1; is_idstart['B'] = 1; is_idstart['C'] = 1;
316   is_idstart['D'] = 1; is_idstart['E'] = 1; is_idstart['F'] = 1;
317   is_idstart['G'] = 1; is_idstart['H'] = 1; is_idstart['I'] = 1;
318   is_idstart['J'] = 1; is_idstart['K'] = 1; is_idstart['L'] = 1;
319   is_idstart['M'] = 1; is_idstart['N'] = 1; is_idstart['O'] = 1;
320   is_idstart['P'] = 1; is_idstart['Q'] = 1; is_idstart['R'] = 1;
321   is_idstart['S'] = 1; is_idstart['T'] = 1; is_idstart['U'] = 1;
322   is_idstart['V'] = 1; is_idstart['W'] = 1; is_idstart['X'] = 1;
323   is_idstart['Y'] = 1; is_idstart['Z'] = 1;
324
325   is_idstart['_'] = 1;
326
327   is_idchar['a'] = 1; is_idchar['b'] = 1; is_idchar['c'] = 1;
328   is_idchar['d'] = 1; is_idchar['e'] = 1; is_idchar['f'] = 1;
329   is_idchar['g'] = 1; is_idchar['h'] = 1; is_idchar['i'] = 1;
330   is_idchar['j'] = 1; is_idchar['k'] = 1; is_idchar['l'] = 1;
331   is_idchar['m'] = 1; is_idchar['n'] = 1; is_idchar['o'] = 1;
332   is_idchar['p'] = 1;  is_idchar['q'] = 1; is_idchar['r'] = 1;
333   is_idchar['s'] = 1; is_idchar['t'] = 1;  is_idchar['u'] = 1;
334   is_idchar['v'] = 1; is_idchar['w'] = 1; is_idchar['x'] = 1;
335   is_idchar['y'] = 1; is_idchar['z'] = 1;
336
337   is_idchar['A'] = 1; is_idchar['B'] = 1; is_idchar['C'] = 1;
338   is_idchar['D'] = 1; is_idchar['E'] = 1; is_idchar['F'] = 1;
339   is_idchar['G'] = 1; is_idchar['H'] = 1; is_idchar['I'] = 1;
340   is_idchar['J'] = 1; is_idchar['K'] = 1; is_idchar['L'] = 1;
341   is_idchar['M'] = 1; is_idchar['N'] = 1; is_idchar['O'] = 1;
342   is_idchar['P'] = 1; is_idchar['Q'] = 1; is_idchar['R'] = 1;
343   is_idchar['S'] = 1; is_idchar['T'] = 1;  is_idchar['U'] = 1;
344   is_idchar['V'] = 1; is_idchar['W'] = 1; is_idchar['X'] = 1;
345   is_idchar['Y'] = 1; is_idchar['Z'] = 1;
346
347   is_idchar['1'] = 1; is_idchar['2'] = 1; is_idchar['3'] = 1;
348   is_idchar['4'] = 1; is_idchar['5'] = 1; is_idchar['6'] = 1;
349   is_idchar['7'] = 1; is_idchar['8'] = 1; is_idchar['9'] = 1;
350   is_idchar['0'] = 1;
351
352   is_idchar['_']  = 1;
353
354   is_idchar['$']  = dollar_in_ident;
355   is_idstart['$'] = dollar_in_ident;
356
357   /* white space tables */
358   is_hor_space[' '] = 1;
359   is_hor_space['\t'] = 1;
360   is_hor_space['\v'] = 1;
361   is_hor_space['\f'] = 1;
362
363   is_space[' '] = 1;
364   is_space['\t'] = 1;
365   is_space['\v'] = 1;
366   is_space['\f'] = 1;
367   is_space['\n'] = 1;
368
369   /* trigraph conversion */
370   trigraph_table['='] = '#';  trigraph_table[')'] = ']';
371   trigraph_table['!'] = '|';  trigraph_table['('] = '[';
372   trigraph_table['\''] = '^'; trigraph_table['>'] = '}';
373   trigraph_table['/'] = '\\'; trigraph_table['<'] = '{';
374   trigraph_table['-'] = '~';
375 }
376
377 #endif /* Not GCC. */
378
379 /* Given a colon-separated list of file names PATH,
380    add all the names to the search path for include files.  */
381
382 static void
383 path_include (pfile, pend, list, path)
384      cpp_reader *pfile;
385      struct cpp_pending *pend;
386      char *list;
387      int path;
388 {
389   char *p, *q, *name;
390
391   p = list;
392
393   do
394     {
395       /* Find the end of this name.  */
396       q = p;
397       while (*q != 0 && *q != PATH_SEPARATOR) q++;
398       if (q == p)
399         {
400           /* An empty name in the path stands for the current directory.  */
401           name = (char *) xmalloc (2);
402           name[0] = '.';
403           name[1] = 0;
404         }
405       else
406         {
407           /* Otherwise use the directory that is named.  */
408           name = (char *) xmalloc (q - p + 1);
409           memcpy (name, p, q - p);
410           name[q - p] = 0;
411         }
412
413       append_include_chain (pfile, pend, name, path);
414
415       /* Advance past this name.  */
416       if (*q == 0)
417         break;
418       p = q + 1;
419     }
420   while (1);
421 }
422
423 /* Find the base name of a (partial) pathname FNAME.
424    Returns a pointer into the string passed in.
425    Accepts Unix (/-separated) paths on all systems,
426    DOS and VMS paths on those systems.  */
427 static char *
428 base_name (fname)
429      const char *fname;
430 {
431   char *s = (char *)fname;
432   char *p;
433 #if defined (HAVE_DOS_BASED_FILE_SYSTEM)
434   if (ISALPHA (s[0]) && s[1] == ':') s += 2;
435   if ((p = rindex (s, '\\'))) s = p + 1;
436 #elif defined VMS
437   if ((p = rindex (s, ':'))) s = p + 1; /* Skip device.  */
438   if ((p = rindex (s, ']'))) s = p + 1; /* Skip directory.  */
439   if ((p = rindex (s, '>'))) s = p + 1; /* Skip alternate (int'n'l) dir.  */
440 #endif
441   if ((p = rindex (s, '/'))) s = p + 1;
442   return s;
443 }
444      
445
446 /* Append DIR to include path PATH.  DIR must be permanently allocated
447    and writable. */
448 static void
449 append_include_chain (pfile, pend, dir, path)
450      cpp_reader *pfile;
451      struct cpp_pending *pend;
452      char *dir;
453      int path;
454 {
455   struct file_name_list *new;
456   struct stat st;
457   unsigned int len;
458
459   simplify_pathname (dir);
460   if (stat (dir, &st))
461     {
462       /* Dirs that don't exist are silently ignored. */
463       if (errno != ENOENT)
464         cpp_perror_with_name (pfile, dir);
465       else if (CPP_OPTIONS (pfile)->verbose)
466         cpp_notice ("ignoring nonexistent directory `%s'\n", dir);
467       return;
468     }
469
470   if (!S_ISDIR (st.st_mode))
471     {
472       cpp_message (pfile, 1, "%s: %s: Not a directory", progname, dir);
473       return;
474     }
475
476   len = strlen (dir);
477   if (len > pfile->max_include_len)
478     pfile->max_include_len = len;
479   
480   new = (struct file_name_list *)xmalloc (sizeof (struct file_name_list));
481   new->name = dir;
482   new->nlen = len;
483   new->ino  = st.st_ino;
484   new->dev  = st.st_dev;
485   new->sysp = (path == SYSTEM);
486   new->name_map = NULL;
487
488   switch (path)
489     {
490     case QUOTE:         APPEND (pend, quote, new); break;
491     case BRACKET:       APPEND (pend, brack, new); break;
492     case SYSTEM:        APPEND (pend, systm, new); break;
493     case AFTER:         APPEND (pend, after, new); break;
494     }
495 }
496
497
498 /* Write out a #define command for the special named MACRO_NAME
499    to PFILE's token_buffer.  */
500
501 static void
502 dump_special_to_buffer (pfile, macro_name)
503      cpp_reader *pfile;
504      char *macro_name;
505 {
506   static char define_directive[] = "#define ";
507   int macro_name_length = strlen (macro_name);
508   output_line_command (pfile, same_file);
509   CPP_RESERVE (pfile, sizeof(define_directive) + macro_name_length);
510   CPP_PUTS_Q (pfile, define_directive, sizeof(define_directive)-1);
511   CPP_PUTS_Q (pfile, macro_name, macro_name_length);
512   CPP_PUTC_Q (pfile, ' ');
513   cpp_expand_to_buffer (pfile, macro_name, macro_name_length);
514   CPP_PUTC (pfile, '\n');
515 }
516
517 /* Initialize a cpp_options structure. */
518 void
519 cpp_options_init (opts)
520      cpp_options *opts;
521 {
522   bzero ((char *) opts, sizeof (struct cpp_options));
523
524   opts->dollars_in_ident = 1;
525   opts->cplusplus_comments = 1;
526   opts->warn_import = 1;
527
528   opts->pending = (struct cpp_pending *) xmalloc (sizeof (struct cpp_pending));
529   bzero ((char *) opts->pending, sizeof (struct cpp_pending));
530 }
531
532 /* Initialize a cpp_reader structure. */
533 void
534 cpp_reader_init (pfile)
535      cpp_reader *pfile;
536 {
537   bzero ((char *) pfile, sizeof (cpp_reader));
538 #if 0
539   pfile->get_token = cpp_get_token;
540 #endif
541
542   pfile->token_buffer_size = 200;
543   pfile->token_buffer = (U_CHAR *) xmalloc (pfile->token_buffer_size);
544   CPP_SET_WRITTEN (pfile, 0);
545
546   pfile->hashtab = (HASHNODE **) xcalloc (HASHSIZE, sizeof (HASHNODE *));
547 }
548
549 /* Free resources used by PFILE.
550    This is the cpp_reader 'finalizer' or 'destructor' (in C++ terminology).  */
551 void
552 cpp_cleanup (pfile)
553      cpp_reader *pfile;
554 {
555   int i;
556   while (CPP_BUFFER (pfile) != CPP_NULL_BUFFER (pfile))
557     cpp_pop_buffer (pfile);
558
559   if (pfile->token_buffer)
560     {
561       free (pfile->token_buffer);
562       pfile->token_buffer = NULL;
563     }
564
565   if (pfile->deps_buffer)
566     {
567       free (pfile->deps_buffer);
568       pfile->deps_buffer = NULL;
569       pfile->deps_allocated_size = 0;
570     }
571
572   if (pfile->input_buffer)
573     {
574       free (pfile->input_buffer);
575       free (pfile->input_speccase);
576       pfile->input_buffer = pfile->input_speccase = NULL;
577       pfile->input_buffer_len = 0;
578     }
579
580   while (pfile->if_stack)
581     {
582       IF_STACK_FRAME *temp = pfile->if_stack;
583       pfile->if_stack = temp->next;
584       free (temp);
585     }
586
587   for (i = ALL_INCLUDE_HASHSIZE; --i >= 0; )
588     {
589       struct include_hash *imp = pfile->all_include_files[i];
590       while (imp)
591         {
592           struct include_hash *next = imp->next;
593 #if 0
594           /* This gets freed elsewhere - I think. */
595           free (imp->name);
596 #endif
597           free (imp);
598           imp = next;
599         }
600       pfile->all_include_files[i] = 0;
601     }
602
603   for (i = HASHSIZE; --i >= 0;)
604     {
605       while (pfile->hashtab[i])
606         delete_macro (pfile->hashtab[i]);
607     }
608   free (pfile->hashtab);
609 }
610
611
612 /* Initialize the built-in macros.  */
613 static void
614 initialize_builtins (pfile)
615      cpp_reader *pfile;
616 {
617 #define NAME(str) (U_CHAR *)str, sizeof str - 1
618   cpp_install (pfile, NAME("__TIME__"),           T_TIME,       0, -1);
619   cpp_install (pfile, NAME("__DATE__"),           T_DATE,       0, -1);
620   cpp_install (pfile, NAME("__FILE__"),           T_FILE,       0, -1);
621   cpp_install (pfile, NAME("__BASE_FILE__"),      T_BASE_FILE,  0, -1);
622   cpp_install (pfile, NAME("__LINE__"),           T_SPECLINE,   0, -1);
623   cpp_install (pfile, NAME("__INCLUDE_LEVEL__"),  T_INCLUDE_LEVEL, 0, -1);
624   cpp_install (pfile, NAME("__VERSION__"),        T_VERSION,    0, -1);
625 #ifndef NO_BUILTIN_SIZE_TYPE
626   cpp_install (pfile, NAME("__SIZE_TYPE__"),      T_CONST, SIZE_TYPE, -1);
627 #endif
628 #ifndef NO_BUILTIN_PTRDIFF_TYPE
629   cpp_install (pfile, NAME("__PTRDIFF_TYPE__ "),  T_CONST, PTRDIFF_TYPE, -1);
630 #endif
631   cpp_install (pfile, NAME("__WCHAR_TYPE__"),     T_CONST, WCHAR_TYPE, -1);
632   cpp_install (pfile, NAME("__USER_LABEL_PREFIX__"), T_CONST, user_label_prefix, -1);
633   cpp_install (pfile, NAME("__REGISTER_PREFIX__"),  T_CONST, REGISTER_PREFIX, -1);
634   cpp_install (pfile, NAME("__HAVE_BUILTIN_SETJMP__"), T_CONST, "1", -1);
635   if (!CPP_TRADITIONAL (pfile))
636     {
637       cpp_install (pfile, NAME("__STDC__"),       T_STDC,  0, -1);
638 #if 0
639       if (CPP_OPTIONS (pfile)->c9x)
640         cpp_install (pfile, NAME("__STDC_VERSION__"),T_CONST, "199909L", -1);
641       else
642 #endif
643         cpp_install (pfile, NAME("__STDC_VERSION__"),T_CONST, "199409L", -1);
644     }
645 #undef NAME
646
647   if (CPP_OPTIONS (pfile)->debug_output)
648     {
649       dump_special_to_buffer (pfile, "__BASE_FILE__");
650       dump_special_to_buffer (pfile, "__VERSION__");
651 #ifndef NO_BUILTIN_SIZE_TYPE
652       dump_special_to_buffer (pfile, "__SIZE_TYPE__");
653 #endif
654 #ifndef NO_BUILTIN_PTRDIFF_TYPE
655       dump_special_to_buffer (pfile, "__PTRDIFF_TYPE__");
656 #endif
657       dump_special_to_buffer (pfile, "__WCHAR_TYPE__");
658       dump_special_to_buffer (pfile, "__DATE__");
659       dump_special_to_buffer (pfile, "__TIME__");
660       if (!CPP_TRADITIONAL (pfile))
661         dump_special_to_buffer (pfile, "__STDC__");
662     }
663 }
664
665 /* Another subroutine of cpp_start_read.  This one sets up to do
666    dependency-file output. */
667 static void
668 initialize_dependency_output (pfile)
669      cpp_reader *pfile;
670 {
671   cpp_options *opts = CPP_OPTIONS (pfile);
672   char *spec, *s, *output_file;
673   
674   /* Either of two environment variables can specify output of deps.
675      Its value is either "OUTPUT_FILE" or "OUTPUT_FILE DEPS_TARGET",
676      where OUTPUT_FILE is the file to write deps info to
677      and DEPS_TARGET is the target to mention in the deps.  */
678
679   if (opts->print_deps == 0)
680     {
681       spec = getenv ("DEPENDENCIES_OUTPUT");
682       if (spec)
683         opts->print_deps = 1;
684       else
685         {
686           spec = getenv ("SUNPRO_DEPENDENCIES");
687           if (spec)
688             opts->print_deps = 2;
689           else
690             return;
691         }
692
693       /* Find the space before the DEPS_TARGET, if there is one.  */
694       s = strchr (spec, ' ');
695       if (s)
696         {
697           opts->deps_target = s + 1;
698           output_file = (char *) xmalloc (s - spec + 1);
699           memcpy (output_file, spec, s - spec);
700           output_file[s - spec] = 0;
701         }
702       else
703         {
704           opts->deps_target = 0;
705           output_file = spec;
706         }
707
708       opts->deps_file = output_file;
709       opts->print_deps_append = 1;
710     }
711
712   /* Print the expected object file name as the target of this Make-rule.  */
713   pfile->deps_allocated_size = 200;
714   pfile->deps_buffer = (char *) xmalloc (pfile->deps_allocated_size);
715   pfile->deps_buffer[0] = 0;
716   pfile->deps_size = 0;
717   pfile->deps_column = 0;
718
719   if (opts->deps_target)
720     deps_output (pfile, opts->deps_target, ':');
721   else if (*opts->in_fname == 0)
722     deps_output (pfile, "-", ':');
723   else
724     {
725       char *p, *q, *r;
726       int len, x;
727
728       /* Discard all directory prefixes from filename.  */
729       q = base_name (opts->in_fname);
730
731       /* Copy remainder to mungable area.  */
732       len = strlen (q);
733       p = (char *) alloca (len + 8);
734       strcpy (p, q);
735
736       /* Output P, but remove known suffixes.  */
737       q = p + len;
738       /* Point to the filename suffix.  */
739       r = rindex (p, '.');
740       /* Compare against the known suffixes.  */
741       for (x = 0; known_suffixes[x]; x++)
742         {
743           if (strncmp (known_suffixes[x], r, q - r) == 0)
744             {
745               /* Make q point to the bit we're going to overwrite
746                  with an object suffix.  */
747               q = r;
748               break;
749             }
750         }
751
752       /* Supply our own suffix.  */
753       strcpy (q, OBJECT_SUFFIX);
754
755       deps_output (pfile, p, ':');
756       deps_output (pfile, opts->in_fname, ' ');
757     }
758 }
759
760 /* This is called after options have been processed.
761  * Check options for consistency, and setup for processing input
762  * from the file named FNAME.  (Use standard input if FNAME==NULL.)
763  * Return 1 on success, 0 on failure.
764  */
765
766 int
767 cpp_start_read (pfile, fname)
768      cpp_reader *pfile;
769      char *fname;
770 {
771   struct cpp_options *opts = CPP_OPTIONS (pfile);
772   struct pending_option *p, *q;
773   int f;
774   cpp_buffer *fp;
775   struct include_hash *ih_fake;
776
777   /* -MG doesn't select the form of output and must be specified with one of
778      -M or -MM.  -MG doesn't make sense with -MD or -MMD since they don't
779      inhibit compilation.  */
780   if (opts->print_deps_missing_files
781       && (opts->print_deps == 0 || !opts->no_output))
782     {
783       cpp_fatal (pfile, "-MG must be specified with one of -M or -MM");
784       return 0;
785     }
786
787   /* Chill should not be used with -trigraphs. */
788   if (opts->chill && opts->trigraphs)
789     {
790       cpp_warning (pfile, "-lang-chill and -trigraphs are mutually exclusive");
791       opts->trigraphs = 0;
792     }
793
794   /* Set this if it hasn't been set already. */
795   if (user_label_prefix == NULL)
796     user_label_prefix = USER_LABEL_PREFIX;
797   
798   /* Now that we know dollars_in_ident, we can initialize the syntax
799      tables. */
800   initialize_char_syntax (opts->dollars_in_ident);
801
802   /* Do partial setup of input buffer for the sake of generating
803      early #line directives (when -g is in effect).  */
804   fp = cpp_push_buffer (pfile, NULL, 0);
805   if (!fp)
806     return 0;
807   if (opts->in_fname == NULL || *opts->in_fname == 0)
808     {
809       opts->in_fname = fname;
810       if (opts->in_fname == NULL)
811         opts->in_fname = "";
812     }
813   fp->nominal_fname = fp->fname = opts->in_fname;
814   fp->lineno = 0;
815
816   /* Install __LINE__, etc.  Must follow initialize_char_syntax
817      and option processing.  */
818   initialize_builtins (pfile);
819
820   /* Do -U's, -D's and -A's in the order they were seen.  */
821   p = opts->pending->define_head;
822   while (p)
823     {
824       if (opts->debug_output)
825         output_line_command (pfile, same_file);
826       if (p->undef)
827         cpp_undef (pfile, p->arg);
828       else
829         cpp_define (pfile, p->arg);
830
831       q = p->next;
832       free (p);
833       p = q;
834     }
835
836   p = opts->pending->assert_head;
837   while (p)
838     {
839       if (opts->debug_output)
840         output_line_command (pfile, same_file);
841       if (p->undef)
842         cpp_unassert (pfile, p->arg);
843       else
844         cpp_assert (pfile, p->arg);
845
846       q = p->next;
847       free (p);
848       p = q;
849     }
850   
851   opts->done_initializing = 1;
852
853   /* Several environment variables may add to the include search path.
854      CPATH specifies an additional list of directories to be searched
855      as if specified with -I, while C_INCLUDE_PATH, CPLUS_INCLUDE_PATH,
856      etc. specify an additional list of directories to be searched as
857      if specified with -isystem, for the language indicated.
858
859      These variables are ignored if -nostdinc is on.  */
860   if (! opts->no_standard_includes)
861     {
862       char *path;
863       GET_ENV_PATH_LIST (path, "CPATH");
864       if (path != 0 && *path != 0)
865         path_include (pfile, opts->pending, path, BRACKET);
866
867       switch ((opts->objc << 1) + opts->cplusplus)
868         {
869         case 0:
870           GET_ENV_PATH_LIST (path, "C_INCLUDE_PATH");
871           break;
872         case 1:
873           GET_ENV_PATH_LIST (path, "CPLUS_INCLUDE_PATH");
874           break;
875         case 2:
876           GET_ENV_PATH_LIST (path, "OBJC_INCLUDE_PATH");
877           break;
878         case 3:
879           GET_ENV_PATH_LIST (path, "OBJCPLUS_INCLUDE_PATH");
880           break;
881         }
882       if (path != 0 && *path != 0)
883         path_include (pfile, opts->pending, path, SYSTEM);
884     }
885
886   /* Unless -nostdinc, add the compiled-in include path to the list,
887      translating prefixes. */
888   if (!opts->no_standard_includes)
889     {
890       struct default_include *p = include_defaults_array;
891       char *specd_prefix = opts->include_prefix;
892
893       /* Search "translated" versions of GNU directories.
894          These have /usr/local/lib/gcc... replaced by specd_prefix.  */
895       if (specd_prefix != 0)
896         {
897           char *default_prefix = alloca (sizeof GCC_INCLUDE_DIR - 7);
898           /* Remove the `include' from /usr/local/lib/gcc.../include.
899              GCC_INCLUDE_DIR will always end in /include. */
900           int default_len = sizeof GCC_INCLUDE_DIR - 8;
901           int specd_len = strlen (specd_prefix);
902
903           default_len = sizeof GCC_INCLUDE_DIR - 8;
904           memcpy (default_prefix, GCC_INCLUDE_DIR, default_len);
905           default_prefix[default_len] = '\0';
906
907           for (p = include_defaults_array; p->fname; p++)
908             {
909               /* Some standard dirs are only for C++.  */
910               if (!p->cplusplus
911                   || (opts->cplusplus
912                       && !opts->no_standard_cplusplus_includes))
913                 {
914                   /* Does this dir start with the prefix?  */
915                   if (!strncmp (p->fname, default_prefix, default_len))
916                     {
917                       /* Yes; change prefix and add to search list.  */
918                       int flen = strlen (p->fname);
919                       int this_len = specd_len + flen - default_len;
920                       char *str = (char *) xmalloc (this_len + 1);
921                       memcpy (str, specd_prefix, specd_len);
922                       memcpy (str + specd_len,
923                               p->fname + default_len,
924                               flen - default_len + 1);
925
926                       append_include_chain (pfile, opts->pending,
927                                             str, SYSTEM);
928                     }
929                 }
930             }
931         }
932
933       /* Search ordinary names for GNU include directories.  */
934       for (p = include_defaults_array; p->fname; p++)
935         {
936           /* Some standard dirs are only for C++.  */
937           if (!p->cplusplus
938               || (opts->cplusplus
939                   && !opts->no_standard_cplusplus_includes))
940             {
941               char *str = (char *) update_path (p->fname, p->component);
942               str = xstrdup (str);  /* XXX Potential memory leak! */
943               append_include_chain (pfile, opts->pending, str, SYSTEM);
944             }
945         }
946     }
947
948   merge_include_chains (opts);
949
950   /* With -v, print the list of dirs to search.  */
951   if (opts->verbose)
952     {
953       struct file_name_list *p;
954       cpp_message (pfile, -1, "#include \"...\" search starts here:\n");
955       for (p = opts->quote_include; p; p = p->next)
956         {
957           if (p == opts->bracket_include)
958             cpp_message (pfile, -1, "#include <...> search starts here:\n");
959           fprintf (stderr, " %s\n", p->name);
960         }
961       cpp_message (pfile, -1, "End of search list.\n");
962     }
963
964   /* Don't bother trying to do macro expansion if we've already done
965      preprocessing.  */
966   if (opts->preprocessed)
967     pfile->no_macro_expand++;
968
969   /* Open the main input file.
970      We do this in nonblocking mode so we don't get stuck here if
971      someone clever has asked cpp to process /dev/rmt0;
972      finclude() will check that we have a real file to work with.  */
973   if (fname == NULL || *fname == 0)
974     {
975       fname = "";
976       f = 0;
977     }
978   else if ((f = open (fname, O_RDONLY|O_NONBLOCK|O_NOCTTY, 0666)) < 0)
979     cpp_pfatal_with_name (pfile, fname);
980
981   initialize_dependency_output (pfile);
982
983   /* Must call finclude() on the main input before processing
984      -include switches; otherwise the -included text winds up
985      after the main input. */
986   ih_fake = (struct include_hash *) xmalloc (sizeof (struct include_hash));
987   ih_fake->next = 0;
988   ih_fake->next_this_file = 0;
989   ih_fake->foundhere = ABSOLUTE_PATH;  /* well sort of ... */
990   ih_fake->name = fname;
991   ih_fake->control_macro = 0;
992   ih_fake->buf = (char *)-1;
993   ih_fake->limit = 0;
994   if (!finclude (pfile, f, ih_fake))
995     return 0;
996   if (opts->preprocessed)
997     /* If we've already processed this code, we want to trust the #line
998        directives in the input.  But we still need to update our line
999        counter accordingly.  */
1000     pfile->lineno = CPP_BUFFER (pfile)->lineno;
1001   else
1002     output_line_command (pfile, same_file);
1003   pfile->only_seen_white = 2;
1004
1005   /* The -imacros files can be scanned now, but the -include files
1006      have to be pushed onto the include stack and processed later,
1007      in the main loop calling cpp_get_token.  */
1008   
1009   pfile->no_record_file++;
1010   opts->no_output++;
1011   p = opts->pending->imacros_head;
1012   while (p)
1013     {
1014       int fd = open (p->arg, O_RDONLY|O_NONBLOCK|O_NOCTTY, 0666);
1015       if (fd < 0)
1016         {
1017           cpp_perror_with_name (pfile, p->arg);
1018           return 0;
1019         }
1020       if (!cpp_push_buffer (pfile, NULL, 0))
1021         return 0;
1022
1023       ih_fake = (struct include_hash *)
1024         xmalloc (sizeof (struct include_hash));
1025       ih_fake->next = 0;
1026       ih_fake->next_this_file = 0;
1027       ih_fake->foundhere = ABSOLUTE_PATH;  /* well sort of ... */
1028       ih_fake->name = p->arg;
1029       ih_fake->control_macro = 0;
1030       ih_fake->buf = (char *)-1;
1031       ih_fake->limit = 0;
1032       if (!finclude (pfile, fd, ih_fake))
1033         cpp_scan_buffer (pfile);
1034       free (ih_fake);
1035
1036       q = p->next;
1037       free (p);
1038       p = q;
1039     }
1040
1041   opts->no_output--;
1042
1043   p = opts->pending->include_head;
1044   while (p)
1045     {
1046       int fd = open (p->arg, O_RDONLY|O_NONBLOCK|O_NOCTTY, 0666);
1047       if (fd < 0)
1048         {
1049           cpp_perror_with_name (pfile, p->arg);
1050           return 0;
1051         }
1052       if (!cpp_push_buffer (pfile, NULL, 0))
1053         return 0;
1054
1055       ih_fake = (struct include_hash *)
1056         xmalloc (sizeof (struct include_hash));
1057       ih_fake->next = 0;
1058       ih_fake->next_this_file = 0;
1059       ih_fake->foundhere = ABSOLUTE_PATH;  /* well sort of ... */
1060       ih_fake->name = p->arg;
1061       ih_fake->control_macro = 0;
1062       ih_fake->buf = (char *)-1;
1063       ih_fake->limit = 0;
1064       if (finclude (pfile, fd, ih_fake))
1065         output_line_command (pfile, enter_file);
1066
1067       q = p->next;
1068       free (p);
1069       p = q;
1070     }
1071   pfile->no_record_file--;
1072
1073   free (opts->pending);
1074   opts->pending = NULL;
1075
1076   return 1;
1077 }
1078
1079 /* This is called at the end of preprocessing.  It pops the
1080    last buffer and writes dependency output.  It should also
1081    clear macro definitions, such that you could call cpp_start_read
1082    with a new filename to restart processing. */
1083 void
1084 cpp_finish (pfile)
1085      cpp_reader *pfile;
1086 {
1087   struct cpp_options *opts = CPP_OPTIONS (pfile);
1088
1089   if (CPP_PREV_BUFFER (CPP_BUFFER (pfile)) != CPP_NULL_BUFFER (pfile))
1090     cpp_fatal (pfile,
1091                "cpplib internal error: buffers still stacked in cpp_finish");
1092   cpp_pop_buffer (pfile);
1093   
1094   if (opts->print_deps)
1095     {
1096       /* Stream on which to print the dependency information.  */
1097       FILE *deps_stream;
1098
1099       /* Don't actually write the deps file if compilation has failed.  */
1100       if (pfile->errors == 0)
1101         {
1102           char *deps_mode = opts->print_deps_append ? "a" : "w";
1103           if (opts->deps_file == 0)
1104             deps_stream = stdout;
1105           else if ((deps_stream = fopen (opts->deps_file, deps_mode)) == 0)
1106             cpp_pfatal_with_name (pfile, opts->deps_file);
1107           fputs (pfile->deps_buffer, deps_stream);
1108           putc ('\n', deps_stream);
1109           if (opts->deps_file)
1110             {
1111               if (ferror (deps_stream) || fclose (deps_stream) != 0)
1112                 cpp_fatal (pfile, "I/O error on output");
1113             }
1114         }
1115     }
1116
1117   if (opts->dump_macros == dump_only)
1118     {
1119       int i;
1120       HASHNODE *h;
1121       MACRODEF m;
1122       for (i = HASHSIZE; --i >= 0;)
1123         {
1124           for (h = pfile->hashtab[i]; h; h = h->next)
1125             if (h->type == T_MACRO)
1126               {
1127                 m.defn = h->value.defn;
1128                 m.symnam = h->name;
1129                 m.symlen = h->length;
1130                 dump_definition (pfile, m);
1131                 CPP_PUTC (pfile, '\n');
1132               }
1133         }
1134     }
1135 }
1136
1137 /* Handle one command-line option in (argc, argv).
1138    Can be called multiple times, to handle multiple sets of options.
1139    Returns number of strings consumed.  */
1140 int
1141 cpp_handle_option (pfile, argc, argv)
1142      cpp_reader *pfile;
1143      int argc;
1144      char **argv;
1145 {
1146   struct cpp_options *opts = CPP_OPTIONS (pfile);
1147   int i = 0;
1148
1149   if (argv[i][0] != '-')
1150     {
1151       if (opts->out_fname != NULL)
1152         {
1153           print_help ();
1154           cpp_fatal (pfile, "Too many arguments");
1155         }
1156       else if (opts->in_fname != NULL)
1157         opts->out_fname = argv[i];
1158       else
1159         opts->in_fname = argv[i];
1160     }
1161   else
1162     switch (argv[i][1])
1163       {
1164       case 'f':
1165         if (!strcmp (argv[i], "-fleading-underscore"))
1166           user_label_prefix = "_";
1167         else if (!strcmp (argv[i], "-fno-leading-underscore"))
1168           user_label_prefix = "";
1169         else if (!strcmp (argv[i], "-fpreprocessed"))
1170           opts->preprocessed = 1;
1171         else if (!strcmp (argv[i], "-fno-preprocessed"))
1172           opts->preprocessed = 0;
1173         break;
1174
1175       case 'I':                 /* Add directory to path for includes.  */
1176         if (!strcmp (argv[i] + 2, "-"))
1177           {
1178             /* -I- means:
1179                Use the preceding -I directories for #include "..."
1180                but not #include <...>.
1181                Don't search the directory of the present file
1182                for #include "...".  (Note that -I. -I- is not the same as
1183                the default setup; -I. uses the compiler's working dir.)  */
1184             if (! opts->ignore_srcdir)
1185               {
1186                 opts->ignore_srcdir = 1;
1187                 opts->pending->quote_head = opts->pending->brack_head;
1188                 opts->pending->quote_tail = opts->pending->brack_tail;
1189                 opts->pending->brack_head = 0;
1190                 opts->pending->brack_tail = 0;
1191               }
1192             else
1193               {
1194                 cpp_fatal (pfile, "-I- specified twice");
1195                 return argc;
1196               }
1197           }
1198         else
1199           {
1200             char *fname;
1201             if (argv[i][2] != 0)
1202               fname = argv[i] + 2;
1203             else if (i + 1 == argc)
1204               goto missing_dirname;
1205             else
1206               fname = argv[++i];
1207             append_include_chain (pfile, opts->pending,
1208                                   xstrdup (fname), BRACKET);
1209           }
1210         break;
1211
1212       case 'i':
1213         /* Add directory to beginning of system include path, as a system
1214            include directory. */
1215         if (!strcmp (argv[i], "-isystem"))
1216           {
1217             if (i + 1 == argc)
1218               goto missing_filename;
1219             append_include_chain (pfile, opts->pending,
1220                                   xstrdup (argv[++i]), SYSTEM);
1221           }
1222         else if (!strcmp (argv[i], "-include"))
1223           {
1224             if (i + 1 == argc)
1225               goto missing_filename;
1226             else
1227               {
1228                 struct pending_option *o = (struct pending_option *)
1229                   xmalloc (sizeof (struct pending_option));
1230                 o->arg = argv[++i];
1231
1232                 /* This list has to be built in reverse order so that
1233                    when cpp_start_read pushes all the -include files onto
1234                    the buffer stack, they will be scanned in forward order.  */
1235                 o->next = opts->pending->include_head;
1236                 opts->pending->include_head = o;
1237               }
1238           }
1239         else if (!strcmp (argv[i], "-imacros"))
1240           {
1241             if (i + 1 == argc)
1242               goto missing_filename;
1243             else
1244               {
1245                 struct pending_option *o = (struct pending_option *)
1246                   xmalloc (sizeof (struct pending_option));
1247                 o->arg = argv[++i];
1248                 o->next = NULL;
1249
1250                 APPEND (opts->pending, imacros, o);
1251               }
1252           }
1253         /* Add directory to end of path for includes,
1254            with the default prefix at the front of its name.  */
1255         else if (!strcmp (argv[i], "-iwithprefix"))
1256           {
1257             char *fname;
1258             int len;
1259             if (i + 1 == argc)
1260               goto missing_dirname;
1261             ++i;
1262             len = strlen (argv[i]);
1263
1264             if (opts->include_prefix != 0)
1265               {
1266                 fname = xmalloc (opts->include_prefix_len + len + 1);
1267                 memcpy (fname, opts->include_prefix, opts->include_prefix_len);
1268                 memcpy (fname + opts->include_prefix_len, argv[i], len + 1);
1269               }
1270             else
1271               {
1272                 fname = xmalloc (sizeof GCC_INCLUDE_DIR - 8 + len);
1273                 memcpy (fname, GCC_INCLUDE_DIR, sizeof GCC_INCLUDE_DIR - 9);
1274                 memcpy (fname + sizeof GCC_INCLUDE_DIR - 9, argv[i], len + 1);
1275               }
1276           
1277             append_include_chain (pfile, opts->pending, fname, SYSTEM);
1278           }
1279         /* Add directory to main path for includes,
1280            with the default prefix at the front of its name.  */
1281         else if (!strcmp (argv[i], "-iwithprefixbefore"))
1282           {
1283             char *fname;
1284             int len;
1285             if (i + 1 == argc)
1286               goto missing_dirname;
1287             ++i;
1288             len = strlen (argv[i]);
1289
1290             if (opts->include_prefix != 0)
1291               {
1292                 fname = xmalloc (opts->include_prefix_len + len + 1);
1293                 memcpy (fname, opts->include_prefix, opts->include_prefix_len);
1294                 memcpy (fname + opts->include_prefix_len, argv[i], len + 1);
1295               }
1296             else
1297               {
1298                 fname = xmalloc (sizeof GCC_INCLUDE_DIR - 8 + len);
1299                 memcpy (fname, GCC_INCLUDE_DIR, sizeof GCC_INCLUDE_DIR - 9);
1300                 memcpy (fname + sizeof GCC_INCLUDE_DIR - 9, argv[i], len + 1);
1301               }
1302           
1303             append_include_chain (pfile, opts->pending, fname, BRACKET);
1304           }
1305         /* Add directory to end of path for includes.  */
1306         else if (!strcmp (argv[i], "-idirafter"))
1307           {
1308             if (i + 1 == argc)
1309               goto missing_dirname;
1310             append_include_chain (pfile, opts->pending,
1311                                   xstrdup (argv[++i]), AFTER);
1312           }
1313         else if (!strcmp (argv[i], "-iprefix"))
1314           {
1315             if (i + 1 == argc)
1316               goto missing_filename;
1317             else
1318               {
1319                 opts->include_prefix = argv[++i];
1320                 opts->include_prefix_len = strlen (argv[i]);
1321               }
1322           }
1323         else if (!strcmp (argv[i], "-ifoutput"))
1324           opts->output_conditionals = 1;
1325
1326         break;
1327       
1328       case 'o':
1329         if (opts->out_fname != NULL)
1330           {
1331             cpp_fatal (pfile, "Output filename specified twice");
1332             return argc;
1333           }
1334         if (i + 1 == argc)
1335           goto missing_filename;
1336         opts->out_fname = argv[++i];
1337         if (!strcmp (opts->out_fname, "-"))
1338           opts->out_fname = "";
1339         break;
1340       
1341       case 'p':
1342         if (!strcmp (argv[i], "-pedantic"))
1343           CPP_PEDANTIC (pfile) = 1;
1344         else if (!strcmp (argv[i], "-pedantic-errors"))
1345           {
1346             CPP_PEDANTIC (pfile) = 1;
1347             opts->pedantic_errors = 1;
1348           }
1349 #if 0
1350         else if (!strcmp (argv[i], "-pcp")) {
1351           char *pcp_fname = argv[++i];
1352           pcp_outfile = ((pcp_fname[0] != '-' || pcp_fname[1] != '\0')
1353                          ? fopen (pcp_fname, "w")
1354                          : fdopen (dup (fileno (stdout)), "w"));
1355           if (pcp_outfile == 0)
1356             cpp_pfatal_with_name (pfile, pcp_fname);
1357           no_precomp = 1;
1358         }
1359 #endif
1360         break;
1361       
1362       case 't':
1363         if (!strcmp (argv[i], "-traditional"))
1364           {
1365             opts->traditional = 1;
1366             opts->cplusplus_comments = 0;
1367           }
1368         else if (!strcmp (argv[i], "-trigraphs"))
1369           opts->trigraphs = 1;
1370         break;
1371       
1372       case 'l':
1373         if (! strcmp (argv[i], "-lang-c"))
1374           opts->cplusplus = 0, opts->cplusplus_comments = 1, opts->c89 = 0,
1375             opts->c9x = 1, opts->objc = 0;
1376         if (! strcmp (argv[i], "-lang-c89"))
1377           opts->cplusplus = 0, opts->cplusplus_comments = 0, opts->c89 = 1,
1378             opts->c9x = 0, opts->objc = 0;
1379         if (! strcmp (argv[i], "-lang-c++"))
1380           opts->cplusplus = 1, opts->cplusplus_comments = 1, opts->c89 = 0,
1381             opts->c9x = 0, opts->objc = 0;
1382         if (! strcmp (argv[i], "-lang-objc"))
1383           opts->cplusplus = 0, opts->cplusplus_comments = 1, opts->c89 = 0,
1384             opts->c9x = 0, opts->objc = 1;
1385         if (! strcmp (argv[i], "-lang-objc++"))
1386           opts->cplusplus = 1, opts->cplusplus_comments = 1, opts->c89 = 0,
1387             opts->c9x = 0, opts->objc = 1;
1388         if (! strcmp (argv[i], "-lang-asm"))
1389           opts->lang_asm = 1;
1390         if (! strcmp (argv[i], "-lint"))
1391           opts->for_lint = 1;
1392         if (! strcmp (argv[i], "-lang-chill"))
1393           opts->objc = 0, opts->cplusplus = 0, opts->chill = 1,
1394             opts->traditional = 1;
1395         break;
1396       
1397       case '+':
1398         opts->cplusplus = 1, opts->cplusplus_comments = 1;
1399         break;
1400
1401       case 's':
1402         if (!strcmp (argv[i], "-std=iso9899:1990")
1403             || !strcmp (argv[i], "-std=iso9899:199409")
1404             || !strcmp (argv[i], "-std=c89")
1405             || !strcmp (argv[i], "-std=gnu89"))
1406           opts->cplusplus = 0, opts->cplusplus_comments = 0,
1407             opts->c89 = 1, opts->c9x = 0, opts->objc = 0;
1408         else if (!strcmp (argv[i], "-std=iso9899:199x")
1409                  || !strcmp (argv[i], "-std=c9x")
1410                  || !strcmp (argv[i], "-std=gnu9x"))
1411           opts->cplusplus = 0, opts->cplusplus_comments = 1, opts->c89 = 0,
1412             opts->c9x = 1, opts->objc = 0;
1413         break;
1414
1415       case 'w':
1416         opts->inhibit_warnings = 1;
1417         break;
1418       
1419       case 'W':
1420         if (!strcmp (argv[i], "-Wtrigraphs"))
1421           opts->warn_trigraphs = 1;
1422         else if (!strcmp (argv[i], "-Wno-trigraphs"))
1423           opts->warn_trigraphs = 0;
1424         else if (!strcmp (argv[i], "-Wcomment"))
1425           opts->warn_comments = 1;
1426         else if (!strcmp (argv[i], "-Wno-comment"))
1427           opts->warn_comments = 0;
1428         else if (!strcmp (argv[i], "-Wcomments"))
1429           opts->warn_comments = 1;
1430         else if (!strcmp (argv[i], "-Wno-comments"))
1431           opts->warn_comments = 0;
1432         else if (!strcmp (argv[i], "-Wtraditional"))
1433           opts->warn_stringify = 1;
1434         else if (!strcmp (argv[i], "-Wno-traditional"))
1435           opts->warn_stringify = 0;
1436         else if (!strcmp (argv[i], "-Wundef"))
1437           opts->warn_undef = 1;
1438         else if (!strcmp (argv[i], "-Wno-undef"))
1439           opts->warn_undef = 0;
1440         else if (!strcmp (argv[i], "-Wimport"))
1441           opts->warn_import = 1;
1442         else if (!strcmp (argv[i], "-Wno-import"))
1443           opts->warn_import = 0;
1444         else if (!strcmp (argv[i], "-Werror"))
1445           opts->warnings_are_errors = 1;
1446         else if (!strcmp (argv[i], "-Wno-error"))
1447           opts->warnings_are_errors = 0;
1448         else if (!strcmp (argv[i], "-Wall"))
1449           {
1450             opts->warn_trigraphs = 1;
1451             opts->warn_comments = 1;
1452           }
1453         break;
1454       
1455       case 'M':
1456         /* The style of the choices here is a bit mixed.
1457            The chosen scheme is a hybrid of keeping all options in one string
1458            and specifying each option in a separate argument:
1459            -M|-MM|-MD file|-MMD file [-MG].  An alternative is:
1460            -M|-MM|-MD file|-MMD file|-MG|-MMG; or more concisely:
1461            -M[M][G][D file].  This is awkward to handle in specs, and is not
1462            as extensible.  */
1463         /* ??? -MG must be specified in addition to one of -M or -MM.
1464            This can be relaxed in the future without breaking anything.
1465            The converse isn't true.  */
1466       
1467         /* -MG isn't valid with -MD or -MMD.  This is checked for later.  */
1468         if (!strcmp (argv[i], "-MG"))
1469           {
1470             opts->print_deps_missing_files = 1;
1471             break;
1472           }
1473         if (!strcmp (argv[i], "-M"))
1474           opts->print_deps = 2;
1475         else if (!strcmp (argv[i], "-MM"))
1476           opts->print_deps = 1;
1477         else if (!strcmp (argv[i], "-MD"))
1478           opts->print_deps = 2;
1479         else if (!strcmp (argv[i], "-MMD"))
1480           opts->print_deps = 1;
1481         /* For -MD and -MMD options, write deps on file named by next arg.  */
1482         if (!strcmp (argv[i], "-MD") || !strcmp (argv[i], "-MMD"))
1483           {
1484             if (i+1 == argc)
1485               goto missing_filename;
1486             opts->deps_file = argv[++i];
1487           }
1488         else
1489           {
1490             /* For -M and -MM, write deps on standard output
1491                and suppress the usual output.  */
1492             opts->no_output = 1;
1493           }       
1494         break;
1495       
1496       case 'd':
1497         {
1498           char *p = argv[i] + 2;
1499           char c;
1500           while ((c = *p++) != 0)
1501             {
1502               /* Arg to -d specifies what parts of macros to dump */
1503               switch (c)
1504                 {
1505                 case 'M':
1506                   opts->dump_macros = dump_only;
1507                   opts->no_output = 1;
1508                   break;
1509                 case 'N':
1510                   opts->dump_macros = dump_names;
1511                   break;
1512                 case 'D':
1513                   opts->dump_macros = dump_definitions;
1514                   break;
1515                 case 'I':
1516                   opts->dump_includes = 1;
1517                   break;
1518                 }
1519             }
1520         }
1521         break;
1522     
1523       case 'g':
1524         if (argv[i][2] == '3')
1525           opts->debug_output = 1;
1526         break;
1527       
1528       case '-':
1529         if (!strcmp (argv[i], "--help"))
1530           print_help ();
1531         else if (!strcmp (argv[i], "--version"))
1532           cpp_notice ("GNU CPP version %s\n", version_string);
1533         exit (0);  /* XXX */
1534         break;
1535         
1536       case 'v':
1537         cpp_notice ("GNU CPP version %s", version_string);
1538 #ifdef TARGET_VERSION
1539         TARGET_VERSION;
1540 #endif
1541         fputc ('\n', stderr);
1542         opts->verbose = 1;
1543         break;
1544       
1545       case 'H':
1546         opts->print_include_names = 1;
1547         break;
1548       
1549       case 'D':
1550         {
1551           struct pending_option *o = (struct pending_option *)
1552             xmalloc (sizeof (struct pending_option));
1553           if (argv[i][2] != 0)
1554             o->arg = argv[i] + 2;
1555           else if (i + 1 == argc)
1556             {
1557               cpp_fatal (pfile, "Macro name missing after -D option");
1558               return argc;
1559             }
1560           else
1561             o->arg = argv[++i];
1562
1563           o->next = NULL;
1564           o->undef = 0;
1565           APPEND (opts->pending, define, o);
1566         }
1567         break;
1568       
1569       case 'A':
1570         {
1571           char *p;
1572         
1573           if (argv[i][2] != 0)
1574             p = argv[i] + 2;
1575           else if (i + 1 == argc)
1576             {
1577               cpp_fatal (pfile, "Assertion missing after -A option");
1578               return argc;
1579             }
1580           else
1581             p = argv[++i];
1582         
1583           if (strcmp (p, "-"))
1584             {
1585               struct pending_option *o = (struct pending_option *)
1586                 xmalloc (sizeof (struct pending_option));
1587
1588               o->arg = p;
1589               o->next = NULL;
1590               o->undef = 0;
1591               APPEND (opts->pending, assert, o);
1592             }
1593           else
1594             {
1595               /* -A- eliminates all predefined macros and assertions.
1596                  Let's include also any that were specified earlier
1597                  on the command line.  That way we can get rid of any
1598                  that were passed automatically in from GCC.  */
1599               struct pending_option *o1, *o2;
1600
1601               o1 = opts->pending->define_head;
1602               while (o1)
1603                 {
1604                   o2 = o1->next;
1605                   free (o1);
1606                   o1 = o2;
1607                 }
1608               o1 = opts->pending->assert_head;
1609               while (o1)
1610                 {
1611                   o2 = o1->next;
1612                   free (o1);
1613                   o1 = o2;
1614                 }
1615               opts->pending->assert_head = NULL;
1616               opts->pending->assert_tail = NULL;
1617               opts->pending->define_head = NULL;
1618               opts->pending->define_tail = NULL;
1619             }
1620         }
1621         break;
1622     
1623       case 'U':
1624         {
1625           struct pending_option *o = (struct pending_option *)
1626             xmalloc (sizeof (struct pending_option));
1627           
1628           if (argv[i][2] != 0)
1629             o->arg = argv[i] + 2;
1630           else if (i + 1 == argc)
1631             {
1632               cpp_fatal (pfile, "Macro name missing after -U option");
1633               return argc;
1634             }
1635           else
1636             o->arg = argv[++i];
1637
1638           o->next = NULL;
1639           o->undef = 1;
1640           APPEND (opts->pending, define, o);
1641         }
1642         break;
1643       
1644       case 'C':
1645         opts->put_out_comments = 1;
1646         break;
1647       
1648       case 'E':                 /* -E comes from cc -E; ignore it.  */
1649         break;
1650       
1651       case 'P':
1652         opts->no_line_commands = 1;
1653         break;
1654       
1655       case '$':                 /* Don't include $ in identifiers.  */
1656         opts->dollars_in_ident = 0;
1657         break;
1658       
1659       case 'n':
1660         if (!strcmp (argv[i], "-nostdinc"))
1661           /* -nostdinc causes no default include directories.
1662              You must specify all include-file directories with -I.  */
1663           opts->no_standard_includes = 1;
1664         else if (!strcmp (argv[i], "-nostdinc++"))
1665           /* -nostdinc++ causes no default C++-specific include directories. */
1666           opts->no_standard_cplusplus_includes = 1;
1667 #if 0
1668         else if (!strcmp (argv[i], "-noprecomp"))
1669           no_precomp = 1;
1670 #endif
1671         break;
1672       
1673       case 'r':
1674         if (!strcmp (argv[i], "-remap"))
1675           opts->remap = 1;
1676         break;
1677       
1678       case '\0': /* JF handle '-' as file name meaning stdin or stdout */
1679         if (opts->in_fname == NULL)
1680           opts->in_fname = "";
1681         else if (opts->out_fname == NULL)
1682           opts->out_fname = "";
1683         else
1684           return i;  /* error */
1685         break;
1686
1687       default:
1688         return i;
1689       }
1690
1691   return i + 1;
1692
1693  missing_filename:
1694   cpp_fatal (pfile, "Filename missing after `%s' option", argv[i]);
1695   return argc;
1696  missing_dirname:
1697   cpp_fatal (pfile, "Directory name missing after `%s' option", argv[i]);
1698   return argc;
1699 }
1700
1701 /* Handle command-line options in (argc, argv).
1702    Can be called multiple times, to handle multiple sets of options.
1703    Returns if an unrecognized option is seen.
1704    Returns number of strings consumed.  */
1705
1706 int
1707 cpp_handle_options (pfile, argc, argv)
1708      cpp_reader *pfile;
1709      int argc;
1710      char **argv;
1711 {
1712   int i;
1713   int strings_processed;
1714   for (i = 0; i < argc; i += strings_processed)
1715     {
1716       strings_processed = cpp_handle_option (pfile, argc - i, argv + i);
1717       if (strings_processed == 0)
1718         break;
1719     }
1720   return i;
1721 }
1722
1723 static void
1724 print_help ()
1725 {
1726   cpp_notice ("Usage: %s [switches] input output\n", progname);
1727   fputs (_("\
1728 Switches:\n\
1729   -include <file>           Include the contents of <file> before other files\n\
1730   -imacros <file>           Accept definition of macros in <file>\n\
1731   -iprefix <path>           Specify <path> as a prefix for next two options\n\
1732   -iwithprefix <dir>        Add <dir> to the end of the system include path\n\
1733   -iwithprefixbefore <dir>  Add <dir> to the end of the main include path\n\
1734   -isystem <dir>            Add <dir> to the start of the system include path\n\
1735   -idirafter <dir>          Add <dir> to the end of the system include path\n\
1736   -I <dir>                  Add <dir> to the end of the main include path\n\
1737   -nostdinc                 Do not search system include directories\n\
1738                              (dirs specified with -isystem will still be used)\n\
1739   -nostdinc++               Do not search system include directories for C++\n\
1740   -o <file>                 Put output into <file>\n\
1741   -pedantic                 Issue all warnings demanded by strict ANSI C\n\
1742   -traditional              Follow K&R pre-processor behaviour\n\
1743   -trigraphs                Support ANSI C trigraphs\n\
1744   -lang-c                   Assume that the input sources are in C\n\
1745   -lang-c89                 Assume that the input sources are in C89\n\
1746   -lang-c++                 Assume that the input sources are in C++\n\
1747   -lang-objc                Assume that the input sources are in ObjectiveC\n\
1748   -lang-objc++              Assume that the input sources are in ObjectiveC++\n\
1749   -lang-asm                 Assume that the input sources are in assembler\n\
1750   -lang-chill               Assume that the input sources are in Chill\n\
1751   -std=<std name>           Specify the conformance standard; one of:\n\
1752                             gnu89, gnu9x, c89, c9x, iso9899:1990,\n\
1753                             iso9899:199409, iso9899:199x\n\
1754   -+                        Allow parsing of C++ style features\n\
1755   -w                        Inhibit warning messages\n\
1756   -Wtrigraphs               Warn if trigraphs are encountered\n\
1757   -Wno-trigraphs            Do not warn about trigraphs\n\
1758   -Wcomment{s}              Warn if one comment starts inside another\n\
1759   -Wno-comment{s}           Do not warn about comments\n\
1760   -Wtraditional             Warn if a macro argument is/would be turned into\n\
1761                              a string if -traditional is specified\n\
1762   -Wno-traditional          Do not warn about stringification\n\
1763   -Wundef                   Warn if an undefined macro is used by #if\n\
1764   -Wno-undef                Do not warn about testing undefined macros\n\
1765   -Wimport                  Warn about the use of the #import directive\n\
1766   -Wno-import               Do not warn about the use of #import\n\
1767   -Werror                   Treat all warnings as errors\n\
1768   -Wno-error                Do not treat warnings as errors\n\
1769   -Wall                     Enable all preprocessor warnings\n\
1770   -M                        Generate make dependencies\n\
1771   -MM                       As -M, but ignore system header files\n\
1772   -MD                       As -M, but put output in a .d file\n\
1773   -MMD                      As -MD, but ignore system header files\n\
1774   -MG                       Treat missing header file as generated files\n\
1775   -g                        Include #define and #undef directives in the output\n\
1776   -D<macro>                 Define a <macro> with string '1' as its value\n\
1777   -D<macro>=<val>           Define a <macro> with <val> as its value\n\
1778   -A<question> (<answer>)   Assert the <answer> to <question>\n\
1779   -U<macro>                 Undefine <macro> \n\
1780   -v                        Display the version number\n\
1781   -H                        Print the name of header files as they are used\n\
1782   -C                        Do not discard comments\n\
1783   -dM                       Display a list of macro definitions active at end\n\
1784   -dD                       Preserve macro definitions in output\n\
1785   -dN                       As -dD except that only the names are preserved\n\
1786   -dI                       Include #include directives in the output\n\
1787   -ifoutput                 Describe skipped code blocks in output \n\
1788   -P                        Do not generate #line directives\n\
1789   -$                        Do not allow '$' in identifiers\n\
1790   -remap                    Remap file names when including files.\n\
1791   -h or --help              Display this information\n\
1792 "), stdout);
1793 }