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