OSDN Git Service

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