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