OSDN Git Service

* gcc.c, config/fr30/fr30.c, config/v850/v850-c.c, toplev.c: Use
[pf3gnuchains/gcc-fork.git] / gcc / gcc.c
1 /* Compiler driver program that can handle many languages.
2    Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3    1999, 2000, 2001 Free Software Foundation, Inc.
4
5 This file is part of GCC.
6
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
11
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
15 for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING.  If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA.
21
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!!  */
24
25 /* This program is the user interface to the C compiler and possibly to
26 other compilers.  It is used because compilation is a complicated procedure
27 which involves running several programs and passing temporary files between
28 them, forwarding the users switches to those programs selectively,
29 and deleting the temporary files at the end.
30
31 CC recognizes how to compile each input file by suffixes in the file names.
32 Once it knows which kind of compilation to perform, the procedure for
33 compilation is specified by a string called a "spec".  */
34
35 /* A Short Introduction to Adding a Command-Line Option.
36
37    Before adding a command-line option, consider if it is really
38    necessary.  Each additional command-line option adds complexity and
39    is difficult to remove in subsequent versions.
40
41    In the following, consider adding the command-line argument
42    `--bar'.
43
44    1. Each command-line option is specified in the specs file.  The
45    notation is described below in the comment entitled "The Specs
46    Language".  Read it.
47
48    2. In this file, add an entry to "option_map" equating the long
49    `--' argument version and any shorter, single letter version.  Read
50    the comments in the declaration of "struct option_map" for an
51    explanation.  Do not omit the first `-'.
52
53    3. Look in the "specs" file to determine which program or option
54    list should be given the argument, e.g., "cc1_options".  Add the
55    appropriate syntax for the shorter option version to the
56    corresponding "const char *" entry in this file.  Omit the first
57    `-' from the option.  For example, use `-bar', rather than `--bar'.
58
59    4. If the argument takes an argument, e.g., `--baz argument1',
60    modify either DEFAULT_SWITCH_TAKES_ARG or
61    DEFAULT_WORD_SWITCH_TAKES_ARG in this file.  Omit the first `-'
62    from `--baz'.
63
64    5. Document the option in this file's display_help().  If the
65    option is passed to a subprogram, modify its corresponding
66    function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
67    instead.
68
69    6. Compile and test.  Make sure that your new specs file is being
70    read.  For example, use a debugger to investigate the value of
71    "specs_file" in main().  */
72
73 #include "config.h"
74 #include "system.h"
75 #include <signal.h>
76 #if ! defined( SIGCHLD ) && defined( SIGCLD )
77 #  define SIGCHLD SIGCLD
78 #endif
79 #include "obstack.h"
80 #include "intl.h"
81 #include "prefix.h"
82 #include "gcc.h"
83 #include "flags.h"
84
85 #ifdef HAVE_SYS_RESOURCE_H
86 #include <sys/resource.h>
87 #endif
88 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
89 extern int getrusage PARAMS ((int, struct rusage *));
90 #endif
91
92 /* By default there is no special suffix for target executables.  */
93 /* FIXME: when autoconf is fixed, remove the host check - dj */
94 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
95 #define HAVE_TARGET_EXECUTABLE_SUFFIX
96 #else
97 #undef TARGET_EXECUTABLE_SUFFIX
98 #define TARGET_EXECUTABLE_SUFFIX ""
99 #endif
100
101 /* By default there is no special suffix for host executables.  */
102 #ifdef HOST_EXECUTABLE_SUFFIX
103 #define HAVE_HOST_EXECUTABLE_SUFFIX
104 #else
105 #define HOST_EXECUTABLE_SUFFIX ""
106 #endif
107
108 /* By default, the suffix for target object files is ".o".  */
109 #ifdef TARGET_OBJECT_SUFFIX
110 #define HAVE_TARGET_OBJECT_SUFFIX
111 #else
112 #define TARGET_OBJECT_SUFFIX ".o"
113 #endif
114
115 #ifndef VMS
116 /* FIXME: the location independence code for VMS is hairier than this,
117    and hasn't been written.  */
118 #ifndef DIR_UP
119 #define DIR_UP ".."
120 #endif /* DIR_UP */
121 #endif /* VMS */
122
123 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
124
125 #define obstack_chunk_alloc xmalloc
126 #define obstack_chunk_free free
127
128 #ifndef GET_ENV_PATH_LIST
129 #define GET_ENV_PATH_LIST(VAR,NAME)     do { (VAR) = getenv (NAME); } while (0)
130 #endif
131
132 /* Most every one is fine with LIBRARY_PATH.  For some, it conflicts.  */
133 #ifndef LIBRARY_PATH_ENV
134 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
135 #endif
136
137 #ifndef HAVE_KILL
138 #define kill(p,s) raise(s)
139 #endif
140
141 /* If a stage of compilation returns an exit status >= 1,
142    compilation of that file ceases.  */
143
144 #define MIN_FATAL_STATUS 1
145
146 /* Flag set by cppspec.c to 1.  */
147 int is_cpp_driver;
148
149 /* Flag saying to pass the greatest exit code returned by a sub-process
150    to the calling program.  */
151 static int pass_exit_codes;
152
153 /* Definition of string containing the arguments given to configure.  */
154 #include "configargs.h"
155
156 /* Flag saying to print the directories gcc will search through looking for
157    programs, libraries, etc.  */
158
159 static int print_search_dirs;
160
161 /* Flag saying to print the full filename of this file
162    as found through our usual search mechanism.  */
163
164 static const char *print_file_name = NULL;
165
166 /* As print_file_name, but search for executable file.  */
167
168 static const char *print_prog_name = NULL;
169
170 /* Flag saying to print the relative path we'd use to
171    find libgcc.a given the current compiler flags.  */
172
173 static int print_multi_directory;
174
175 /* Flag saying to print the list of subdirectories and
176    compiler flags used to select them in a standard form.  */
177
178 static int print_multi_lib;
179
180 /* Flag saying to print the command line options understood by gcc and its
181    sub-processes.  */
182
183 static int print_help_list;
184
185 /* Flag indicating whether we should print the command and arguments */
186
187 static int verbose_flag;
188
189 /* Flag indicating whether we should ONLY print the command and
190    arguments (like verbose_flag) without executing the command.
191    Displayed arguments are quoted so that the generated command
192    line is suitable for execution.  This is intended for use in
193    shell scripts to capture the driver-generated command line.  */
194 static int verbose_only_flag;
195
196 /* Flag indicating to print target specific command line options.  */
197
198 static int target_help_flag;
199
200 /* Flag indicating whether we should report subprocess execution times
201    (if this is supported by the system - see pexecute.c).  */
202
203 static int report_times;
204
205 /* Nonzero means write "temp" files in source directory
206    and use the source file's name in them, and don't delete them.  */
207
208 static int save_temps_flag;
209
210 /* The compiler version.  */
211
212 static const char *compiler_version;
213
214 /* The target version specified with -V */
215
216 static const char *spec_version = DEFAULT_TARGET_VERSION;
217
218 /* The target machine specified with -b.  */
219
220 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
221
222 /* Nonzero if cross-compiling.
223    When -b is used, the value comes from the `specs' file.  */
224
225 #ifdef CROSS_COMPILE
226 static const char *cross_compile = "1";
227 #else
228 static const char *cross_compile = "0";
229 #endif
230
231 #ifdef MODIFY_TARGET_NAME
232
233 /* Information on how to alter the target name based on a command-line
234    switch.  The only case we support now is simply appending or deleting a
235    string to or from the end of the first part of the configuration name.  */
236
237 const struct modify_target
238 {
239   const char *const sw;
240   const enum add_del {ADD, DELETE} add_del;
241   const char *const str;
242 }
243 modify_target[] = MODIFY_TARGET_NAME;
244 #endif
245  
246 /* The number of errors that have occurred; the link phase will not be
247    run if this is non-zero.  */
248 static int error_count = 0;
249
250 /* Greatest exit code of sub-processes that has been encountered up to
251    now.  */
252 static int greatest_status = 1;
253
254 /* This is the obstack which we use to allocate many strings.  */
255
256 static struct obstack obstack;
257
258 /* This is the obstack to build an environment variable to pass to
259    collect2 that describes all of the relevant switches of what to
260    pass the compiler in building the list of pointers to constructors
261    and destructors.  */
262
263 static struct obstack collect_obstack;
264
265 /* These structs are used to collect resource usage information for
266    subprocesses.  */
267 #ifdef HAVE_GETRUSAGE
268 static struct rusage rus, prus;
269 #endif
270
271 /* Forward declaration for prototypes.  */
272 struct path_prefix;
273
274 static void init_spec           PARAMS ((void));
275 #ifndef VMS
276 static char **split_directories PARAMS ((const char *, int *));
277 static void free_split_directories PARAMS ((char **));
278 static char *make_relative_prefix PARAMS ((const char *, const char *, const char *));
279 #endif /* VMS */
280 static void store_arg           PARAMS ((const char *, int, int));
281 static char *load_specs         PARAMS ((const char *));
282 static void read_specs          PARAMS ((const char *, int));
283 static void set_spec            PARAMS ((const char *, const char *));
284 static struct compiler *lookup_compiler PARAMS ((const char *, size_t, const char *));
285 static char *build_search_list  PARAMS ((struct path_prefix *, const char *, int));
286 static void putenv_from_prefixes PARAMS ((struct path_prefix *, const char *));
287 static int access_check         PARAMS ((const char *, int));
288 static char *find_a_file        PARAMS ((struct path_prefix *, const char *, int));
289 static void add_prefix          PARAMS ((struct path_prefix *, const char *,
290                                          const char *, int, int, int *));
291 static void translate_options   PARAMS ((int *, const char *const **));
292 static char *skip_whitespace    PARAMS ((char *));
293 static void delete_if_ordinary  PARAMS ((const char *));
294 static void delete_temp_files   PARAMS ((void));
295 static void delete_failure_queue PARAMS ((void));
296 static void clear_failure_queue PARAMS ((void));
297 static int check_live_switch    PARAMS ((int, int));
298 static const char *handle_braces PARAMS ((const char *));
299 static char *save_string        PARAMS ((const char *, int));
300 static void set_collect_gcc_options PARAMS ((void));
301 static int do_spec_1            PARAMS ((const char *, int, const char *));
302 static const char *find_file    PARAMS ((const char *));
303 static int is_directory         PARAMS ((const char *, const char *, int));
304 static void validate_switches   PARAMS ((const char *));
305 static void validate_all_switches PARAMS ((void));
306 static void give_switch         PARAMS ((int, int, int));
307 static int used_arg             PARAMS ((const char *, int));
308 static int default_arg          PARAMS ((const char *, int));
309 static void set_multilib_dir    PARAMS ((void));
310 static void print_multilib_info PARAMS ((void));
311 static void perror_with_name    PARAMS ((const char *));
312 static void pfatal_pexecute     PARAMS ((const char *, const char *))
313   ATTRIBUTE_NORETURN;
314 static void notice              PARAMS ((const char *, ...))
315   ATTRIBUTE_PRINTF_1;
316 static void display_help        PARAMS ((void));
317 static void add_preprocessor_option     PARAMS ((const char *, int));
318 static void add_assembler_option        PARAMS ((const char *, int));
319 static void add_linker_option           PARAMS ((const char *, int));
320 static void process_command             PARAMS ((int, const char *const *));
321 static int execute                      PARAMS ((void));
322 static void clear_args                  PARAMS ((void));
323 static void fatal_error                 PARAMS ((int));
324 #ifdef ENABLE_SHARED_LIBGCC
325 static void init_gcc_specs              PARAMS ((struct obstack *,
326                                                  const char *, const char *,
327                                                  const char *));
328 #endif
329 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
330 static const char *convert_filename     PARAMS ((const char *, int, int));
331 #endif
332 \f
333 /* The Specs Language
334
335 Specs are strings containing lines, each of which (if not blank)
336 is made up of a program name, and arguments separated by spaces.
337 The program name must be exact and start from root, since no path
338 is searched and it is unreliable to depend on the current working directory.
339 Redirection of input or output is not supported; the subprograms must
340 accept filenames saying what files to read and write.
341
342 In addition, the specs can contain %-sequences to substitute variable text
343 or for conditional text.  Here is a table of all defined %-sequences.
344 Note that spaces are not generated automatically around the results of
345 expanding these sequences; therefore, you can concatenate them together
346 or with constant text in a single argument.
347
348  %%     substitute one % into the program name or argument.
349  %i     substitute the name of the input file being processed.
350  %b     substitute the basename of the input file being processed.
351         This is the substring up to (and not including) the last period
352         and not including the directory.
353  %B     same as %b, but include the file suffix (text after the last period).
354  %gSUFFIX
355         substitute a file name that has suffix SUFFIX and is chosen
356         once per compilation, and mark the argument a la %d.  To reduce
357         exposure to denial-of-service attacks, the file name is now
358         chosen in a way that is hard to predict even when previously
359         chosen file names are known.  For example, `%g.s ... %g.o ... %g.s'
360         might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'.  SUFFIX matches
361         the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
362         had been pre-processed.  Previously, %g was simply substituted
363         with a file name chosen once per compilation, without regard
364         to any appended suffix (which was therefore treated just like
365         ordinary text), making such attacks more likely to succeed.
366  %uSUFFIX
367         like %g, but generates a new temporary file name even if %uSUFFIX
368         was already seen.
369  %USUFFIX
370         substitutes the last file name generated with %uSUFFIX, generating a
371         new one if there is no such last file name.  In the absence of any
372         %uSUFFIX, this is just like %gSUFFIX, except they don't share
373         the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
374         would involve the generation of two distinct file names, one
375         for each `%g.s' and another for each `%U.s'.  Previously, %U was
376         simply substituted with a file name chosen for the previous %u,
377         without regard to any appended suffix.
378  %jSUFFIX
379         substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
380         writable, and if save-temps is off; otherwise, substitute the name
381         of a temporary file, just like %u.  This temporary file is not
382         meant for communication between processes, but rather as a junk
383         disposal mechanism.
384  %.SUFFIX
385         substitutes .SUFFIX for the suffixes of a matched switch's args when
386         it is subsequently output with %*. SUFFIX is terminated by the next
387         space or %.
388  %d     marks the argument containing or following the %d as a
389         temporary file name, so that that file will be deleted if CC exits
390         successfully.  Unlike %g, this contributes no text to the argument.
391  %w     marks the argument containing or following the %w as the
392         "output file" of this compilation.  This puts the argument
393         into the sequence of arguments that %o will substitute later.
394  %W{...}
395         like %{...} but mark last argument supplied within
396         as a file to be deleted on failure.
397  %o     substitutes the names of all the output files, with spaces
398         automatically placed around them.  You should write spaces
399         around the %o as well or the results are undefined.
400         %o is for use in the specs for running the linker.
401         Input files whose names have no recognized suffix are not compiled
402         at all, but they are included among the output files, so they will
403         be linked.
404  %O     substitutes the suffix for object files.  Note that this is
405         handled specially when it immediately follows %g, %u, or %U
406         (with or without a suffix argument) because of the need for
407         those to form complete file names.  The handling is such that
408         %O is treated exactly as if it had already been substituted,
409         except that %g, %u, and %U do not currently support additional
410         SUFFIX characters following %O as they would following, for
411         example, `.o'.
412  %p     substitutes the standard macro predefinitions for the
413         current target machine.  Use this when running cpp.
414  %P     like %p, but puts `__' before and after the name of each macro.
415         (Except macros that already have __.)
416         This is for ANSI C.
417  %I     Substitute a -iprefix option made from GCC_EXEC_PREFIX.
418  %s     current argument is the name of a library or startup file of some sort.
419         Search for that file in a standard list of directories
420         and substitute the full name found.
421  %eSTR  Print STR as an error message.  STR is terminated by a newline.
422         Use this when inconsistent options are detected.
423  %nSTR  Print STR as an notice.  STR is terminated by a newline.
424  %x{OPTION}     Accumulate an option for %X.
425  %X     Output the accumulated linker options specified by compilations.
426  %Y     Output the accumulated assembler options specified by compilations.
427  %Z     Output the accumulated preprocessor options specified by compilations.
428  %v1    Substitute the major version number of GCC.
429         (For version 2.5.3, this is 2.)
430  %v2    Substitute the minor version number of GCC.
431         (For version 2.5.3, this is 5.)
432  %v3    Substitute the patch level number of GCC.
433         (For version 2.5.3, this is 3.)
434  %a     process ASM_SPEC as a spec.
435         This allows config.h to specify part of the spec for running as.
436  %A     process ASM_FINAL_SPEC as a spec.  A capital A is actually
437         used here.  This can be used to run a post-processor after the
438         assembler has done its job.
439  %D     Dump out a -L option for each directory in startfile_prefixes.
440         If multilib_dir is set, extra entries are generated with it affixed.
441  %l     process LINK_SPEC as a spec.
442  %L     process LIB_SPEC as a spec.
443  %G     process LIBGCC_SPEC as a spec.
444  %M     output multilib_dir with directory separators replaced with "_";
445         if multilib_dir is not set or is ".", output "".
446  %S     process STARTFILE_SPEC as a spec.  A capital S is actually used here.
447  %E     process ENDFILE_SPEC as a spec.  A capital E is actually used here.
448  %c     process SIGNED_CHAR_SPEC as a spec.
449  %C     process CPP_SPEC as a spec.
450  %1     process CC1_SPEC as a spec.
451  %2     process CC1PLUS_SPEC as a spec.
452  %|     output "-" if the input for the current command is coming from a pipe.
453  %*     substitute the variable part of a matched option.  (See below.)
454         Note that each comma in the substituted string is replaced by
455         a single space.
456  %{S}   substitutes the -S switch, if that switch was given to CC.
457         If that switch was not specified, this substitutes nothing.
458         Here S is a metasyntactic variable.
459  %{S*}  substitutes all the switches specified to CC whose names start
460         with -S.  This is used for -o, -I, etc; switches that take
461         arguments.  CC considers `-o foo' as being one switch whose
462         name starts with `o'.  %{o*} would substitute this text,
463         including the space; thus, two arguments would be generated.
464  %{^S*} likewise, but don't put a blank between a switch and any args.
465  %{S*&T*} likewise, but preserve order of S and T options (the order
466         of S and T in the spec is not significant).  Can be any number
467         of ampersand-separated variables; for each the wild card is
468         optional.  Useful for CPP as %{D*&U*&A*}.
469  %{S*:X} substitutes X if one or more switches whose names start with -S are
470         specified to CC.  Note that the tail part of the -S option
471         (i.e. the part matched by the `*') will be substituted for each
472         occurrence of %* within X.
473  %{<S}  remove all occurrences of -S from the command line.
474         Note - this option is position dependent.  % commands in the
475         spec string before this option will see -S, % commands in the
476         spec string after this option will not.
477  %{S:X} substitutes X, but only if the -S switch was given to CC.
478  %{!S:X} substitutes X, but only if the -S switch was NOT given to CC.
479  %{|S:X} like %{S:X}, but if no S switch, substitute `-'.
480  %{|!S:X} like %{!S:X}, but if there is an S switch, substitute `-'.
481  %{.S:X} substitutes X, but only if processing a file with suffix S.
482  %{!.S:X} substitutes X, but only if NOT processing a file with suffix S.
483  %{S|P:X} substitutes X if either -S or -P was given to CC.  This may be
484           combined with ! and . as above binding stronger than the OR.
485  %(Spec) processes a specification defined in a specs file as *Spec:
486  %[Spec] as above, but put __ around -D arguments
487
488 The conditional text X in a %{S:X} or %{!S:X} construct may contain
489 other nested % constructs or spaces, or even newlines.  They are
490 processed as usual, as described above.
491
492 The -O, -f, -m, and -W switches are handled specifically in these
493 constructs.  If another value of -O or the negated form of a -f, -m, or
494 -W switch is found later in the command line, the earlier switch
495 value is ignored, except with {S*} where S is just one letter; this
496 passes all matching options.
497
498 The character | at the beginning of the predicate text is used to indicate
499 that a command should be piped to the following command, but only if -pipe
500 is specified.
501
502 Note that it is built into CC which switches take arguments and which
503 do not.  You might think it would be useful to generalize this to
504 allow each compiler's spec to say which switches take arguments.  But
505 this cannot be done in a consistent fashion.  CC cannot even decide
506 which input files have been specified without knowing which switches
507 take arguments, and it must know which input files to compile in order
508 to tell which compilers to run.
509
510 CC also knows implicitly that arguments starting in `-l' are to be
511 treated as compiler output files, and passed to the linker in their
512 proper position among the other output files.  */
513 \f
514 /* Define the macros used for specs %a, %l, %L, %S, %c, %C, %1.  */
515
516 /* config.h can define ASM_SPEC to provide extra args to the assembler
517    or extra switch-translations.  */
518 #ifndef ASM_SPEC
519 #define ASM_SPEC ""
520 #endif
521
522 /* config.h can define ASM_FINAL_SPEC to run a post processor after
523    the assembler has run.  */
524 #ifndef ASM_FINAL_SPEC
525 #define ASM_FINAL_SPEC ""
526 #endif
527
528 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
529    or extra switch-translations.  */
530 #ifndef CPP_SPEC
531 #define CPP_SPEC ""
532 #endif
533
534 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
535    or extra switch-translations.  */
536 #ifndef CC1_SPEC
537 #define CC1_SPEC ""
538 #endif
539
540 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
541    or extra switch-translations.  */
542 #ifndef CC1PLUS_SPEC
543 #define CC1PLUS_SPEC ""
544 #endif
545
546 /* config.h can define LINK_SPEC to provide extra args to the linker
547    or extra switch-translations.  */
548 #ifndef LINK_SPEC
549 #define LINK_SPEC ""
550 #endif
551
552 /* config.h can define LIB_SPEC to override the default libraries.  */
553 #ifndef LIB_SPEC
554 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
555 #endif
556
557 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
558    included.  */
559 #ifndef LIBGCC_SPEC
560 #if defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
561 /* Have gcc do the search for libgcc.a.  */
562 #define LIBGCC_SPEC "libgcc.a%s"
563 #else
564 #define LIBGCC_SPEC "-lgcc"
565 #endif
566 #endif
567
568 /* config.h can define STARTFILE_SPEC to override the default crt0 files.  */
569 #ifndef STARTFILE_SPEC
570 #define STARTFILE_SPEC  \
571   "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
572 #endif
573
574 /* config.h can define SWITCHES_NEED_SPACES to control which options
575    require spaces between the option and the argument.  */
576 #ifndef SWITCHES_NEED_SPACES
577 #define SWITCHES_NEED_SPACES ""
578 #endif
579
580 /* config.h can define ENDFILE_SPEC to override the default crtn files.  */
581 #ifndef ENDFILE_SPEC
582 #define ENDFILE_SPEC ""
583 #endif
584
585 /* This spec is used for telling cpp whether char is signed or not.  */
586 #ifndef SIGNED_CHAR_SPEC
587 /* Use #if rather than ?:
588    because MIPS C compiler rejects like ?: in initializers.  */
589 #if DEFAULT_SIGNED_CHAR
590 #define SIGNED_CHAR_SPEC "%{funsigned-char:-D__CHAR_UNSIGNED__}"
591 #else
592 #define SIGNED_CHAR_SPEC "%{!fsigned-char:-D__CHAR_UNSIGNED__}"
593 #endif
594 #endif
595
596 #ifndef LINKER_NAME
597 #define LINKER_NAME "collect2"
598 #endif
599
600 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
601    to the assembler.  */
602 #ifndef ASM_DEBUG_SPEC
603 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
604      && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
605 #  define ASM_DEBUG_SPEC                                        \
606       (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG                    \
607        ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}"   \
608        : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
609 # else
610 #  if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
611 #   define ASM_DEBUG_SPEC "%{g*:--gstabs}"
612 #  endif
613 #  if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
614 #   define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
615 #  endif
616 # endif
617 #endif
618 #ifndef ASM_DEBUG_SPEC
619 # define ASM_DEBUG_SPEC ""
620 #endif
621
622 /* Here is the spec for running the linker, after compiling all files.  */
623
624 /* -u* was put back because both BSD and SysV seem to support it.  */
625 /* %{static:} simply prevents an error message if the target machine
626    doesn't handle -static.  */
627 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
628    scripts which exist in user specified directories, or in standard
629    directories.  */
630 #ifndef LINK_COMMAND_SPEC
631 #define LINK_COMMAND_SPEC "\
632 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
633     %(linker) %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r} %{s} %{t}\
634     %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
635     %{static:} %{L*} %(link_libgcc) %o %{!nostdlib:%{!nodefaultlibs:%G %L %G}}\
636     %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
637 #endif
638
639 #ifndef LINK_LIBGCC_SPEC
640 # ifdef LINK_LIBGCC_SPECIAL
641 /* Don't generate -L options for startfile prefix list.  */
642 #  define LINK_LIBGCC_SPEC ""
643 # else
644 /* Do generate them.  */
645 #  define LINK_LIBGCC_SPEC "%D"
646 # endif
647 #endif
648
649 static const char *asm_debug = ASM_DEBUG_SPEC;
650 static const char *cpp_spec = CPP_SPEC;
651 static const char *cpp_predefines = CPP_PREDEFINES;
652 static const char *cc1_spec = CC1_SPEC;
653 static const char *cc1plus_spec = CC1PLUS_SPEC;
654 static const char *signed_char_spec = SIGNED_CHAR_SPEC;
655 static const char *asm_spec = ASM_SPEC;
656 static const char *asm_final_spec = ASM_FINAL_SPEC;
657 static const char *link_spec = LINK_SPEC;
658 static const char *lib_spec = LIB_SPEC;
659 static const char *libgcc_spec = LIBGCC_SPEC;
660 static const char *endfile_spec = ENDFILE_SPEC;
661 static const char *startfile_spec = STARTFILE_SPEC;
662 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
663 static const char *linker_name_spec = LINKER_NAME;
664 static const char *link_command_spec = LINK_COMMAND_SPEC;
665 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
666
667 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
668    There should be no need to override these in target dependent files,
669    but we need to copy them to the specs file so that newer versions
670    of the GCC driver can correctly drive older tool chains with the
671    appropriate -B options.  */
672
673 static const char *trad_capable_cpp =
674 "%{traditional|ftraditional|traditional-cpp:trad}cpp0";
675
676 static const char *cpp_options =
677 "%{C:%{!E:%eGNU C does not support -C without using -E}}\
678  %{std*} %{nostdinc*}\
679  %{C} %{v} %{I*} %{P} %{$} %I\
680  %{MD:-M -MF %W{!o: %b.d}%W{o*:%.d%*}}\
681  %{MMD:-MM -MF %W{!o: %b.d}%W{o*:%.d%*}}\
682  %{M} %{MM} %W{MF*} %{MG} %{MP} %{MQ*} %{MT*} %{M|MD|MM|MMD:%{o*:-MQ %*}}\
683  %{!no-gcc:-D__GNUC__=%v1 -D__GNUC_MINOR__=%v2 -D__GNUC_PATCHLEVEL__=%v3}\
684  %{!undef:%{!ansi:%{!std=*:%p}%{std=gnu*:%p}} %P} %{trigraphs}\
685  %c %{Os:-D__OPTIMIZE_SIZE__} %{O*:%{!O0:-D__OPTIMIZE__}}\
686  %{fno-inline|O0|!O*:-D__NO_INLINE__} %{ffast-math:-D__FAST_MATH__}\
687  %{fshort-wchar:-U__WCHAR_TYPE__ -D__WCHAR_TYPE__=short\\ unsigned\\ int}\
688  %{ffreestanding:-D__STDC_HOSTED__=0} %{fno-hosted:-D__STDC_HOSTED__=0}\
689  %{!ffreestanding:%{!fno-hosted:-D__STDC_HOSTED__=1}}\
690  %{fshow-column} %{fno-show-column}\
691  %{fleading-underscore} %{fno-leading-underscore}\
692  %{fno-operator-names} %{ftabstop=*} %{remap}\
693  %{g3:-dD} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*&U*&A*} %{i*} %Z %i\
694  %{E:%{!M*:%W{o*}}}";
695
696 /* NB: This is shared amongst all front-ends.  */
697 static const char *cc1_options =
698 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
699  %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
700  %{g*} %{O*} %{W*} %{w} %{pedantic*} %{std*} %{ansi}\
701  %{traditional} %{v:-version} %{pg:-p} %{p} %{f*}\
702  %{Qn:-fno-ident} %{--help:--help}\
703  %{--target-help:--target-help}\
704  %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
705  %{fsyntax-only:-o %j} %{-param*}";
706
707 static const char *asm_options =
708 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
709
710 static const char *invoke_as =
711 "%{!S:-o %{|!pipe:%g.s} |\n as %(asm_options) %{!pipe:%g.s} %A }";
712
713 /* Some compilers have limits on line lengths, and the multilib_select
714    and/or multilib_matches strings can be very long, so we build them at
715    run time.  */
716 static struct obstack multilib_obstack;
717 static const char *multilib_select;
718 static const char *multilib_matches;
719 static const char *multilib_defaults;
720 static const char *multilib_exclusions;
721 #include "multilib.h"
722
723 /* Check whether a particular argument is a default argument.  */
724
725 #ifndef MULTILIB_DEFAULTS
726 #define MULTILIB_DEFAULTS { "" }
727 #endif
728
729 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
730
731 struct user_specs
732 {
733   struct user_specs *next;
734   const char *filename;
735 };
736
737 static struct user_specs *user_specs_head, *user_specs_tail;
738
739 /* This defines which switch letters take arguments.  */
740
741 #define DEFAULT_SWITCH_TAKES_ARG(CHAR) \
742   ((CHAR) == 'D' || (CHAR) == 'U' || (CHAR) == 'o' \
743    || (CHAR) == 'e' || (CHAR) == 'T' || (CHAR) == 'u' \
744    || (CHAR) == 'I' || (CHAR) == 'm' || (CHAR) == 'x' \
745    || (CHAR) == 'L' || (CHAR) == 'A' || (CHAR) == 'V' \
746    || (CHAR) == 'B' || (CHAR) == 'b')
747
748 #ifndef SWITCH_TAKES_ARG
749 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
750 #endif
751
752 /* This defines which multi-letter switches take arguments.  */
753
754 #define DEFAULT_WORD_SWITCH_TAKES_ARG(STR)              \
755  (!strcmp (STR, "Tdata") || !strcmp (STR, "Ttext")      \
756   || !strcmp (STR, "Tbss") || !strcmp (STR, "include")  \
757   || !strcmp (STR, "imacros") || !strcmp (STR, "aux-info") \
758   || !strcmp (STR, "idirafter") || !strcmp (STR, "iprefix") \
759   || !strcmp (STR, "iwithprefix") || !strcmp (STR, "iwithprefixbefore") \
760   || !strcmp (STR, "isystem") || !strcmp (STR, "-param") \
761   || !strcmp (STR, "specs") \
762   || !strcmp (STR, "MF") || !strcmp (STR, "MT") || !strcmp (STR, "MQ"))
763
764 #ifndef WORD_SWITCH_TAKES_ARG
765 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
766 #endif
767 \f
768 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
769 /* This defines which switches stop a full compilation.  */
770 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
771   ((CHAR) == 'c' || (CHAR) == 'S')
772
773 #ifndef SWITCH_CURTAILS_COMPILATION
774 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
775   DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
776 #endif
777 #endif
778
779 /* Record the mapping from file suffixes for compilation specs.  */
780
781 struct compiler
782 {
783   const char *suffix;           /* Use this compiler for input files
784                                    whose names end in this suffix.  */
785
786   const char *spec;             /* To use this compiler, run this spec.  */
787
788   const char *cpp_spec;         /* If non-NULL, substitute this spec
789                                    for `%C', rather than the usual
790                                    cpp_spec.  */
791 };
792
793 /* Pointer to a vector of `struct compiler' that gives the spec for
794    compiling a file, based on its suffix.
795    A file that does not end in any of these suffixes will be passed
796    unchanged to the loader and nothing else will be done to it.
797
798    An entry containing two 0s is used to terminate the vector.
799
800    If multiple entries match a file, the last matching one is used.  */
801
802 static struct compiler *compilers;
803
804 /* Number of entries in `compilers', not counting the null terminator.  */
805
806 static int n_compilers;
807
808 /* The default list of file name suffixes and their compilation specs.  */
809
810 static struct compiler default_compilers[] =
811 {
812   /* Add lists of suffixes of known languages here.  If those languages
813      were not present when we built the driver, we will hit these copies
814      and be given a more meaningful error than "file not used since
815      linking is not done".  */
816   {".m",  "#Objective-C", 0}, {".mi",  "#Objective-C", 0},
817   {".cc", "#C++", 0}, {".cxx", "#C++", 0}, {".cpp", "#C++", 0},
818   {".cp", "#C++", 0}, {".c++", "#C++", 0}, {".C", "#C++", 0},
819   {".ii", "#C++", 0},
820   {".ads", "#Ada", 0}, {".adb", "#Ada", 0},
821   {".f", "#Fortran", 0}, {".for", "#Fortran", 0}, {".fpp", "#Fortran", 0},
822   {".F", "#Fortran", 0}, {".FOR", "#Fortran", 0}, {".FPP", "#Fortran", 0},
823   {".r", "#Ratfor", 0},
824   {".p", "#Pascal", 0}, {".pas", "#Pascal", 0},
825   {".ch", "#Chill", 0}, {".chi", "#Chill", 0},
826   {".java", "#Java", 0}, {".class", "#Java", 0},
827   {".zip", "#Java", 0}, {".jar", "#Java", 0},
828   /* Next come the entries for C.  */
829   {".c", "@c", 0},
830   {"@c",
831    /* cc1 has an integrated ISO C preprocessor.  We should invoke the
832       external preprocessor if -save-temps or -traditional is given.  */
833      "%{E|M|MM:%(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)}\
834       %{!E:%{!M:%{!MM:\
835           %{save-temps:%(trad_capable_cpp) -lang-c %{ansi:-std=c89}\
836                 %(cpp_options) %b.i \n\
837                     cc1 -fpreprocessed %b.i %(cc1_options)}\
838           %{!save-temps:\
839             %{traditional|ftraditional|traditional-cpp:\
840                 tradcpp0 -lang-c %{ansi:-std=c89} %(cpp_options) %{!pipe:%g.i} |\n\
841                     cc1 -fpreprocessed %{!pipe:%g.i} %(cc1_options)}\
842             %{!traditional:%{!ftraditional:%{!traditional-cpp:\
843                 cc1 -lang-c %{ansi:-std=c89} %(cpp_options) %(cc1_options)}}}}\
844         %{!fsyntax-only:%(invoke_as)}}}}", 0},
845   {"-",
846    "%{!E:%e-E required when input is from standard input}\
847     %(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)", 0},
848   {".h", "@c-header", 0},
849   {"@c-header",
850    "%{!E:%ecompilation of header file requested} \
851     %(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)", 0},
852   {".i", "@cpp-output", 0},
853   {"@cpp-output",
854    "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0},
855   {".s", "@assembler", 0},
856   {"@assembler",
857    "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0},
858   {".S", "@assembler-with-cpp", 0},
859   {"@assembler-with-cpp",
860    "%(trad_capable_cpp) -lang-asm %(cpp_options)\
861       %{!M:%{!MM:%{!E:%{!S:-o %{|!pipe:%g.s} |\n\
862        as %(asm_debug) %(asm_options) %{!pipe:%g.s} %A }}}}", 0},
863 #include "specs.h"
864   /* Mark end of table */
865   {0, 0, 0}
866 };
867
868 /* Number of elements in default_compilers, not counting the terminator.  */
869
870 static int n_default_compilers
871   = (sizeof default_compilers / sizeof (struct compiler)) - 1;
872
873 /* A vector of options to give to the linker.
874    These options are accumulated by %x,
875    and substituted into the linker command with %X.  */
876 static int n_linker_options;
877 static char **linker_options;
878
879 /* A vector of options to give to the assembler.
880    These options are accumulated by -Wa,
881    and substituted into the assembler command with %Y.  */
882 static int n_assembler_options;
883 static char **assembler_options;
884
885 /* A vector of options to give to the preprocessor.
886    These options are accumulated by -Wp,
887    and substituted into the preprocessor command with %Z.  */
888 static int n_preprocessor_options;
889 static char **preprocessor_options;
890 \f
891 /* Define how to map long options into short ones.  */
892
893 /* This structure describes one mapping.  */
894 struct option_map
895 {
896   /* The long option's name.  */
897   const char *const name;
898   /* The equivalent short option.  */
899   const char *const equivalent;
900   /* Argument info.  A string of flag chars; NULL equals no options.
901      a => argument required.
902      o => argument optional.
903      j => join argument to equivalent, making one word.
904      * => require other text after NAME as an argument.  */
905   const char *const arg_info;
906 };
907
908 /* This is the table of mappings.  Mappings are tried sequentially
909    for each option encountered; the first one that matches, wins.  */
910
911 static const struct option_map option_map[] =
912  {
913    {"--all-warnings", "-Wall", 0},
914    {"--ansi", "-ansi", 0},
915    {"--assemble", "-S", 0},
916    {"--assert", "-A", "a"},
917    {"--classpath", "-fclasspath=", "aj"},
918    {"--CLASSPATH", "-fCLASSPATH=", "aj"},
919    {"--comments", "-C", 0},
920    {"--compile", "-c", 0},
921    {"--debug", "-g", "oj"},
922    {"--define-macro", "-D", "aj"},
923    {"--dependencies", "-M", 0},
924    {"--dump", "-d", "a"},
925    {"--dumpbase", "-dumpbase", "a"},
926    {"--entry", "-e", 0},
927    {"--extra-warnings", "-W", 0},
928    {"--for-assembler", "-Wa", "a"},
929    {"--for-linker", "-Xlinker", "a"},
930    {"--force-link", "-u", "a"},
931    {"--imacros", "-imacros", "a"},
932    {"--include", "-include", "a"},
933    {"--include-barrier", "-I-", 0},
934    {"--include-directory", "-I", "aj"},
935    {"--include-directory-after", "-idirafter", "a"},
936    {"--include-prefix", "-iprefix", "a"},
937    {"--include-with-prefix", "-iwithprefix", "a"},
938    {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
939    {"--include-with-prefix-after", "-iwithprefix", "a"},
940    {"--language", "-x", "a"},
941    {"--library-directory", "-L", "a"},
942    {"--machine", "-m", "aj"},
943    {"--machine-", "-m", "*j"},
944    {"--no-line-commands", "-P", 0},
945    {"--no-precompiled-includes", "-noprecomp", 0},
946    {"--no-standard-includes", "-nostdinc", 0},
947    {"--no-standard-libraries", "-nostdlib", 0},
948    {"--no-warnings", "-w", 0},
949    {"--optimize", "-O", "oj"},
950    {"--output", "-o", "a"},
951    {"--output-class-directory", "-foutput-class-dir=", "ja"},
952    {"--param", "--param", "a"},
953    {"--pedantic", "-pedantic", 0},
954    {"--pedantic-errors", "-pedantic-errors", 0},
955    {"--pipe", "-pipe", 0},
956    {"--prefix", "-B", "a"},
957    {"--preprocess", "-E", 0},
958    {"--print-search-dirs", "-print-search-dirs", 0},
959    {"--print-file-name", "-print-file-name=", "aj"},
960    {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
961    {"--print-missing-file-dependencies", "-MG", 0},
962    {"--print-multi-lib", "-print-multi-lib", 0},
963    {"--print-multi-directory", "-print-multi-directory", 0},
964    {"--print-prog-name", "-print-prog-name=", "aj"},
965    {"--profile", "-p", 0},
966    {"--profile-blocks", "-a", 0},
967    {"--quiet", "-q", 0},
968    {"--save-temps", "-save-temps", 0},
969    {"--shared", "-shared", 0},
970    {"--silent", "-q", 0},
971    {"--specs", "-specs=", "aj"},
972    {"--static", "-static", 0},
973    {"--std", "-std=", "aj"},
974    {"--symbolic", "-symbolic", 0},
975    {"--target", "-b", "a"},
976    {"--time", "-time", 0},
977    {"--trace-includes", "-H", 0},
978    {"--traditional", "-traditional", 0},
979    {"--traditional-cpp", "-traditional-cpp", 0},
980    {"--trigraphs", "-trigraphs", 0},
981    {"--undefine-macro", "-U", "aj"},
982    {"--use-version", "-V", "a"},
983    {"--user-dependencies", "-MM", 0},
984    {"--verbose", "-v", 0},
985    {"--version", "-dumpversion", 0},
986    {"--warn-", "-W", "*j"},
987    {"--write-dependencies", "-MD", 0},
988    {"--write-user-dependencies", "-MMD", 0},
989    {"--", "-f", "*j"}
990  };
991 \f
992
993 #ifdef TARGET_OPTION_TRANSLATE_TABLE
994 static const struct {
995   const char *const option_found;
996   const char *const replacements;
997 } target_option_translations[] =
998 {
999   TARGET_OPTION_TRANSLATE_TABLE,
1000   { 0, 0 }
1001 };
1002 #endif
1003
1004 /* Translate the options described by *ARGCP and *ARGVP.
1005    Make a new vector and store it back in *ARGVP,
1006    and store its length in *ARGVC.  */
1007
1008 static void
1009 translate_options (argcp, argvp)
1010      int *argcp;
1011      const char *const **argvp;
1012 {
1013   int i;
1014   int argc = *argcp;
1015   const char *const *argv = *argvp;
1016   int newvsize = (argc + 2) * 2 * sizeof (const char *);
1017   const char **newv =
1018     (const char **) xmalloc (newvsize);
1019   int newindex = 0;
1020
1021   i = 0;
1022   newv[newindex++] = argv[i++];
1023
1024   while (i < argc)
1025     {
1026 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1027       int tott_idx;
1028
1029       for (tott_idx = 0;
1030            target_option_translations[tott_idx].option_found;
1031            tott_idx++)
1032         {
1033           if (strcmp (target_option_translations[tott_idx].option_found,
1034                       argv[i]) == 0)
1035             {
1036               int spaces = 1;
1037               const char *sp;
1038               char *np;
1039
1040               for (sp = target_option_translations[tott_idx].replacements;
1041                    *sp; sp++)
1042                 {
1043                   if (*sp == ' ')
1044                     spaces ++;
1045                 }
1046
1047               newvsize += spaces * sizeof (const char *);
1048               newv = (const char **) xrealloc (newv, newvsize);
1049
1050               sp = target_option_translations[tott_idx].replacements;
1051               np = xstrdup (sp);
1052
1053               while (1)
1054                 {
1055                   while (*np == ' ')
1056                     np++;
1057                   if (*np == 0)
1058                     break;
1059                   newv[newindex++] = np;
1060                   while (*np != ' ' && *np)
1061                     np++;
1062                   if (*np == 0)
1063                     break;
1064                   *np++ = 0;
1065                 }
1066
1067               i ++;
1068               break;
1069             }
1070         }
1071       if (target_option_translations[tott_idx].option_found)
1072         continue;
1073 #endif
1074
1075       /* Translate -- options.  */
1076       if (argv[i][0] == '-' && argv[i][1] == '-')
1077         {
1078           size_t j;
1079           /* Find a mapping that applies to this option.  */
1080           for (j = 0; j < ARRAY_SIZE (option_map); j++)
1081             {
1082               size_t optlen = strlen (option_map[j].name);
1083               size_t arglen = strlen (argv[i]);
1084               size_t complen = arglen > optlen ? optlen : arglen;
1085               const char *arginfo = option_map[j].arg_info;
1086
1087               if (arginfo == 0)
1088                 arginfo = "";
1089
1090               if (!strncmp (argv[i], option_map[j].name, complen))
1091                 {
1092                   const char *arg = 0;
1093
1094                   if (arglen < optlen)
1095                     {
1096                       size_t k;
1097                       for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1098                         if (strlen (option_map[k].name) >= arglen
1099                             && !strncmp (argv[i], option_map[k].name, arglen))
1100                           {
1101                             error ("ambiguous abbreviation %s", argv[i]);
1102                             break;
1103                           }
1104
1105                       if (k != ARRAY_SIZE (option_map))
1106                         break;
1107                     }
1108
1109                   if (arglen > optlen)
1110                     {
1111                       /* If the option has an argument, accept that.  */
1112                       if (argv[i][optlen] == '=')
1113                         arg = argv[i] + optlen + 1;
1114
1115                       /* If this mapping requires extra text at end of name,
1116                          accept that as "argument".  */
1117                       else if (strchr (arginfo, '*') != 0)
1118                         arg = argv[i] + optlen;
1119
1120                       /* Otherwise, extra text at end means mismatch.
1121                          Try other mappings.  */
1122                       else
1123                         continue;
1124                     }
1125
1126                   else if (strchr (arginfo, '*') != 0)
1127                     {
1128                       error ("incomplete `%s' option", option_map[j].name);
1129                       break;
1130                     }
1131
1132                   /* Handle arguments.  */
1133                   if (strchr (arginfo, 'a') != 0)
1134                     {
1135                       if (arg == 0)
1136                         {
1137                           if (i + 1 == argc)
1138                             {
1139                               error ("missing argument to `%s' option",
1140                                      option_map[j].name);
1141                               break;
1142                             }
1143
1144                           arg = argv[++i];
1145                         }
1146                     }
1147                   else if (strchr (arginfo, '*') != 0)
1148                     ;
1149                   else if (strchr (arginfo, 'o') == 0)
1150                     {
1151                       if (arg != 0)
1152                         error ("extraneous argument to `%s' option",
1153                                option_map[j].name);
1154                       arg = 0;
1155                     }
1156
1157                   /* Store the translation as one argv elt or as two.  */
1158                   if (arg != 0 && strchr (arginfo, 'j') != 0)
1159                     newv[newindex++] = concat (option_map[j].equivalent, arg,
1160                                                NULL);
1161                   else if (arg != 0)
1162                     {
1163                       newv[newindex++] = option_map[j].equivalent;
1164                       newv[newindex++] = arg;
1165                     }
1166                   else
1167                     newv[newindex++] = option_map[j].equivalent;
1168
1169                   break;
1170                 }
1171             }
1172           i++;
1173         }
1174
1175       /* Handle old-fashioned options--just copy them through,
1176          with their arguments.  */
1177       else if (argv[i][0] == '-')
1178         {
1179           const char *p = argv[i] + 1;
1180           int c = *p;
1181           int nskip = 1;
1182
1183           if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1184             nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1185           else if (WORD_SWITCH_TAKES_ARG (p))
1186             nskip += WORD_SWITCH_TAKES_ARG (p);
1187           else if ((c == 'B' || c == 'b' || c == 'V' || c == 'x')
1188                    && p[1] == 0)
1189             nskip += 1;
1190           else if (! strcmp (p, "Xlinker"))
1191             nskip += 1;
1192
1193           /* Watch out for an option at the end of the command line that
1194              is missing arguments, and avoid skipping past the end of the
1195              command line.  */
1196           if (nskip + i > argc)
1197             nskip = argc - i;
1198
1199           while (nskip > 0)
1200             {
1201               newv[newindex++] = argv[i++];
1202               nskip--;
1203             }
1204         }
1205       else
1206         /* Ordinary operands, or +e options.  */
1207         newv[newindex++] = argv[i++];
1208     }
1209
1210   newv[newindex] = 0;
1211
1212   *argvp = newv;
1213   *argcp = newindex;
1214 }
1215 \f
1216 static char *
1217 skip_whitespace (p)
1218      char *p;
1219 {
1220   while (1)
1221     {
1222       /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1223          be considered whitespace.  */
1224       if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1225         return p + 1;
1226       else if (*p == '\n' || *p == ' ' || *p == '\t')
1227         p++;
1228       else if (*p == '#')
1229         {
1230           while (*p != '\n')
1231             p++;
1232           p++;
1233         }
1234       else
1235         break;
1236     }
1237
1238   return p;
1239 }
1240 /* Structures to keep track of prefixes to try when looking for files.  */
1241
1242 struct prefix_list
1243 {
1244   const char *prefix;         /* String to prepend to the path.  */
1245   struct prefix_list *next;   /* Next in linked list.  */
1246   int require_machine_suffix; /* Don't use without machine_suffix.  */
1247   /* 2 means try both machine_suffix and just_machine_suffix.  */
1248   int *used_flag_ptr;         /* 1 if a file was found with this prefix.  */
1249   int priority;               /* Sort key - priority within list */
1250 };
1251
1252 struct path_prefix
1253 {
1254   struct prefix_list *plist;  /* List of prefixes to try */
1255   int max_len;                /* Max length of a prefix in PLIST */
1256   const char *name;           /* Name of this list (used in config stuff) */
1257 };
1258
1259 /* List of prefixes to try when looking for executables.  */
1260
1261 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1262
1263 /* List of prefixes to try when looking for startup (crt0) files.  */
1264
1265 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1266
1267 /* List of prefixes to try when looking for include files.  */
1268
1269 static struct path_prefix include_prefixes = { 0, 0, "include" };
1270
1271 /* Suffix to attach to directories searched for commands.
1272    This looks like `MACHINE/VERSION/'.  */
1273
1274 static const char *machine_suffix = 0;
1275
1276 /* Suffix to attach to directories searched for commands.
1277    This is just `MACHINE/'.  */
1278
1279 static const char *just_machine_suffix = 0;
1280
1281 /* Adjusted value of GCC_EXEC_PREFIX envvar.  */
1282
1283 static const char *gcc_exec_prefix;
1284
1285 /* Default prefixes to attach to command names.  */
1286
1287 #ifdef CROSS_COMPILE  /* Don't use these prefixes for a cross compiler.  */
1288 #undef MD_EXEC_PREFIX
1289 #undef MD_STARTFILE_PREFIX
1290 #undef MD_STARTFILE_PREFIX_1
1291 #endif
1292
1293 /* If no prefixes defined, use the null string, which will disable them.  */
1294 #ifndef MD_EXEC_PREFIX
1295 #define MD_EXEC_PREFIX ""
1296 #endif
1297 #ifndef MD_STARTFILE_PREFIX
1298 #define MD_STARTFILE_PREFIX ""
1299 #endif
1300 #ifndef MD_STARTFILE_PREFIX_1
1301 #define MD_STARTFILE_PREFIX_1 ""
1302 #endif
1303
1304 /* Supply defaults for the standard prefixes.  */
1305
1306 #ifndef STANDARD_EXEC_PREFIX
1307 #define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
1308 #endif
1309 #ifndef STANDARD_STARTFILE_PREFIX
1310 #define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
1311 #endif
1312 #ifndef TOOLDIR_BASE_PREFIX
1313 #define TOOLDIR_BASE_PREFIX "/usr/local/"
1314 #endif
1315 #ifndef STANDARD_BINDIR_PREFIX
1316 #define STANDARD_BINDIR_PREFIX "/usr/local/bin"
1317 #endif
1318
1319 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1320 static const char *const standard_exec_prefix_1 = "/usr/lib/gcc/";
1321 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1322
1323 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1324 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1325 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1326 static const char *const standard_startfile_prefix_1 = "/lib/";
1327 static const char *const standard_startfile_prefix_2 = "/usr/lib/";
1328
1329 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1330 static const char *tooldir_prefix;
1331
1332 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1333
1334 /* Subdirectory to use for locating libraries.  Set by
1335    set_multilib_dir based on the compilation options.  */
1336
1337 static const char *multilib_dir;
1338 \f
1339 /* Structure to keep track of the specs that have been defined so far.
1340    These are accessed using %(specname) or %[specname] in a compiler
1341    or link spec.  */
1342
1343 struct spec_list
1344 {
1345                                 /* The following 2 fields must be first */
1346                                 /* to allow EXTRA_SPECS to be initialized */
1347   const char *name;             /* name of the spec.  */
1348   const char *ptr;              /* available ptr if no static pointer */
1349
1350                                 /* The following fields are not initialized */
1351                                 /* by EXTRA_SPECS */
1352   const char **ptr_spec;        /* pointer to the spec itself.  */
1353   struct spec_list *next;       /* Next spec in linked list.  */
1354   int name_len;                 /* length of the name */
1355   int alloc_p;                  /* whether string was allocated */
1356 };
1357
1358 #define INIT_STATIC_SPEC(NAME,PTR) \
1359 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1360
1361 /* List of statically defined specs.  */
1362 static struct spec_list static_specs[] =
1363 {
1364   INIT_STATIC_SPEC ("asm",                      &asm_spec),
1365   INIT_STATIC_SPEC ("asm_debug",                &asm_debug),
1366   INIT_STATIC_SPEC ("asm_final",                &asm_final_spec),
1367   INIT_STATIC_SPEC ("asm_options",              &asm_options),
1368   INIT_STATIC_SPEC ("invoke_as",                &invoke_as),
1369   INIT_STATIC_SPEC ("cpp",                      &cpp_spec),
1370   INIT_STATIC_SPEC ("cpp_options",              &cpp_options),
1371   INIT_STATIC_SPEC ("trad_capable_cpp",         &trad_capable_cpp),
1372   INIT_STATIC_SPEC ("cc1",                      &cc1_spec),
1373   INIT_STATIC_SPEC ("cc1_options",              &cc1_options),
1374   INIT_STATIC_SPEC ("cc1plus",                  &cc1plus_spec),
1375   INIT_STATIC_SPEC ("endfile",                  &endfile_spec),
1376   INIT_STATIC_SPEC ("link",                     &link_spec),
1377   INIT_STATIC_SPEC ("lib",                      &lib_spec),
1378   INIT_STATIC_SPEC ("libgcc",                   &libgcc_spec),
1379   INIT_STATIC_SPEC ("startfile",                &startfile_spec),
1380   INIT_STATIC_SPEC ("switches_need_spaces",     &switches_need_spaces),
1381   INIT_STATIC_SPEC ("signed_char",              &signed_char_spec),
1382   INIT_STATIC_SPEC ("predefines",               &cpp_predefines),
1383   INIT_STATIC_SPEC ("cross_compile",            &cross_compile),
1384   INIT_STATIC_SPEC ("version",                  &compiler_version),
1385   INIT_STATIC_SPEC ("multilib",                 &multilib_select),
1386   INIT_STATIC_SPEC ("multilib_defaults",        &multilib_defaults),
1387   INIT_STATIC_SPEC ("multilib_extra",           &multilib_extra),
1388   INIT_STATIC_SPEC ("multilib_matches",         &multilib_matches),
1389   INIT_STATIC_SPEC ("multilib_exclusions",      &multilib_exclusions),
1390   INIT_STATIC_SPEC ("linker",                   &linker_name_spec),
1391   INIT_STATIC_SPEC ("link_libgcc",              &link_libgcc_spec),
1392   INIT_STATIC_SPEC ("md_exec_prefix",           &md_exec_prefix),
1393   INIT_STATIC_SPEC ("md_startfile_prefix",      &md_startfile_prefix),
1394   INIT_STATIC_SPEC ("md_startfile_prefix_1",    &md_startfile_prefix_1),
1395 };
1396
1397 #ifdef EXTRA_SPECS              /* additional specs needed */
1398 /* Structure to keep track of just the first two args of a spec_list.
1399    That is all that the EXTRA_SPECS macro gives us.  */
1400 struct spec_list_1
1401 {
1402   const char *const name;
1403   const char *const ptr;
1404 };
1405
1406 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1407 static struct spec_list *extra_specs = (struct spec_list *) 0;
1408 #endif
1409
1410 /* List of dynamically allocates specs that have been defined so far.  */
1411
1412 static struct spec_list *specs = (struct spec_list *) 0;
1413 \f
1414 /* Add appropriate libgcc specs to OBSTACK, taking into account
1415    various permutations of -shared-libgcc, -shared, and such.  */
1416
1417 #ifdef ENABLE_SHARED_LIBGCC
1418 static void
1419 init_gcc_specs (obstack, shared_name, static_name, eh_name)
1420      struct obstack *obstack;
1421      const char *shared_name;
1422      const char *static_name;
1423      const char *eh_name;
1424 {
1425   char buffer[128];
1426   const char *p;
1427
1428   /* If we see -shared-libgcc, then use the shared version.  */
1429   sprintf (buffer, "%%{shared-libgcc:%s %s}", shared_name, static_name);
1430   obstack_grow (obstack, buffer, strlen (buffer));
1431   /* If we see -static-libgcc, then use the static version.  */
1432   sprintf (buffer, "%%{static-libgcc:%s %s}", static_name, eh_name);
1433   obstack_grow (obstack, buffer, strlen (buffer));
1434   /* Otherwise, if we see -shared, then use the shared version
1435      if using EH registration routines or static version without
1436      exception handling routines otherwise.  */
1437   p = "%{!shared-libgcc:%{!static-libgcc:%{shared:";
1438   obstack_grow (obstack, p, strlen (p));
1439 #ifdef LINK_EH_SPEC
1440   sprintf (buffer, "%s}}}", static_name);
1441 #else
1442   sprintf (buffer, "%s %s}}}", shared_name, static_name);
1443 #endif
1444   obstack_grow (obstack, buffer, strlen (buffer));
1445   /* Otherwise, use the static version.  */
1446   sprintf (buffer, 
1447            "%%{!shared-libgcc:%%{!static-libgcc:%%{!shared:%s %s}}}", 
1448            static_name, eh_name);
1449   obstack_grow (obstack, buffer, strlen (buffer));
1450 }
1451 #endif /* ENABLE_SHARED_LIBGCC */
1452
1453 /* Initialize the specs lookup routines.  */
1454
1455 static void
1456 init_spec ()
1457 {
1458   struct spec_list *next = (struct spec_list *) 0;
1459   struct spec_list *sl   = (struct spec_list *) 0;
1460   int i;
1461
1462   if (specs)
1463     return;                     /* Already initialized.  */
1464
1465   if (verbose_flag)
1466     notice ("Using builtin specs.\n");
1467
1468 #ifdef EXTRA_SPECS
1469   extra_specs = (struct spec_list *)
1470     xcalloc (sizeof (struct spec_list), ARRAY_SIZE (extra_specs_1));
1471
1472   for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1473     {
1474       sl = &extra_specs[i];
1475       sl->name = extra_specs_1[i].name;
1476       sl->ptr = extra_specs_1[i].ptr;
1477       sl->next = next;
1478       sl->name_len = strlen (sl->name);
1479       sl->ptr_spec = &sl->ptr;
1480       next = sl;
1481     }
1482 #endif
1483
1484   for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1485     {
1486       sl = &static_specs[i];
1487       sl->next = next;
1488       next = sl;
1489     }
1490
1491 #ifdef ENABLE_SHARED_LIBGCC
1492   /* ??? If neither -shared-libgcc nor --static-libgcc was
1493      seen, then we should be making an educated guess.  Some proposed
1494      heuristics for ELF include:
1495
1496         (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1497             program will be doing dynamic loading, which will likely
1498             need the shared libgcc.
1499
1500         (2) If "-ldl", then it's also a fair bet that we're doing
1501             dynamic loading.
1502
1503         (3) For each ET_DYN we're linking against (either through -lfoo
1504             or /some/path/foo.so), check to see whether it or one of
1505             its dependencies depends on a shared libgcc.
1506
1507         (4) If "-shared"
1508
1509             If the runtime is fixed to look for program headers instead
1510             of calling __register_frame_info at all, for each object,
1511             use the shared libgcc if any EH symbol referenced.
1512
1513             If crtstuff is fixed to not invoke __register_frame_info
1514             automatically, for each object, use the shared libgcc if
1515             any non-empty unwind section found.
1516
1517      Doing any of this probably requires invoking an external program to
1518      do the actual object file scanning.  */
1519   {
1520     const char *p = libgcc_spec;
1521     int in_sep = 1;
1522  
1523     /* Transform the extant libgcc_spec into one that uses the shared libgcc
1524        when given the proper command line arguments.  */
1525     while (*p)
1526       {
1527         if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1528           {
1529             init_gcc_specs (&obstack,
1530 #ifdef NO_SHARED_LIBGCC_MULTILIB
1531                             "-lgcc_s"
1532 #else
1533                             "-lgcc_s%M"
1534 #endif
1535                             ,
1536                             "-lgcc",
1537                             "-lgcc_eh");
1538             p += 5;
1539             in_sep = 0;
1540           }
1541         else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1542           {
1543             /* Ug.  We don't know shared library extensions.  Hope that
1544                systems that use this form don't do shared libraries.  */
1545             init_gcc_specs (&obstack,
1546 #ifdef NO_SHARED_LIBGCC_MULTILIB
1547                             "-lgcc_s"
1548 #else
1549                             "-lgcc_s%M"
1550 #endif
1551                             ,
1552                             "libgcc.a%s",
1553                             "libgcc_eh.a%s");
1554             p += 10;
1555             in_sep = 0;
1556           }
1557         else
1558           {
1559             obstack_1grow (&obstack, *p);
1560             in_sep = (*p == ' ');
1561             p += 1;
1562           }
1563       }
1564
1565     obstack_1grow (&obstack, '\0');
1566     libgcc_spec = obstack_finish (&obstack);
1567   }
1568 #endif
1569 #ifdef USE_AS_TRADITIONAL_FORMAT
1570   /* Prepend "--traditional-format" to whatever asm_spec we had before.  */
1571   {
1572     static const char tf[] = "--traditional-format ";
1573     obstack_grow (&obstack, tf, sizeof(tf) - 1);
1574     obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1575     asm_spec = obstack_finish (&obstack);
1576   }
1577 #endif
1578 #ifdef LINK_EH_SPEC
1579   /* Prepend LINK_EH_SPEC to whatever link_spec we had before.  */
1580   obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1581   obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1582   link_spec = obstack_finish (&obstack);
1583 #endif
1584
1585   specs = sl;
1586 }
1587 \f
1588 /* Change the value of spec NAME to SPEC.  If SPEC is empty, then the spec is
1589    removed; If the spec starts with a + then SPEC is added to the end of the
1590    current spec.  */
1591
1592 static void
1593 set_spec (name, spec)
1594      const char *name;
1595      const char *spec;
1596 {
1597   struct spec_list *sl;
1598   const char *old_spec;
1599   int name_len = strlen (name);
1600   int i;
1601
1602   /* If this is the first call, initialize the statically allocated specs.  */
1603   if (!specs)
1604     {
1605       struct spec_list *next = (struct spec_list *) 0;
1606       for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1607         {
1608           sl = &static_specs[i];
1609           sl->next = next;
1610           next = sl;
1611         }
1612       specs = sl;
1613     }
1614
1615   /* See if the spec already exists.  */
1616   for (sl = specs; sl; sl = sl->next)
1617     if (name_len == sl->name_len && !strcmp (sl->name, name))
1618       break;
1619
1620   if (!sl)
1621     {
1622       /* Not found - make it.  */
1623       sl = (struct spec_list *) xmalloc (sizeof (struct spec_list));
1624       sl->name = xstrdup (name);
1625       sl->name_len = name_len;
1626       sl->ptr_spec = &sl->ptr;
1627       sl->alloc_p = 0;
1628       *(sl->ptr_spec) = "";
1629       sl->next = specs;
1630       specs = sl;
1631     }
1632
1633   old_spec = *(sl->ptr_spec);
1634   *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1635                      ? concat (old_spec, spec + 1, NULL)
1636                      : xstrdup (spec));
1637
1638 #ifdef DEBUG_SPECS
1639   if (verbose_flag)
1640     notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1641 #endif
1642
1643   /* Free the old spec.  */
1644   if (old_spec && sl->alloc_p)
1645     free ((PTR) old_spec);
1646
1647   sl->alloc_p = 1;
1648 }
1649 \f
1650 /* Accumulate a command (program name and args), and run it.  */
1651
1652 /* Vector of pointers to arguments in the current line of specifications.  */
1653
1654 static const char **argbuf;
1655
1656 /* Number of elements allocated in argbuf.  */
1657
1658 static int argbuf_length;
1659
1660 /* Number of elements in argbuf currently in use (containing args).  */
1661
1662 static int argbuf_index;
1663
1664 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1665    temp file.  If the HOST_BIT_BUCKET is used for %j, no entry is made for
1666    it here.  */
1667
1668 static struct temp_name {
1669   const char *suffix;   /* suffix associated with the code.  */
1670   int length;           /* strlen (suffix).  */
1671   int unique;           /* Indicates whether %g or %u/%U was used.  */
1672   const char *filename; /* associated filename.  */
1673   int filename_length;  /* strlen (filename).  */
1674   struct temp_name *next;
1675 } *temp_names;
1676
1677 /* Number of commands executed so far.  */
1678
1679 static int execution_count;
1680
1681 /* Number of commands that exited with a signal.  */
1682
1683 static int signal_count;
1684
1685 /* Name with which this program was invoked.  */
1686
1687 static const char *programname;
1688 \f
1689 /* Clear out the vector of arguments (after a command is executed).  */
1690
1691 static void
1692 clear_args ()
1693 {
1694   argbuf_index = 0;
1695 }
1696
1697 /* Add one argument to the vector at the end.
1698    This is done when a space is seen or at the end of the line.
1699    If DELETE_ALWAYS is nonzero, the arg is a filename
1700     and the file should be deleted eventually.
1701    If DELETE_FAILURE is nonzero, the arg is a filename
1702     and the file should be deleted if this compilation fails.  */
1703
1704 static void
1705 store_arg (arg, delete_always, delete_failure)
1706      const char *arg;
1707      int delete_always, delete_failure;
1708 {
1709   if (argbuf_index + 1 == argbuf_length)
1710     argbuf
1711       = (const char **) xrealloc (argbuf,
1712                                   (argbuf_length *= 2) * sizeof (const char *));
1713
1714   argbuf[argbuf_index++] = arg;
1715   argbuf[argbuf_index] = 0;
1716
1717   if (delete_always || delete_failure)
1718     record_temp_file (arg, delete_always, delete_failure);
1719 }
1720 \f
1721 /* Load specs from a file name named FILENAME, replacing occurrences of
1722    various different types of line-endings, \r\n, \n\r and just \r, with
1723    a single \n.  */
1724
1725 static char *
1726 load_specs (filename)
1727      const char *filename;
1728 {
1729   int desc;
1730   int readlen;
1731   struct stat statbuf;
1732   char *buffer;
1733   char *buffer_p;
1734   char *specs;
1735   char *specs_p;
1736
1737   if (verbose_flag)
1738     notice ("Reading specs from %s\n", filename);
1739
1740   /* Open and stat the file.  */
1741   desc = open (filename, O_RDONLY, 0);
1742   if (desc < 0)
1743     pfatal_with_name (filename);
1744   if (stat (filename, &statbuf) < 0)
1745     pfatal_with_name (filename);
1746
1747   /* Read contents of file into BUFFER.  */
1748   buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1749   readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1750   if (readlen < 0)
1751     pfatal_with_name (filename);
1752   buffer[readlen] = 0;
1753   close (desc);
1754
1755   specs = xmalloc (readlen + 1);
1756   specs_p = specs;
1757   for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1758     {
1759       int skip = 0;
1760       char c = *buffer_p;
1761       if (c == '\r')
1762         {
1763           if (buffer_p > buffer && *(buffer_p - 1) == '\n')     /* \n\r */
1764             skip = 1;
1765           else if (*(buffer_p + 1) == '\n')                     /* \r\n */
1766             skip = 1;
1767           else                                                  /* \r */
1768             c = '\n';
1769         }
1770       if (! skip)
1771         *specs_p++ = c;
1772     }
1773   *specs_p = '\0';
1774
1775   free (buffer);
1776   return (specs);
1777 }
1778
1779 /* Read compilation specs from a file named FILENAME,
1780    replacing the default ones.
1781
1782    A suffix which starts with `*' is a definition for
1783    one of the machine-specific sub-specs.  The "suffix" should be
1784    *asm, *cc1, *cpp, *link, *startfile, *signed_char, etc.
1785    The corresponding spec is stored in asm_spec, etc.,
1786    rather than in the `compilers' vector.
1787
1788    Anything invalid in the file is a fatal error.  */
1789
1790 static void
1791 read_specs (filename, main_p)
1792      const char *filename;
1793      int main_p;
1794 {
1795   char *buffer;
1796   char *p;
1797
1798   buffer = load_specs (filename);
1799
1800   /* Scan BUFFER for specs, putting them in the vector.  */
1801   p = buffer;
1802   while (1)
1803     {
1804       char *suffix;
1805       char *spec;
1806       char *in, *out, *p1, *p2, *p3;
1807
1808       /* Advance P in BUFFER to the next nonblank nocomment line.  */
1809       p = skip_whitespace (p);
1810       if (*p == 0)
1811         break;
1812
1813       /* Is this a special command that starts with '%'? */
1814       /* Don't allow this for the main specs file, since it would
1815          encourage people to overwrite it.  */
1816       if (*p == '%' && !main_p)
1817         {
1818           p1 = p;
1819           while (*p && *p != '\n')
1820             p++;
1821
1822           /* Skip '\n'.  */
1823           p++;
1824
1825           if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1826               && (p1[sizeof "%include" - 1] == ' '
1827                   || p1[sizeof "%include" - 1] == '\t'))
1828             {
1829               char *new_filename;
1830
1831               p1 += sizeof ("%include");
1832               while (*p1 == ' ' || *p1 == '\t')
1833                 p1++;
1834
1835               if (*p1++ != '<' || p[-2] != '>')
1836                 fatal ("specs %%include syntax malformed after %ld characters",
1837                        (long) (p1 - buffer + 1));
1838
1839               p[-2] = '\0';
1840               new_filename = find_a_file (&startfile_prefixes, p1, R_OK);
1841               read_specs (new_filename ? new_filename : p1, FALSE);
1842               continue;
1843             }
1844           else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1845                    && (p1[sizeof "%include_noerr" - 1] == ' '
1846                        || p1[sizeof "%include_noerr" - 1] == '\t'))
1847             {
1848               char *new_filename;
1849
1850               p1 += sizeof "%include_noerr";
1851               while (*p1 == ' ' || *p1 == '\t')
1852                 p1++;
1853
1854               if (*p1++ != '<' || p[-2] != '>')
1855                 fatal ("specs %%include syntax malformed after %ld characters",
1856                        (long) (p1 - buffer + 1));
1857
1858               p[-2] = '\0';
1859               new_filename = find_a_file (&startfile_prefixes, p1, R_OK);
1860               if (new_filename)
1861                 read_specs (new_filename, FALSE);
1862               else if (verbose_flag)
1863                 notice ("could not find specs file %s\n", p1);
1864               continue;
1865             }
1866           else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1867                    && (p1[sizeof "%rename" - 1] == ' '
1868                        || p1[sizeof "%rename" - 1] == '\t'))
1869             {
1870               int name_len;
1871               struct spec_list *sl;
1872
1873               /* Get original name */
1874               p1 += sizeof "%rename";
1875               while (*p1 == ' ' || *p1 == '\t')
1876                 p1++;
1877
1878               if (! ISALPHA ((unsigned char) *p1))
1879                 fatal ("specs %%rename syntax malformed after %ld characters",
1880                        (long) (p1 - buffer));
1881
1882               p2 = p1;
1883               while (*p2 && !ISSPACE ((unsigned char) *p2))
1884                 p2++;
1885
1886               if (*p2 != ' ' && *p2 != '\t')
1887                 fatal ("specs %%rename syntax malformed after %ld characters",
1888                        (long) (p2 - buffer));
1889
1890               name_len = p2 - p1;
1891               *p2++ = '\0';
1892               while (*p2 == ' ' || *p2 == '\t')
1893                 p2++;
1894
1895               if (! ISALPHA ((unsigned char) *p2))
1896                 fatal ("specs %%rename syntax malformed after %ld characters",
1897                        (long) (p2 - buffer));
1898
1899               /* Get new spec name.  */
1900               p3 = p2;
1901               while (*p3 && !ISSPACE ((unsigned char) *p3))
1902                 p3++;
1903
1904               if (p3 != p - 1)
1905                 fatal ("specs %%rename syntax malformed after %ld characters",
1906                        (long) (p3 - buffer));
1907               *p3 = '\0';
1908
1909               for (sl = specs; sl; sl = sl->next)
1910                 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1911                   break;
1912
1913               if (!sl)
1914                 fatal ("specs %s spec was not found to be renamed", p1);
1915
1916               if (strcmp (p1, p2) == 0)
1917                 continue;
1918
1919               if (verbose_flag)
1920                 {
1921                   notice ("rename spec %s to %s\n", p1, p2);
1922 #ifdef DEBUG_SPECS
1923                   notice ("spec is '%s'\n\n", *(sl->ptr_spec));
1924 #endif
1925                 }
1926
1927               set_spec (p2, *(sl->ptr_spec));
1928               if (sl->alloc_p)
1929                 free ((PTR) *(sl->ptr_spec));
1930
1931               *(sl->ptr_spec) = "";
1932               sl->alloc_p = 0;
1933               continue;
1934             }
1935           else
1936             fatal ("specs unknown %% command after %ld characters",
1937                    (long) (p1 - buffer));
1938         }
1939
1940       /* Find the colon that should end the suffix.  */
1941       p1 = p;
1942       while (*p1 && *p1 != ':' && *p1 != '\n')
1943         p1++;
1944
1945       /* The colon shouldn't be missing.  */
1946       if (*p1 != ':')
1947         fatal ("specs file malformed after %ld characters",
1948                (long) (p1 - buffer));
1949
1950       /* Skip back over trailing whitespace.  */
1951       p2 = p1;
1952       while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1953         p2--;
1954
1955       /* Copy the suffix to a string.  */
1956       suffix = save_string (p, p2 - p);
1957       /* Find the next line.  */
1958       p = skip_whitespace (p1 + 1);
1959       if (p[1] == 0)
1960         fatal ("specs file malformed after %ld characters",
1961                (long) (p - buffer));
1962
1963       p1 = p;
1964       /* Find next blank line or end of string.  */
1965       while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1966         p1++;
1967
1968       /* Specs end at the blank line and do not include the newline.  */
1969       spec = save_string (p, p1 - p);
1970       p = p1;
1971
1972       /* Delete backslash-newline sequences from the spec.  */
1973       in = spec;
1974       out = spec;
1975       while (*in != 0)
1976         {
1977           if (in[0] == '\\' && in[1] == '\n')
1978             in += 2;
1979           else if (in[0] == '#')
1980             while (*in && *in != '\n')
1981               in++;
1982
1983           else
1984             *out++ = *in++;
1985         }
1986       *out = 0;
1987
1988       if (suffix[0] == '*')
1989         {
1990           if (! strcmp (suffix, "*link_command"))
1991             link_command_spec = spec;
1992           else
1993             set_spec (suffix + 1, spec);
1994         }
1995       else
1996         {
1997           /* Add this pair to the vector.  */
1998           compilers
1999             = ((struct compiler *)
2000                xrealloc (compilers,
2001                          (n_compilers + 2) * sizeof (struct compiler)));
2002
2003           compilers[n_compilers].suffix = suffix;
2004           compilers[n_compilers].spec = spec;
2005           n_compilers++;
2006           memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2007         }
2008
2009       if (*suffix == 0)
2010         link_command_spec = spec;
2011     }
2012
2013   if (link_command_spec == 0)
2014     fatal ("spec file has no spec for linking");
2015 }
2016 \f
2017 /* Record the names of temporary files we tell compilers to write,
2018    and delete them at the end of the run.  */
2019
2020 /* This is the common prefix we use to make temp file names.
2021    It is chosen once for each run of this program.
2022    It is substituted into a spec by %g or %j.
2023    Thus, all temp file names contain this prefix.
2024    In practice, all temp file names start with this prefix.
2025
2026    This prefix comes from the envvar TMPDIR if it is defined;
2027    otherwise, from the P_tmpdir macro if that is defined;
2028    otherwise, in /usr/tmp or /tmp;
2029    or finally the current directory if all else fails.  */
2030
2031 static const char *temp_filename;
2032
2033 /* Length of the prefix.  */
2034
2035 static int temp_filename_length;
2036
2037 /* Define the list of temporary files to delete.  */
2038
2039 struct temp_file
2040 {
2041   const char *name;
2042   struct temp_file *next;
2043 };
2044
2045 /* Queue of files to delete on success or failure of compilation.  */
2046 static struct temp_file *always_delete_queue;
2047 /* Queue of files to delete on failure of compilation.  */
2048 static struct temp_file *failure_delete_queue;
2049
2050 /* Record FILENAME as a file to be deleted automatically.
2051    ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2052    otherwise delete it in any case.
2053    FAIL_DELETE nonzero means delete it if a compilation step fails;
2054    otherwise delete it in any case.  */
2055
2056 void
2057 record_temp_file (filename, always_delete, fail_delete)
2058      const char *filename;
2059      int always_delete;
2060      int fail_delete;
2061 {
2062   char *const name = xstrdup (filename);
2063
2064   if (always_delete)
2065     {
2066       struct temp_file *temp;
2067       for (temp = always_delete_queue; temp; temp = temp->next)
2068         if (! strcmp (name, temp->name))
2069           goto already1;
2070
2071       temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2072       temp->next = always_delete_queue;
2073       temp->name = name;
2074       always_delete_queue = temp;
2075
2076     already1:;
2077     }
2078
2079   if (fail_delete)
2080     {
2081       struct temp_file *temp;
2082       for (temp = failure_delete_queue; temp; temp = temp->next)
2083         if (! strcmp (name, temp->name))
2084           goto already2;
2085
2086       temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2087       temp->next = failure_delete_queue;
2088       temp->name = name;
2089       failure_delete_queue = temp;
2090
2091     already2:;
2092     }
2093 }
2094
2095 /* Delete all the temporary files whose names we previously recorded.  */
2096
2097 static void
2098 delete_if_ordinary (name)
2099      const char *name;
2100 {
2101   struct stat st;
2102 #ifdef DEBUG
2103   int i, c;
2104
2105   printf ("Delete %s? (y or n) ", name);
2106   fflush (stdout);
2107   i = getchar ();
2108   if (i != '\n')
2109     while ((c = getchar ()) != '\n' && c != EOF)
2110       ;
2111
2112   if (i == 'y' || i == 'Y')
2113 #endif /* DEBUG */
2114     if (stat (name, &st) >= 0 && S_ISREG (st.st_mode))
2115       if (unlink (name) < 0)
2116         if (verbose_flag)
2117           perror_with_name (name);
2118 }
2119
2120 static void
2121 delete_temp_files ()
2122 {
2123   struct temp_file *temp;
2124
2125   for (temp = always_delete_queue; temp; temp = temp->next)
2126     delete_if_ordinary (temp->name);
2127   always_delete_queue = 0;
2128 }
2129
2130 /* Delete all the files to be deleted on error.  */
2131
2132 static void
2133 delete_failure_queue ()
2134 {
2135   struct temp_file *temp;
2136
2137   for (temp = failure_delete_queue; temp; temp = temp->next)
2138     delete_if_ordinary (temp->name);
2139 }
2140
2141 static void
2142 clear_failure_queue ()
2143 {
2144   failure_delete_queue = 0;
2145 }
2146 \f
2147 /* Build a list of search directories from PATHS.
2148    PREFIX is a string to prepend to the list.
2149    If CHECK_DIR_P is non-zero we ensure the directory exists.
2150    This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2151    It is also used by the --print-search-dirs flag.  */
2152
2153 static char *
2154 build_search_list (paths, prefix, check_dir_p)
2155      struct path_prefix *paths;
2156      const char *prefix;
2157      int check_dir_p;
2158 {
2159   int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2160   int just_suffix_len
2161     = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2162   int first_time = TRUE;
2163   struct prefix_list *pprefix;
2164
2165   obstack_grow (&collect_obstack, prefix, strlen (prefix));
2166   obstack_1grow (&collect_obstack, '=');
2167
2168   for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2169     {
2170       int len = strlen (pprefix->prefix);
2171
2172       if (machine_suffix
2173           && (! check_dir_p
2174               || is_directory (pprefix->prefix, machine_suffix, 0)))
2175         {
2176           if (!first_time)
2177             obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2178
2179           first_time = FALSE;
2180           obstack_grow (&collect_obstack, pprefix->prefix, len);
2181           obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2182         }
2183
2184       if (just_machine_suffix
2185           && pprefix->require_machine_suffix == 2
2186           && (! check_dir_p
2187               || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2188         {
2189           if (! first_time)
2190             obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2191
2192           first_time = FALSE;
2193           obstack_grow (&collect_obstack, pprefix->prefix, len);
2194           obstack_grow (&collect_obstack, just_machine_suffix,
2195                         just_suffix_len);
2196         }
2197
2198       if (! pprefix->require_machine_suffix)
2199         {
2200           if (! first_time)
2201             obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2202
2203           first_time = FALSE;
2204           obstack_grow (&collect_obstack, pprefix->prefix, len);
2205         }
2206     }
2207
2208   obstack_1grow (&collect_obstack, '\0');
2209   return obstack_finish (&collect_obstack);
2210 }
2211
2212 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2213    for collect.  */
2214
2215 static void
2216 putenv_from_prefixes (paths, env_var)
2217      struct path_prefix *paths;
2218      const char *env_var;
2219 {
2220   putenv (build_search_list (paths, env_var, 1));
2221 }
2222 \f
2223 #ifndef VMS
2224
2225 /* FIXME: the location independence code for VMS is hairier than this,
2226    and hasn't been written.  */
2227
2228 /* Split a filename into component directories.  */
2229
2230 static char **
2231 split_directories (name, ptr_num_dirs)
2232      const char *name;
2233      int *ptr_num_dirs;
2234 {
2235   int num_dirs = 0;
2236   char **dirs;
2237   const char *p, *q;
2238   int ch;
2239
2240   /* Count the number of directories.  Special case MSDOS disk names as part
2241      of the initial directory.  */
2242   p = name;
2243 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2244   if (name[1] == ':' && IS_DIR_SEPARATOR (name[2]))
2245     {
2246       p += 3;
2247       num_dirs++;
2248     }
2249 #endif /* HAVE_DOS_BASED_FILE_SYSTEM */
2250
2251   while ((ch = *p++) != '\0')
2252     {
2253       if (IS_DIR_SEPARATOR (ch))
2254         {
2255           num_dirs++;
2256           while (IS_DIR_SEPARATOR (*p))
2257             p++;
2258         }
2259     }
2260
2261   dirs = (char **) xmalloc (sizeof (char *) * (num_dirs + 2));
2262
2263   /* Now copy the directory parts.  */
2264   num_dirs = 0;
2265   p = name;
2266 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2267   if (name[1] == ':' && IS_DIR_SEPARATOR (name[2]))
2268     {
2269       dirs[num_dirs++] = save_string (p, 3);
2270       p += 3;
2271     }
2272 #endif /* HAVE_DOS_BASED_FILE_SYSTEM */
2273
2274   q = p;
2275   while ((ch = *p++) != '\0')
2276     {
2277       if (IS_DIR_SEPARATOR (ch))
2278         {
2279           while (IS_DIR_SEPARATOR (*p))
2280             p++;
2281
2282           dirs[num_dirs++] = save_string (q, p - q);
2283           q = p;
2284         }
2285     }
2286
2287   if (p - 1 - q > 0)
2288     dirs[num_dirs++] = save_string (q, p - 1 - q);
2289
2290   dirs[num_dirs] = NULL;
2291   if (ptr_num_dirs)
2292     *ptr_num_dirs = num_dirs;
2293
2294   return dirs;
2295 }
2296
2297 /* Release storage held by split directories.  */
2298
2299 static void
2300 free_split_directories (dirs)
2301      char **dirs;
2302 {
2303   int i = 0;
2304
2305   while (dirs[i] != NULL)
2306     free (dirs[i++]);
2307
2308   free ((char *) dirs);
2309 }
2310
2311 /* Given three strings PROGNAME, BIN_PREFIX, PREFIX, return a string that gets
2312    to PREFIX starting with the directory portion of PROGNAME and a relative
2313    pathname of the difference between BIN_PREFIX and PREFIX.
2314
2315    For example, if BIN_PREFIX is /alpha/beta/gamma/gcc/delta, PREFIX is
2316    /alpha/beta/gamma/omega/, and PROGNAME is /red/green/blue/gcc, then this
2317    function will return /red/green/blue/../omega.
2318
2319    If no relative prefix can be found, return NULL.  */
2320
2321 static char *
2322 make_relative_prefix (progname, bin_prefix, prefix)
2323      const char *progname;
2324      const char *bin_prefix;
2325      const char *prefix;
2326 {
2327   char **prog_dirs, **bin_dirs, **prefix_dirs;
2328   int prog_num, bin_num, prefix_num, std_loc_p;
2329   int i, n, common;
2330
2331   prog_dirs = split_directories (progname, &prog_num);
2332   bin_dirs = split_directories (bin_prefix, &bin_num);
2333
2334   /* If there is no full pathname, try to find the program by checking in each
2335      of the directories specified in the PATH environment variable.  */
2336   if (prog_num == 1)
2337     {
2338       char *temp;
2339
2340       GET_ENV_PATH_LIST (temp, "PATH");
2341       if (temp)
2342         {
2343           char *startp, *endp, *nstore;
2344           size_t prefixlen = strlen (temp) + 1;
2345           if (prefixlen < 2)
2346             prefixlen = 2;
2347
2348           nstore = (char *) alloca (prefixlen + strlen (progname) + 1);
2349
2350           startp = endp = temp;
2351           while (1)
2352             {
2353               if (*endp == PATH_SEPARATOR || *endp == 0)
2354                 {
2355                   if (endp == startp)
2356                     {
2357                       nstore[0] = '.';
2358                       nstore[1] = DIR_SEPARATOR;
2359                       nstore[2] = '\0';
2360                     }
2361                   else
2362                     {
2363                       strncpy (nstore, startp, endp - startp);
2364                       if (! IS_DIR_SEPARATOR (endp[-1]))
2365                         {
2366                           nstore[endp - startp] = DIR_SEPARATOR;
2367                           nstore[endp - startp + 1] = 0;
2368                         }
2369                       else
2370                         nstore[endp - startp] = 0;
2371                     }
2372                   strcat (nstore, progname);
2373                   if (! access (nstore, X_OK)
2374 #ifdef HAVE_HOST_EXECUTABLE_SUFFIX
2375                       || ! access (strcat (nstore, HOST_EXECUTABLE_SUFFIX), X_OK)
2376 #endif
2377                       )
2378                     {
2379                       free_split_directories (prog_dirs);
2380                       progname = nstore;
2381                       prog_dirs = split_directories (progname, &prog_num);
2382                       break;
2383                     }
2384
2385                   if (*endp == 0)
2386                     break;
2387                   endp = startp = endp + 1;
2388                 }
2389               else
2390                 endp++;
2391             }
2392         }
2393     }
2394
2395   /* Remove the program name from comparison of directory names.  */
2396   prog_num--;
2397
2398   /* Determine if the compiler is installed in the standard location, and if
2399      so, we don't need to specify relative directories.  Also, if argv[0]
2400      doesn't contain any directory specifiers, there is not much we can do.  */
2401   std_loc_p = 0;
2402   if (prog_num == bin_num)
2403     {
2404       for (i = 0; i < bin_num; i++)
2405         {
2406           if (strcmp (prog_dirs[i], bin_dirs[i]) != 0)
2407             break;
2408         }
2409
2410       if (prog_num <= 0 || i == bin_num)
2411         {
2412           std_loc_p = 1;
2413           free_split_directories (prog_dirs);
2414           free_split_directories (bin_dirs);
2415           prog_dirs = bin_dirs = (char **) 0;
2416           return NULL;
2417         }
2418     }
2419
2420   prefix_dirs = split_directories (prefix, &prefix_num);
2421
2422   /* Find how many directories are in common between bin_prefix & prefix.  */
2423   n = (prefix_num < bin_num) ? prefix_num : bin_num;
2424   for (common = 0; common < n; common++)
2425     {
2426       if (strcmp (bin_dirs[common], prefix_dirs[common]) != 0)
2427         break;
2428     }
2429
2430   /* If there are no common directories, there can be no relative prefix.  */
2431   if (common == 0)
2432     {
2433       free_split_directories (prog_dirs);
2434       free_split_directories (bin_dirs);
2435       free_split_directories (prefix_dirs);
2436       return NULL;
2437     }
2438
2439   /* Build up the pathnames in argv[0].  */
2440   for (i = 0; i < prog_num; i++)
2441     obstack_grow (&obstack, prog_dirs[i], strlen (prog_dirs[i]));
2442
2443   /* Now build up the ..'s.  */
2444   for (i = common; i < n; i++)
2445     {
2446       obstack_grow (&obstack, DIR_UP, sizeof (DIR_UP) - 1);
2447       obstack_1grow (&obstack, DIR_SEPARATOR);
2448     }
2449
2450   /* Put in directories to move over to prefix.  */
2451   for (i = common; i < prefix_num; i++)
2452     obstack_grow (&obstack, prefix_dirs[i], strlen (prefix_dirs[i]));
2453
2454   free_split_directories (prog_dirs);
2455   free_split_directories (bin_dirs);
2456   free_split_directories (prefix_dirs);
2457
2458   obstack_1grow (&obstack, '\0');
2459   return obstack_finish (&obstack);
2460 }
2461 #endif /* VMS */
2462 \f
2463 /* Check whether NAME can be accessed in MODE.  This is like access,
2464    except that it never considers directories to be executable.  */
2465
2466 static int
2467 access_check (name, mode)
2468      const char *name;
2469      int mode;
2470 {
2471   if (mode == X_OK)
2472     {
2473       struct stat st;
2474
2475       if (stat (name, &st) < 0
2476           || S_ISDIR (st.st_mode))
2477         return -1;
2478     }
2479
2480   return access (name, mode);
2481 }
2482
2483 /* Search for NAME using the prefix list PREFIXES.  MODE is passed to
2484    access to check permissions.
2485    Return 0 if not found, otherwise return its name, allocated with malloc.  */
2486
2487 static char *
2488 find_a_file (pprefix, name, mode)
2489      struct path_prefix *pprefix;
2490      const char *name;
2491      int mode;
2492 {
2493   char *temp;
2494   const char *const file_suffix =
2495     ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2496   struct prefix_list *pl;
2497   int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2498
2499 #ifdef DEFAULT_ASSEMBLER
2500   if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2501     return xstrdup (DEFAULT_ASSEMBLER);
2502 #endif
2503
2504 #ifdef DEFAULT_LINKER
2505   if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2506     return xstrdup (DEFAULT_LINKER);
2507 #endif
2508
2509   if (machine_suffix)
2510     len += strlen (machine_suffix);
2511
2512   temp = xmalloc (len);
2513
2514   /* Determine the filename to execute (special case for absolute paths).  */
2515
2516   if (IS_ABSOLUTE_PATHNAME (name))
2517     {
2518       if (access (name, mode) == 0)
2519         {
2520           strcpy (temp, name);
2521           return temp;
2522         }
2523     }
2524   else
2525     for (pl = pprefix->plist; pl; pl = pl->next)
2526       {
2527         if (machine_suffix)
2528           {
2529             /* Some systems have a suffix for executable files.
2530                So try appending that first.  */
2531             if (file_suffix[0] != 0)
2532               {
2533                 strcpy (temp, pl->prefix);
2534                 strcat (temp, machine_suffix);
2535                 strcat (temp, name);
2536                 strcat (temp, file_suffix);
2537                 if (access_check (temp, mode) == 0)
2538                   {
2539                     if (pl->used_flag_ptr != 0)
2540                       *pl->used_flag_ptr = 1;
2541                     return temp;
2542                   }
2543               }
2544
2545             /* Now try just the name.  */
2546             strcpy (temp, pl->prefix);
2547             strcat (temp, machine_suffix);
2548             strcat (temp, name);
2549             if (access_check (temp, mode) == 0)
2550               {
2551                 if (pl->used_flag_ptr != 0)
2552                   *pl->used_flag_ptr = 1;
2553                 return temp;
2554               }
2555           }
2556
2557         /* Certain prefixes are tried with just the machine type,
2558            not the version.  This is used for finding as, ld, etc.  */
2559         if (just_machine_suffix && pl->require_machine_suffix == 2)
2560           {
2561             /* Some systems have a suffix for executable files.
2562                So try appending that first.  */
2563             if (file_suffix[0] != 0)
2564               {
2565                 strcpy (temp, pl->prefix);
2566                 strcat (temp, just_machine_suffix);
2567                 strcat (temp, name);
2568                 strcat (temp, file_suffix);
2569                 if (access_check (temp, mode) == 0)
2570                   {
2571                     if (pl->used_flag_ptr != 0)
2572                       *pl->used_flag_ptr = 1;
2573                     return temp;
2574                   }
2575               }
2576
2577             strcpy (temp, pl->prefix);
2578             strcat (temp, just_machine_suffix);
2579             strcat (temp, name);
2580             if (access_check (temp, mode) == 0)
2581               {
2582                 if (pl->used_flag_ptr != 0)
2583                   *pl->used_flag_ptr = 1;
2584                 return temp;
2585               }
2586           }
2587
2588         /* Certain prefixes can't be used without the machine suffix
2589            when the machine or version is explicitly specified.  */
2590         if (! pl->require_machine_suffix)
2591           {
2592             /* Some systems have a suffix for executable files.
2593                So try appending that first.  */
2594             if (file_suffix[0] != 0)
2595               {
2596                 strcpy (temp, pl->prefix);
2597                 strcat (temp, name);
2598                 strcat (temp, file_suffix);
2599                 if (access_check (temp, mode) == 0)
2600                   {
2601                     if (pl->used_flag_ptr != 0)
2602                       *pl->used_flag_ptr = 1;
2603                     return temp;
2604                   }
2605               }
2606
2607             strcpy (temp, pl->prefix);
2608             strcat (temp, name);
2609             if (access_check (temp, mode) == 0)
2610               {
2611                 if (pl->used_flag_ptr != 0)
2612                   *pl->used_flag_ptr = 1;
2613                 return temp;
2614               }
2615           }
2616       }
2617
2618   free (temp);
2619   return 0;
2620 }
2621
2622 /* Ranking of prefixes in the sort list. -B prefixes are put before
2623    all others.  */
2624
2625 enum path_prefix_priority
2626 {
2627   PREFIX_PRIORITY_B_OPT,
2628   PREFIX_PRIORITY_LAST
2629 };
2630
2631 /* Add an entry for PREFIX in PLIST.  The PLIST is kept in assending
2632    order according to PRIORITY.  Within each PRIORITY, new entries are
2633    appended.
2634
2635    If WARN is nonzero, we will warn if no file is found
2636    through this prefix.  WARN should point to an int
2637    which will be set to 1 if this entry is used.
2638
2639    COMPONENT is the value to be passed to update_path.
2640
2641    REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2642    the complete value of machine_suffix.
2643    2 means try both machine_suffix and just_machine_suffix.  */
2644
2645 static void
2646 add_prefix (pprefix, prefix, component, priority, require_machine_suffix, warn)
2647      struct path_prefix *pprefix;
2648      const char *prefix;
2649      const char *component;
2650      /* enum prefix_priority */ int priority;
2651      int require_machine_suffix;
2652      int *warn;
2653 {
2654   struct prefix_list *pl, **prev;
2655   int len;
2656
2657   for (prev = &pprefix->plist;
2658        (*prev) != NULL && (*prev)->priority <= priority;
2659        prev = &(*prev)->next)
2660     ;
2661
2662   /* Keep track of the longest prefix */
2663
2664   prefix = update_path (prefix, component);
2665   len = strlen (prefix);
2666   if (len > pprefix->max_len)
2667     pprefix->max_len = len;
2668
2669   pl = (struct prefix_list *) xmalloc (sizeof (struct prefix_list));
2670   pl->prefix = prefix;
2671   pl->require_machine_suffix = require_machine_suffix;
2672   pl->used_flag_ptr = warn;
2673   pl->priority = priority;
2674   if (warn)
2675     *warn = 0;
2676
2677   /* Insert after PREV */
2678   pl->next = (*prev);
2679   (*prev) = pl;
2680 }
2681 \f
2682 /* Execute the command specified by the arguments on the current line of spec.
2683    When using pipes, this includes several piped-together commands
2684    with `|' between them.
2685
2686    Return 0 if successful, -1 if failed.  */
2687
2688 static int
2689 execute ()
2690 {
2691   int i;
2692   int n_commands;               /* # of command.  */
2693   char *string;
2694   struct command
2695   {
2696     const char *prog;           /* program name.  */
2697     const char **argv;          /* vector of args.  */
2698     int pid;                    /* pid of process for this command.  */
2699   };
2700
2701   struct command *commands;     /* each command buffer with above info.  */
2702
2703   /* Count # of piped commands.  */
2704   for (n_commands = 1, i = 0; i < argbuf_index; i++)
2705     if (strcmp (argbuf[i], "|") == 0)
2706       n_commands++;
2707
2708   /* Get storage for each command.  */
2709   commands = (struct command *) alloca (n_commands * sizeof (struct command));
2710
2711   /* Split argbuf into its separate piped processes,
2712      and record info about each one.
2713      Also search for the programs that are to be run.  */
2714
2715   commands[0].prog = argbuf[0]; /* first command.  */
2716   commands[0].argv = &argbuf[0];
2717   string = find_a_file (&exec_prefixes, commands[0].prog, X_OK);
2718
2719   if (string)
2720     commands[0].argv[0] = string;
2721
2722   for (n_commands = 1, i = 0; i < argbuf_index; i++)
2723     if (strcmp (argbuf[i], "|") == 0)
2724       {                         /* each command.  */
2725 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2726         fatal ("-pipe not supported");
2727 #endif
2728         argbuf[i] = 0;  /* termination of command args.  */
2729         commands[n_commands].prog = argbuf[i + 1];
2730         commands[n_commands].argv = &argbuf[i + 1];
2731         string = find_a_file (&exec_prefixes, commands[n_commands].prog, X_OK);
2732         if (string)
2733           commands[n_commands].argv[0] = string;
2734         n_commands++;
2735       }
2736
2737   argbuf[argbuf_index] = 0;
2738
2739   /* If -v, print what we are about to do, and maybe query.  */
2740
2741   if (verbose_flag)
2742     {
2743       /* For help listings, put a blank line between sub-processes.  */
2744       if (print_help_list)
2745         fputc ('\n', stderr);
2746
2747       /* Print each piped command as a separate line.  */
2748       for (i = 0; i < n_commands; i++)
2749         {
2750           const char *const *j;
2751
2752           if (verbose_only_flag)
2753             {
2754               for (j = commands[i].argv; *j; j++)
2755                 {
2756                   const char *p;
2757                   fprintf (stderr, " \"");
2758                   for (p = *j; *p; ++p)
2759                     {
2760                       if (*p == '"' || *p == '\\' || *p == '$')
2761                         fputc ('\\', stderr);
2762                       fputc (*p, stderr);
2763                     }
2764                   fputc ('"', stderr);
2765                 }
2766             }
2767           else
2768             for (j = commands[i].argv; *j; j++)
2769               fprintf (stderr, " %s", *j);
2770
2771           /* Print a pipe symbol after all but the last command.  */
2772           if (i + 1 != n_commands)
2773             fprintf (stderr, " |");
2774           fprintf (stderr, "\n");
2775         }
2776       fflush (stderr);
2777       if (verbose_only_flag != 0)
2778         return 0;
2779 #ifdef DEBUG
2780       notice ("\nGo ahead? (y or n) ");
2781       fflush (stderr);
2782       i = getchar ();
2783       if (i != '\n')
2784         while (getchar () != '\n')
2785           ;
2786
2787       if (i != 'y' && i != 'Y')
2788         return 0;
2789 #endif /* DEBUG */
2790     }
2791
2792   /* Run each piped subprocess.  */
2793
2794   for (i = 0; i < n_commands; i++)
2795     {
2796       char *errmsg_fmt, *errmsg_arg;
2797       const char *string = commands[i].argv[0];
2798
2799       /* For some bizarre reason, the second argument of execvp() is
2800          char *const *, not const char *const *.  */
2801       commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2802                                   programname, temp_filename,
2803                                   &errmsg_fmt, &errmsg_arg,
2804                                   ((i == 0 ? PEXECUTE_FIRST : 0)
2805                                    | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2806                                    | (string == commands[i].prog
2807                                       ? PEXECUTE_SEARCH : 0)
2808                                    | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2809
2810       if (commands[i].pid == -1)
2811         pfatal_pexecute (errmsg_fmt, errmsg_arg);
2812
2813       if (string != commands[i].prog)
2814         free ((PTR) string);
2815     }
2816
2817   execution_count++;
2818
2819   /* Wait for all the subprocesses to finish.
2820      We don't care what order they finish in;
2821      we know that N_COMMANDS waits will get them all.
2822      Ignore subprocesses that we don't know about,
2823      since they can be spawned by the process that exec'ed us.  */
2824
2825   {
2826     int ret_code = 0;
2827 #ifdef HAVE_GETRUSAGE
2828     struct timeval d;
2829     double ut = 0.0, st = 0.0;
2830 #endif
2831
2832     for (i = 0; i < n_commands;)
2833       {
2834         int j;
2835         int status;
2836         int pid;
2837
2838         pid = pwait (commands[i].pid, &status, 0);
2839         if (pid < 0)
2840           abort ();
2841
2842 #ifdef HAVE_GETRUSAGE
2843         if (report_times)
2844           {
2845             /* getrusage returns the total resource usage of all children
2846                up to now.  Copy the previous values into prus, get the
2847                current statistics, then take the difference.  */
2848
2849             prus = rus;
2850             getrusage (RUSAGE_CHILDREN, &rus);
2851             d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2852             d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2853             ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2854
2855             d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2856             d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2857             st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2858           }
2859 #endif
2860
2861         for (j = 0; j < n_commands; j++)
2862           if (commands[j].pid == pid)
2863             {
2864               i++;
2865               if (WIFSIGNALED (status))
2866                 {
2867 #ifdef SIGPIPE
2868                   /* SIGPIPE is a special case.  It happens in -pipe mode
2869                      when the compiler dies before the preprocessor is
2870                      done, or the assembler dies before the compiler is
2871                      done.  There's generally been an error already, and
2872                      this is just fallout.  So don't generate another error
2873                      unless we would otherwise have succeeded.  */
2874                   if (WTERMSIG (status) == SIGPIPE
2875                       && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2876                     ;
2877                   else
2878 #endif
2879                     fatal ("\
2880 Internal error: %s (program %s)\n\
2881 Please submit a full bug report.\n\
2882 See %s for instructions.",
2883                            strsignal (WTERMSIG (status)), commands[j].prog,
2884                            GCCBUGURL);
2885                   signal_count++;
2886                   ret_code = -1;
2887                 }
2888               else if (WIFEXITED (status)
2889                        && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2890                 {
2891                   if (WEXITSTATUS (status) > greatest_status)
2892                     greatest_status = WEXITSTATUS (status);
2893                   ret_code = -1;
2894                 }
2895 #ifdef HAVE_GETRUSAGE
2896               if (report_times && ut + st != 0)
2897                 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2898 #endif
2899               break;
2900             }
2901       }
2902     return ret_code;
2903   }
2904 }
2905 \f
2906 /* Find all the switches given to us
2907    and make a vector describing them.
2908    The elements of the vector are strings, one per switch given.
2909    If a switch uses following arguments, then the `part1' field
2910    is the switch itself and the `args' field
2911    is a null-terminated vector containing the following arguments.
2912    The `live_cond' field is:
2913    0 when initialized
2914    1 if the switch is true in a conditional spec,
2915    -1 if false (overridden by a later switch)
2916    -2 if this switch should be ignored (used in %{<S})
2917    The `validated' field is nonzero if any spec has looked at this switch;
2918    if it remains zero at the end of the run, it must be meaningless.  */
2919
2920 #define SWITCH_OK       0
2921 #define SWITCH_FALSE   -1
2922 #define SWITCH_IGNORE  -2
2923 #define SWITCH_LIVE     1
2924
2925 struct switchstr
2926 {
2927   const char *part1;
2928   const char **args;
2929   int live_cond;
2930   unsigned char validated;
2931   unsigned char ordering;
2932 };
2933
2934 static struct switchstr *switches;
2935
2936 static int n_switches;
2937
2938 struct infile
2939 {
2940   const char *name;
2941   const char *language;
2942 };
2943
2944 /* Also a vector of input files specified.  */
2945
2946 static struct infile *infiles;
2947
2948 int n_infiles;
2949
2950 /* This counts the number of libraries added by lang_specific_driver, so that
2951    we can tell if there were any user supplied any files or libraries.  */
2952
2953 static int added_libraries;
2954
2955 /* And a vector of corresponding output files is made up later.  */
2956
2957 const char **outfiles;
2958
2959 /* Used to track if none of the -B paths are used.  */
2960 static int warn_B;
2961
2962 /* Used to track if standard path isn't used and -b or -V is specified.  */
2963 static int warn_std;
2964
2965 /* Gives value to pass as "warn" to add_prefix for standard prefixes.  */
2966 static int *warn_std_ptr = 0;
2967 \f
2968 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2969
2970 /* Convert NAME to a new name if it is the standard suffix.  DO_EXE
2971    is true if we should look for an executable suffix.  DO_OBJ
2972    is true if we should look for an object suffix.  */
2973
2974 static const char *
2975 convert_filename (name, do_exe, do_obj)
2976      const char *name;
2977      int do_exe ATTRIBUTE_UNUSED;
2978      int do_obj ATTRIBUTE_UNUSED;
2979 {
2980 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2981   int i;
2982 #endif
2983   int len;
2984
2985   if (name == NULL)
2986     return NULL;
2987
2988   len = strlen (name);
2989
2990 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2991   /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj".  */
2992   if (do_obj && len > 2
2993       && name[len - 2] == '.'
2994       && name[len - 1] == 'o')
2995     {
2996       obstack_grow (&obstack, name, len - 2);
2997       obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2998       name = obstack_finish (&obstack);
2999     }
3000 #endif
3001
3002 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3003   /* If there is no filetype, make it the executable suffix (which includes
3004      the ".").  But don't get confused if we have just "-o".  */
3005   if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3006     return name;
3007
3008   for (i = len - 1; i >= 0; i--)
3009     if (IS_DIR_SEPARATOR (name[i]))
3010       break;
3011
3012   for (i++; i < len; i++)
3013     if (name[i] == '.')
3014       return name;
3015
3016   obstack_grow (&obstack, name, len);
3017   obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3018                  strlen (TARGET_EXECUTABLE_SUFFIX));
3019   name = obstack_finish (&obstack);
3020 #endif
3021
3022   return name;
3023 }
3024 #endif
3025 \f
3026 /* Display the command line switches accepted by gcc.  */
3027 static void
3028 display_help ()
3029 {
3030   printf (_("Usage: %s [options] file...\n"), programname);
3031   fputs (_("Options:\n"), stdout);
3032
3033   fputs (_("  -pass-exit-codes         Exit with highest error code from a phase\n"), stdout);
3034   fputs (_("  --help                   Display this information\n"), stdout);
3035   fputs (_("  --target-help            Display target specific command line options\n"), stdout);
3036   if (! verbose_flag)
3037     fputs (_("  (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3038   fputs (_("  -dumpspecs               Display all of the built in spec strings\n"), stdout);
3039   fputs (_("  -dumpversion             Display the version of the compiler\n"), stdout);
3040   fputs (_("  -dumpmachine             Display the compiler's target processor\n"), stdout);
3041   fputs (_("  -print-search-dirs       Display the directories in the compiler's search path\n"), stdout);
3042   fputs (_("  -print-libgcc-file-name  Display the name of the compiler's companion library\n"), stdout);
3043   fputs (_("  -print-file-name=<lib>   Display the full path to library <lib>\n"), stdout);
3044   fputs (_("  -print-prog-name=<prog>  Display the full path to compiler component <prog>\n"), stdout);
3045   fputs (_("  -print-multi-directory   Display the root directory for versions of libgcc\n"), stdout);
3046   fputs (_("\
3047   -print-multi-lib         Display the mapping between command line options and\n\
3048                            multiple library search directories\n"), stdout);
3049   fputs (_("  -Wa,<options>            Pass comma-separated <options> on to the assembler\n"), stdout);
3050   fputs (_("  -Wp,<options>            Pass comma-separated <options> on to the preprocessor\n"), stdout);
3051   fputs (_("  -Wl,<options>            Pass comma-separated <options> on to the linker\n"), stdout);
3052   fputs (_("  -Xlinker <arg>           Pass <arg> on to the linker\n"), stdout);
3053   fputs (_("  -save-temps              Do not delete intermediate files\n"), stdout);
3054   fputs (_("  -pipe                    Use pipes rather than intermediate files\n"), stdout);
3055   fputs (_("  -time                    Time the execution of each subprocess\n"), stdout);
3056   fputs (_("  -specs=<file>            Override builtin specs with the contents of <file>\n"), stdout);
3057   fputs (_("  -std=<standard>          Assume that the input sources are for <standard>\n"), stdout);
3058   fputs (_("  -B <directory>           Add <directory> to the compiler's search paths\n"), stdout);
3059   fputs (_("  -b <machine>             Run gcc for target <machine>, if installed\n"), stdout);
3060   fputs (_("  -V <version>             Run gcc version number <version>, if installed\n"), stdout);
3061   fputs (_("  -v                       Display the programs invoked by the compiler\n"), stdout);
3062   fputs (_("  -###                     Like -v but options quoted and commands not executed\n"), stdout);
3063   fputs (_("  -E                       Preprocess only; do not compile, assemble or link\n"), stdout);
3064   fputs (_("  -S                       Compile only; do not assemble or link\n"), stdout);
3065   fputs (_("  -c                       Compile and assemble, but do not link\n"), stdout);
3066   fputs (_("  -o <file>                Place the output into <file>\n"), stdout);
3067   fputs (_("\
3068   -x <language>            Specify the language of the following input files\n\
3069                            Permissable languages include: c c++ assembler none\n\
3070                            'none' means revert to the default behavior of\n\
3071                            guessing the language based on the file's extension\n\
3072 "), stdout);
3073
3074   printf (_("\
3075 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3076  passed on to the various sub-processes invoked by %s.  In order to pass\n\
3077  other options on to these processes the -W<letter> options must be used.\n\
3078 "), programname);
3079
3080   /* The rest of the options are displayed by invocations of the various
3081      sub-processes.  */
3082 }
3083
3084 static void
3085 add_preprocessor_option (option, len)
3086      const char *option;
3087      int len;
3088 {
3089   n_preprocessor_options++;
3090
3091   if (! preprocessor_options)
3092     preprocessor_options
3093       = (char **) xmalloc (n_preprocessor_options * sizeof (char *));
3094   else
3095     preprocessor_options
3096       = (char **) xrealloc (preprocessor_options,
3097                             n_preprocessor_options * sizeof (char *));
3098
3099   preprocessor_options [n_preprocessor_options - 1] =
3100     save_string (option, len);
3101 }
3102
3103 static void
3104 add_assembler_option (option, len)
3105      const char *option;
3106      int len;
3107 {
3108   n_assembler_options++;
3109
3110   if (! assembler_options)
3111     assembler_options
3112       = (char **) xmalloc (n_assembler_options * sizeof (char *));
3113   else
3114     assembler_options
3115       = (char **) xrealloc (assembler_options,
3116                             n_assembler_options * sizeof (char *));
3117
3118   assembler_options [n_assembler_options - 1] = save_string (option, len);
3119 }
3120
3121 static void
3122 add_linker_option (option, len)
3123      const char *option;
3124      int len;
3125 {
3126   n_linker_options++;
3127
3128   if (! linker_options)
3129     linker_options
3130       = (char **) xmalloc (n_linker_options * sizeof (char *));
3131   else
3132     linker_options
3133       = (char **) xrealloc (linker_options,
3134                             n_linker_options * sizeof (char *));
3135
3136   linker_options [n_linker_options - 1] = save_string (option, len);
3137 }
3138 \f
3139 /* Create the vector `switches' and its contents.
3140    Store its length in `n_switches'.  */
3141
3142 static void
3143 process_command (argc, argv)
3144      int argc;
3145      const char *const *argv;
3146 {
3147   int i;
3148   const char *temp;
3149   char *temp1;
3150   const char *spec_lang = 0;
3151   int last_language_n_infiles;
3152   int have_c = 0;
3153   int have_o = 0;
3154   int lang_n_infiles = 0;
3155 #ifdef MODIFY_TARGET_NAME
3156   int is_modify_target_name;
3157   int j;
3158 #endif
3159
3160   GET_ENV_PATH_LIST (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3161
3162   n_switches = 0;
3163   n_infiles = 0;
3164   added_libraries = 0;
3165
3166   /* Figure compiler version from version string.  */
3167
3168   compiler_version = temp1 = xstrdup (version_string);
3169
3170   for (; *temp1; ++temp1)
3171     {
3172       if (*temp1 == ' ')
3173         {
3174           *temp1 = '\0';
3175           break;
3176         }
3177     }
3178
3179   /* Set up the default search paths.  If there is no GCC_EXEC_PREFIX,
3180      see if we can create it from the pathname specified in argv[0].  */
3181
3182 #ifndef VMS
3183   /* FIXME: make_relative_prefix doesn't yet work for VMS.  */
3184   if (!gcc_exec_prefix)
3185     {
3186       gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3187                                               standard_exec_prefix);
3188       if (gcc_exec_prefix)
3189         putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3190     }
3191 #endif
3192
3193   if (gcc_exec_prefix)
3194     {
3195       int len = strlen (gcc_exec_prefix);
3196
3197       if (len > (int) sizeof ("/lib/gcc-lib/") - 1
3198           && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3199         {
3200           temp = gcc_exec_prefix + len - sizeof ("/lib/gcc-lib/") + 1;
3201           if (IS_DIR_SEPARATOR (*temp)
3202               && strncmp (temp + 1, "lib", 3) == 0
3203               && IS_DIR_SEPARATOR (temp[4])
3204               && strncmp (temp + 5, "gcc-lib", 7) == 0)
3205             len -= sizeof ("/lib/gcc-lib/") - 1;
3206         }
3207
3208       set_std_prefix (gcc_exec_prefix, len);
3209       add_prefix (&exec_prefixes, gcc_exec_prefix, "GCC",
3210                   PREFIX_PRIORITY_LAST, 0, NULL);
3211       add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3212                   PREFIX_PRIORITY_LAST, 0, NULL);
3213     }
3214
3215   /* COMPILER_PATH and LIBRARY_PATH have values
3216      that are lists of directory names with colons.  */
3217
3218   GET_ENV_PATH_LIST (temp, "COMPILER_PATH");
3219   if (temp)
3220     {
3221       const char *startp, *endp;
3222       char *nstore = (char *) alloca (strlen (temp) + 3);
3223
3224       startp = endp = temp;
3225       while (1)
3226         {
3227           if (*endp == PATH_SEPARATOR || *endp == 0)
3228             {
3229               strncpy (nstore, startp, endp - startp);
3230               if (endp == startp)
3231                 strcpy (nstore, concat (".", dir_separator_str, NULL));
3232               else if (!IS_DIR_SEPARATOR (endp[-1]))
3233                 {
3234                   nstore[endp - startp] = DIR_SEPARATOR;
3235                   nstore[endp - startp + 1] = 0;
3236                 }
3237               else
3238                 nstore[endp - startp] = 0;
3239               add_prefix (&exec_prefixes, nstore, 0,
3240                           PREFIX_PRIORITY_LAST, 0, NULL);
3241               add_prefix (&include_prefixes,
3242                           concat (nstore, "include", NULL),
3243                           0, PREFIX_PRIORITY_LAST, 0, NULL);
3244               if (*endp == 0)
3245                 break;
3246               endp = startp = endp + 1;
3247             }
3248           else
3249             endp++;
3250         }
3251     }
3252
3253   GET_ENV_PATH_LIST (temp, LIBRARY_PATH_ENV);
3254   if (temp && *cross_compile == '0')
3255     {
3256       const char *startp, *endp;
3257       char *nstore = (char *) alloca (strlen (temp) + 3);
3258
3259       startp = endp = temp;
3260       while (1)
3261         {
3262           if (*endp == PATH_SEPARATOR || *endp == 0)
3263             {
3264               strncpy (nstore, startp, endp - startp);
3265               if (endp == startp)
3266                 strcpy (nstore, concat (".", dir_separator_str, NULL));
3267               else if (!IS_DIR_SEPARATOR (endp[-1]))
3268                 {
3269                   nstore[endp - startp] = DIR_SEPARATOR;
3270                   nstore[endp - startp + 1] = 0;
3271                 }
3272               else
3273                 nstore[endp - startp] = 0;
3274               add_prefix (&startfile_prefixes, nstore, NULL,
3275                           PREFIX_PRIORITY_LAST, 0, NULL);
3276               if (*endp == 0)
3277                 break;
3278               endp = startp = endp + 1;
3279             }
3280           else
3281             endp++;
3282         }
3283     }
3284
3285   /* Use LPATH like LIBRARY_PATH (for the CMU build program).  */
3286   GET_ENV_PATH_LIST (temp, "LPATH");
3287   if (temp && *cross_compile == '0')
3288     {
3289       const char *startp, *endp;
3290       char *nstore = (char *) alloca (strlen (temp) + 3);
3291
3292       startp = endp = temp;
3293       while (1)
3294         {
3295           if (*endp == PATH_SEPARATOR || *endp == 0)
3296             {
3297               strncpy (nstore, startp, endp - startp);
3298               if (endp == startp)
3299                 strcpy (nstore, concat (".", dir_separator_str, NULL));
3300               else if (!IS_DIR_SEPARATOR (endp[-1]))
3301                 {
3302                   nstore[endp - startp] = DIR_SEPARATOR;
3303                   nstore[endp - startp + 1] = 0;
3304                 }
3305               else
3306                 nstore[endp - startp] = 0;
3307               add_prefix (&startfile_prefixes, nstore, NULL,
3308                           PREFIX_PRIORITY_LAST, 0, NULL);
3309               if (*endp == 0)
3310                 break;
3311               endp = startp = endp + 1;
3312             }
3313           else
3314             endp++;
3315         }
3316     }
3317
3318   /* Convert new-style -- options to old-style.  */
3319   translate_options (&argc, &argv);
3320
3321   /* Do language-specific adjustment/addition of flags.  */
3322   lang_specific_driver (&argc, &argv, &added_libraries);
3323
3324   /* Scan argv twice.  Here, the first time, just count how many switches
3325      there will be in their vector, and how many input files in theirs.
3326      Also parse any switches that determine the configuration name, such as -b.
3327      Here we also parse the switches that cc itself uses (e.g. -v).  */
3328
3329   for (i = 1; i < argc; i++)
3330     {
3331       if (! strcmp (argv[i], "-dumpspecs"))
3332         {
3333           struct spec_list *sl;
3334           init_spec ();
3335           for (sl = specs; sl; sl = sl->next)
3336             printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3337           if (link_command_spec)
3338             printf ("*link_command:\n%s\n\n", link_command_spec);
3339           exit (0);
3340         }
3341       else if (! strcmp (argv[i], "-dumpversion"))
3342         {
3343           printf ("%s\n", spec_version);
3344           exit (0);
3345         }
3346       else if (! strcmp (argv[i], "-dumpmachine"))
3347         {
3348           printf ("%s\n", spec_machine);
3349           exit (0);
3350         }
3351       else if (strcmp (argv[i], "-fhelp") == 0)
3352         {
3353           /* translate_options () has turned --help into -fhelp.  */
3354           print_help_list = 1;
3355
3356           /* We will be passing a dummy file on to the sub-processes.  */
3357           n_infiles++;
3358           n_switches++;
3359
3360           /* CPP driver cannot obtain switch from cc1_options.  */
3361           if (is_cpp_driver)
3362             add_preprocessor_option ("--help", 6);
3363           add_assembler_option ("--help", 6);
3364           add_linker_option ("--help", 6);
3365         }
3366       else if (strcmp (argv[i], "-ftarget-help") == 0)
3367         {
3368           /* translate_options() has turned --target-help into -ftarget-help.  */
3369           target_help_flag = 1;
3370
3371           /* We will be passing a dummy file on to the sub-processes.  */
3372           n_infiles++;
3373           n_switches++;
3374
3375           /* CPP driver cannot obtain switch from cc1_options.  */
3376           if (is_cpp_driver)
3377             add_preprocessor_option ("--target-help", 13);
3378           add_assembler_option ("--target-help", 13);
3379           add_linker_option ("--target-help", 13);
3380         }
3381       else if (! strcmp (argv[i], "-pass-exit-codes"))
3382         {
3383           pass_exit_codes = 1;
3384           n_switches++;
3385         }
3386       else if (! strcmp (argv[i], "-print-search-dirs"))
3387         print_search_dirs = 1;
3388       else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3389         print_file_name = "libgcc.a";
3390       else if (! strncmp (argv[i], "-print-file-name=", 17))
3391         print_file_name = argv[i] + 17;
3392       else if (! strncmp (argv[i], "-print-prog-name=", 17))
3393         print_prog_name = argv[i] + 17;
3394       else if (! strcmp (argv[i], "-print-multi-lib"))
3395         print_multi_lib = 1;
3396       else if (! strcmp (argv[i], "-print-multi-directory"))
3397         print_multi_directory = 1;
3398       else if (! strncmp (argv[i], "-Wa,", 4))
3399         {
3400           int prev, j;
3401           /* Pass the rest of this option to the assembler.  */
3402
3403           /* Split the argument at commas.  */
3404           prev = 4;
3405           for (j = 4; argv[i][j]; j++)
3406             if (argv[i][j] == ',')
3407               {
3408                 add_assembler_option (argv[i] + prev, j - prev);
3409                 prev = j + 1;
3410               }
3411
3412           /* Record the part after the last comma.  */
3413           add_assembler_option (argv[i] + prev, j - prev);
3414         }
3415       else if (! strncmp (argv[i], "-Wp,", 4))
3416         {
3417           int prev, j;
3418           /* Pass the rest of this option to the preprocessor.  */
3419
3420           /* Split the argument at commas.  */
3421           prev = 4;
3422           for (j = 4; argv[i][j]; j++)
3423             if (argv[i][j] == ',')
3424               {
3425                 add_preprocessor_option (argv[i] + prev, j - prev);
3426                 prev = j + 1;
3427               }
3428
3429           /* Record the part after the last comma.  */
3430           add_preprocessor_option (argv[i] + prev, j - prev);
3431         }
3432       else if (argv[i][0] == '+' && argv[i][1] == 'e')
3433         /* The +e options to the C++ front-end.  */
3434         n_switches++;
3435       else if (strncmp (argv[i], "-Wl,", 4) == 0)
3436         {
3437           int j;
3438           /* Split the argument at commas.  */
3439           for (j = 3; argv[i][j]; j++)
3440             n_infiles += (argv[i][j] == ',');
3441         }
3442       else if (strcmp (argv[i], "-Xlinker") == 0)
3443         {
3444           if (i + 1 == argc)
3445             fatal ("argument to `-Xlinker' is missing");
3446
3447           n_infiles++;
3448           i++;
3449         }
3450       else if (strcmp (argv[i], "-l") == 0)
3451         {
3452           if (i + 1 == argc)
3453             fatal ("argument to `-l' is missing");
3454
3455           n_infiles++;
3456           i++;
3457         }
3458       else if (strncmp (argv[i], "-l", 2) == 0)
3459         n_infiles++;
3460       else if (strcmp (argv[i], "-save-temps") == 0)
3461         {
3462           save_temps_flag = 1;
3463           n_switches++;
3464         }
3465       else if (strcmp (argv[i], "-specs") == 0)
3466         {
3467           struct user_specs *user = (struct user_specs *)
3468             xmalloc (sizeof (struct user_specs));
3469           if (++i >= argc)
3470             fatal ("argument to `-specs' is missing");
3471
3472           user->next = (struct user_specs *) 0;
3473           user->filename = argv[i];
3474           if (user_specs_tail)
3475             user_specs_tail->next = user;
3476           else
3477             user_specs_head = user;
3478           user_specs_tail = user;
3479         }
3480       else if (strncmp (argv[i], "-specs=", 7) == 0)
3481         {
3482           struct user_specs *user = (struct user_specs *)
3483             xmalloc (sizeof (struct user_specs));
3484           if (strlen (argv[i]) == 7)
3485             fatal ("argument to `-specs=' is missing");
3486
3487           user->next = (struct user_specs *) 0;
3488           user->filename = argv[i] + 7;
3489           if (user_specs_tail)
3490             user_specs_tail->next = user;
3491           else
3492             user_specs_head = user;
3493           user_specs_tail = user;
3494         }
3495       else if (strcmp (argv[i], "-time") == 0)
3496         report_times = 1;
3497       else if (strcmp (argv[i], "-###") == 0)
3498         {
3499           /* This is similar to -v except that there is no execution
3500              of the commands and the echoed arguments are quoted.  It
3501              is intended for use in shell scripts to capture the
3502              driver-generated command line.  */
3503           verbose_only_flag++;
3504           verbose_flag++;
3505         }
3506       else if (argv[i][0] == '-' && argv[i][1] != 0)
3507         {
3508           const char *p = &argv[i][1];
3509           int c = *p;
3510
3511           switch (c)
3512             {
3513             case 'b':
3514               n_switches++;
3515               if (p[1] == 0 && i + 1 == argc)
3516                 fatal ("argument to `-b' is missing");
3517               if (p[1] == 0)
3518                 spec_machine = argv[++i];
3519               else
3520                 spec_machine = p + 1;
3521
3522               warn_std_ptr = &warn_std;
3523               break;
3524
3525             case 'B':
3526               {
3527                 const char *value;
3528                 int len;
3529
3530                 if (p[1] == 0 && i + 1 == argc)
3531                   fatal ("argument to `-B' is missing");
3532                 if (p[1] == 0)
3533                   value = argv[++i];
3534                 else
3535                   value = p + 1;
3536
3537                 len = strlen (value);
3538
3539                 /* Catch the case where the user has forgotten to append a
3540                    directory separator to the path.  Note, they may be using
3541                    -B to add an executable name prefix, eg "i386-elf-", in
3542                    order to distinguish between multiple installations of
3543                    GCC in the same directory.  Hence we must check to see
3544                    if appending a directory separator actually makes a
3545                    valid directory name.  */
3546                 if (! IS_DIR_SEPARATOR (value [len - 1])
3547                     && is_directory (value, "", 0))
3548                   {
3549                     char *tmp = xmalloc (len + 2);
3550                     strcpy (tmp, value);
3551                     tmp[len] = DIR_SEPARATOR;
3552                     tmp[++ len] = 0;
3553                     value = tmp;
3554                   }
3555                 
3556                 /* As a kludge, if the arg is "[foo/]stageN/", just
3557                    add "[foo/]include" to the include prefix.  */
3558                 if ((len == 7
3559                      || (len > 7
3560                          && (IS_DIR_SEPARATOR (value[len - 8]))))
3561                     && strncmp (value + len - 7, "stage", 5) == 0
3562                     && ISDIGIT (value[len - 2])
3563                     && (IS_DIR_SEPARATOR (value[len - 1])))
3564                   {
3565                     if (len == 7)
3566                       add_prefix (&include_prefixes, "include", NULL,
3567                                   PREFIX_PRIORITY_B_OPT, 0, NULL);
3568                     else
3569                       {
3570                         char * string = xmalloc (len + 1);
3571
3572                         strncpy (string, value, len - 7);
3573                         strcpy (string + len - 7, "include");
3574                         add_prefix (&include_prefixes, string, NULL,
3575                                     PREFIX_PRIORITY_B_OPT, 0, NULL);
3576                       }
3577                   }
3578
3579                 add_prefix (&exec_prefixes, value, NULL,
3580                             PREFIX_PRIORITY_B_OPT, 0, &warn_B);
3581                 add_prefix (&startfile_prefixes, value, NULL,
3582                             PREFIX_PRIORITY_B_OPT, 0, &warn_B);
3583                 add_prefix (&include_prefixes, concat (value, "include", NULL),
3584                             NULL, PREFIX_PRIORITY_B_OPT, 0, NULL);
3585                 n_switches++;
3586               }
3587               break;
3588
3589             case 'v':   /* Print our subcommands and print versions.  */
3590               n_switches++;
3591               /* If they do anything other than exactly `-v', don't set
3592                  verbose_flag; rather, continue on to give the error.  */
3593               if (p[1] != 0)
3594                 break;
3595               verbose_flag++;
3596               break;
3597
3598             case 'V':
3599               n_switches++;
3600               if (p[1] == 0 && i + 1 == argc)
3601                 fatal ("argument to `-V' is missing");
3602               if (p[1] == 0)
3603                 spec_version = argv[++i];
3604               else
3605                 spec_version = p + 1;
3606               compiler_version = spec_version;
3607               warn_std_ptr = &warn_std;
3608
3609               /* Validate the version number.  Use the same checks
3610                  done when inserting it into a spec.
3611
3612                  The format of the version string is
3613                  ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)?  */
3614               {
3615                 const char *v = compiler_version;
3616
3617                 /* Ignore leading non-digits.  i.e. "foo-" in "foo-2.7.2".  */
3618                 while (! ISDIGIT (*v))
3619                   v++;
3620
3621                 if (v > compiler_version && v[-1] != '-')
3622                   fatal ("invalid version number format");
3623
3624                 /* Set V after the first period.  */
3625                 while (ISDIGIT (*v))
3626                   v++;
3627
3628                 if (*v != '.')
3629                   fatal ("invalid version number format");
3630
3631                 v++;
3632                 while (ISDIGIT (*v))
3633                   v++;
3634
3635                 if (*v != 0 && *v != ' ' && *v != '.' && *v != '-')
3636                   fatal ("invalid version number format");
3637               }
3638               break;
3639
3640             case 'S':
3641             case 'c':
3642               if (p[1] == 0)
3643                 {
3644                   have_c = 1;
3645                   n_switches++;
3646                   break;
3647                 }
3648               goto normal_switch;
3649
3650             case 'o':
3651               have_o = 1;
3652 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3653               if (! have_c)
3654                 {
3655                   int skip;
3656
3657                   /* Forward scan, just in case -S or -c is specified
3658                      after -o.  */
3659                   int j = i + 1;
3660                   if (p[1] == 0)
3661                     ++j;
3662                   while (j < argc)
3663                     {
3664                       if (argv[j][0] == '-')
3665                         {
3666                           if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3667                               && argv[j][2] == 0)
3668                             {
3669                               have_c = 1;
3670                               break;
3671                             }
3672                           else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3673                             j += skip - (argv[j][2] != 0);
3674                           else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3675                             j += skip;
3676                         }
3677                       j++;
3678                     }
3679                 }
3680 #endif
3681 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3682               if (p[1] == 0)
3683                 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3684               else
3685                 argv[i] = convert_filename (argv[i], ! have_c, 0);
3686 #endif
3687               goto normal_switch;
3688
3689             default:
3690             normal_switch:
3691
3692 #ifdef MODIFY_TARGET_NAME
3693               is_modify_target_name = 0;
3694
3695               for (j = 0;
3696                    j < sizeof modify_target / sizeof modify_target[0]; j++)
3697                 if (! strcmp (argv[i], modify_target[j].sw))
3698                   {
3699                     char *new_name
3700                       = (char *) xmalloc (strlen (modify_target[j].str)
3701                                           + strlen (spec_machine));
3702                     const char *p, *r;
3703                     char *q;
3704                     int made_addition = 0;
3705
3706                     is_modify_target_name = 1;
3707                     for (p = spec_machine, q = new_name; *p != 0; )
3708                       {
3709                         if (modify_target[j].add_del == DELETE
3710                             && (! strncmp (q, modify_target[j].str,
3711                                            strlen (modify_target[j].str))))
3712                           p += strlen (modify_target[j].str);
3713                         else if (modify_target[j].add_del == ADD
3714                                  && ! made_addition && *p == '-')
3715                           {
3716                             for (r = modify_target[j].str; *r != 0; )
3717                               *q++ = *r++;
3718                             made_addition = 1;
3719                           }
3720
3721                         *q++ = *p++;
3722                       }
3723
3724                     spec_machine = new_name;
3725                   }
3726
3727               if (is_modify_target_name)
3728                 break;
3729 #endif                
3730
3731               n_switches++;
3732
3733               if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3734                 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3735               else if (WORD_SWITCH_TAKES_ARG (p))
3736                 i += WORD_SWITCH_TAKES_ARG (p);
3737             }
3738         }
3739       else
3740         {
3741           n_infiles++;
3742           lang_n_infiles++;
3743         }
3744     }
3745
3746   if (have_c && have_o && lang_n_infiles > 1)
3747     fatal ("cannot specify -o with -c or -S and multiple compilations");
3748
3749   /* Set up the search paths before we go looking for config files.  */
3750
3751   /* These come before the md prefixes so that we will find gcc's subcommands
3752      (such as cpp) rather than those of the host system.  */
3753   /* Use 2 as fourth arg meaning try just the machine as a suffix,
3754      as well as trying the machine and the version.  */
3755 #ifndef OS2
3756   add_prefix (&exec_prefixes, standard_exec_prefix, "GCC",
3757               PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3758   add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3759               PREFIX_PRIORITY_LAST, 2, warn_std_ptr);
3760   add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3761               PREFIX_PRIORITY_LAST, 2, warn_std_ptr);
3762 #endif
3763
3764   add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3765               PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3766   add_prefix (&startfile_prefixes, standard_exec_prefix_1, "BINUTILS",
3767               PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3768
3769   tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3770                            dir_separator_str, NULL);
3771
3772   /* If tooldir is relative, base it on exec_prefixes.  A relative
3773      tooldir lets us move the installed tree as a unit.
3774
3775      If GCC_EXEC_PREFIX is defined, then we want to add two relative
3776      directories, so that we can search both the user specified directory
3777      and the standard place.  */
3778
3779   if (!IS_ABSOLUTE_PATHNAME (tooldir_prefix))
3780     {
3781       if (gcc_exec_prefix)
3782         {
3783           char *gcc_exec_tooldir_prefix
3784             = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3785                       spec_version, dir_separator_str, tooldir_prefix, NULL);
3786
3787           add_prefix (&exec_prefixes,
3788                       concat (gcc_exec_tooldir_prefix, "bin",
3789                               dir_separator_str, NULL),
3790                       NULL, PREFIX_PRIORITY_LAST, 0, NULL);
3791           add_prefix (&startfile_prefixes,
3792                       concat (gcc_exec_tooldir_prefix, "lib",
3793                               dir_separator_str, NULL),
3794                       NULL, PREFIX_PRIORITY_LAST, 0, NULL);
3795         }
3796
3797       tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3798                                dir_separator_str, spec_version,
3799                                dir_separator_str, tooldir_prefix, NULL);
3800     }
3801
3802   add_prefix (&exec_prefixes,
3803               concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3804               "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
3805   add_prefix (&startfile_prefixes,
3806               concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3807               "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
3808
3809   /* More prefixes are enabled in main, after we read the specs file
3810      and determine whether this is cross-compilation or not.  */
3811
3812   /* Then create the space for the vectors and scan again.  */
3813
3814   switches = ((struct switchstr *)
3815               xmalloc ((n_switches + 1) * sizeof (struct switchstr)));
3816   infiles = (struct infile *) xmalloc ((n_infiles + 1) * sizeof (struct infile));
3817   n_switches = 0;
3818   n_infiles = 0;
3819   last_language_n_infiles = -1;
3820
3821   /* This, time, copy the text of each switch and store a pointer
3822      to the copy in the vector of switches.
3823      Store all the infiles in their vector.  */
3824
3825   for (i = 1; i < argc; i++)
3826     {
3827       /* Just skip the switches that were handled by the preceding loop.  */
3828 #ifdef MODIFY_TARGET_NAME
3829       is_modify_target_name = 0;
3830
3831       for (j = 0; j < sizeof modify_target / sizeof modify_target[0]; j++)
3832         if (! strcmp (argv[i], modify_target[j].sw))
3833           is_modify_target_name = 1;
3834
3835       if (is_modify_target_name)
3836         ;
3837       else
3838 #endif
3839       if (! strncmp (argv[i], "-Wa,", 4))
3840         ;
3841       else if (! strncmp (argv[i], "-Wp,", 4))
3842         ;
3843       else if (! strcmp (argv[i], "-pass-exit-codes"))
3844         ;
3845       else if (! strcmp (argv[i], "-print-search-dirs"))
3846         ;
3847       else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3848         ;
3849       else if (! strncmp (argv[i], "-print-file-name=", 17))
3850         ;
3851       else if (! strncmp (argv[i], "-print-prog-name=", 17))
3852         ;
3853       else if (! strcmp (argv[i], "-print-multi-lib"))
3854         ;
3855       else if (! strcmp (argv[i], "-print-multi-directory"))
3856         ;
3857       else if (! strcmp (argv[i], "-ftarget-help"))
3858         ;
3859       else if (! strcmp (argv[i], "-fhelp"))
3860         ;
3861       else if (argv[i][0] == '+' && argv[i][1] == 'e')
3862         {
3863           /* Compensate for the +e options to the C++ front-end;
3864              they're there simply for cfront call-compatibility.  We do
3865              some magic in default_compilers to pass them down properly.
3866              Note we deliberately start at the `+' here, to avoid passing
3867              -e0 or -e1 down into the linker.  */
3868           switches[n_switches].part1 = &argv[i][0];
3869           switches[n_switches].args = 0;
3870           switches[n_switches].live_cond = SWITCH_OK;
3871           switches[n_switches].validated = 0;
3872           n_switches++;
3873         }
3874       else if (strncmp (argv[i], "-Wl,", 4) == 0)
3875         {
3876           int prev, j;
3877           /* Split the argument at commas.  */
3878           prev = 4;
3879           for (j = 4; argv[i][j]; j++)
3880             if (argv[i][j] == ',')
3881               {
3882                 infiles[n_infiles].language = "*";
3883                 infiles[n_infiles++].name
3884                   = save_string (argv[i] + prev, j - prev);
3885                 prev = j + 1;
3886               }
3887           /* Record the part after the last comma.  */
3888           infiles[n_infiles].language = "*";
3889           infiles[n_infiles++].name = argv[i] + prev;
3890         }
3891       else if (strcmp (argv[i], "-Xlinker") == 0)
3892         {
3893           infiles[n_infiles].language = "*";
3894           infiles[n_infiles++].name = argv[++i];
3895         }
3896       else if (strcmp (argv[i], "-l") == 0)
3897         { /* POSIX allows separation of -l and the lib arg;
3898              canonicalize by concatenating -l with its arg */
3899           infiles[n_infiles].language = "*";
3900           infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3901         }
3902       else if (strncmp (argv[i], "-l", 2) == 0)
3903         {
3904           infiles[n_infiles].language = "*";
3905           infiles[n_infiles++].name = argv[i];
3906         }
3907       else if (strcmp (argv[i], "-specs") == 0)
3908         i++;
3909       else if (strncmp (argv[i], "-specs=", 7) == 0)
3910         ;
3911       else if (strcmp (argv[i], "-time") == 0)
3912         ;
3913       else if ((save_temps_flag || report_times)
3914                && strcmp (argv[i], "-pipe") == 0)
3915         {
3916           /* -save-temps overrides -pipe, so that temp files are produced */
3917           if (save_temps_flag)
3918             error ("warning: -pipe ignored because -save-temps specified");
3919           /* -time overrides -pipe because we can't get correct stats when
3920              multiple children are running at once.  */
3921           else if (report_times)
3922             error ("warning: -pipe ignored because -time specified");
3923         }
3924       else if (strcmp (argv[i], "-###") == 0)
3925         ;
3926       else if (argv[i][0] == '-' && argv[i][1] != 0)
3927         {
3928           const char *p = &argv[i][1];
3929           int c = *p;
3930
3931           if (c == 'x')
3932             {
3933               if (p[1] == 0 && i + 1 == argc)
3934                 fatal ("argument to `-x' is missing");
3935               if (p[1] == 0)
3936                 spec_lang = argv[++i];
3937               else
3938                 spec_lang = p + 1;
3939               if (! strcmp (spec_lang, "none"))
3940                 /* Suppress the warning if -xnone comes after the last input
3941                    file, because alternate command interfaces like g++ might
3942                    find it useful to place -xnone after each input file.  */
3943                 spec_lang = 0;
3944               else
3945                 last_language_n_infiles = n_infiles;
3946               continue;
3947             }
3948           switches[n_switches].part1 = p;
3949           /* Deal with option arguments in separate argv elements.  */
3950           if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
3951               || WORD_SWITCH_TAKES_ARG (p))
3952             {
3953               int j = 0;
3954               int n_args = WORD_SWITCH_TAKES_ARG (p);
3955
3956               if (n_args == 0)
3957                 {
3958                   /* Count only the option arguments in separate argv elements.  */
3959                   n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
3960                 }
3961               if (i + n_args >= argc)
3962                 fatal ("argument to `-%s' is missing", p);
3963               switches[n_switches].args
3964                 = (const char **) xmalloc ((n_args + 1) * sizeof(const char *));
3965               while (j < n_args)
3966                 switches[n_switches].args[j++] = argv[++i];
3967               /* Null-terminate the vector.  */
3968               switches[n_switches].args[j] = 0;
3969             }
3970           else if (strchr (switches_need_spaces, c))
3971             {
3972               /* On some systems, ld cannot handle some options without
3973                  a space.  So split the option from its argument.  */
3974               char *part1 = (char *) xmalloc (2);
3975               part1[0] = c;
3976               part1[1] = '\0';
3977
3978               switches[n_switches].part1 = part1;
3979               switches[n_switches].args
3980                 = (const char **) xmalloc (2 * sizeof (const char *));
3981               switches[n_switches].args[0] = xstrdup (p+1);
3982               switches[n_switches].args[1] = 0;
3983             }
3984           else
3985             switches[n_switches].args = 0;
3986
3987           switches[n_switches].live_cond = SWITCH_OK;
3988           switches[n_switches].validated = 0;
3989           switches[n_switches].ordering = 0;
3990           /* These are always valid, since gcc.c itself understands it.  */
3991           if (!strcmp (p, "save-temps")
3992               || !strcmp (p, "static-libgcc")
3993               || !strcmp (p, "shared-libgcc"))
3994             switches[n_switches].validated = 1;
3995           else
3996             {
3997               char ch = switches[n_switches].part1[0];
3998               if (ch == 'V' || ch == 'b' || ch == 'B')
3999                 switches[n_switches].validated = 1;
4000             }
4001           n_switches++;
4002         }
4003       else
4004         {
4005 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4006           argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4007 #endif
4008
4009           if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4010             {
4011               perror_with_name (argv[i]);
4012               error_count++;
4013             }
4014           else
4015             {
4016               infiles[n_infiles].language = spec_lang;
4017               infiles[n_infiles++].name = argv[i];
4018             }
4019         }
4020     }
4021
4022   if (n_infiles == last_language_n_infiles && spec_lang != 0)
4023     error ("warning: `-x %s' after last input file has no effect", spec_lang);
4024
4025   /* Ensure we only invoke each subprocess once.  */
4026   if (target_help_flag || print_help_list)
4027     {
4028       n_infiles = 1;
4029
4030       /* Create a dummy input file, so that we can pass --target-help on to
4031          the various sub-processes.  */
4032       infiles[0].language = "c";
4033       infiles[0].name   = "help-dummy";
4034
4035       if (target_help_flag)
4036         {
4037           switches[n_switches].part1     = "--target-help";
4038           switches[n_switches].args      = 0;
4039           switches[n_switches].live_cond = SWITCH_OK;
4040           switches[n_switches].validated = 0;
4041
4042           n_switches++;
4043         }
4044
4045       if (print_help_list)
4046         {
4047           switches[n_switches].part1     = "--help";
4048           switches[n_switches].args      = 0;
4049           switches[n_switches].live_cond = SWITCH_OK;
4050           switches[n_switches].validated = 0;
4051
4052           n_switches++;
4053         }
4054     }
4055
4056   switches[n_switches].part1 = 0;
4057   infiles[n_infiles].name = 0;
4058 }
4059
4060 /* Store switches not filtered out by %{<S} in spec in COLLECT_GCC_OPTIONS
4061    and place that in the environment.  */
4062
4063 static void
4064 set_collect_gcc_options ()
4065 {
4066   int i;
4067   int first_time;
4068
4069   /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4070      the compiler.  */
4071   obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4072                 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4073
4074   first_time = TRUE;
4075   for (i = 0; (int) i < n_switches; i++)
4076     {
4077       const char *const *args;
4078       const char *p, *q;
4079       if (!first_time)
4080         obstack_grow (&collect_obstack, " ", 1);
4081
4082       first_time = FALSE;
4083
4084       /* Ignore elided switches.  */
4085       if (switches[i].live_cond == SWITCH_IGNORE)
4086         continue;
4087
4088       obstack_grow (&collect_obstack, "'-", 2);
4089       q = switches[i].part1;
4090       while ((p = strchr (q, '\'')))
4091         {
4092           obstack_grow (&collect_obstack, q, p - q);
4093           obstack_grow (&collect_obstack, "'\\''", 4);
4094           q = ++p;
4095         }
4096       obstack_grow (&collect_obstack, q, strlen (q));
4097       obstack_grow (&collect_obstack, "'", 1);
4098
4099       for (args = switches[i].args; args && *args; args++)
4100         {
4101           obstack_grow (&collect_obstack, " '", 2);
4102           q = *args;
4103           while ((p = strchr (q, '\'')))
4104             {
4105               obstack_grow (&collect_obstack, q, p - q);
4106               obstack_grow (&collect_obstack, "'\\''", 4);
4107               q = ++p;
4108             }
4109           obstack_grow (&collect_obstack, q, strlen (q));
4110           obstack_grow (&collect_obstack, "'", 1);
4111         }
4112     }
4113   obstack_grow (&collect_obstack, "\0", 1);
4114   putenv (obstack_finish (&collect_obstack));
4115 }
4116 \f
4117 /* Process a spec string, accumulating and running commands.  */
4118
4119 /* These variables describe the input file name.
4120    input_file_number is the index on outfiles of this file,
4121    so that the output file name can be stored for later use by %o.
4122    input_basename is the start of the part of the input file
4123    sans all directory names, and basename_length is the number
4124    of characters starting there excluding the suffix .c or whatever.  */
4125
4126 const char *input_filename;
4127 static int input_file_number;
4128 size_t input_filename_length;
4129 static int basename_length;
4130 static int suffixed_basename_length;
4131 static const char *input_basename;
4132 static const char *input_suffix;
4133 static struct stat input_stat;
4134 static int input_stat_set;
4135
4136 /* The compiler used to process the current input file.  */
4137 static struct compiler *input_file_compiler;
4138
4139 /* These are variables used within do_spec and do_spec_1.  */
4140
4141 /* Nonzero if an arg has been started and not yet terminated
4142    (with space, tab or newline).  */
4143 static int arg_going;
4144
4145 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4146    is a temporary file name.  */
4147 static int delete_this_arg;
4148
4149 /* Nonzero means %w has been seen; the next arg to be terminated
4150    is the output file name of this compilation.  */
4151 static int this_is_output_file;
4152
4153 /* Nonzero means %s has been seen; the next arg to be terminated
4154    is the name of a library file and we should try the standard
4155    search dirs for it.  */
4156 static int this_is_library_file;
4157
4158 /* Nonzero means that the input of this command is coming from a pipe.  */
4159 static int input_from_pipe;
4160
4161 /* Nonnull means substitute this for any suffix when outputting a switches
4162    arguments.  */
4163 static const char *suffix_subst;
4164
4165 /* Process the spec SPEC and run the commands specified therein.
4166    Returns 0 if the spec is successfully processed; -1 if failed.  */
4167
4168 int
4169 do_spec (spec)
4170      const char *spec;
4171 {
4172   int value;
4173
4174   clear_args ();
4175   arg_going = 0;
4176   delete_this_arg = 0;
4177   this_is_output_file = 0;
4178   this_is_library_file = 0;
4179   input_from_pipe = 0;
4180   suffix_subst = NULL;
4181
4182   value = do_spec_1 (spec, 0, NULL);
4183
4184   /* Force out any unfinished command.
4185      If -pipe, this forces out the last command if it ended in `|'.  */
4186   if (value == 0)
4187     {
4188       if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4189         argbuf_index--;
4190
4191       set_collect_gcc_options ();
4192
4193       if (argbuf_index > 0)
4194         value = execute ();
4195     }
4196
4197   return value;
4198 }
4199
4200 /* Process the sub-spec SPEC as a portion of a larger spec.
4201    This is like processing a whole spec except that we do
4202    not initialize at the beginning and we do not supply a
4203    newline by default at the end.
4204    INSWITCH nonzero means don't process %-sequences in SPEC;
4205    in this case, % is treated as an ordinary character.
4206    This is used while substituting switches.
4207    INSWITCH nonzero also causes SPC not to terminate an argument.
4208
4209    Value is zero unless a line was finished
4210    and the command on that line reported an error.  */
4211
4212 static int
4213 do_spec_1 (spec, inswitch, soft_matched_part)
4214      const char *spec;
4215      int inswitch;
4216      const char *soft_matched_part;
4217 {
4218   const char *p = spec;
4219   int c;
4220   int i;
4221   const char *string;
4222   int value;
4223
4224   while ((c = *p++))
4225     /* If substituting a switch, treat all chars like letters.
4226        Otherwise, NL, SPC, TAB and % are special.  */
4227     switch (inswitch ? 'a' : c)
4228       {
4229       case '\n':
4230         /* End of line: finish any pending argument,
4231            then run the pending command if one has been started.  */
4232         if (arg_going)
4233           {
4234             obstack_1grow (&obstack, 0);
4235             string = obstack_finish (&obstack);
4236             if (this_is_library_file)
4237               string = find_file (string);
4238             store_arg (string, delete_this_arg, this_is_output_file);
4239             if (this_is_output_file)
4240               outfiles[input_file_number] = string;
4241           }
4242         arg_going = 0;
4243
4244         if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4245           {
4246             for (i = 0; i < n_switches; i++)
4247               if (!strcmp (switches[i].part1, "pipe"))
4248                 break;
4249
4250             /* A `|' before the newline means use a pipe here,
4251                but only if -pipe was specified.
4252                Otherwise, execute now and don't pass the `|' as an arg.  */
4253             if (i < n_switches)
4254               {
4255                 input_from_pipe = 1;
4256                 switches[i].validated = 1;
4257                 break;
4258               }
4259             else
4260               argbuf_index--;
4261           }
4262
4263         set_collect_gcc_options ();
4264
4265         if (argbuf_index > 0)
4266           {
4267             value = execute ();
4268             if (value)
4269               return value;
4270           }
4271         /* Reinitialize for a new command, and for a new argument.  */
4272         clear_args ();
4273         arg_going = 0;
4274         delete_this_arg = 0;
4275         this_is_output_file = 0;
4276         this_is_library_file = 0;
4277         input_from_pipe = 0;
4278         break;
4279
4280       case '|':
4281         /* End any pending argument.  */
4282         if (arg_going)
4283           {
4284             obstack_1grow (&obstack, 0);
4285             string = obstack_finish (&obstack);
4286             if (this_is_library_file)
4287               string = find_file (string);
4288             store_arg (string, delete_this_arg, this_is_output_file);
4289             if (this_is_output_file)
4290               outfiles[input_file_number] = string;
4291           }
4292
4293         /* Use pipe */
4294         obstack_1grow (&obstack, c);
4295         arg_going = 1;
4296         break;
4297
4298       case '\t':
4299       case ' ':
4300         /* Space or tab ends an argument if one is pending.  */
4301         if (arg_going)
4302           {
4303             obstack_1grow (&obstack, 0);
4304             string = obstack_finish (&obstack);
4305             if (this_is_library_file)
4306               string = find_file (string);
4307             store_arg (string, delete_this_arg, this_is_output_file);
4308             if (this_is_output_file)
4309               outfiles[input_file_number] = string;
4310           }
4311         /* Reinitialize for a new argument.  */
4312         arg_going = 0;
4313         delete_this_arg = 0;
4314         this_is_output_file = 0;
4315         this_is_library_file = 0;
4316         break;
4317
4318       case '%':
4319         switch (c = *p++)
4320           {
4321           case 0:
4322             fatal ("invalid specification!  Bug in cc");
4323
4324           case 'b':
4325             obstack_grow (&obstack, input_basename, basename_length);
4326             arg_going = 1;
4327             break;
4328
4329           case 'B':
4330             obstack_grow (&obstack, input_basename, suffixed_basename_length);
4331             arg_going = 1;
4332             break;
4333
4334           case 'd':
4335             delete_this_arg = 2;
4336             break;
4337
4338           /* Dump out the directories specified with LIBRARY_PATH,
4339              followed by the absolute directories
4340              that we search for startfiles.  */
4341           case 'D':
4342             {
4343               struct prefix_list *pl = startfile_prefixes.plist;
4344               size_t bufsize = 100;
4345               char *buffer = (char *) xmalloc (bufsize);
4346               int idx;
4347
4348               for (; pl; pl = pl->next)
4349                 {
4350 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4351                   /* Used on systems which record the specified -L dirs
4352                      and use them to search for dynamic linking.  */
4353                   /* Relative directories always come from -B,
4354                      and it is better not to use them for searching
4355                      at run time.  In particular, stage1 loses.  */
4356                   if (!IS_ABSOLUTE_PATHNAME (pl->prefix))
4357                     continue;
4358 #endif
4359                   /* Try subdirectory if there is one.  */
4360                   if (multilib_dir != NULL)
4361                     {
4362                       if (machine_suffix)
4363                         {
4364                           if (strlen (pl->prefix) + strlen (machine_suffix)
4365                               >= bufsize)
4366                             bufsize = (strlen (pl->prefix)
4367                                        + strlen (machine_suffix)) * 2 + 1;
4368                           buffer = (char *) xrealloc (buffer, bufsize);
4369                           strcpy (buffer, pl->prefix);
4370                           strcat (buffer, machine_suffix);
4371                           if (is_directory (buffer, multilib_dir, 1))
4372                             {
4373                               do_spec_1 ("-L", 0, NULL);
4374 #ifdef SPACE_AFTER_L_OPTION
4375                               do_spec_1 (" ", 0, NULL);
4376 #endif
4377                               do_spec_1 (buffer, 1, NULL);
4378                               do_spec_1 (multilib_dir, 1, NULL);
4379                               /* Make this a separate argument.  */
4380                               do_spec_1 (" ", 0, NULL);
4381                             }
4382                         }
4383                       if (!pl->require_machine_suffix)
4384                         {
4385                           if (is_directory (pl->prefix, multilib_dir, 1))
4386                             {
4387                               do_spec_1 ("-L", 0, NULL);
4388 #ifdef SPACE_AFTER_L_OPTION
4389                               do_spec_1 (" ", 0, NULL);
4390 #endif
4391                               do_spec_1 (pl->prefix, 1, NULL);
4392                               do_spec_1 (multilib_dir, 1, NULL);
4393                               /* Make this a separate argument.  */
4394                               do_spec_1 (" ", 0, NULL);
4395                             }
4396                         }
4397                     }
4398                   if (machine_suffix)
4399                     {
4400                       if (is_directory (pl->prefix, machine_suffix, 1))
4401                         {
4402                           do_spec_1 ("-L", 0, NULL);
4403 #ifdef SPACE_AFTER_L_OPTION
4404                           do_spec_1 (" ", 0, NULL);
4405 #endif
4406                           do_spec_1 (pl->prefix, 1, NULL);
4407                           /* Remove slash from machine_suffix.  */
4408                           if (strlen (machine_suffix) >= bufsize)
4409                             bufsize = strlen (machine_suffix) * 2 + 1;
4410                           buffer = (char *) xrealloc (buffer, bufsize);
4411                           strcpy (buffer, machine_suffix);
4412                           idx = strlen (buffer);
4413                           if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4414                             buffer[idx - 1] = 0;
4415                           do_spec_1 (buffer, 1, NULL);
4416                           /* Make this a separate argument.  */
4417                           do_spec_1 (" ", 0, NULL);
4418                         }
4419                     }
4420                   if (!pl->require_machine_suffix)
4421                     {
4422                       if (is_directory (pl->prefix, "", 1))
4423                         {
4424                           do_spec_1 ("-L", 0, NULL);
4425 #ifdef SPACE_AFTER_L_OPTION
4426                           do_spec_1 (" ", 0, NULL);
4427 #endif
4428                           /* Remove slash from pl->prefix.  */
4429                           if (strlen (pl->prefix) >= bufsize)
4430                             bufsize = strlen (pl->prefix) * 2 + 1;
4431                           buffer = (char *) xrealloc (buffer, bufsize);
4432                           strcpy (buffer, pl->prefix);
4433                           idx = strlen (buffer);
4434                           if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4435                             buffer[idx - 1] = 0;
4436                           do_spec_1 (buffer, 1, NULL);
4437                           /* Make this a separate argument.  */
4438                           do_spec_1 (" ", 0, NULL);
4439                         }
4440                     }
4441                 }
4442               free (buffer);
4443             }
4444             break;
4445
4446           case 'e':
4447             /* %efoo means report an error with `foo' as error message
4448                and don't execute any more commands for this file.  */
4449             {
4450               const char *q = p;
4451               char *buf;
4452               while (*p != 0 && *p != '\n')
4453                 p++;
4454               buf = (char *) alloca (p - q + 1);
4455               strncpy (buf, q, p - q);
4456               buf[p - q] = 0;
4457               error ("%s", buf);
4458               return -1;
4459             }
4460             break;
4461           case 'n':
4462             /* %nfoo means report an notice with `foo' on stderr.  */
4463             {
4464               const char *q = p;
4465               char *buf;
4466               while (*p != 0 && *p != '\n')
4467                 p++;
4468               buf = (char *) alloca (p - q + 1);
4469               strncpy (buf, q, p - q);
4470               buf[p - q] = 0;
4471               notice ("%s\n", buf);
4472               if (*p)
4473                 p++;
4474             }
4475             break;
4476
4477           case 'j':
4478             {
4479               struct stat st;
4480
4481               /* If save_temps_flag is off, and the HOST_BIT_BUCKET is defined,
4482                  and it is not a directory, and it is writable, use it.
4483                  Otherwise, fall through and treat this like any other
4484                  temporary file.  */
4485
4486               if ((!save_temps_flag)
4487                   && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4488                   && (access (HOST_BIT_BUCKET, W_OK) == 0))
4489                 {
4490                   obstack_grow (&obstack, HOST_BIT_BUCKET,
4491                                 strlen (HOST_BIT_BUCKET));
4492                   delete_this_arg = 0;
4493                   arg_going = 1;
4494                   break;
4495                 }
4496             }
4497           case 'g':
4498           case 'u':
4499           case 'U':
4500               {
4501                 struct temp_name *t;
4502                 int suffix_length;
4503                 const char *suffix = p;
4504                 char *saved_suffix = NULL;
4505
4506                 while (*p == '.' || ISALPHA ((unsigned char) *p))
4507                   p++;
4508                 suffix_length = p - suffix;
4509                 if (p[0] == '%' && p[1] == 'O')
4510                   {
4511                     p += 2;
4512                     /* We don't support extra suffix characters after %O.  */
4513                     if (*p == '.' || ISALPHA ((unsigned char) *p))
4514                       abort ();
4515                     if (suffix_length == 0)
4516                       suffix = TARGET_OBJECT_SUFFIX;
4517                     else
4518                       {
4519                         saved_suffix
4520                           = (char *) xmalloc (suffix_length
4521                                               + strlen (TARGET_OBJECT_SUFFIX));
4522                         strncpy (saved_suffix, suffix, suffix_length);
4523                         strcpy (saved_suffix + suffix_length,
4524                                 TARGET_OBJECT_SUFFIX);
4525                       }
4526                     suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4527                   }
4528                 
4529                 /* If the input_filename has the same suffix specified
4530                    for the %g, %u, or %U, and -save-temps is specified,
4531                    we could end up using that file as an intermediate
4532                    thus clobbering the user's source file (.e.g.,
4533                    gcc -save-temps foo.s would clobber foo.s with the
4534                    output of cpp0).  So check for this condition and
4535                    generate a temp file as the intermediate.  */
4536                    
4537                 if (save_temps_flag)
4538                   {
4539                     temp_filename_length = basename_length + suffix_length;
4540                     temp_filename = alloca (temp_filename_length + 1);
4541                     strncpy ((char *) temp_filename, input_basename, basename_length);
4542                     strncpy ((char *) temp_filename + basename_length, suffix,
4543                              suffix_length);
4544                     *((char *) temp_filename + temp_filename_length) = '\0';
4545                     if (strcmp (temp_filename, input_filename) != 0)
4546                       {
4547                         struct stat st_temp;
4548                         
4549                         /* Note, set_input() resets input_stat_set to 0.  */
4550                         if (input_stat_set == 0)
4551                           {
4552                             input_stat_set = stat (input_filename, &input_stat);
4553                             if (input_stat_set >= 0)
4554                               input_stat_set = 1;
4555                           }
4556                           
4557                         /* If we have the stat for the input_filename
4558                            and we can do the stat for the temp_filename
4559                            then the they could still refer to the same
4560                            file if st_dev/st_ino's are the same.  */
4561                         
4562                         if (input_stat_set != 1
4563                             || stat (temp_filename, &st_temp) < 0
4564                             || input_stat.st_dev != st_temp.st_dev
4565                             || input_stat.st_ino != st_temp.st_ino)
4566                           {
4567                             temp_filename = save_string (temp_filename,
4568                                                          temp_filename_length + 1);
4569                             obstack_grow (&obstack, temp_filename,
4570                                                     temp_filename_length);
4571                             arg_going = 1;
4572                             break;
4573                           }
4574                       }
4575                   }
4576
4577                 /* See if we already have an association of %g/%u/%U and
4578                    suffix.  */
4579                 for (t = temp_names; t; t = t->next)
4580                   if (t->length == suffix_length
4581                       && strncmp (t->suffix, suffix, suffix_length) == 0
4582                       && t->unique == (c != 'g'))
4583                     break;
4584
4585                 /* Make a new association if needed.  %u and %j
4586                    require one.  */
4587                 if (t == 0 || c == 'u' || c == 'j')
4588                   {
4589                     if (t == 0)
4590                       {
4591                         t = (struct temp_name *) xmalloc (sizeof (struct temp_name));
4592                         t->next = temp_names;
4593                         temp_names = t;
4594                       }
4595                     t->length = suffix_length;
4596                     if (saved_suffix)
4597                       {
4598                         t->suffix = saved_suffix;
4599                         saved_suffix = NULL;
4600                       }
4601                     else
4602                       t->suffix = save_string (suffix, suffix_length);
4603                     t->unique = (c != 'g');
4604                     temp_filename = make_temp_file (t->suffix);
4605                     temp_filename_length = strlen (temp_filename);
4606                     t->filename = temp_filename;
4607                     t->filename_length = temp_filename_length;
4608                   }
4609
4610                 if (saved_suffix)
4611                   free (saved_suffix);
4612
4613                 obstack_grow (&obstack, t->filename, t->filename_length);
4614                 delete_this_arg = 1;
4615               }
4616             arg_going = 1;
4617             break;
4618
4619           case 'i':
4620             obstack_grow (&obstack, input_filename, input_filename_length);
4621             arg_going = 1;
4622             break;
4623
4624           case 'I':
4625             {
4626               struct prefix_list *pl = include_prefixes.plist;
4627
4628               if (gcc_exec_prefix)
4629                 {
4630                   do_spec_1 ("-iprefix", 1, NULL);
4631                   /* Make this a separate argument.  */
4632                   do_spec_1 (" ", 0, NULL);
4633                   do_spec_1 (gcc_exec_prefix, 1, NULL);
4634                   do_spec_1 (" ", 0, NULL);
4635                 }
4636
4637               for (; pl; pl = pl->next)
4638                 {
4639                   do_spec_1 ("-isystem", 1, NULL);
4640                   /* Make this a separate argument.  */
4641                   do_spec_1 (" ", 0, NULL);
4642                   do_spec_1 (pl->prefix, 1, NULL);
4643                   do_spec_1 (" ", 0, NULL);
4644                 }
4645             }
4646             break;
4647
4648           case 'o':
4649             {
4650               int max = n_infiles;
4651               max += lang_specific_extra_outfiles;
4652
4653               for (i = 0; i < max; i++)
4654                 if (outfiles[i])
4655                   store_arg (outfiles[i], 0, 0);
4656               break;
4657             }
4658
4659           case 'O':
4660             obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4661             arg_going = 1;
4662             break;
4663
4664           case 's':
4665             this_is_library_file = 1;
4666             break;
4667
4668           case 'w':
4669             this_is_output_file = 1;
4670             break;
4671
4672           case 'W':
4673             {
4674               int cur_index = argbuf_index;
4675               /* Handle the {...} following the %W.  */
4676               if (*p != '{')
4677                 abort ();
4678               p = handle_braces (p + 1);
4679               if (p == 0)
4680                 return -1;
4681               /* If any args were output, mark the last one for deletion
4682                  on failure.  */
4683               if (argbuf_index != cur_index)
4684                 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4685               break;
4686             }
4687
4688           /* %x{OPTION} records OPTION for %X to output.  */
4689           case 'x':
4690             {
4691               const char *p1 = p;
4692               char *string;
4693
4694               /* Skip past the option value and make a copy.  */
4695               if (*p != '{')
4696                 abort ();
4697               while (*p++ != '}')
4698                 ;
4699               string = save_string (p1 + 1, p - p1 - 2);
4700
4701               /* See if we already recorded this option.  */
4702               for (i = 0; i < n_linker_options; i++)
4703                 if (! strcmp (string, linker_options[i]))
4704                   {
4705                     free (string);
4706                     return 0;
4707                   }
4708
4709               /* This option is new; add it.  */
4710               add_linker_option (string, strlen (string));
4711             }
4712             break;
4713
4714           /* Dump out the options accumulated previously using %x.  */
4715           case 'X':
4716             for (i = 0; i < n_linker_options; i++)
4717               {
4718                 do_spec_1 (linker_options[i], 1, NULL);
4719                 /* Make each accumulated option a separate argument.  */
4720                 do_spec_1 (" ", 0, NULL);
4721               }
4722             break;
4723
4724           /* Dump out the options accumulated previously using -Wa,.  */
4725           case 'Y':
4726             for (i = 0; i < n_assembler_options; i++)
4727               {
4728                 do_spec_1 (assembler_options[i], 1, NULL);
4729                 /* Make each accumulated option a separate argument.  */
4730                 do_spec_1 (" ", 0, NULL);
4731               }
4732             break;
4733
4734           /* Dump out the options accumulated previously using -Wp,.  */
4735           case 'Z':
4736             for (i = 0; i < n_preprocessor_options; i++)
4737               {
4738                 do_spec_1 (preprocessor_options[i], 1, NULL);
4739                 /* Make each accumulated option a separate argument.  */
4740                 do_spec_1 (" ", 0, NULL);
4741               }
4742             break;
4743
4744             /* Here are digits and numbers that just process
4745                a certain constant string as a spec.  */
4746
4747           case '1':
4748             value = do_spec_1 (cc1_spec, 0, NULL);
4749             if (value != 0)
4750               return value;
4751             break;
4752
4753           case '2':
4754             value = do_spec_1 (cc1plus_spec, 0, NULL);
4755             if (value != 0)
4756               return value;
4757             break;
4758
4759           case 'a':
4760             value = do_spec_1 (asm_spec, 0, NULL);
4761             if (value != 0)
4762               return value;
4763             break;
4764
4765           case 'A':
4766             value = do_spec_1 (asm_final_spec, 0, NULL);
4767             if (value != 0)
4768               return value;
4769             break;
4770
4771           case 'c':
4772             value = do_spec_1 (signed_char_spec, 0, NULL);
4773             if (value != 0)
4774               return value;
4775             break;
4776
4777           case 'C':
4778             {
4779               const char *const spec
4780                 = (input_file_compiler->cpp_spec 
4781                    ? input_file_compiler->cpp_spec 
4782                    : cpp_spec);
4783               value = do_spec_1 (spec, 0, NULL);
4784               if (value != 0)
4785                 return value;
4786             }
4787             break;
4788
4789           case 'E':
4790             value = do_spec_1 (endfile_spec, 0, NULL);
4791             if (value != 0)
4792               return value;
4793             break;
4794
4795           case 'l':
4796             value = do_spec_1 (link_spec, 0, NULL);
4797             if (value != 0)
4798               return value;
4799             break;
4800
4801           case 'L':
4802             value = do_spec_1 (lib_spec, 0, NULL);
4803             if (value != 0)
4804               return value;
4805             break;
4806
4807           case 'G':
4808             value = do_spec_1 (libgcc_spec, 0, NULL);
4809             if (value != 0)
4810               return value;
4811             break;
4812
4813           case 'M':
4814             if (multilib_dir && strcmp (multilib_dir, ".") != 0)
4815               {
4816                 char *p;
4817                 const char *q;
4818                 size_t len;
4819
4820                 len = strlen (multilib_dir);
4821                 obstack_blank (&obstack, len + 1);
4822                 p = obstack_next_free (&obstack) - (len + 1);
4823
4824                 *p++ = '_';
4825                 for (q = multilib_dir; *q ; ++q, ++p)
4826                   *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
4827               }
4828             break;
4829
4830           case 'p':
4831             {
4832               char *x = (char *) alloca (strlen (cpp_predefines) + 1);
4833               char *buf = x;
4834               const char *y;
4835
4836               /* Copy all of the -D options in CPP_PREDEFINES into BUF.  */
4837               y = cpp_predefines;
4838               while (*y != 0)
4839                 {
4840                   if (! strncmp (y, "-D", 2))
4841                     /* Copy the whole option.  */
4842                     while (*y && *y != ' ' && *y != '\t')
4843                       *x++ = *y++;
4844                   else if (*y == ' ' || *y == '\t')
4845                     /* Copy whitespace to the result.  */
4846                     *x++ = *y++;
4847                   /* Don't copy other options.  */
4848                   else
4849                     y++;
4850                 }
4851
4852               *x = 0;
4853
4854               value = do_spec_1 (buf, 0, NULL);
4855               if (value != 0)
4856                 return value;
4857             }
4858             break;
4859
4860           case 'P':
4861             {
4862               char *x = (char *) alloca (strlen (cpp_predefines) * 4 + 1);
4863               char *buf = x;
4864               const char *y;
4865
4866               /* Copy all of CPP_PREDEFINES into BUF,
4867                  but force them all into the reserved name space if they
4868                  aren't already there.  The reserved name space is all
4869                  identifiers beginning with two underscores or with one
4870                  underscore and a capital letter.  We do the forcing by
4871                  adding up to two underscores to the beginning and end
4872                  of each symbol. e.g. mips, _mips, mips_, and _mips_ all
4873                  become __mips__.  */
4874               y = cpp_predefines;
4875               while (*y != 0)
4876                 {
4877                   if (! strncmp (y, "-D", 2))
4878                     {
4879                       int flag = 0;
4880
4881                       *x++ = *y++;
4882                       *x++ = *y++;
4883
4884                       if (*y != '_'
4885                           || (*(y + 1) != '_'
4886                               && ! ISUPPER ((unsigned char) *(y + 1))))
4887                         {
4888                           /* Stick __ at front of macro name.  */
4889                           if (*y != '_')
4890                             *x++ = '_';
4891                           *x++ = '_';
4892                           /* Arrange to stick __ at the end as well.  */
4893                           flag = 1;
4894                         }
4895
4896                       /* Copy the macro name.  */
4897                       while (*y && *y != '=' && *y != ' ' && *y != '\t')
4898                         *x++ = *y++;
4899
4900                       if (flag)
4901                         {
4902                           if (x[-1] != '_')
4903                             {
4904                               if (x[-2] != '_')
4905                                 *x++ = '_';
4906                               *x++ = '_';
4907                             }
4908                         }
4909
4910                       /* Copy the value given, if any.  */
4911                       while (*y && *y != ' ' && *y != '\t')
4912                         *x++ = *y++;
4913                     }
4914                   else if (*y == ' ' || *y == '\t')
4915                     /* Copy whitespace to the result.  */
4916                     *x++ = *y++;
4917                   /* Don't copy -A options  */
4918                   else
4919                     y++;
4920                 }
4921               *x++ = ' ';
4922
4923               /* Copy all of CPP_PREDEFINES into BUF,
4924                  but put __ after every -D.  */
4925               y = cpp_predefines;
4926               while (*y != 0)
4927                 {
4928                   if (! strncmp (y, "-D", 2))
4929                     {
4930                       y += 2;
4931
4932                       if (*y != '_'
4933                           || (*(y + 1) != '_'
4934                               && ! ISUPPER ((unsigned char) *(y + 1))))
4935                         {
4936                           /* Stick -D__ at front of macro name.  */
4937                           *x++ = '-';
4938                           *x++ = 'D';
4939                           if (*y != '_')
4940                             *x++ = '_';
4941                           *x++ = '_';
4942
4943                           /* Copy the macro name.  */
4944                           while (*y && *y != '=' && *y != ' ' && *y != '\t')
4945                             *x++ = *y++;
4946
4947                           /* Copy the value given, if any.  */
4948                           while (*y && *y != ' ' && *y != '\t')
4949                             *x++ = *y++;
4950                         }
4951                       else
4952                         {
4953                           /* Do not copy this macro - we have just done it before */
4954                           while (*y && *y != ' ' && *y != '\t')
4955                             y++;
4956                         }
4957                     }
4958                   else if (*y == ' ' || *y == '\t')
4959                     /* Copy whitespace to the result.  */
4960                     *x++ = *y++;
4961                   /* Don't copy -A options.  */
4962                   else
4963                     y++;
4964                 }
4965               *x++ = ' ';
4966
4967               /* Copy all of the -A options in CPP_PREDEFINES into BUF.  */
4968               y = cpp_predefines;
4969               while (*y != 0)
4970                 {
4971                   if (! strncmp (y, "-A", 2))
4972                     /* Copy the whole option.  */
4973                     while (*y && *y != ' ' && *y != '\t')
4974                       *x++ = *y++;
4975                   else if (*y == ' ' || *y == '\t')
4976                     /* Copy whitespace to the result.  */
4977                     *x++ = *y++;
4978                   /* Don't copy other options.  */
4979                   else
4980                     y++;
4981                 }
4982
4983               *x = 0;
4984
4985               value = do_spec_1 (buf, 0, NULL);
4986               if (value != 0)
4987                 return value;
4988             }
4989             break;
4990
4991           case 'S':
4992             value = do_spec_1 (startfile_spec, 0, NULL);
4993             if (value != 0)
4994               return value;
4995             break;
4996
4997             /* Here we define characters other than letters and digits.  */
4998
4999           case '{':
5000             p = handle_braces (p);
5001             if (p == 0)
5002               return -1;
5003             break;
5004
5005           case '%':
5006             obstack_1grow (&obstack, '%');
5007             break;
5008
5009          case '.':
5010            {
5011              unsigned len = 0;
5012
5013              while (p[len] && p[len] != ' ' && p[len] != '%')
5014                len++;
5015              suffix_subst = save_string (p - 1, len + 1);
5016              p += len;
5017            }
5018            break;
5019           
5020           case '*':
5021             if (soft_matched_part)
5022               {
5023                 do_spec_1 (soft_matched_part, 1, NULL);
5024                 do_spec_1 (" ", 0, NULL);
5025               }
5026             else
5027               /* Catch the case where a spec string contains something like
5028                  '%{foo:%*}'.  ie there is no * in the pattern on the left
5029                  hand side of the :.  */
5030               error ("spec failure: '%%*' has not been initialized by pattern match");
5031             break;
5032
5033             /* Process a string found as the value of a spec given by name.
5034                This feature allows individual machine descriptions
5035                to add and use their own specs.
5036                %[...] modifies -D options the way %P does;
5037                %(...) uses the spec unmodified.  */
5038           case '[':
5039             error ("warning: use of obsolete %%[ operator in specs");
5040           case '(':
5041             {
5042               const char *name = p;
5043               struct spec_list *sl;
5044               int len;
5045
5046               /* The string after the S/P is the name of a spec that is to be
5047                  processed.  */
5048               while (*p && *p != ')' && *p != ']')
5049                 p++;
5050
5051               /* See if it's in the list.  */
5052               for (len = p - name, sl = specs; sl; sl = sl->next)
5053                 if (sl->name_len == len && !strncmp (sl->name, name, len))
5054                   {
5055                     name = *(sl->ptr_spec);
5056 #ifdef DEBUG_SPECS
5057                     notice ("Processing spec %c%s%c, which is '%s'\n",
5058                             c, sl->name, (c == '(') ? ')' : ']', name);
5059 #endif
5060                     break;
5061                   }
5062
5063               if (sl)
5064                 {
5065                   if (c == '(')
5066                     {
5067                       value = do_spec_1 (name, 0, NULL);
5068                       if (value != 0)
5069                         return value;
5070                     }
5071                   else
5072                     {
5073                       char *x = (char *) alloca (strlen (name) * 2 + 1);
5074                       char *buf = x;
5075                       const char *y = name;
5076                       int flag = 0;
5077
5078                       /* Copy all of NAME into BUF, but put __ after
5079                          every -D and at the end of each arg.  */
5080                       while (1)
5081                         {
5082                           if (! strncmp (y, "-D", 2))
5083                             {
5084                               *x++ = '-';
5085                               *x++ = 'D';
5086                               *x++ = '_';
5087                               *x++ = '_';
5088                               y += 2;
5089                               flag = 1;
5090                               continue;
5091                             }
5092                           else if (flag
5093                                    && (*y == ' ' || *y == '\t' || *y == '='
5094                                        || *y == '}' || *y == 0))
5095                             {
5096                               *x++ = '_';
5097                               *x++ = '_';
5098                               flag = 0;
5099                             }
5100                           if (*y == 0)
5101                             break;
5102                           else
5103                             *x++ = *y++;
5104                         }
5105                       *x = 0;
5106
5107                       value = do_spec_1 (buf, 0, NULL);
5108                       if (value != 0)
5109                         return value;
5110                     }
5111                 }
5112
5113               /* Discard the closing paren or bracket.  */
5114               if (*p)
5115                 p++;
5116             }
5117             break;
5118
5119           case 'v':
5120             {
5121               int c1 = *p++;  /* Select first or second version number.  */
5122               const char *v = compiler_version;
5123               const char *q;
5124               static const char zeroc = '0';
5125
5126               /* The format of the version string is
5127                  ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)?  */
5128
5129               /* Ignore leading non-digits.  i.e. "foo-" in "foo-2.7.2".  */
5130               while (! ISDIGIT (*v))
5131                 v++;
5132               if (v > compiler_version && v[-1] != '-')
5133                 abort ();
5134
5135               /* If desired, advance to second version number.  */
5136               if (c1 >= '2')
5137                 {
5138                   /* Set V after the first period.  */
5139                   while (ISDIGIT (*v))
5140                     v++;
5141                   if (*v != '.')
5142                     abort ();
5143                   v++;
5144                 }
5145
5146               /* If desired, advance to third version number.
5147                  But don't complain if it's not present */
5148               if (c1 == '3')
5149                 {
5150                   /* Set V after the second period.  */
5151                   while (ISDIGIT (*v))
5152                     v++;
5153                   if ((*v != 0) && (*v != ' ') && (*v != '.') && (*v != '-'))
5154                     abort ();
5155                   if (*v != 0)
5156                     v++;
5157                 }
5158
5159               /* Set Q at the next period or at the end.  */
5160               q = v;
5161               while (ISDIGIT (*q))
5162                 q++;
5163               if (*q != 0 && q > v && *q != ' ' && *q != '.' && *q != '-')
5164                 abort ();
5165
5166               if (q > v)
5167                 /* Put that part into the command.  */
5168                 obstack_grow (&obstack, v, q - v);
5169               else
5170                 /* Default to "0" */
5171                 obstack_grow (&obstack, &zeroc, 1);
5172               arg_going = 1;
5173             }
5174             break;
5175
5176           case '|':
5177             if (input_from_pipe)
5178               do_spec_1 ("-", 0, NULL);
5179             break;
5180
5181           default:
5182             error ("spec failure: unrecognized spec option '%c'", c);
5183             break;
5184           }
5185         break;
5186
5187       case '\\':
5188         /* Backslash: treat next character as ordinary.  */
5189         c = *p++;
5190
5191         /* fall through */
5192       default:
5193         /* Ordinary character: put it into the current argument.  */
5194         obstack_1grow (&obstack, c);
5195         arg_going = 1;
5196       }
5197
5198   /* End of string.  */
5199   return 0;
5200 }
5201
5202 /* Return 0 if we call do_spec_1 and that returns -1.  */
5203
5204 static const char *
5205 handle_braces (p)
5206      const char *p;
5207 {
5208   const char *filter, *body = NULL, *endbody = NULL;
5209   int pipe_p = 0;
5210   int true_once = 0;    /* If, in %{a|b:d}, at least one of a,b was seen.  */
5211   int negate;
5212   int suffix;
5213   int include_blanks = 1;
5214   int elide_switch = 0;
5215   int ordered = 0;
5216
5217   if (*p == '^')
5218     {
5219       /* A '^' after the open-brace means to not give blanks before args.  */
5220       include_blanks = 0;
5221       ++p;
5222     }
5223
5224   if (*p == '|')
5225     {
5226       /* A `|' after the open-brace means,
5227          if the test fails, output a single minus sign rather than nothing.
5228          This is used in %{|!pipe:...}.  */
5229       pipe_p = 1;
5230       ++p;
5231     }
5232
5233   if (*p == '<')
5234     {
5235       /* A `<' after the open-brace means that the switch should be
5236          removed from the command-line.  */
5237       elide_switch = 1;
5238       ++p;
5239     }
5240
5241 next_member:
5242   negate = suffix = 0;
5243
5244   if (*p == '!')
5245     /* A `!' after the open-brace negates the condition:
5246        succeed if the specified switch is not present.  */
5247     negate = 1, ++p;
5248
5249   if (*p == '.')
5250     /* A `.' after the open-brace means test against the current suffix.  */
5251     {
5252       if (pipe_p)
5253         abort ();
5254
5255       suffix = 1;
5256       ++p;
5257     }
5258
5259   if (elide_switch && (negate || pipe_p || suffix))
5260     {
5261       /* It doesn't make sense to mix elision with other flags.  We
5262          could fatal() here, but the standard seems to be to abort.  */
5263       abort ();
5264     }
5265
5266  next_ampersand:
5267   filter = p;
5268   while (*p != ':' && *p != '}' && *p != '|' && *p != '&')
5269     p++;
5270
5271   if (*p == '|' && (pipe_p || ordered))
5272     abort ();
5273
5274   if (!body)
5275     {
5276       if (*p != '}' && *p != '&')
5277         {
5278           int count = 1;
5279           const char *q = p;
5280
5281           while (*q++ != ':')
5282             continue;
5283           body = q;
5284
5285           while (count > 0)
5286             {
5287               if (*q == '{')
5288                 count++;
5289               else if (*q == '}')
5290                 count--;
5291               else if (*q == 0)
5292                 fatal ("mismatched braces in specs");
5293               q++;
5294             }
5295           endbody = q;
5296         }
5297       else
5298         body = p, endbody = p + 1;
5299     }
5300
5301   if (suffix)
5302     {
5303       int found = (input_suffix != 0
5304                    && (long) strlen (input_suffix) == (long) (p - filter)
5305                    && strncmp (input_suffix, filter, p - filter) == 0);
5306
5307       if (body[0] == '}')
5308         abort ();
5309
5310       if (negate != found
5311           && do_spec_1 (save_string (body, endbody-body-1), 0, NULL) < 0)
5312         return 0;
5313     }
5314   else if (p[-1] == '*' && (p[0] == '}' || p[0] == '&'))
5315     {
5316       /* Substitute all matching switches as separate args.  */
5317       int i;
5318
5319       for (i = 0; i < n_switches; i++)
5320         if (!strncmp (switches[i].part1, filter, p - 1 - filter)
5321             && check_live_switch (i, p - 1 - filter))
5322           {
5323             if (elide_switch)
5324               {
5325                 switches[i].live_cond = SWITCH_IGNORE;
5326                 switches[i].validated = 1;
5327               }
5328             else
5329               ordered = 1, switches[i].ordering = 1;
5330           }
5331     }
5332   else
5333     {
5334       /* Test for presence of the specified switch.  */
5335       int i;
5336       int present = 0;
5337
5338       /* If name specified ends in *, as in {x*:...},
5339          check for %* and handle that case.  */
5340       if (p[-1] == '*' && !negate)
5341         {
5342           int substitution;
5343           const char *r = body;
5344
5345           /* First see whether we have %*.  */
5346           substitution = 0;
5347           while (r < endbody)
5348             {
5349               if (*r == '%' && r[1] == '*')
5350                 substitution = 1;
5351               r++;
5352             }
5353           /* If we do, handle that case.  */
5354           if (substitution)
5355             {
5356               /* Substitute all matching switches as separate args.
5357                  But do this by substituting for %*
5358                  in the text that follows the colon.  */
5359
5360               unsigned hard_match_len = p - filter - 1;
5361               char *string = save_string (body, endbody - body - 1);
5362
5363               for (i = 0; i < n_switches; i++)
5364                 if (!strncmp (switches[i].part1, filter, hard_match_len)
5365                     && check_live_switch (i, -1))
5366                   {
5367                     do_spec_1 (string, 0, &switches[i].part1[hard_match_len]);
5368                     /* Pass any arguments this switch has.  */
5369                     give_switch (i, 1, 1);
5370                     suffix_subst = NULL;
5371                   }
5372
5373               /* We didn't match.  Try again.  */
5374               if (*p++ == '|')
5375                 goto next_member;
5376               return endbody;
5377             }
5378         }
5379
5380       /* If name specified ends in *, as in {x*:...},
5381          check for presence of any switch name starting with x.  */
5382       if (p[-1] == '*')
5383         {
5384           for (i = 0; i < n_switches; i++)
5385             {
5386               unsigned hard_match_len = p - filter - 1;
5387
5388               if (!strncmp (switches[i].part1, filter, hard_match_len)
5389                   && check_live_switch (i, hard_match_len))
5390                 {
5391                   present = 1;
5392                   break;
5393                 }
5394             }
5395         }
5396       /* Otherwise, check for presence of exact name specified.  */
5397       else
5398         {
5399           for (i = 0; i < n_switches; i++)
5400             {
5401               if (!strncmp (switches[i].part1, filter, p - filter)
5402                   && switches[i].part1[p - filter] == 0
5403                   && check_live_switch (i, -1))
5404                 {
5405                   present = 1;
5406                   break;
5407                 }
5408             }
5409         }
5410
5411       /* If it is as desired (present for %{s...}, absent for %{!s...})
5412          then substitute either the switch or the specified
5413          conditional text.  */
5414       if (present != negate)
5415         {
5416           if (elide_switch)
5417             {
5418               switches[i].live_cond = SWITCH_IGNORE;
5419               switches[i].validated = 1;
5420             }
5421           else if (ordered || *p == '&')
5422             ordered = 1, switches[i].ordering = 1;
5423           else if (*p == '}')
5424             give_switch (i, 0, include_blanks);
5425           else
5426             /* Even if many alternatives are matched, only output once.  */
5427             true_once = 1;
5428         }
5429       else if (pipe_p)
5430         {
5431           /* Here if a %{|...} conditional fails: output a minus sign,
5432              which means "standard output" or "standard input".  */
5433           do_spec_1 ("-", 0, NULL);
5434           return endbody;
5435         }
5436     }
5437
5438   /* We didn't match; try again.  */
5439   if (*p++ == '|')
5440     goto next_member;
5441
5442   if (p[-1] == '&')
5443     {
5444       body = 0;
5445       goto next_ampersand;
5446     }
5447
5448   if (ordered)
5449     {
5450       int i;
5451       /* Doing this set of switches later preserves their command-line
5452          ordering.  This is needed for e.g. -U, -D and -A.  */
5453       for (i = 0; i < n_switches; i++)
5454         if (switches[i].ordering == 1)
5455           {
5456             switches[i].ordering = 0;
5457             give_switch (i, 0, include_blanks);
5458           }
5459     }
5460   /* Process the spec just once, regardless of match count.  */
5461   else if (true_once)
5462     {
5463       if (do_spec_1 (save_string (body, endbody - body - 1),
5464                      0, NULL) < 0)
5465         return 0;
5466     }
5467
5468   return endbody;
5469 }
5470 \f
5471 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5472    on the command line.  PREFIX_LENGTH is the length of XXX in an {XXX*}
5473    spec, or -1 if either exact match or %* is used.
5474
5475    A -O switch is obsoleted by a later -O switch.  A -f, -m, or -W switch
5476    whose value does not begin with "no-" is obsoleted by the same value
5477    with the "no-", similarly for a switch with the "no-" prefix.  */
5478
5479 static int
5480 check_live_switch (switchnum, prefix_length)
5481      int switchnum;
5482      int prefix_length;
5483 {
5484   const char *name = switches[switchnum].part1;
5485   int i;
5486
5487   /* In the common case of {<at-most-one-letter>*}, a negating
5488      switch would always match, so ignore that case.  We will just
5489      send the conflicting switches to the compiler phase.  */
5490   if (prefix_length >= 0 && prefix_length <= 1)
5491     return 1;
5492
5493   /* If we already processed this switch and determined if it was
5494      live or not, return our past determination.  */
5495   if (switches[switchnum].live_cond != 0)
5496     return switches[switchnum].live_cond > 0;
5497
5498   /* Now search for duplicate in a manner that depends on the name.  */
5499   switch (*name)
5500     {
5501     case 'O':
5502       for (i = switchnum + 1; i < n_switches; i++)
5503         if (switches[i].part1[0] == 'O')
5504           {
5505             switches[switchnum].validated = 1;
5506             switches[switchnum].live_cond = SWITCH_FALSE;
5507             return 0;
5508           }
5509       break;
5510
5511     case 'W':  case 'f':  case 'm':
5512       if (! strncmp (name + 1, "no-", 3))
5513         {
5514           /* We have Xno-YYY, search for XYYY.  */
5515           for (i = switchnum + 1; i < n_switches; i++)
5516             if (switches[i].part1[0] == name[0]
5517                 && ! strcmp (&switches[i].part1[1], &name[4]))
5518               {
5519                 switches[switchnum].validated = 1;
5520                 switches[switchnum].live_cond = SWITCH_FALSE;
5521                 return 0;
5522               }
5523         }
5524       else
5525         {
5526           /* We have XYYY, search for Xno-YYY.  */
5527           for (i = switchnum + 1; i < n_switches; i++)
5528             if (switches[i].part1[0] == name[0]
5529                 && switches[i].part1[1] == 'n'
5530                 && switches[i].part1[2] == 'o'
5531                 && switches[i].part1[3] == '-'
5532                 && !strcmp (&switches[i].part1[4], &name[1]))
5533               {
5534                 switches[switchnum].validated = 1;
5535                 switches[switchnum].live_cond = SWITCH_FALSE;
5536                 return 0;
5537               }
5538         }
5539       break;
5540     }
5541
5542   /* Otherwise the switch is live.  */
5543   switches[switchnum].live_cond = SWITCH_LIVE;
5544   return 1;
5545 }
5546 \f
5547 /* Pass a switch to the current accumulating command
5548    in the same form that we received it.
5549    SWITCHNUM identifies the switch; it is an index into
5550    the vector of switches gcc received, which is `switches'.
5551    This cannot fail since it never finishes a command line.
5552
5553    If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument.
5554
5555    If INCLUDE_BLANKS is nonzero, then we include blanks before each argument
5556    of the switch.  */
5557
5558 static void
5559 give_switch (switchnum, omit_first_word, include_blanks)
5560      int switchnum;
5561      int omit_first_word;
5562      int include_blanks;
5563 {
5564   if (switches[switchnum].live_cond == SWITCH_IGNORE)
5565     return;
5566
5567   if (!omit_first_word)
5568     {
5569       do_spec_1 ("-", 0, NULL);
5570       do_spec_1 (switches[switchnum].part1, 1, NULL);
5571     }
5572
5573   if (switches[switchnum].args != 0)
5574     {
5575       const char **p;
5576       for (p = switches[switchnum].args; *p; p++)
5577         {
5578           const char *arg = *p;
5579
5580           if (include_blanks)
5581             do_spec_1 (" ", 0, NULL);
5582           if (suffix_subst)
5583             {
5584               unsigned length = strlen (arg);
5585               int dot = 0;
5586
5587               while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5588                 if (arg[length] == '.')
5589                   {
5590                     ((char *)arg)[length] = 0;
5591                     dot = 1;
5592                     break;
5593                   }
5594               do_spec_1 (arg, 1, NULL);
5595               if (dot)
5596                 ((char *)arg)[length] = '.';
5597               do_spec_1 (suffix_subst, 1, NULL);
5598             }
5599           else
5600             do_spec_1 (arg, 1, NULL);
5601         }
5602     }
5603
5604   do_spec_1 (" ", 0, NULL);
5605   switches[switchnum].validated = 1;
5606 }
5607 \f
5608 /* Search for a file named NAME trying various prefixes including the
5609    user's -B prefix and some standard ones.
5610    Return the absolute file name found.  If nothing is found, return NAME.  */
5611
5612 static const char *
5613 find_file (name)
5614      const char *name;
5615 {
5616   char *newname;
5617
5618   /* Try multilib_dir if it is defined.  */
5619   if (multilib_dir != NULL)
5620     {
5621       const char *const try = ACONCAT ((multilib_dir, dir_separator_str, name, NULL));
5622
5623       newname = find_a_file (&startfile_prefixes, try, R_OK);
5624
5625       /* If we don't find it in the multi library dir, then fall
5626          through and look for it in the normal places.  */
5627       if (newname != NULL)
5628         return newname;
5629     }
5630
5631   newname = find_a_file (&startfile_prefixes, name, R_OK);
5632   return newname ? newname : name;
5633 }
5634
5635 /* Determine whether a directory exists.  If LINKER, return 0 for
5636    certain fixed names not needed by the linker.  If not LINKER, it is
5637    only important to return 0 if the host machine has a small ARG_MAX
5638    limit.  */
5639
5640 static int
5641 is_directory (path1, path2, linker)
5642      const char *path1;
5643      const char *path2;
5644      int linker;
5645 {
5646   int len1 = strlen (path1);
5647   int len2 = strlen (path2);
5648   char *path = (char *) alloca (3 + len1 + len2);
5649   char *cp;
5650   struct stat st;
5651
5652 #ifndef SMALL_ARG_MAX
5653   if (! linker)
5654     return 1;
5655 #endif
5656
5657   /* Construct the path from the two parts.  Ensure the string ends with "/.".
5658      The resulting path will be a directory even if the given path is a
5659      symbolic link.  */
5660   memcpy (path, path1, len1);
5661   memcpy (path + len1, path2, len2);
5662   cp = path + len1 + len2;
5663   if (!IS_DIR_SEPARATOR (cp[-1]))
5664     *cp++ = DIR_SEPARATOR;
5665   *cp++ = '.';
5666   *cp = '\0';
5667
5668   /* Exclude directories that the linker is known to search.  */
5669   if (linker
5670       && ((cp - path == 6
5671            && strcmp (path, concat (dir_separator_str, "lib",
5672                                     dir_separator_str, ".", NULL)) == 0)
5673           || (cp - path == 10
5674               && strcmp (path, concat (dir_separator_str, "usr",
5675                                        dir_separator_str, "lib",
5676                                        dir_separator_str, ".", NULL)) == 0)))
5677     return 0;
5678
5679   return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5680 }
5681
5682 /* Set up the various global variables to indicate that we're processing
5683    the input file named FILENAME.  */
5684
5685 void
5686 set_input (filename)
5687      const char *filename;
5688 {
5689   const char *p;
5690
5691   input_filename = filename;
5692   input_filename_length = strlen (input_filename);
5693
5694   input_basename = input_filename;
5695 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5696   /* Skip drive name so 'x:foo' is handled properly.  */
5697   if (input_basename[1] == ':')
5698     input_basename += 2;
5699 #endif
5700   for (p = input_basename; *p; p++)
5701     if (IS_DIR_SEPARATOR (*p))
5702       input_basename = p + 1;
5703
5704   /* Find a suffix starting with the last period,
5705      and set basename_length to exclude that suffix.  */
5706   basename_length = strlen (input_basename);
5707   suffixed_basename_length = basename_length;
5708   p = input_basename + basename_length;
5709   while (p != input_basename && *p != '.')
5710     --p;
5711   if (*p == '.' && p != input_basename)
5712     {
5713       basename_length = p - input_basename;
5714       input_suffix = p + 1;
5715     }
5716   else
5717     input_suffix = "";
5718   
5719   /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5720      we will need to do a stat on the input_filename.  The
5721      INPUT_STAT_SET signals that the stat is needed.  */
5722   input_stat_set = 0;
5723 }
5724 \f
5725 /* On fatal signals, delete all the temporary files.  */
5726
5727 static void
5728 fatal_error (signum)
5729      int signum;
5730 {
5731   signal (signum, SIG_DFL);
5732   delete_failure_queue ();
5733   delete_temp_files ();
5734   /* Get the same signal again, this time not handled,
5735      so its normal effect occurs.  */
5736   kill (getpid (), signum);
5737 }
5738
5739 extern int main PARAMS ((int, const char *const *));
5740
5741 int
5742 main (argc, argv)
5743      int argc;
5744      const char *const *argv;
5745 {
5746   size_t i;
5747   int value;
5748   int linker_was_run = 0;
5749   char *explicit_link_files;
5750   char *specs_file;
5751   const char *p;
5752   struct user_specs *uptr;
5753
5754   p = argv[0] + strlen (argv[0]);
5755   while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
5756     --p;
5757   programname = p;
5758
5759   xmalloc_set_program_name (programname);
5760
5761 #ifdef GCC_DRIVER_HOST_INITIALIZATION
5762   /* Perform host dependent initialization when needed.  */
5763   GCC_DRIVER_HOST_INITIALIZATION;
5764 #endif
5765
5766   gcc_init_libintl ();
5767
5768   if (signal (SIGINT, SIG_IGN) != SIG_IGN)
5769     signal (SIGINT, fatal_error);
5770 #ifdef SIGHUP
5771   if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
5772     signal (SIGHUP, fatal_error);
5773 #endif
5774   if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
5775     signal (SIGTERM, fatal_error);
5776 #ifdef SIGPIPE
5777   if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
5778     signal (SIGPIPE, fatal_error);
5779 #endif
5780 #ifdef SIGCHLD
5781   /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
5782      receive the signal.  A different setting is inheritable */
5783   signal (SIGCHLD, SIG_DFL);
5784 #endif
5785
5786   argbuf_length = 10;
5787   argbuf = (const char **) xmalloc (argbuf_length * sizeof (const char *));
5788
5789   obstack_init (&obstack);
5790
5791   /* Build multilib_select, et. al from the separate lines that make up each
5792      multilib selection.  */
5793   {
5794     const char *const *q = multilib_raw;
5795     int need_space;
5796
5797     obstack_init (&multilib_obstack);
5798     while ((p = *q++) != (char *) 0)
5799       obstack_grow (&multilib_obstack, p, strlen (p));
5800
5801     obstack_1grow (&multilib_obstack, 0);
5802     multilib_select = obstack_finish (&multilib_obstack);
5803
5804     q = multilib_matches_raw;
5805     while ((p = *q++) != (char *) 0)
5806       obstack_grow (&multilib_obstack, p, strlen (p));
5807
5808     obstack_1grow (&multilib_obstack, 0);
5809     multilib_matches = obstack_finish (&multilib_obstack);
5810
5811     q = multilib_exclusions_raw;
5812     while ((p = *q++) != (char *) 0)
5813       obstack_grow (&multilib_obstack, p, strlen (p));
5814
5815     obstack_1grow (&multilib_obstack, 0);
5816     multilib_exclusions = obstack_finish (&multilib_obstack);
5817
5818     need_space = FALSE;
5819     for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
5820       {
5821         if (need_space)
5822           obstack_1grow (&multilib_obstack, ' ');
5823         obstack_grow (&multilib_obstack,
5824                       multilib_defaults_raw[i],
5825                       strlen (multilib_defaults_raw[i]));
5826         need_space = TRUE;
5827       }
5828
5829     obstack_1grow (&multilib_obstack, 0);
5830     multilib_defaults = obstack_finish (&multilib_obstack);
5831   }
5832
5833   /* Set up to remember the pathname of gcc and any options
5834      needed for collect.  We use argv[0] instead of programname because
5835      we need the complete pathname.  */
5836   obstack_init (&collect_obstack);
5837   obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
5838   obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
5839   putenv (obstack_finish (&collect_obstack));
5840
5841 #ifdef INIT_ENVIRONMENT
5842   /* Set up any other necessary machine specific environment variables.  */
5843   putenv (INIT_ENVIRONMENT);
5844 #endif
5845
5846   /* Make a table of what switches there are (switches, n_switches).
5847      Make a table of specified input files (infiles, n_infiles).
5848      Decode switches that are handled locally.  */
5849
5850   process_command (argc, argv);
5851
5852   /* Initialize the vector of specs to just the default.
5853      This means one element containing 0s, as a terminator.  */
5854
5855   compilers = (struct compiler *) xmalloc (sizeof default_compilers);
5856   memcpy ((char *) compilers, (char *) default_compilers,
5857           sizeof default_compilers);
5858   n_compilers = n_default_compilers;
5859
5860   /* Read specs from a file if there is one.  */
5861
5862   machine_suffix = concat (spec_machine, dir_separator_str,
5863                            spec_version, dir_separator_str, NULL);
5864   just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
5865
5866   specs_file = find_a_file (&startfile_prefixes, "specs", R_OK);
5867   /* Read the specs file unless it is a default one.  */
5868   if (specs_file != 0 && strcmp (specs_file, "specs"))
5869     read_specs (specs_file, TRUE);
5870   else
5871     init_spec ();
5872
5873   /* We need to check standard_exec_prefix/just_machine_suffix/specs
5874      for any override of as, ld and libraries.  */
5875   specs_file = (char *) alloca (strlen (standard_exec_prefix)
5876                                 + strlen (just_machine_suffix)
5877                                 + sizeof ("specs"));
5878
5879   strcpy (specs_file, standard_exec_prefix);
5880   strcat (specs_file, just_machine_suffix);
5881   strcat (specs_file, "specs");
5882   if (access (specs_file, R_OK) == 0)
5883     read_specs (specs_file, TRUE);
5884
5885   /* If not cross-compiling, look for startfiles in the standard places.  */
5886   if (*cross_compile == '0')
5887     {
5888       if (*md_exec_prefix)
5889         {
5890           add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
5891                       PREFIX_PRIORITY_LAST, 0, NULL);
5892           add_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
5893                       PREFIX_PRIORITY_LAST, 0, NULL);
5894         }
5895
5896       if (*md_startfile_prefix)
5897         add_prefix (&startfile_prefixes, md_startfile_prefix, "GCC",
5898                     PREFIX_PRIORITY_LAST, 0, NULL);
5899
5900       if (*md_startfile_prefix_1)
5901         add_prefix (&startfile_prefixes, md_startfile_prefix_1, "GCC",
5902                     PREFIX_PRIORITY_LAST, 0, NULL);
5903
5904       /* If standard_startfile_prefix is relative, base it on
5905          standard_exec_prefix.  This lets us move the installed tree
5906          as a unit.  If GCC_EXEC_PREFIX is defined, base
5907          standard_startfile_prefix on that as well.  */
5908       if (IS_ABSOLUTE_PATHNAME (standard_startfile_prefix))
5909         add_prefix (&startfile_prefixes, standard_startfile_prefix, "BINUTILS",
5910                     PREFIX_PRIORITY_LAST, 0, NULL);
5911       else
5912         {
5913           if (gcc_exec_prefix)
5914             add_prefix (&startfile_prefixes,
5915                         concat (gcc_exec_prefix, machine_suffix,
5916                                 standard_startfile_prefix, NULL),
5917                         NULL, PREFIX_PRIORITY_LAST, 0, NULL);
5918           add_prefix (&startfile_prefixes,
5919                       concat (standard_exec_prefix,
5920                               machine_suffix,
5921                               standard_startfile_prefix, NULL),
5922                       NULL, PREFIX_PRIORITY_LAST, 0, NULL);
5923         }
5924
5925       add_prefix (&startfile_prefixes, standard_startfile_prefix_1,
5926                   "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5927       add_prefix (&startfile_prefixes, standard_startfile_prefix_2,
5928                   "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5929 #if 0 /* Can cause surprises, and one can use -B./ instead.  */
5930       add_prefix (&startfile_prefixes, "./", NULL,
5931                   PREFIX_PRIORITY_LAST, 1, NULL);
5932 #endif
5933     }
5934   else
5935     {
5936       if (!IS_ABSOLUTE_PATHNAME (standard_startfile_prefix)
5937           && gcc_exec_prefix)
5938         add_prefix (&startfile_prefixes,
5939                     concat (gcc_exec_prefix, machine_suffix,
5940                             standard_startfile_prefix, NULL),
5941                     "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5942     }
5943
5944   /* Process any user specified specs in the order given on the command
5945      line.  */
5946   for (uptr = user_specs_head; uptr; uptr = uptr->next)
5947     {
5948       char *filename = find_a_file (&startfile_prefixes, uptr->filename, R_OK);
5949       read_specs (filename ? filename : uptr->filename, FALSE);
5950     }
5951
5952   /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake.  */
5953   if (gcc_exec_prefix)
5954     gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
5955                               spec_version, dir_separator_str, NULL);
5956
5957   /* Now we have the specs.
5958      Set the `valid' bits for switches that match anything in any spec.  */
5959
5960   validate_all_switches ();
5961
5962   /* Now that we have the switches and the specs, set
5963      the subdirectory based on the options.  */
5964   set_multilib_dir ();
5965
5966   /* Warn about any switches that no pass was interested in.  */
5967
5968   for (i = 0; (int) i < n_switches; i++)
5969     if (! switches[i].validated)
5970       error ("unrecognized option `-%s'", switches[i].part1);
5971
5972   /* Obey some of the options.  */
5973
5974   if (print_search_dirs)
5975     {
5976       printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
5977       printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
5978       printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
5979       return (0);
5980     }
5981
5982   if (print_file_name)
5983     {
5984       printf ("%s\n", find_file (print_file_name));
5985       return (0);
5986     }
5987
5988   if (print_prog_name)
5989     {
5990       char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK);
5991       printf ("%s\n", (newname ? newname : print_prog_name));
5992       return (0);
5993     }
5994
5995   if (print_multi_lib)
5996     {
5997       print_multilib_info ();
5998       return (0);
5999     }
6000
6001   if (print_multi_directory)
6002     {
6003       if (multilib_dir == NULL)
6004         printf (".\n");
6005       else
6006         printf ("%s\n", multilib_dir);
6007       return (0);
6008     }
6009
6010   if (target_help_flag)
6011    {
6012       /* Print if any target specific options.*/
6013
6014       /* We do not exit here. Instead we have created a fake input file
6015          called 'target-dummy' which needs to be compiled, and we pass this
6016          on to the various sub-processes, along with the --target-help
6017          switch.  */
6018     }
6019
6020   if (print_help_list)
6021     {
6022       display_help ();
6023
6024       if (! verbose_flag)
6025         {
6026           printf (_("\nFor bug reporting instructions, please see:\n"));
6027           printf ("%s.\n", GCCBUGURL);
6028
6029           return (0);
6030         }
6031
6032       /* We do not exit here.  Instead we have created a fake input file
6033          called 'help-dummy' which needs to be compiled, and we pass this
6034          on the various sub-processes, along with the --help switch.  */
6035     }
6036
6037   if (verbose_flag)
6038     {
6039       int n;
6040       const char *thrmod;
6041
6042       notice ("Configured with: %s\n", configuration_arguments);
6043
6044 #ifdef THREAD_MODEL_SPEC
6045       /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6046          but there's no point in doing all this processing just to get
6047          thread_model back.  */
6048       obstack_init (&obstack);
6049       do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6050       obstack_1grow (&obstack, '\0');
6051       thrmod = obstack_finish (&obstack);
6052 #else
6053       thrmod = thread_model;
6054 #endif
6055
6056       notice ("Thread model: %s\n", thrmod);
6057
6058       /* compiler_version is truncated at the first space when initialized
6059          from version string, so truncate version_string at the first space
6060          before comparing.  */
6061       for (n = 0; version_string[n]; n++)
6062         if (version_string[n] == ' ')
6063           break;
6064
6065       if (! strncmp (version_string, compiler_version, n)
6066           && compiler_version[n] == 0)
6067         notice ("gcc version %s\n", version_string);
6068       else
6069         notice ("gcc driver version %s executing gcc version %s\n",
6070                 version_string, compiler_version);
6071
6072       if (n_infiles == 0)
6073         return (0);
6074     }
6075
6076   if (n_infiles == added_libraries)
6077     fatal ("no input files");
6078
6079   /* Make a place to record the compiler output file names
6080      that correspond to the input files.  */
6081
6082   i = n_infiles;
6083   i += lang_specific_extra_outfiles;
6084   outfiles = (const char **) xcalloc (i, sizeof (char *));
6085
6086   /* Record which files were specified explicitly as link input.  */
6087
6088   explicit_link_files = xcalloc (1, n_infiles);
6089
6090   for (i = 0; (int) i < n_infiles; i++)
6091     {
6092       int this_file_error = 0;
6093
6094       /* Tell do_spec what to substitute for %i.  */
6095
6096       input_file_number = i;
6097       set_input (infiles[i].name);
6098
6099       /* Use the same thing in %o, unless cp->spec says otherwise.  */
6100
6101       outfiles[i] = input_filename;
6102
6103       /* Figure out which compiler from the file's suffix.  */
6104
6105       input_file_compiler
6106         = lookup_compiler (infiles[i].name, input_filename_length,
6107                            infiles[i].language);
6108       
6109       if (input_file_compiler)
6110         {
6111           /* Ok, we found an applicable compiler.  Run its spec.  */
6112
6113           if (input_file_compiler->spec[0] == '#')
6114             {
6115               error ("%s: %s compiler not installed on this system",
6116                      input_filename, &input_file_compiler->spec[1]);
6117               this_file_error = 1;
6118             }
6119           else
6120             {
6121               value = do_spec (input_file_compiler->spec);
6122               if (value < 0)
6123                 this_file_error = 1;
6124             }
6125         }
6126
6127       /* If this file's name does not contain a recognized suffix,
6128          record it as explicit linker input.  */
6129
6130       else
6131         explicit_link_files[i] = 1;
6132
6133       /* Clear the delete-on-failure queue, deleting the files in it
6134          if this compilation failed.  */
6135
6136       if (this_file_error)
6137         {
6138           delete_failure_queue ();
6139           error_count++;
6140         }
6141       /* If this compilation succeeded, don't delete those files later.  */
6142       clear_failure_queue ();
6143     }
6144
6145   /* Reset the output file name to the first input file name, for use
6146      with %b in LINK_SPEC on a target that prefers not to emit a.out
6147      by default.  */
6148   if (n_infiles > 0)
6149     set_input (infiles[0].name);
6150
6151   if (error_count == 0)
6152     {
6153       /* Make sure INPUT_FILE_NUMBER points to first available open
6154          slot.  */
6155       input_file_number = n_infiles;
6156       if (lang_specific_pre_link ())
6157         error_count++;
6158     }
6159
6160   /* Run ld to link all the compiler output files.  */
6161
6162   if (error_count == 0)
6163     {
6164       int tmp = execution_count;
6165
6166       /* We'll use ld if we can't find collect2.  */
6167       if (! strcmp (linker_name_spec, "collect2"))
6168         {
6169           char *s = find_a_file (&exec_prefixes, "collect2", X_OK);
6170           if (s == NULL)
6171             linker_name_spec = "ld";
6172         }
6173       /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6174          for collect.  */
6175       putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6176       putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6177
6178       value = do_spec (link_command_spec);
6179       if (value < 0)
6180         error_count = 1;
6181       linker_was_run = (tmp != execution_count);
6182     }
6183
6184   /* If options said don't run linker,
6185      complain about input files to be given to the linker.  */
6186
6187   if (! linker_was_run && error_count == 0)
6188     for (i = 0; (int) i < n_infiles; i++)
6189       if (explicit_link_files[i])
6190         error ("%s: linker input file unused because linking not done",
6191                outfiles[i]);
6192
6193   /* Delete some or all of the temporary files we made.  */
6194
6195   if (error_count)
6196     delete_failure_queue ();
6197   delete_temp_files ();
6198
6199   if (print_help_list)
6200     {
6201       printf (("\nFor bug reporting instructions, please see:\n"));
6202       printf ("%s\n", GCCBUGURL);
6203     }
6204
6205   return (signal_count != 0 ? 2
6206           : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6207           : 0);
6208 }
6209
6210 /* Find the proper compilation spec for the file name NAME,
6211    whose length is LENGTH.  LANGUAGE is the specified language,
6212    or 0 if this file is to be passed to the linker.  */
6213
6214 static struct compiler *
6215 lookup_compiler (name, length, language)
6216      const char *name;
6217      size_t length;
6218      const char *language;
6219 {
6220   struct compiler *cp;
6221
6222   /* If this was specified by the user to be a linker input, indicate that.  */
6223   if (language != 0 && language[0] == '*')
6224     return 0;
6225
6226   /* Otherwise, look for the language, if one is spec'd.  */
6227   if (language != 0)
6228     {
6229       for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6230         if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6231           return cp;
6232
6233       error ("language %s not recognized", language);
6234       return 0;
6235     }
6236
6237   /* Look for a suffix.  */
6238   for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6239     {
6240       if (/* The suffix `-' matches only the file name `-'.  */
6241           (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6242           || (strlen (cp->suffix) < length
6243               /* See if the suffix matches the end of NAME.  */
6244               && !strcmp (cp->suffix,
6245                           name + length - strlen (cp->suffix))
6246          ))
6247         break;
6248     }
6249
6250 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6251   /* look again, but case-insensitively this time.  */
6252   if (cp < compilers)
6253     for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6254       {
6255         if (/* The suffix `-' matches only the file name `-'.  */
6256             (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6257             || (strlen (cp->suffix) < length
6258                 /* See if the suffix matches the end of NAME.  */
6259                 && ((!strcmp (cp->suffix,
6260                              name + length - strlen (cp->suffix))
6261                      || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6262                     && !strcasecmp (cp->suffix,
6263                                     name + length - strlen (cp->suffix)))
6264            ))
6265           break;
6266       }
6267 #endif
6268
6269   if (cp >= compilers)
6270     {
6271       if (cp->spec[0] != '@')
6272         /* A non-alias entry: return it.  */
6273         return cp;
6274
6275       /* An alias entry maps a suffix to a language.
6276          Search for the language; pass 0 for NAME and LENGTH
6277          to avoid infinite recursion if language not found.  */
6278       return lookup_compiler (NULL, 0, cp->spec + 1);
6279     }
6280   return 0;
6281 }
6282 \f
6283 static char *
6284 save_string (s, len)
6285      const char *s;
6286      int len;
6287 {
6288   char *result = xmalloc (len + 1);
6289
6290   memcpy (result, s, len);
6291   result[len] = 0;
6292   return result;
6293 }
6294
6295 void
6296 pfatal_with_name (name)
6297      const char *name;
6298 {
6299   perror_with_name (name);
6300   delete_temp_files ();
6301   exit (1);
6302 }
6303
6304 static void
6305 perror_with_name (name)
6306      const char *name;
6307 {
6308   error ("%s: %s", name, xstrerror (errno));
6309 }
6310
6311 static void
6312 pfatal_pexecute (errmsg_fmt, errmsg_arg)
6313      const char *errmsg_fmt;
6314      const char *errmsg_arg;
6315 {
6316   if (errmsg_arg)
6317     {
6318       int save_errno = errno;
6319
6320       /* Space for trailing '\0' is in %s.  */
6321       char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6322       sprintf (msg, errmsg_fmt, errmsg_arg);
6323       errmsg_fmt = msg;
6324
6325       errno = save_errno;
6326     }
6327
6328   pfatal_with_name (errmsg_fmt);
6329 }
6330
6331 /* Output an error message and exit */
6332
6333 void
6334 fancy_abort ()
6335 {
6336   fatal ("internal gcc abort");
6337 }
6338 \f
6339 /* Output an error message and exit */
6340
6341 void
6342 fatal VPARAMS ((const char *msgid, ...))
6343 {
6344   VA_OPEN (ap, msgid);
6345   VA_FIXEDARG (ap, const char *, msgid);
6346
6347   fprintf (stderr, "%s: ", programname);
6348   vfprintf (stderr, _(msgid), ap);
6349   VA_CLOSE (ap);
6350   fprintf (stderr, "\n");
6351   delete_temp_files ();
6352   exit (1);
6353 }
6354
6355 void
6356 error VPARAMS ((const char *msgid, ...))
6357 {
6358   VA_OPEN (ap, msgid);
6359   VA_FIXEDARG (ap, const char *, msgid);
6360
6361   fprintf (stderr, "%s: ", programname);
6362   vfprintf (stderr, _(msgid), ap);
6363   VA_CLOSE (ap);
6364
6365   fprintf (stderr, "\n");
6366 }
6367
6368 static void
6369 notice VPARAMS ((const char *msgid, ...))
6370 {
6371   VA_OPEN (ap, msgid);
6372   VA_FIXEDARG (ap, const char *, msgid);
6373
6374   vfprintf (stderr, _(msgid), ap);
6375   VA_CLOSE (ap);
6376 }
6377 \f
6378 static void
6379 validate_all_switches ()
6380 {
6381   struct compiler *comp;
6382   const char *p;
6383   char c;
6384   struct spec_list *spec;
6385
6386   for (comp = compilers; comp->spec; comp++)
6387     {
6388       p = comp->spec;
6389       while ((c = *p++))
6390         if (c == '%' && *p == '{')
6391           /* We have a switch spec.  */
6392           validate_switches (p + 1);
6393     }
6394
6395   /* Look through the linked list of specs read from the specs file.  */
6396   for (spec = specs; spec; spec = spec->next)
6397     {
6398       p = *(spec->ptr_spec);
6399       while ((c = *p++))
6400         if (c == '%' && *p == '{')
6401           /* We have a switch spec.  */
6402           validate_switches (p + 1);
6403     }
6404
6405   p = link_command_spec;
6406   while ((c = *p++))
6407     if (c == '%' && *p == '{')
6408       /* We have a switch spec.  */
6409       validate_switches (p + 1);
6410 }
6411
6412 /* Look at the switch-name that comes after START
6413    and mark as valid all supplied switches that match it.  */
6414
6415 static void
6416 validate_switches (start)
6417      const char *start;
6418 {
6419   const char *p = start;
6420   const char *filter;
6421   int i;
6422   int suffix;
6423
6424   if (*p == '|')
6425     ++p;
6426
6427 next_member:
6428   if (*p == '!')
6429     ++p;
6430
6431   suffix = 0;
6432   if (*p == '.')
6433     suffix = 1, ++p;
6434
6435   filter = p;
6436   while (*p != ':' && *p != '}' && *p != '|' && *p != '&')
6437     p++;
6438
6439   if (suffix)
6440     ;
6441   else if (p[-1] == '*')
6442     {
6443       /* Mark all matching switches as valid.  */
6444       for (i = 0; i < n_switches; i++)
6445         if (!strncmp (switches[i].part1, filter, p - filter - 1))
6446           switches[i].validated = 1;
6447     }
6448   else
6449     {
6450       /* Mark an exact matching switch as valid.  */
6451       for (i = 0; i < n_switches; i++)
6452         {
6453           if (!strncmp (switches[i].part1, filter, p - filter)
6454               && switches[i].part1[p - filter] == 0)
6455             switches[i].validated = 1;
6456         }
6457     }
6458
6459   if (*p++ == '|' || p[-1] == '&')
6460     goto next_member;
6461 }
6462 \f
6463 /* Check whether a particular argument was used.  The first time we
6464    canonicalize the switches to keep only the ones we care about.  */
6465
6466 static int
6467 used_arg (p, len)
6468      const char *p;
6469      int len;
6470 {
6471   struct mswitchstr
6472   {
6473     const char *str;
6474     const char *replace;
6475     int len;
6476     int rep_len;
6477   };
6478
6479   static struct mswitchstr *mswitches;
6480   static int n_mswitches;
6481   int i, j;
6482
6483   if (!mswitches)
6484     {
6485       struct mswitchstr *matches;
6486       const char *q;
6487       int cnt = 0;
6488
6489       /* Break multilib_matches into the component strings of string
6490          and replacement string.  */
6491       for (q = multilib_matches; *q != '\0'; q++)
6492         if (*q == ';')
6493           cnt++;
6494
6495       matches =
6496         (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
6497       i = 0;
6498       q = multilib_matches;
6499       while (*q != '\0')
6500         {
6501           matches[i].str = q;
6502           while (*q != ' ')
6503             {
6504               if (*q == '\0')
6505                 abort ();
6506               q++;
6507             }
6508           matches[i].len = q - matches[i].str;
6509
6510           matches[i].replace = ++q;
6511           while (*q != ';' && *q != '\0')
6512             {
6513               if (*q == ' ')
6514                 abort ();
6515               q++;
6516             }
6517           matches[i].rep_len = q - matches[i].replace;
6518           i++;
6519           if (*q == ';')
6520             q++;
6521         }
6522
6523       /* Now build a list of the replacement string for switches that we care
6524          about.  Make sure we allocate at least one entry.  This prevents
6525          xmalloc from calling fatal, and prevents us from re-executing this
6526          block of code.  */
6527       mswitches
6528         = (struct mswitchstr *) xmalloc ((sizeof (struct mswitchstr))
6529                                          * (n_switches ? n_switches : 1));
6530       for (i = 0; i < n_switches; i++)
6531         {
6532           int xlen = strlen (switches[i].part1);
6533           for (j = 0; j < cnt; j++)
6534             if (xlen == matches[j].len
6535                 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6536               {
6537                 mswitches[n_mswitches].str = matches[j].replace;
6538                 mswitches[n_mswitches].len = matches[j].rep_len;
6539                 mswitches[n_mswitches].replace = (char *) 0;
6540                 mswitches[n_mswitches].rep_len = 0;
6541                 n_mswitches++;
6542                 break;
6543               }
6544         }
6545     }
6546
6547   for (i = 0; i < n_mswitches; i++)
6548     if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
6549       return 1;
6550
6551   return 0;
6552 }
6553
6554 static int
6555 default_arg (p, len)
6556      const char *p;
6557      int len;
6558 {
6559   const char *start, *end;
6560
6561   for (start = multilib_defaults; *start != '\0'; start = end + 1)
6562     {
6563       while (*start == ' ' || *start == '\t')
6564         start++;
6565
6566       if (*start == '\0')
6567         break;
6568
6569       for (end = start + 1; *end != ' ' && *end != '\t' && *end != '\0'; end++)
6570         ;
6571
6572       if ((end - start) == len && strncmp (p, start, len) == 0)
6573         return 1;
6574
6575       if (*end == '\0')
6576         break;
6577     }
6578
6579   return 0;
6580 }
6581
6582 /* Work out the subdirectory to use based on the options. The format of
6583    multilib_select is a list of elements. Each element is a subdirectory
6584    name followed by a list of options followed by a semicolon. The format
6585    of multilib_exclusions is the same, but without the preceding
6586    directory. First gcc will check the exclusions, if none of the options
6587    beginning with an exclamation point are present, and all of the other
6588    options are present, then we will ignore this completely. Passing
6589    that, gcc will consider each multilib_select in turn using the same
6590    rules for matching the options. If a match is found, that subdirectory
6591    will be used.  */
6592
6593 static void
6594 set_multilib_dir ()
6595 {
6596   const char *p;
6597   unsigned int this_path_len;
6598   const char *this_path, *this_arg;
6599   int not_arg;
6600   int ok;
6601
6602   p = multilib_exclusions;
6603   while (*p != '\0')
6604     {
6605       /* Ignore newlines.  */
6606       if (*p == '\n')
6607         {
6608           ++p;
6609           continue;
6610         }
6611
6612       /* Check the arguments.  */
6613       ok = 1;
6614       while (*p != ';')
6615         {
6616           if (*p == '\0')
6617             abort ();
6618
6619           if (! ok)
6620             {
6621               ++p;
6622               continue;
6623             }
6624
6625           this_arg = p;
6626           while (*p != ' ' && *p != ';')
6627             {
6628               if (*p == '\0')
6629                 abort ();
6630               ++p;
6631             }
6632
6633           if (*this_arg != '!')
6634             not_arg = 0;
6635           else
6636             {
6637               not_arg = 1;
6638               ++this_arg;
6639             }
6640
6641           ok = used_arg (this_arg, p - this_arg);
6642           if (not_arg)
6643             ok = ! ok;
6644
6645           if (*p == ' ')
6646             ++p;
6647         }
6648
6649       if (ok)
6650         return;
6651
6652       ++p;
6653     }
6654
6655   p = multilib_select;
6656   while (*p != '\0')
6657     {
6658       /* Ignore newlines.  */
6659       if (*p == '\n')
6660         {
6661           ++p;
6662           continue;
6663         }
6664
6665       /* Get the initial path.  */
6666       this_path = p;
6667       while (*p != ' ')
6668         {
6669           if (*p == '\0')
6670             abort ();
6671           ++p;
6672         }
6673       this_path_len = p - this_path;
6674
6675       /* Check the arguments.  */
6676       ok = 1;
6677       ++p;
6678       while (*p != ';')
6679         {
6680           if (*p == '\0')
6681             abort ();
6682
6683           if (! ok)
6684             {
6685               ++p;
6686               continue;
6687             }
6688
6689           this_arg = p;
6690           while (*p != ' ' && *p != ';')
6691             {
6692               if (*p == '\0')
6693                 abort ();
6694               ++p;
6695             }
6696
6697           if (*this_arg != '!')
6698             not_arg = 0;
6699           else
6700             {
6701               not_arg = 1;
6702               ++this_arg;
6703             }
6704
6705           /* If this is a default argument, we can just ignore it.
6706              This is true even if this_arg begins with '!'.  Beginning
6707              with '!' does not mean that this argument is necessarily
6708              inappropriate for this library: it merely means that
6709              there is a more specific library which uses this
6710              argument.  If this argument is a default, we need not
6711              consider that more specific library.  */
6712           if (! default_arg (this_arg, p - this_arg))
6713             {
6714               ok = used_arg (this_arg, p - this_arg);
6715               if (not_arg)
6716                 ok = ! ok;
6717             }
6718
6719           if (*p == ' ')
6720             ++p;
6721         }
6722
6723       if (ok)
6724         {
6725           if (this_path_len != 1
6726               || this_path[0] != '.')
6727             {
6728               char *new_multilib_dir = xmalloc (this_path_len + 1);
6729               strncpy (new_multilib_dir, this_path, this_path_len);
6730               new_multilib_dir[this_path_len] = '\0';
6731               multilib_dir = new_multilib_dir;
6732             }
6733           break;
6734         }
6735
6736       ++p;
6737     }
6738 }
6739
6740 /* Print out the multiple library subdirectory selection
6741    information.  This prints out a series of lines.  Each line looks
6742    like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
6743    required.  Only the desired options are printed out, the negative
6744    matches.  The options are print without a leading dash.  There are
6745    no spaces to make it easy to use the information in the shell.
6746    Each subdirectory is printed only once.  This assumes the ordering
6747    generated by the genmultilib script. Also, we leave out ones that match
6748    the exclusions.  */
6749
6750 static void
6751 print_multilib_info ()
6752 {
6753   const char *p = multilib_select;
6754   const char *last_path = 0, *this_path;
6755   int skip;
6756   unsigned int last_path_len = 0;
6757
6758   while (*p != '\0')
6759     {
6760       skip = 0;
6761       /* Ignore newlines.  */
6762       if (*p == '\n')
6763         {
6764           ++p;
6765           continue;
6766         }
6767
6768       /* Get the initial path.  */
6769       this_path = p;
6770       while (*p != ' ')
6771         {
6772           if (*p == '\0')
6773             abort ();
6774           ++p;
6775         }
6776
6777       /* Check for matches with the multilib_exclusions. We don't bother
6778          with the '!' in either list. If any of the exclusion rules match
6779          all of its options with the select rule, we skip it.  */
6780       {
6781         const char *e = multilib_exclusions;
6782         const char *this_arg;
6783
6784         while (*e != '\0')
6785           {
6786             int m = 1;
6787             /* Ignore newlines.  */
6788             if (*e == '\n')
6789               {
6790                 ++e;
6791                 continue;
6792               }
6793
6794             /* Check the arguments.  */
6795             while (*e != ';')
6796               {
6797                 const char *q;
6798                 int mp = 0;
6799
6800                 if (*e == '\0')
6801                   abort ();
6802
6803                 if (! m)
6804                   {
6805                     ++e;
6806                     continue;
6807                   }
6808
6809                 this_arg = e;
6810
6811                 while (*e != ' ' && *e != ';')
6812                   {
6813                     if (*e == '\0')
6814                       abort ();
6815                     ++e;
6816                   }
6817
6818                 q = p + 1;
6819                 while (*q != ';')
6820                   {
6821                     const char *arg;
6822                     int len = e - this_arg;
6823
6824                     if (*q == '\0')
6825                       abort ();
6826
6827                     arg = q;
6828
6829                     while (*q != ' ' && *q != ';')
6830                       {
6831                         if (*q == '\0')
6832                           abort ();
6833                         ++q;
6834                       }
6835
6836                     if (! strncmp (arg, this_arg, (len < q - arg) ? q - arg : len) ||
6837                         default_arg (this_arg, e - this_arg))
6838                       {
6839                         mp = 1;
6840                         break;
6841                       }
6842
6843                     if (*q == ' ')
6844                       ++q;
6845                   }
6846
6847                 if (! mp)
6848                   m = 0;
6849
6850                 if (*e == ' ')
6851                   ++e;
6852               }
6853
6854             if (m)
6855               {
6856                 skip = 1;
6857                 break;
6858               }
6859
6860             if (*e != '\0')
6861               ++e;
6862           }
6863       }
6864
6865       if (! skip)
6866         {
6867           /* If this is a duplicate, skip it.  */
6868           skip = (last_path != 0 && (unsigned int) (p - this_path) == last_path_len
6869                   && ! strncmp (last_path, this_path, last_path_len));
6870
6871           last_path = this_path;
6872           last_path_len = p - this_path;
6873         }
6874
6875       /* If this directory requires any default arguments, we can skip
6876          it.  We will already have printed a directory identical to
6877          this one which does not require that default argument.  */
6878       if (! skip)
6879         {
6880           const char *q;
6881
6882           q = p + 1;
6883           while (*q != ';')
6884             {
6885               const char *arg;
6886
6887               if (*q == '\0')
6888                 abort ();
6889
6890               if (*q == '!')
6891                 arg = NULL;
6892               else
6893                 arg = q;
6894
6895               while (*q != ' ' && *q != ';')
6896                 {
6897                   if (*q == '\0')
6898                     abort ();
6899                   ++q;
6900                 }
6901
6902               if (arg != NULL
6903                   && default_arg (arg, q - arg))
6904                 {
6905                   skip = 1;
6906                   break;
6907                 }
6908
6909               if (*q == ' ')
6910                 ++q;
6911             }
6912         }
6913
6914       if (! skip)
6915         {
6916           const char *p1;
6917
6918           for (p1 = last_path; p1 < p; p1++)
6919             putchar (*p1);
6920           putchar (';');
6921         }
6922
6923       ++p;
6924       while (*p != ';')
6925         {
6926           int use_arg;
6927
6928           if (*p == '\0')
6929             abort ();
6930
6931           if (skip)
6932             {
6933               ++p;
6934               continue;
6935             }
6936
6937           use_arg = *p != '!';
6938
6939           if (use_arg)
6940             putchar ('@');
6941
6942           while (*p != ' ' && *p != ';')
6943             {
6944               if (*p == '\0')
6945                 abort ();
6946               if (use_arg)
6947                 putchar (*p);
6948               ++p;
6949             }
6950
6951           if (*p == ' ')
6952             ++p;
6953         }
6954
6955       if (! skip)
6956         {
6957           /* If there are extra options, print them now.  */
6958           if (multilib_extra && *multilib_extra)
6959             {
6960               int print_at = TRUE;
6961               const char *q;
6962
6963               for (q = multilib_extra; *q != '\0'; q++)
6964                 {
6965                   if (*q == ' ')
6966                     print_at = TRUE;
6967                   else
6968                     {
6969                       if (print_at)
6970                         putchar ('@');
6971                       putchar (*q);
6972                       print_at = FALSE;
6973                     }
6974                 }
6975             }
6976
6977           putchar ('\n');
6978         }
6979
6980       ++p;
6981     }
6982 }