OSDN Git Service

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