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