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