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