2003-03-10 Aldy Hernandez <aldyh@redhat.com>
[official-gcc.git] / gcc / gcc.c
blob301abfc6212f9fb32d1ec427c1ccc07e01a7a8ae
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA.
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!! */
25 /* This program is the user interface to the C compiler and possibly to
26 other compilers. It is used because compilation is a complicated procedure
27 which involves running several programs and passing temporary files between
28 them, forwarding the users switches to those programs selectively,
29 and deleting the temporary files at the end.
31 CC recognizes how to compile each input file by suffixes in the file names.
32 Once it knows which kind of compilation to perform, the procedure for
33 compilation is specified by a string called a "spec". */
35 /* A Short Introduction to Adding a Command-Line Option.
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.
41 In the following, consider adding the command-line argument
42 `--bar'.
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.
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 `-'.
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'.
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'.
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.
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(). */
73 #include "config.h"
74 #include "system.h"
75 #include "coretypes.h"
76 #include "tm.h"
77 #include <signal.h>
78 #if ! defined( SIGCHLD ) && defined( SIGCLD )
79 # define SIGCHLD SIGCLD
80 #endif
81 #include "obstack.h"
82 #include "intl.h"
83 #include "prefix.h"
84 #include "gcc.h"
85 #include "flags.h"
87 #ifdef HAVE_SYS_RESOURCE_H
88 #include <sys/resource.h>
89 #endif
90 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
91 extern int getrusage PARAMS ((int, struct rusage *));
92 #endif
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
98 #endif
100 /* By default there is no special suffix for host executables. */
101 #ifdef HOST_EXECUTABLE_SUFFIX
102 #define HAVE_HOST_EXECUTABLE_SUFFIX
103 #else
104 #define HOST_EXECUTABLE_SUFFIX ""
105 #endif
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"
112 #endif
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 */
122 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
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
129 #ifndef HAVE_KILL
130 #define kill(p,s) raise(s)
131 #endif
133 /* If a stage of compilation returns an exit status >= 1,
134 compilation of that file ceases. */
136 #define MIN_FATAL_STATUS 1
138 /* Flag set by cppspec.c to 1. */
139 int is_cpp_driver;
141 /* Flag saying to pass the greatest exit code returned by a sub-process
142 to the calling program. */
143 static int pass_exit_codes;
145 /* Definition of string containing the arguments given to configure. */
146 #include "configargs.h"
148 /* Flag saying to print the directories gcc will search through looking for
149 programs, libraries, etc. */
151 static int print_search_dirs;
153 /* Flag saying to print the full filename of this file
154 as found through our usual search mechanism. */
156 static const char *print_file_name = NULL;
158 /* As print_file_name, but search for executable file. */
160 static const char *print_prog_name = NULL;
162 /* Flag saying to print the relative path we'd use to
163 find libgcc.a given the current compiler flags. */
165 static int print_multi_directory;
167 /* Flag saying to print the relative path we'd use to
168 find OS libraries given the current compiler flags. */
170 static int print_multi_os_directory;
172 /* Flag saying to print the list of subdirectories and
173 compiler flags used to select them in a standard form. */
175 static int print_multi_lib;
177 /* Flag saying to print the command line options understood by gcc and its
178 sub-processes. */
180 static int print_help_list;
182 /* Flag indicating whether we should print the command and arguments */
184 static int verbose_flag;
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. */
191 static int verbose_only_flag;
193 /* Flag indicating to print target specific command line options. */
195 static int target_help_flag;
197 /* Flag indicating whether we should report subprocess execution times
198 (if this is supported by the system - see pexecute.c). */
200 static int report_times;
202 /* Nonzero means place this string before uses of /, so that include
203 and library files can be found in an alternate location. */
205 #ifdef TARGET_SYSTEM_ROOT
206 static const char *target_system_root = TARGET_SYSTEM_ROOT;
207 #else
208 static const char *target_system_root = 0;
209 #endif
211 /* Nonzero means pass the updated target_system_root to the compiler. */
213 static int target_system_root_changed;
215 /* Nonzero means write "temp" files in source directory
216 and use the source file's name in them, and don't delete them. */
218 static int save_temps_flag;
220 /* Nonzero means use pipes to communicate between subprocesses.
221 Overridden by either of the above two flags. */
223 static int use_pipes;
225 /* The compiler version. */
227 static const char *compiler_version;
229 /* The target version specified with -V */
231 static const char *const spec_version = DEFAULT_TARGET_VERSION;
233 /* The target machine specified with -b. */
235 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
237 /* Nonzero if cross-compiling.
238 When -b is used, the value comes from the `specs' file. */
240 #ifdef CROSS_COMPILE
241 static const char *cross_compile = "1";
242 #else
243 static const char *cross_compile = "0";
244 #endif
246 #ifdef MODIFY_TARGET_NAME
248 /* Information on how to alter the target name based on a command-line
249 switch. The only case we support now is simply appending or deleting a
250 string to or from the end of the first part of the configuration name. */
252 static const struct modify_target
254 const char *const sw;
255 const enum add_del {ADD, DELETE} add_del;
256 const char *const str;
258 modify_target[] = MODIFY_TARGET_NAME;
259 #endif
261 /* The number of errors that have occurred; the link phase will not be
262 run if this is nonzero. */
263 static int error_count = 0;
265 /* Greatest exit code of sub-processes that has been encountered up to
266 now. */
267 static int greatest_status = 1;
269 /* This is the obstack which we use to allocate many strings. */
271 static struct obstack obstack;
273 /* This is the obstack to build an environment variable to pass to
274 collect2 that describes all of the relevant switches of what to
275 pass the compiler in building the list of pointers to constructors
276 and destructors. */
278 static struct obstack collect_obstack;
280 /* These structs are used to collect resource usage information for
281 subprocesses. */
282 #ifdef HAVE_GETRUSAGE
283 static struct rusage rus, prus;
284 #endif
286 /* Forward declaration for prototypes. */
287 struct path_prefix;
289 static void init_spec PARAMS ((void));
290 static void store_arg PARAMS ((const char *, int, int));
291 static char *load_specs PARAMS ((const char *));
292 static void read_specs PARAMS ((const char *, int));
293 static void set_spec PARAMS ((const char *, const char *));
294 static struct compiler *lookup_compiler PARAMS ((const char *, size_t, const char *));
295 static char *build_search_list PARAMS ((struct path_prefix *, const char *, int));
296 static void putenv_from_prefixes PARAMS ((struct path_prefix *, const char *));
297 static int access_check PARAMS ((const char *, int));
298 static char *find_a_file PARAMS ((struct path_prefix *, const char *,
299 int, int));
300 static void add_prefix PARAMS ((struct path_prefix *, const char *,
301 const char *, int, int, int *, int));
302 static void add_sysrooted_prefix PARAMS ((struct path_prefix *, const char *,
303 const char *, int, int, int *, int));
304 static void translate_options PARAMS ((int *, const char *const **));
305 static char *skip_whitespace PARAMS ((char *));
306 static void delete_if_ordinary PARAMS ((const char *));
307 static void delete_temp_files PARAMS ((void));
308 static void delete_failure_queue PARAMS ((void));
309 static void clear_failure_queue PARAMS ((void));
310 static int check_live_switch PARAMS ((int, int));
311 static const char *handle_braces PARAMS ((const char *));
312 static inline bool input_suffix_matches PARAMS ((const char *,
313 const char *));
314 static inline bool switch_matches PARAMS ((const char *,
315 const char *, int));
316 static inline void mark_matching_switches PARAMS ((const char *,
317 const char *, int));
318 static inline void process_marked_switches PARAMS ((void));
319 static const char *process_brace_body PARAMS ((const char *, const char *,
320 const char *, int, int));
321 static const struct spec_function *lookup_spec_function PARAMS ((const char *));
322 static const char *eval_spec_function PARAMS ((const char *, const char *));
323 static const char *handle_spec_function PARAMS ((const char *));
324 static char *save_string PARAMS ((const char *, int));
325 static void set_collect_gcc_options PARAMS ((void));
326 static int do_spec_1 PARAMS ((const char *, int, const char *));
327 static int do_spec_2 PARAMS ((const char *));
328 static void do_self_spec PARAMS ((const char *));
329 static const char *find_file PARAMS ((const char *));
330 static int is_directory PARAMS ((const char *, const char *, int));
331 static const char *validate_switches PARAMS ((const char *));
332 static void validate_all_switches PARAMS ((void));
333 static inline void validate_switches_from_spec PARAMS ((const char *));
334 static void give_switch PARAMS ((int, int));
335 static int used_arg PARAMS ((const char *, int));
336 static int default_arg PARAMS ((const char *, int));
337 static void set_multilib_dir PARAMS ((void));
338 static void print_multilib_info PARAMS ((void));
339 static void perror_with_name PARAMS ((const char *));
340 static void pfatal_pexecute PARAMS ((const char *, const char *))
341 ATTRIBUTE_NORETURN;
342 static void notice PARAMS ((const char *, ...))
343 ATTRIBUTE_PRINTF_1;
344 static void display_help PARAMS ((void));
345 static void add_preprocessor_option PARAMS ((const char *, int));
346 static void add_assembler_option PARAMS ((const char *, int));
347 static void add_linker_option PARAMS ((const char *, int));
348 static void process_command PARAMS ((int, const char *const *));
349 static int execute PARAMS ((void));
350 static void alloc_args PARAMS ((void));
351 static void clear_args PARAMS ((void));
352 static void fatal_error PARAMS ((int));
353 #ifdef ENABLE_SHARED_LIBGCC
354 static void init_gcc_specs PARAMS ((struct obstack *,
355 const char *, const char *,
356 const char *));
357 #endif
358 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
359 static const char *convert_filename PARAMS ((const char *, int, int));
360 #endif
362 static const char *if_exists_spec_function PARAMS ((int, const char **));
363 static const char *if_exists_else_spec_function PARAMS ((int, const char **));
365 /* The Specs Language
367 Specs are strings containing lines, each of which (if not blank)
368 is made up of a program name, and arguments separated by spaces.
369 The program name must be exact and start from root, since no path
370 is searched and it is unreliable to depend on the current working directory.
371 Redirection of input or output is not supported; the subprograms must
372 accept filenames saying what files to read and write.
374 In addition, the specs can contain %-sequences to substitute variable text
375 or for conditional text. Here is a table of all defined %-sequences.
376 Note that spaces are not generated automatically around the results of
377 expanding these sequences; therefore, you can concatenate them together
378 or with constant text in a single argument.
380 %% substitute one % into the program name or argument.
381 %i substitute the name of the input file being processed.
382 %b substitute the basename of the input file being processed.
383 This is the substring up to (and not including) the last period
384 and not including the directory.
385 %B same as %b, but include the file suffix (text after the last period).
386 %gSUFFIX
387 substitute a file name that has suffix SUFFIX and is chosen
388 once per compilation, and mark the argument a la %d. To reduce
389 exposure to denial-of-service attacks, the file name is now
390 chosen in a way that is hard to predict even when previously
391 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
392 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
393 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
394 had been pre-processed. Previously, %g was simply substituted
395 with a file name chosen once per compilation, without regard
396 to any appended suffix (which was therefore treated just like
397 ordinary text), making such attacks more likely to succeed.
398 %|SUFFIX
399 like %g, but if -pipe is in effect, expands simply to "-".
400 %mSUFFIX
401 like %g, but if -pipe is in effect, expands to nothing. (We have both
402 %| and %m to accommodate differences between system assemblers; see
403 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
404 %uSUFFIX
405 like %g, but generates a new temporary file name even if %uSUFFIX
406 was already seen.
407 %USUFFIX
408 substitutes the last file name generated with %uSUFFIX, generating a
409 new one if there is no such last file name. In the absence of any
410 %uSUFFIX, this is just like %gSUFFIX, except they don't share
411 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
412 would involve the generation of two distinct file names, one
413 for each `%g.s' and another for each `%U.s'. Previously, %U was
414 simply substituted with a file name chosen for the previous %u,
415 without regard to any appended suffix.
416 %jSUFFIX
417 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
418 writable, and if save-temps is off; otherwise, substitute the name
419 of a temporary file, just like %u. This temporary file is not
420 meant for communication between processes, but rather as a junk
421 disposal mechanism.
422 %.SUFFIX
423 substitutes .SUFFIX for the suffixes of a matched switch's args when
424 it is subsequently output with %*. SUFFIX is terminated by the next
425 space or %.
426 %d marks the argument containing or following the %d as a
427 temporary file name, so that that file will be deleted if CC exits
428 successfully. Unlike %g, this contributes no text to the argument.
429 %w marks the argument containing or following the %w as the
430 "output file" of this compilation. This puts the argument
431 into the sequence of arguments that %o will substitute later.
432 %V indicates that this compilation produces no "output file".
433 %W{...}
434 like %{...} but mark last argument supplied within
435 as a file to be deleted on failure.
436 %o substitutes the names of all the output files, with spaces
437 automatically placed around them. You should write spaces
438 around the %o as well or the results are undefined.
439 %o is for use in the specs for running the linker.
440 Input files whose names have no recognized suffix are not compiled
441 at all, but they are included among the output files, so they will
442 be linked.
443 %O substitutes the suffix for object files. Note that this is
444 handled specially when it immediately follows %g, %u, or %U
445 (with or without a suffix argument) because of the need for
446 those to form complete file names. The handling is such that
447 %O is treated exactly as if it had already been substituted,
448 except that %g, %u, and %U do not currently support additional
449 SUFFIX characters following %O as they would following, for
450 example, `.o'.
451 %p substitutes the standard macro predefinitions for the
452 current target machine. Use this when running cpp.
453 %P like %p, but puts `__' before and after the name of each macro.
454 (Except macros that already have __.)
455 This is for ANSI C.
456 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
457 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
458 and -B options) as necessary.
459 %s current argument is the name of a library or startup file of some sort.
460 Search for that file in a standard list of directories
461 and substitute the full name found.
462 %eSTR Print STR as an error message. STR is terminated by a newline.
463 Use this when inconsistent options are detected.
464 %nSTR Print STR as a notice. STR is terminated by a newline.
465 %x{OPTION} Accumulate an option for %X.
466 %X Output the accumulated linker options specified by compilations.
467 %Y Output the accumulated assembler options specified by compilations.
468 %Z Output the accumulated preprocessor options specified by compilations.
469 %v1 Substitute the major version number of GCC.
470 (For version 2.5.3, this is 2.)
471 %v2 Substitute the minor version number of GCC.
472 (For version 2.5.3, this is 5.)
473 %v3 Substitute the patch level number of GCC.
474 (For version 2.5.3, this is 3.)
475 %a process ASM_SPEC as a spec.
476 This allows config.h to specify part of the spec for running as.
477 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
478 used here. This can be used to run a post-processor after the
479 assembler has done its job.
480 %D Dump out a -L option for each directory in startfile_prefixes.
481 If multilib_dir is set, extra entries are generated with it affixed.
482 %l process LINK_SPEC as a spec.
483 %L process LIB_SPEC as a spec.
484 %G process LIBGCC_SPEC as a spec.
485 %M output multilib_dir with directory separators replaced with "_";
486 if multilib_dir is not set or is ".", output "".
487 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
488 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
489 %C process CPP_SPEC as a spec.
490 %1 process CC1_SPEC as a spec.
491 %2 process CC1PLUS_SPEC as a spec.
492 %* substitute the variable part of a matched option. (See below.)
493 Note that each comma in the substituted string is replaced by
494 a single space.
495 %<S remove all occurrences of -S from the command line.
496 Note - this command is position dependent. % commands in the
497 spec string before this one will see -S, % commands in the
498 spec string after this one will not.
499 %<S* remove all occurrences of all switches beginning with -S from the
500 command line.
501 %:function(args)
502 Call the named function FUNCTION, passing it ARGS. ARGS is
503 first processed as a nested spec string, then split into an
504 argument vector in the usual fashion. The function returns
505 a string which is processed as if it had appeared literally
506 as part of the current spec.
507 %{S} substitutes the -S switch, if that switch was given to CC.
508 If that switch was not specified, this substitutes nothing.
509 Here S is a metasyntactic variable.
510 %{S*} substitutes all the switches specified to CC whose names start
511 with -S. This is used for -o, -I, etc; switches that take
512 arguments. CC considers `-o foo' as being one switch whose
513 name starts with `o'. %{o*} would substitute this text,
514 including the space; thus, two arguments would be generated.
515 %{S*&T*} likewise, but preserve order of S and T options (the order
516 of S and T in the spec is not significant). Can be any number
517 of ampersand-separated variables; for each the wild card is
518 optional. Useful for CPP as %{D*&U*&A*}.
520 %{S:X} substitutes X, if the -S switch was given to CC.
521 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
522 %{S*:X} substitutes X if one or more switches whose names start
523 with -S was given to CC. Normally X is substituted only
524 once, no matter how many such switches appeared. However,
525 if %* appears somewhere in X, then X will be substituted
526 once for each matching switch, with the %* replaced by the
527 part of that switch that matched the '*'.
528 %{.S:X} substitutes X, if processing a file with suffix S.
529 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
531 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
532 combined with !, ., and * as above binding stronger than the OR.
533 If %* appears in X, all of the alternatives must be starred, and
534 only the first matching alternative is substituted.
535 %{S:X; if S was given to CC, substitutes X;
536 T:Y; else if T was given to CC, substitutes Y;
537 :D} else substitutes D. There can be as many clauses as you need.
538 This may be combined with ., !, |, and * as above.
540 %(Spec) processes a specification defined in a specs file as *Spec:
541 %[Spec] as above, but put __ around -D arguments
543 The conditional text X in a %{S:X} or similar construct may contain
544 other nested % constructs or spaces, or even newlines. They are
545 processed as usual, as described above. Trailing white space in X is
546 ignored. White space may also appear anywhere on the left side of the
547 colon in these constructs, except between . or * and the corresponding
548 word.
550 The -O, -f, -m, and -W switches are handled specifically in these
551 constructs. If another value of -O or the negated form of a -f, -m, or
552 -W switch is found later in the command line, the earlier switch
553 value is ignored, except with {S*} where S is just one letter; this
554 passes all matching options.
556 The character | at the beginning of the predicate text is used to indicate
557 that a command should be piped to the following command, but only if -pipe
558 is specified.
560 Note that it is built into CC which switches take arguments and which
561 do not. You might think it would be useful to generalize this to
562 allow each compiler's spec to say which switches take arguments. But
563 this cannot be done in a consistent fashion. CC cannot even decide
564 which input files have been specified without knowing which switches
565 take arguments, and it must know which input files to compile in order
566 to tell which compilers to run.
568 CC also knows implicitly that arguments starting in `-l' are to be
569 treated as compiler output files, and passed to the linker in their
570 proper position among the other output files. */
572 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
574 /* config.h can define ASM_SPEC to provide extra args to the assembler
575 or extra switch-translations. */
576 #ifndef ASM_SPEC
577 #define ASM_SPEC ""
578 #endif
580 /* config.h can define ASM_FINAL_SPEC to run a post processor after
581 the assembler has run. */
582 #ifndef ASM_FINAL_SPEC
583 #define ASM_FINAL_SPEC ""
584 #endif
586 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
587 or extra switch-translations. */
588 #ifndef CPP_SPEC
589 #define CPP_SPEC ""
590 #endif
592 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
593 or extra switch-translations. */
594 #ifndef CC1_SPEC
595 #define CC1_SPEC ""
596 #endif
598 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
599 or extra switch-translations. */
600 #ifndef CC1PLUS_SPEC
601 #define CC1PLUS_SPEC ""
602 #endif
604 /* config.h can define LINK_SPEC to provide extra args to the linker
605 or extra switch-translations. */
606 #ifndef LINK_SPEC
607 #define LINK_SPEC ""
608 #endif
610 /* config.h can define LIB_SPEC to override the default libraries. */
611 #ifndef LIB_SPEC
612 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
613 #endif
615 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
616 included. */
617 #ifndef LIBGCC_SPEC
618 #if defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
619 /* Have gcc do the search for libgcc.a. */
620 #define LIBGCC_SPEC "libgcc.a%s"
621 #else
622 #define LIBGCC_SPEC "-lgcc"
623 #endif
624 #endif
626 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
627 #ifndef STARTFILE_SPEC
628 #define STARTFILE_SPEC \
629 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
630 #endif
632 /* config.h can define SWITCHES_NEED_SPACES to control which options
633 require spaces between the option and the argument. */
634 #ifndef SWITCHES_NEED_SPACES
635 #define SWITCHES_NEED_SPACES ""
636 #endif
638 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
639 #ifndef ENDFILE_SPEC
640 #define ENDFILE_SPEC ""
641 #endif
643 #ifndef LINKER_NAME
644 #define LINKER_NAME "collect2"
645 #endif
647 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
648 to the assembler. */
649 #ifndef ASM_DEBUG_SPEC
650 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
651 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
652 # define ASM_DEBUG_SPEC \
653 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
654 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
655 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
656 # else
657 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
658 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
659 # endif
660 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
661 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
662 # endif
663 # endif
664 #endif
665 #ifndef ASM_DEBUG_SPEC
666 # define ASM_DEBUG_SPEC ""
667 #endif
669 /* Here is the spec for running the linker, after compiling all files. */
671 /* This is overridable by the target in case they need to specify the
672 -lgcc and -lc order specially, yet not require them to override all
673 of LINK_COMMAND_SPEC. */
674 #ifndef LINK_GCC_C_SEQUENCE_SPEC
675 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
676 #endif
678 /* -u* was put back because both BSD and SysV seem to support it. */
679 /* %{static:} simply prevents an error message if the target machine
680 doesn't handle -static. */
681 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
682 scripts which exist in user specified directories, or in standard
683 directories. */
684 #ifndef LINK_COMMAND_SPEC
685 #define LINK_COMMAND_SPEC "\
686 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
687 %(linker) %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r} %{s} %{t}\
688 %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
689 %{static:} %{L*} %(link_libgcc) %o %{fprofile-arcs:-lgcov}\
690 %{!nostdlib:%{!nodefaultlibs:%(link_gcc_c_sequence)}}\
691 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
692 #endif
694 #ifndef LINK_LIBGCC_SPEC
695 # ifdef LINK_LIBGCC_SPECIAL
696 /* Don't generate -L options for startfile prefix list. */
697 # define LINK_LIBGCC_SPEC ""
698 # else
699 /* Do generate them. */
700 # define LINK_LIBGCC_SPEC "%D"
701 # endif
702 #endif
704 #ifndef STARTFILE_PREFIX_SPEC
705 # define STARTFILE_PREFIX_SPEC ""
706 #endif
708 static const char *asm_debug;
709 static const char *cpp_spec = CPP_SPEC;
710 static const char *cpp_predefines = CPP_PREDEFINES;
711 static const char *cc1_spec = CC1_SPEC;
712 static const char *cc1plus_spec = CC1PLUS_SPEC;
713 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
714 static const char *asm_spec = ASM_SPEC;
715 static const char *asm_final_spec = ASM_FINAL_SPEC;
716 static const char *link_spec = LINK_SPEC;
717 static const char *lib_spec = LIB_SPEC;
718 static const char *libgcc_spec = LIBGCC_SPEC;
719 static const char *endfile_spec = ENDFILE_SPEC;
720 static const char *startfile_spec = STARTFILE_SPEC;
721 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
722 static const char *linker_name_spec = LINKER_NAME;
723 static const char *link_command_spec = LINK_COMMAND_SPEC;
724 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
725 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
727 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
728 There should be no need to override these in target dependent files,
729 but we need to copy them to the specs file so that newer versions
730 of the GCC driver can correctly drive older tool chains with the
731 appropriate -B options. */
733 /* When cpplib handles traditional preprocessing, get rid of this, and
734 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
735 that we default the front end language better. */
736 static const char *trad_capable_cpp =
737 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
739 /* We don't wrap .d files in %W{} since a missing .d file, and
740 therefore no dependency entry, confuses make into thinking a .o
741 file that happens to exist is up-to-date. */
742 static const char *cpp_unique_options =
743 "%{C:%{!E:%eGNU C does not support -C without using -E}}\
744 %{CC:%{!E:%eGNU C does not support -CC without using -E}}\
745 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*} %{P} %I\
746 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
747 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
748 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
749 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
750 %{!no-gcc:-D__GNUC__=%v1 -D__GNUC_MINOR__=%v2 -D__GNUC_PATCHLEVEL__=%v3}\
751 %{!undef:%{!ansi:%{!std=*:%p}%{std=gnu*:%p}} %P} %{trigraphs}\
752 %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
753 %{E|M|MM:%W{o*}}";
755 /* This contains cpp options which are common with cc1_options and are passed
756 only when preprocessing only to avoid duplication. We pass the cc1 spec
757 options to the preprocessor so that it the cc1 spec may manipulate
758 options used to set target flags. Those special target flags settings may
759 in turn cause preprocessor symbols to be defined specially. */
760 static const char *cpp_options =
761 "%(cpp_unique_options) %1 %{m*} %{std*} %{ansi} %{W*&pedantic*} %{w} %{f*}\
762 %{O*} %{undef}";
764 /* This contains cpp options which are not passed when the preprocessor
765 output will be used by another program. */
766 static const char *cpp_debug_options = "%{d*}";
768 /* NB: This is shared amongst all front-ends. */
769 static const char *cc1_options =
770 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
771 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
772 -auxbase%{c|S:%{o*:-strip %*}%{!o*: %b}}%{!c:%{!S: %b}}\
773 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*} %{ansi}\
774 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
775 %{Qn:-fno-ident} %{--help:--help}\
776 %{--target-help:--target-help}\
777 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
778 %{fsyntax-only:-o %j} %{-param*}";
780 static const char *asm_options =
781 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
783 static const char *invoke_as =
784 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
785 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
786 #else
787 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
788 #endif
790 /* Some compilers have limits on line lengths, and the multilib_select
791 and/or multilib_matches strings can be very long, so we build them at
792 run time. */
793 static struct obstack multilib_obstack;
794 static const char *multilib_select;
795 static const char *multilib_matches;
796 static const char *multilib_defaults;
797 static const char *multilib_exclusions;
798 #include "multilib.h"
800 /* Check whether a particular argument is a default argument. */
802 #ifndef MULTILIB_DEFAULTS
803 #define MULTILIB_DEFAULTS { "" }
804 #endif
806 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
808 #ifndef DRIVER_SELF_SPECS
809 #define DRIVER_SELF_SPECS ""
810 #endif
812 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
814 struct user_specs
816 struct user_specs *next;
817 const char *filename;
820 static struct user_specs *user_specs_head, *user_specs_tail;
822 /* This defines which switch letters take arguments. */
824 #define DEFAULT_SWITCH_TAKES_ARG(CHAR) \
825 ((CHAR) == 'D' || (CHAR) == 'U' || (CHAR) == 'o' \
826 || (CHAR) == 'e' || (CHAR) == 'T' || (CHAR) == 'u' \
827 || (CHAR) == 'I' || (CHAR) == 'm' || (CHAR) == 'x' \
828 || (CHAR) == 'L' || (CHAR) == 'A' || (CHAR) == 'B' || (CHAR) == 'b')
830 #ifndef SWITCH_TAKES_ARG
831 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
832 #endif
834 /* This defines which multi-letter switches take arguments. */
836 #define DEFAULT_WORD_SWITCH_TAKES_ARG(STR) \
837 (!strcmp (STR, "Tdata") || !strcmp (STR, "Ttext") \
838 || !strcmp (STR, "Tbss") || !strcmp (STR, "include") \
839 || !strcmp (STR, "imacros") || !strcmp (STR, "aux-info") \
840 || !strcmp (STR, "idirafter") || !strcmp (STR, "iprefix") \
841 || !strcmp (STR, "iwithprefix") || !strcmp (STR, "iwithprefixbefore") \
842 || !strcmp (STR, "isystem") || !strcmp (STR, "-param") \
843 || !strcmp (STR, "specs") \
844 || !strcmp (STR, "MF") || !strcmp (STR, "MT") || !strcmp (STR, "MQ"))
846 #ifndef WORD_SWITCH_TAKES_ARG
847 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
848 #endif
850 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
851 /* This defines which switches stop a full compilation. */
852 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
853 ((CHAR) == 'c' || (CHAR) == 'S')
855 #ifndef SWITCH_CURTAILS_COMPILATION
856 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
857 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
858 #endif
859 #endif
861 /* Record the mapping from file suffixes for compilation specs. */
863 struct compiler
865 const char *suffix; /* Use this compiler for input files
866 whose names end in this suffix. */
868 const char *spec; /* To use this compiler, run this spec. */
870 const char *cpp_spec; /* If non-NULL, substitute this spec
871 for `%C', rather than the usual
872 cpp_spec. */
875 /* Pointer to a vector of `struct compiler' that gives the spec for
876 compiling a file, based on its suffix.
877 A file that does not end in any of these suffixes will be passed
878 unchanged to the loader and nothing else will be done to it.
880 An entry containing two 0s is used to terminate the vector.
882 If multiple entries match a file, the last matching one is used. */
884 static struct compiler *compilers;
886 /* Number of entries in `compilers', not counting the null terminator. */
888 static int n_compilers;
890 /* The default list of file name suffixes and their compilation specs. */
892 static const struct compiler default_compilers[] =
894 /* Add lists of suffixes of known languages here. If those languages
895 were not present when we built the driver, we will hit these copies
896 and be given a more meaningful error than "file not used since
897 linking is not done". */
898 {".m", "#Objective-C", 0}, {".mi", "#Objective-C", 0},
899 {".cc", "#C++", 0}, {".cxx", "#C++", 0}, {".cpp", "#C++", 0},
900 {".cp", "#C++", 0}, {".c++", "#C++", 0}, {".C", "#C++", 0},
901 {".CPP", "#C++", 0}, {".ii", "#C++", 0},
902 {".ads", "#Ada", 0}, {".adb", "#Ada", 0},
903 {".f", "#Fortran", 0}, {".for", "#Fortran", 0}, {".fpp", "#Fortran", 0},
904 {".F", "#Fortran", 0}, {".FOR", "#Fortran", 0}, {".FPP", "#Fortran", 0},
905 {".r", "#Ratfor", 0},
906 {".p", "#Pascal", 0}, {".pas", "#Pascal", 0},
907 {".java", "#Java", 0}, {".class", "#Java", 0},
908 {".zip", "#Java", 0}, {".jar", "#Java", 0},
909 /* Next come the entries for C. */
910 {".c", "@c", 0},
911 {"@c",
912 /* cc1 has an integrated ISO C preprocessor. We should invoke the
913 external preprocessor if -save-temps is given. */
914 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
915 %{!E:%{!M:%{!MM:\
916 %{traditional|ftraditional:\
917 %eGNU C no longer supports -traditional without -E}\
918 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
919 %(cpp_options) %{save-temps:%b.i} %{!save-temps:%g.i} \n\
920 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} %(cc1_options)}\
921 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
922 cc1 %(cpp_unique_options) %(cc1_options)}}}\
923 %{!fsyntax-only:%(invoke_as)}}}}", 0},
924 {"-",
925 "%{!E:%e-E required when input is from standard input}\
926 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0},
927 {".h", "@c-header", 0},
928 {"@c-header",
929 /* cc1 has an integrated ISO C preprocessor. We should invoke the
930 external preprocessor if -save-temps is given. */
931 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
932 %{!E:%{!M:%{!MM:\
933 %{save-temps|traditional-cpp:%(trad_capable_cpp) \
934 %(cpp_options) %b.i \n\
935 cc1 -fpreprocessed %b.i %(cc1_options)\
936 -o %g.s %{!o*:--output-pch=%i.gch}\
937 %W{o*:--output-pch=%*}%V}\
938 %{!save-temps:%{!traditional-cpp:\
939 cc1 %(cpp_unique_options) %(cc1_options)\
940 -o %g.s %{!o*:--output-pch=%i.gch}\
941 %W{o*:--output-pch=%*}%V}}}}}", 0},
942 {".i", "@cpp-output", 0},
943 {"@cpp-output",
944 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0},
945 {".s", "@assembler", 0},
946 {"@assembler",
947 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0},
948 {".S", "@assembler-with-cpp", 0},
949 {"@assembler-with-cpp",
950 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
951 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
952 %{E|M|MM:%(cpp_debug_options)}\
953 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
954 as %(asm_debug) %(asm_options) %|.s %A }}}}"
955 #else
956 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
957 %{E|M|MM:%(cpp_debug_options)}\
958 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
959 as %(asm_debug) %(asm_options) %m.s %A }}}}"
960 #endif
961 , 0},
963 #include "specs.h"
964 /* Mark end of table */
965 {0, 0, 0}
968 /* Number of elements in default_compilers, not counting the terminator. */
970 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
972 /* A vector of options to give to the linker.
973 These options are accumulated by %x,
974 and substituted into the linker command with %X. */
975 static int n_linker_options;
976 static char **linker_options;
978 /* A vector of options to give to the assembler.
979 These options are accumulated by -Wa,
980 and substituted into the assembler command with %Y. */
981 static int n_assembler_options;
982 static char **assembler_options;
984 /* A vector of options to give to the preprocessor.
985 These options are accumulated by -Wp,
986 and substituted into the preprocessor command with %Z. */
987 static int n_preprocessor_options;
988 static char **preprocessor_options;
990 /* Define how to map long options into short ones. */
992 /* This structure describes one mapping. */
993 struct option_map
995 /* The long option's name. */
996 const char *const name;
997 /* The equivalent short option. */
998 const char *const equivalent;
999 /* Argument info. A string of flag chars; NULL equals no options.
1000 a => argument required.
1001 o => argument optional.
1002 j => join argument to equivalent, making one word.
1003 * => require other text after NAME as an argument. */
1004 const char *const arg_info;
1007 /* This is the table of mappings. Mappings are tried sequentially
1008 for each option encountered; the first one that matches, wins. */
1010 static const struct option_map option_map[] =
1012 {"--all-warnings", "-Wall", 0},
1013 {"--ansi", "-ansi", 0},
1014 {"--assemble", "-S", 0},
1015 {"--assert", "-A", "a"},
1016 {"--classpath", "-fclasspath=", "aj"},
1017 {"--bootclasspath", "-fbootclasspath=", "aj"},
1018 {"--CLASSPATH", "-fclasspath=", "aj"},
1019 {"--comments", "-C", 0},
1020 {"--comments-in-macros", "-CC", 0},
1021 {"--compile", "-c", 0},
1022 {"--debug", "-g", "oj"},
1023 {"--define-macro", "-D", "aj"},
1024 {"--dependencies", "-M", 0},
1025 {"--dump", "-d", "a"},
1026 {"--dumpbase", "-dumpbase", "a"},
1027 {"--entry", "-e", 0},
1028 {"--extra-warnings", "-W", 0},
1029 {"--for-assembler", "-Wa", "a"},
1030 {"--for-linker", "-Xlinker", "a"},
1031 {"--force-link", "-u", "a"},
1032 {"--imacros", "-imacros", "a"},
1033 {"--include", "-include", "a"},
1034 {"--include-barrier", "-I-", 0},
1035 {"--include-directory", "-I", "aj"},
1036 {"--include-directory-after", "-idirafter", "a"},
1037 {"--include-prefix", "-iprefix", "a"},
1038 {"--include-with-prefix", "-iwithprefix", "a"},
1039 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1040 {"--include-with-prefix-after", "-iwithprefix", "a"},
1041 {"--language", "-x", "a"},
1042 {"--library-directory", "-L", "a"},
1043 {"--machine", "-m", "aj"},
1044 {"--machine-", "-m", "*j"},
1045 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1046 {"--no-line-commands", "-P", 0},
1047 {"--no-precompiled-includes", "-noprecomp", 0},
1048 {"--no-standard-includes", "-nostdinc", 0},
1049 {"--no-standard-libraries", "-nostdlib", 0},
1050 {"--no-warnings", "-w", 0},
1051 {"--optimize", "-O", "oj"},
1052 {"--output", "-o", "a"},
1053 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1054 {"--param", "--param", "a"},
1055 {"--pedantic", "-pedantic", 0},
1056 {"--pedantic-errors", "-pedantic-errors", 0},
1057 {"--pipe", "-pipe", 0},
1058 {"--prefix", "-B", "a"},
1059 {"--preprocess", "-E", 0},
1060 {"--print-search-dirs", "-print-search-dirs", 0},
1061 {"--print-file-name", "-print-file-name=", "aj"},
1062 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1063 {"--print-missing-file-dependencies", "-MG", 0},
1064 {"--print-multi-lib", "-print-multi-lib", 0},
1065 {"--print-multi-directory", "-print-multi-directory", 0},
1066 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1067 {"--print-prog-name", "-print-prog-name=", "aj"},
1068 {"--profile", "-p", 0},
1069 {"--profile-blocks", "-a", 0},
1070 {"--quiet", "-q", 0},
1071 {"--resource", "-fcompile-resource=", "aj"},
1072 {"--save-temps", "-save-temps", 0},
1073 {"--shared", "-shared", 0},
1074 {"--silent", "-q", 0},
1075 {"--specs", "-specs=", "aj"},
1076 {"--static", "-static", 0},
1077 {"--std", "-std=", "aj"},
1078 {"--symbolic", "-symbolic", 0},
1079 {"--target", "-b", "a"},
1080 {"--time", "-time", 0},
1081 {"--trace-includes", "-H", 0},
1082 {"--traditional", "-traditional", 0},
1083 {"--traditional-cpp", "-traditional-cpp", 0},
1084 {"--trigraphs", "-trigraphs", 0},
1085 {"--undefine-macro", "-U", "aj"},
1086 {"--use-version", "-V", "a"},
1087 {"--user-dependencies", "-MM", 0},
1088 {"--verbose", "-v", 0},
1089 {"--warn-", "-W", "*j"},
1090 {"--write-dependencies", "-MD", 0},
1091 {"--write-user-dependencies", "-MMD", 0},
1092 {"--", "-f", "*j"}
1096 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1097 static const struct {
1098 const char *const option_found;
1099 const char *const replacements;
1100 } target_option_translations[] =
1102 TARGET_OPTION_TRANSLATE_TABLE,
1103 { 0, 0 }
1105 #endif
1107 /* Translate the options described by *ARGCP and *ARGVP.
1108 Make a new vector and store it back in *ARGVP,
1109 and store its length in *ARGVC. */
1111 static void
1112 translate_options (argcp, argvp)
1113 int *argcp;
1114 const char *const **argvp;
1116 int i;
1117 int argc = *argcp;
1118 const char *const *argv = *argvp;
1119 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1120 const char **newv =
1121 (const char **) xmalloc (newvsize);
1122 int newindex = 0;
1124 i = 0;
1125 newv[newindex++] = argv[i++];
1127 while (i < argc)
1129 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1130 int tott_idx;
1132 for (tott_idx = 0;
1133 target_option_translations[tott_idx].option_found;
1134 tott_idx++)
1136 if (strcmp (target_option_translations[tott_idx].option_found,
1137 argv[i]) == 0)
1139 int spaces = 1;
1140 const char *sp;
1141 char *np;
1143 for (sp = target_option_translations[tott_idx].replacements;
1144 *sp; sp++)
1146 if (*sp == ' ')
1147 spaces ++;
1150 newvsize += spaces * sizeof (const char *);
1151 newv = (const char **) xrealloc (newv, newvsize);
1153 sp = target_option_translations[tott_idx].replacements;
1154 np = xstrdup (sp);
1156 while (1)
1158 while (*np == ' ')
1159 np++;
1160 if (*np == 0)
1161 break;
1162 newv[newindex++] = np;
1163 while (*np != ' ' && *np)
1164 np++;
1165 if (*np == 0)
1166 break;
1167 *np++ = 0;
1170 i ++;
1171 break;
1174 if (target_option_translations[tott_idx].option_found)
1175 continue;
1176 #endif
1178 /* Translate -- options. */
1179 if (argv[i][0] == '-' && argv[i][1] == '-')
1181 size_t j;
1182 /* Find a mapping that applies to this option. */
1183 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1185 size_t optlen = strlen (option_map[j].name);
1186 size_t arglen = strlen (argv[i]);
1187 size_t complen = arglen > optlen ? optlen : arglen;
1188 const char *arginfo = option_map[j].arg_info;
1190 if (arginfo == 0)
1191 arginfo = "";
1193 if (!strncmp (argv[i], option_map[j].name, complen))
1195 const char *arg = 0;
1197 if (arglen < optlen)
1199 size_t k;
1200 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1201 if (strlen (option_map[k].name) >= arglen
1202 && !strncmp (argv[i], option_map[k].name, arglen))
1204 error ("ambiguous abbreviation %s", argv[i]);
1205 break;
1208 if (k != ARRAY_SIZE (option_map))
1209 break;
1212 if (arglen > optlen)
1214 /* If the option has an argument, accept that. */
1215 if (argv[i][optlen] == '=')
1216 arg = argv[i] + optlen + 1;
1218 /* If this mapping requires extra text at end of name,
1219 accept that as "argument". */
1220 else if (strchr (arginfo, '*') != 0)
1221 arg = argv[i] + optlen;
1223 /* Otherwise, extra text at end means mismatch.
1224 Try other mappings. */
1225 else
1226 continue;
1229 else if (strchr (arginfo, '*') != 0)
1231 error ("incomplete `%s' option", option_map[j].name);
1232 break;
1235 /* Handle arguments. */
1236 if (strchr (arginfo, 'a') != 0)
1238 if (arg == 0)
1240 if (i + 1 == argc)
1242 error ("missing argument to `%s' option",
1243 option_map[j].name);
1244 break;
1247 arg = argv[++i];
1250 else if (strchr (arginfo, '*') != 0)
1252 else if (strchr (arginfo, 'o') == 0)
1254 if (arg != 0)
1255 error ("extraneous argument to `%s' option",
1256 option_map[j].name);
1257 arg = 0;
1260 /* Store the translation as one argv elt or as two. */
1261 if (arg != 0 && strchr (arginfo, 'j') != 0)
1262 newv[newindex++] = concat (option_map[j].equivalent, arg,
1263 NULL);
1264 else if (arg != 0)
1266 newv[newindex++] = option_map[j].equivalent;
1267 newv[newindex++] = arg;
1269 else
1270 newv[newindex++] = option_map[j].equivalent;
1272 break;
1275 i++;
1278 /* Handle old-fashioned options--just copy them through,
1279 with their arguments. */
1280 else if (argv[i][0] == '-')
1282 const char *p = argv[i] + 1;
1283 int c = *p;
1284 int nskip = 1;
1286 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1287 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1288 else if (WORD_SWITCH_TAKES_ARG (p))
1289 nskip += WORD_SWITCH_TAKES_ARG (p);
1290 else if ((c == 'B' || c == 'b' || c == 'x')
1291 && p[1] == 0)
1292 nskip += 1;
1293 else if (! strcmp (p, "Xlinker"))
1294 nskip += 1;
1295 else if (! strcmp (p, "Xpreprocessor"))
1296 nskip += 1;
1297 else if (! strcmp (p, "Xassembler"))
1298 nskip += 1;
1300 /* Watch out for an option at the end of the command line that
1301 is missing arguments, and avoid skipping past the end of the
1302 command line. */
1303 if (nskip + i > argc)
1304 nskip = argc - i;
1306 while (nskip > 0)
1308 newv[newindex++] = argv[i++];
1309 nskip--;
1312 else
1313 /* Ordinary operands, or +e options. */
1314 newv[newindex++] = argv[i++];
1317 newv[newindex] = 0;
1319 *argvp = newv;
1320 *argcp = newindex;
1323 static char *
1324 skip_whitespace (p)
1325 char *p;
1327 while (1)
1329 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1330 be considered whitespace. */
1331 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1332 return p + 1;
1333 else if (*p == '\n' || *p == ' ' || *p == '\t')
1334 p++;
1335 else if (*p == '#')
1337 while (*p != '\n')
1338 p++;
1339 p++;
1341 else
1342 break;
1345 return p;
1347 /* Structures to keep track of prefixes to try when looking for files. */
1349 struct prefix_list
1351 const char *prefix; /* String to prepend to the path. */
1352 struct prefix_list *next; /* Next in linked list. */
1353 int require_machine_suffix; /* Don't use without machine_suffix. */
1354 /* 2 means try both machine_suffix and just_machine_suffix. */
1355 int *used_flag_ptr; /* 1 if a file was found with this prefix. */
1356 int priority; /* Sort key - priority within list. */
1357 int os_multilib; /* 1 if OS multilib scheme should be used,
1358 0 for GCC multilib scheme. */
1361 struct path_prefix
1363 struct prefix_list *plist; /* List of prefixes to try */
1364 int max_len; /* Max length of a prefix in PLIST */
1365 const char *name; /* Name of this list (used in config stuff) */
1368 /* List of prefixes to try when looking for executables. */
1370 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1372 /* List of prefixes to try when looking for startup (crt0) files. */
1374 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1376 /* List of prefixes to try when looking for include files. */
1378 static struct path_prefix include_prefixes = { 0, 0, "include" };
1380 /* Suffix to attach to directories searched for commands.
1381 This looks like `MACHINE/VERSION/'. */
1383 static const char *machine_suffix = 0;
1385 /* Suffix to attach to directories searched for commands.
1386 This is just `MACHINE/'. */
1388 static const char *just_machine_suffix = 0;
1390 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1392 static const char *gcc_exec_prefix;
1394 /* Default prefixes to attach to command names. */
1396 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1397 #undef MD_EXEC_PREFIX
1398 #undef MD_STARTFILE_PREFIX
1399 #undef MD_STARTFILE_PREFIX_1
1400 #endif
1402 /* If no prefixes defined, use the null string, which will disable them. */
1403 #ifndef MD_EXEC_PREFIX
1404 #define MD_EXEC_PREFIX ""
1405 #endif
1406 #ifndef MD_STARTFILE_PREFIX
1407 #define MD_STARTFILE_PREFIX ""
1408 #endif
1409 #ifndef MD_STARTFILE_PREFIX_1
1410 #define MD_STARTFILE_PREFIX_1 ""
1411 #endif
1413 /* Supply defaults for the standard prefixes. */
1415 #ifndef STANDARD_EXEC_PREFIX
1416 #define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
1417 #endif
1418 #ifndef STANDARD_STARTFILE_PREFIX
1419 #define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
1420 #endif
1421 #ifndef TOOLDIR_BASE_PREFIX
1422 #define TOOLDIR_BASE_PREFIX "/usr/local/"
1423 #endif
1424 #ifndef STANDARD_BINDIR_PREFIX
1425 #define STANDARD_BINDIR_PREFIX "/usr/local/bin"
1426 #endif
1428 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1429 static const char *const standard_exec_prefix_1 = "/usr/lib/gcc/";
1430 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1432 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1433 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1434 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1435 static const char *const standard_startfile_prefix_1 = "/lib/";
1436 static const char *const standard_startfile_prefix_2 = "/usr/lib/";
1438 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1439 static const char *tooldir_prefix;
1441 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1443 /* Subdirectory to use for locating libraries. Set by
1444 set_multilib_dir based on the compilation options. */
1446 static const char *multilib_dir;
1448 /* Subdirectory to use for locating libraries in OS conventions. Set by
1449 set_multilib_dir based on the compilation options. */
1451 static const char *multilib_os_dir;
1453 /* Structure to keep track of the specs that have been defined so far.
1454 These are accessed using %(specname) or %[specname] in a compiler
1455 or link spec. */
1457 struct spec_list
1459 /* The following 2 fields must be first */
1460 /* to allow EXTRA_SPECS to be initialized */
1461 const char *name; /* name of the spec. */
1462 const char *ptr; /* available ptr if no static pointer */
1464 /* The following fields are not initialized */
1465 /* by EXTRA_SPECS */
1466 const char **ptr_spec; /* pointer to the spec itself. */
1467 struct spec_list *next; /* Next spec in linked list. */
1468 int name_len; /* length of the name */
1469 int alloc_p; /* whether string was allocated */
1472 #define INIT_STATIC_SPEC(NAME,PTR) \
1473 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1475 /* List of statically defined specs. */
1476 static struct spec_list static_specs[] =
1478 INIT_STATIC_SPEC ("asm", &asm_spec),
1479 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1480 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1481 INIT_STATIC_SPEC ("asm_options", &asm_options),
1482 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1483 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1484 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1485 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1486 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1487 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1488 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1489 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1490 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1491 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1492 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1493 INIT_STATIC_SPEC ("link", &link_spec),
1494 INIT_STATIC_SPEC ("lib", &lib_spec),
1495 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1496 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1497 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1498 INIT_STATIC_SPEC ("predefines", &cpp_predefines),
1499 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1500 INIT_STATIC_SPEC ("version", &compiler_version),
1501 INIT_STATIC_SPEC ("multilib", &multilib_select),
1502 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1503 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1504 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1505 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1506 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1507 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1508 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1509 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1510 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1511 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1512 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1515 #ifdef EXTRA_SPECS /* additional specs needed */
1516 /* Structure to keep track of just the first two args of a spec_list.
1517 That is all that the EXTRA_SPECS macro gives us. */
1518 struct spec_list_1
1520 const char *const name;
1521 const char *const ptr;
1524 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1525 static struct spec_list *extra_specs = (struct spec_list *) 0;
1526 #endif
1528 /* List of dynamically allocates specs that have been defined so far. */
1530 static struct spec_list *specs = (struct spec_list *) 0;
1532 /* List of static spec functions. */
1534 static const struct spec_function static_spec_functions[] =
1536 { "if-exists", if_exists_spec_function },
1537 { "if-exists-else", if_exists_else_spec_function },
1538 { 0, 0 }
1541 static int processing_spec_function;
1543 /* Add appropriate libgcc specs to OBSTACK, taking into account
1544 various permutations of -shared-libgcc, -shared, and such. */
1546 #ifdef ENABLE_SHARED_LIBGCC
1547 static void
1548 init_gcc_specs (obstack, shared_name, static_name, eh_name)
1549 struct obstack *obstack;
1550 const char *shared_name;
1551 const char *static_name;
1552 const char *eh_name;
1554 char *buf;
1556 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1557 "}%{!static:%{!static-libgcc:",
1558 "%{!shared:%{!shared-libgcc:", static_name, " ",
1559 eh_name, "}%{shared-libgcc:", shared_name, " ",
1560 static_name, "}}%{shared:",
1561 #ifdef LINK_EH_SPEC
1562 "%{shared-libgcc:", shared_name,
1563 "}%{!shared-libgcc:", static_name, "}",
1564 #else
1565 shared_name,
1566 #endif
1567 "}}}", NULL);
1569 obstack_grow (obstack, buf, strlen (buf));
1570 free (buf);
1572 #endif /* ENABLE_SHARED_LIBGCC */
1574 /* Initialize the specs lookup routines. */
1576 static void
1577 init_spec ()
1579 struct spec_list *next = (struct spec_list *) 0;
1580 struct spec_list *sl = (struct spec_list *) 0;
1581 int i;
1583 if (specs)
1584 return; /* Already initialized. */
1586 if (verbose_flag)
1587 notice ("Using built-in specs.\n");
1589 #ifdef EXTRA_SPECS
1590 extra_specs = (struct spec_list *)
1591 xcalloc (sizeof (struct spec_list), ARRAY_SIZE (extra_specs_1));
1593 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1595 sl = &extra_specs[i];
1596 sl->name = extra_specs_1[i].name;
1597 sl->ptr = extra_specs_1[i].ptr;
1598 sl->next = next;
1599 sl->name_len = strlen (sl->name);
1600 sl->ptr_spec = &sl->ptr;
1601 next = sl;
1603 #endif
1605 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1606 on ?: in file-scope variable initializations. */
1607 asm_debug = ASM_DEBUG_SPEC;
1609 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1611 sl = &static_specs[i];
1612 sl->next = next;
1613 next = sl;
1616 #ifdef ENABLE_SHARED_LIBGCC
1617 /* ??? If neither -shared-libgcc nor --static-libgcc was
1618 seen, then we should be making an educated guess. Some proposed
1619 heuristics for ELF include:
1621 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1622 program will be doing dynamic loading, which will likely
1623 need the shared libgcc.
1625 (2) If "-ldl", then it's also a fair bet that we're doing
1626 dynamic loading.
1628 (3) For each ET_DYN we're linking against (either through -lfoo
1629 or /some/path/foo.so), check to see whether it or one of
1630 its dependencies depends on a shared libgcc.
1632 (4) If "-shared"
1634 If the runtime is fixed to look for program headers instead
1635 of calling __register_frame_info at all, for each object,
1636 use the shared libgcc if any EH symbol referenced.
1638 If crtstuff is fixed to not invoke __register_frame_info
1639 automatically, for each object, use the shared libgcc if
1640 any non-empty unwind section found.
1642 Doing any of this probably requires invoking an external program to
1643 do the actual object file scanning. */
1645 const char *p = libgcc_spec;
1646 int in_sep = 1;
1648 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1649 when given the proper command line arguments. */
1650 while (*p)
1652 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1654 init_gcc_specs (&obstack,
1655 #ifdef NO_SHARED_LIBGCC_MULTILIB
1656 "-lgcc_s"
1657 #else
1658 "-lgcc_s%M"
1659 #endif
1660 #ifdef USE_LIBUNWIND_EXCEPTIONS
1661 " -lunwind"
1662 #endif
1664 "-lgcc",
1665 "-lgcc_eh");
1666 p += 5;
1667 in_sep = 0;
1669 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1671 /* Ug. We don't know shared library extensions. Hope that
1672 systems that use this form don't do shared libraries. */
1673 init_gcc_specs (&obstack,
1674 #ifdef NO_SHARED_LIBGCC_MULTILIB
1675 "-lgcc_s"
1676 #else
1677 "-lgcc_s%M"
1678 #endif
1680 "libgcc.a%s",
1681 "libgcc_eh.a%s");
1682 p += 10;
1683 in_sep = 0;
1685 else
1687 obstack_1grow (&obstack, *p);
1688 in_sep = (*p == ' ');
1689 p += 1;
1693 obstack_1grow (&obstack, '\0');
1694 libgcc_spec = obstack_finish (&obstack);
1696 #endif
1697 #ifdef USE_AS_TRADITIONAL_FORMAT
1698 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1700 static const char tf[] = "--traditional-format ";
1701 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1702 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1703 asm_spec = obstack_finish (&obstack);
1705 #endif
1706 #ifdef LINK_EH_SPEC
1707 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1708 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1709 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1710 link_spec = obstack_finish (&obstack);
1711 #endif
1713 specs = sl;
1716 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1717 removed; If the spec starts with a + then SPEC is added to the end of the
1718 current spec. */
1720 static void
1721 set_spec (name, spec)
1722 const char *name;
1723 const char *spec;
1725 struct spec_list *sl;
1726 const char *old_spec;
1727 int name_len = strlen (name);
1728 int i;
1730 /* If this is the first call, initialize the statically allocated specs. */
1731 if (!specs)
1733 struct spec_list *next = (struct spec_list *) 0;
1734 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1736 sl = &static_specs[i];
1737 sl->next = next;
1738 next = sl;
1740 specs = sl;
1743 /* See if the spec already exists. */
1744 for (sl = specs; sl; sl = sl->next)
1745 if (name_len == sl->name_len && !strcmp (sl->name, name))
1746 break;
1748 if (!sl)
1750 /* Not found - make it. */
1751 sl = (struct spec_list *) xmalloc (sizeof (struct spec_list));
1752 sl->name = xstrdup (name);
1753 sl->name_len = name_len;
1754 sl->ptr_spec = &sl->ptr;
1755 sl->alloc_p = 0;
1756 *(sl->ptr_spec) = "";
1757 sl->next = specs;
1758 specs = sl;
1761 old_spec = *(sl->ptr_spec);
1762 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1763 ? concat (old_spec, spec + 1, NULL)
1764 : xstrdup (spec));
1766 #ifdef DEBUG_SPECS
1767 if (verbose_flag)
1768 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1769 #endif
1771 /* Free the old spec. */
1772 if (old_spec && sl->alloc_p)
1773 free ((PTR) old_spec);
1775 sl->alloc_p = 1;
1778 /* Accumulate a command (program name and args), and run it. */
1780 /* Vector of pointers to arguments in the current line of specifications. */
1782 static const char **argbuf;
1784 /* Number of elements allocated in argbuf. */
1786 static int argbuf_length;
1788 /* Number of elements in argbuf currently in use (containing args). */
1790 static int argbuf_index;
1792 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1793 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1794 it here. */
1796 static struct temp_name {
1797 const char *suffix; /* suffix associated with the code. */
1798 int length; /* strlen (suffix). */
1799 int unique; /* Indicates whether %g or %u/%U was used. */
1800 const char *filename; /* associated filename. */
1801 int filename_length; /* strlen (filename). */
1802 struct temp_name *next;
1803 } *temp_names;
1805 /* Number of commands executed so far. */
1807 static int execution_count;
1809 /* Number of commands that exited with a signal. */
1811 static int signal_count;
1813 /* Name with which this program was invoked. */
1815 static const char *programname;
1817 /* Allocate the argument vector. */
1819 static void
1820 alloc_args ()
1822 argbuf_length = 10;
1823 argbuf = (const char **) xmalloc (argbuf_length * sizeof (const char *));
1826 /* Clear out the vector of arguments (after a command is executed). */
1828 static void
1829 clear_args ()
1831 argbuf_index = 0;
1834 /* Add one argument to the vector at the end.
1835 This is done when a space is seen or at the end of the line.
1836 If DELETE_ALWAYS is nonzero, the arg is a filename
1837 and the file should be deleted eventually.
1838 If DELETE_FAILURE is nonzero, the arg is a filename
1839 and the file should be deleted if this compilation fails. */
1841 static void
1842 store_arg (arg, delete_always, delete_failure)
1843 const char *arg;
1844 int delete_always, delete_failure;
1846 if (argbuf_index + 1 == argbuf_length)
1847 argbuf
1848 = (const char **) xrealloc (argbuf,
1849 (argbuf_length *= 2) * sizeof (const char *));
1851 argbuf[argbuf_index++] = arg;
1852 argbuf[argbuf_index] = 0;
1854 if (delete_always || delete_failure)
1855 record_temp_file (arg, delete_always, delete_failure);
1858 /* Load specs from a file name named FILENAME, replacing occurrences of
1859 various different types of line-endings, \r\n, \n\r and just \r, with
1860 a single \n. */
1862 static char *
1863 load_specs (filename)
1864 const char *filename;
1866 int desc;
1867 int readlen;
1868 struct stat statbuf;
1869 char *buffer;
1870 char *buffer_p;
1871 char *specs;
1872 char *specs_p;
1874 if (verbose_flag)
1875 notice ("Reading specs from %s\n", filename);
1877 /* Open and stat the file. */
1878 desc = open (filename, O_RDONLY, 0);
1879 if (desc < 0)
1880 pfatal_with_name (filename);
1881 if (stat (filename, &statbuf) < 0)
1882 pfatal_with_name (filename);
1884 /* Read contents of file into BUFFER. */
1885 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1886 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1887 if (readlen < 0)
1888 pfatal_with_name (filename);
1889 buffer[readlen] = 0;
1890 close (desc);
1892 specs = xmalloc (readlen + 1);
1893 specs_p = specs;
1894 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1896 int skip = 0;
1897 char c = *buffer_p;
1898 if (c == '\r')
1900 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1901 skip = 1;
1902 else if (*(buffer_p + 1) == '\n') /* \r\n */
1903 skip = 1;
1904 else /* \r */
1905 c = '\n';
1907 if (! skip)
1908 *specs_p++ = c;
1910 *specs_p = '\0';
1912 free (buffer);
1913 return (specs);
1916 /* Read compilation specs from a file named FILENAME,
1917 replacing the default ones.
1919 A suffix which starts with `*' is a definition for
1920 one of the machine-specific sub-specs. The "suffix" should be
1921 *asm, *cc1, *cpp, *link, *startfile, etc.
1922 The corresponding spec is stored in asm_spec, etc.,
1923 rather than in the `compilers' vector.
1925 Anything invalid in the file is a fatal error. */
1927 static void
1928 read_specs (filename, main_p)
1929 const char *filename;
1930 int main_p;
1932 char *buffer;
1933 char *p;
1935 buffer = load_specs (filename);
1937 /* Scan BUFFER for specs, putting them in the vector. */
1938 p = buffer;
1939 while (1)
1941 char *suffix;
1942 char *spec;
1943 char *in, *out, *p1, *p2, *p3;
1945 /* Advance P in BUFFER to the next nonblank nocomment line. */
1946 p = skip_whitespace (p);
1947 if (*p == 0)
1948 break;
1950 /* Is this a special command that starts with '%'? */
1951 /* Don't allow this for the main specs file, since it would
1952 encourage people to overwrite it. */
1953 if (*p == '%' && !main_p)
1955 p1 = p;
1956 while (*p && *p != '\n')
1957 p++;
1959 /* Skip '\n'. */
1960 p++;
1962 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1963 && (p1[sizeof "%include" - 1] == ' '
1964 || p1[sizeof "%include" - 1] == '\t'))
1966 char *new_filename;
1968 p1 += sizeof ("%include");
1969 while (*p1 == ' ' || *p1 == '\t')
1970 p1++;
1972 if (*p1++ != '<' || p[-2] != '>')
1973 fatal ("specs %%include syntax malformed after %ld characters",
1974 (long) (p1 - buffer + 1));
1976 p[-2] = '\0';
1977 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
1978 read_specs (new_filename ? new_filename : p1, FALSE);
1979 continue;
1981 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1982 && (p1[sizeof "%include_noerr" - 1] == ' '
1983 || p1[sizeof "%include_noerr" - 1] == '\t'))
1985 char *new_filename;
1987 p1 += sizeof "%include_noerr";
1988 while (*p1 == ' ' || *p1 == '\t')
1989 p1++;
1991 if (*p1++ != '<' || p[-2] != '>')
1992 fatal ("specs %%include syntax malformed after %ld characters",
1993 (long) (p1 - buffer + 1));
1995 p[-2] = '\0';
1996 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
1997 if (new_filename)
1998 read_specs (new_filename, FALSE);
1999 else if (verbose_flag)
2000 notice ("could not find specs file %s\n", p1);
2001 continue;
2003 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2004 && (p1[sizeof "%rename" - 1] == ' '
2005 || p1[sizeof "%rename" - 1] == '\t'))
2007 int name_len;
2008 struct spec_list *sl;
2009 struct spec_list *newsl;
2011 /* Get original name. */
2012 p1 += sizeof "%rename";
2013 while (*p1 == ' ' || *p1 == '\t')
2014 p1++;
2016 if (! ISALPHA ((unsigned char) *p1))
2017 fatal ("specs %%rename syntax malformed after %ld characters",
2018 (long) (p1 - buffer));
2020 p2 = p1;
2021 while (*p2 && !ISSPACE ((unsigned char) *p2))
2022 p2++;
2024 if (*p2 != ' ' && *p2 != '\t')
2025 fatal ("specs %%rename syntax malformed after %ld characters",
2026 (long) (p2 - buffer));
2028 name_len = p2 - p1;
2029 *p2++ = '\0';
2030 while (*p2 == ' ' || *p2 == '\t')
2031 p2++;
2033 if (! ISALPHA ((unsigned char) *p2))
2034 fatal ("specs %%rename syntax malformed after %ld characters",
2035 (long) (p2 - buffer));
2037 /* Get new spec name. */
2038 p3 = p2;
2039 while (*p3 && !ISSPACE ((unsigned char) *p3))
2040 p3++;
2042 if (p3 != p - 1)
2043 fatal ("specs %%rename syntax malformed after %ld characters",
2044 (long) (p3 - buffer));
2045 *p3 = '\0';
2047 for (sl = specs; sl; sl = sl->next)
2048 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2049 break;
2051 if (!sl)
2052 fatal ("specs %s spec was not found to be renamed", p1);
2054 if (strcmp (p1, p2) == 0)
2055 continue;
2057 for (newsl = specs; newsl; newsl = newsl->next)
2058 if (strcmp (newsl->name, p2) == 0)
2059 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2060 filename, p1, p2);
2062 if (verbose_flag)
2064 notice ("rename spec %s to %s\n", p1, p2);
2065 #ifdef DEBUG_SPECS
2066 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2067 #endif
2070 set_spec (p2, *(sl->ptr_spec));
2071 if (sl->alloc_p)
2072 free ((PTR) *(sl->ptr_spec));
2074 *(sl->ptr_spec) = "";
2075 sl->alloc_p = 0;
2076 continue;
2078 else
2079 fatal ("specs unknown %% command after %ld characters",
2080 (long) (p1 - buffer));
2083 /* Find the colon that should end the suffix. */
2084 p1 = p;
2085 while (*p1 && *p1 != ':' && *p1 != '\n')
2086 p1++;
2088 /* The colon shouldn't be missing. */
2089 if (*p1 != ':')
2090 fatal ("specs file malformed after %ld characters",
2091 (long) (p1 - buffer));
2093 /* Skip back over trailing whitespace. */
2094 p2 = p1;
2095 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2096 p2--;
2098 /* Copy the suffix to a string. */
2099 suffix = save_string (p, p2 - p);
2100 /* Find the next line. */
2101 p = skip_whitespace (p1 + 1);
2102 if (p[1] == 0)
2103 fatal ("specs file malformed after %ld characters",
2104 (long) (p - buffer));
2106 p1 = p;
2107 /* Find next blank line or end of string. */
2108 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2109 p1++;
2111 /* Specs end at the blank line and do not include the newline. */
2112 spec = save_string (p, p1 - p);
2113 p = p1;
2115 /* Delete backslash-newline sequences from the spec. */
2116 in = spec;
2117 out = spec;
2118 while (*in != 0)
2120 if (in[0] == '\\' && in[1] == '\n')
2121 in += 2;
2122 else if (in[0] == '#')
2123 while (*in && *in != '\n')
2124 in++;
2126 else
2127 *out++ = *in++;
2129 *out = 0;
2131 if (suffix[0] == '*')
2133 if (! strcmp (suffix, "*link_command"))
2134 link_command_spec = spec;
2135 else
2136 set_spec (suffix + 1, spec);
2138 else
2140 /* Add this pair to the vector. */
2141 compilers
2142 = ((struct compiler *)
2143 xrealloc (compilers,
2144 (n_compilers + 2) * sizeof (struct compiler)));
2146 compilers[n_compilers].suffix = suffix;
2147 compilers[n_compilers].spec = spec;
2148 n_compilers++;
2149 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2152 if (*suffix == 0)
2153 link_command_spec = spec;
2156 if (link_command_spec == 0)
2157 fatal ("spec file has no spec for linking");
2160 /* Record the names of temporary files we tell compilers to write,
2161 and delete them at the end of the run. */
2163 /* This is the common prefix we use to make temp file names.
2164 It is chosen once for each run of this program.
2165 It is substituted into a spec by %g or %j.
2166 Thus, all temp file names contain this prefix.
2167 In practice, all temp file names start with this prefix.
2169 This prefix comes from the envvar TMPDIR if it is defined;
2170 otherwise, from the P_tmpdir macro if that is defined;
2171 otherwise, in /usr/tmp or /tmp;
2172 or finally the current directory if all else fails. */
2174 static const char *temp_filename;
2176 /* Length of the prefix. */
2178 static int temp_filename_length;
2180 /* Define the list of temporary files to delete. */
2182 struct temp_file
2184 const char *name;
2185 struct temp_file *next;
2188 /* Queue of files to delete on success or failure of compilation. */
2189 static struct temp_file *always_delete_queue;
2190 /* Queue of files to delete on failure of compilation. */
2191 static struct temp_file *failure_delete_queue;
2193 /* Record FILENAME as a file to be deleted automatically.
2194 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2195 otherwise delete it in any case.
2196 FAIL_DELETE nonzero means delete it if a compilation step fails;
2197 otherwise delete it in any case. */
2199 void
2200 record_temp_file (filename, always_delete, fail_delete)
2201 const char *filename;
2202 int always_delete;
2203 int fail_delete;
2205 char *const name = xstrdup (filename);
2207 if (always_delete)
2209 struct temp_file *temp;
2210 for (temp = always_delete_queue; temp; temp = temp->next)
2211 if (! strcmp (name, temp->name))
2212 goto already1;
2214 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2215 temp->next = always_delete_queue;
2216 temp->name = name;
2217 always_delete_queue = temp;
2219 already1:;
2222 if (fail_delete)
2224 struct temp_file *temp;
2225 for (temp = failure_delete_queue; temp; temp = temp->next)
2226 if (! strcmp (name, temp->name))
2227 goto already2;
2229 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2230 temp->next = failure_delete_queue;
2231 temp->name = name;
2232 failure_delete_queue = temp;
2234 already2:;
2238 /* Delete all the temporary files whose names we previously recorded. */
2240 static void
2241 delete_if_ordinary (name)
2242 const char *name;
2244 struct stat st;
2245 #ifdef DEBUG
2246 int i, c;
2248 printf ("Delete %s? (y or n) ", name);
2249 fflush (stdout);
2250 i = getchar ();
2251 if (i != '\n')
2252 while ((c = getchar ()) != '\n' && c != EOF)
2255 if (i == 'y' || i == 'Y')
2256 #endif /* DEBUG */
2257 if (stat (name, &st) >= 0 && S_ISREG (st.st_mode))
2258 if (unlink (name) < 0)
2259 if (verbose_flag)
2260 perror_with_name (name);
2263 static void
2264 delete_temp_files ()
2266 struct temp_file *temp;
2268 for (temp = always_delete_queue; temp; temp = temp->next)
2269 delete_if_ordinary (temp->name);
2270 always_delete_queue = 0;
2273 /* Delete all the files to be deleted on error. */
2275 static void
2276 delete_failure_queue ()
2278 struct temp_file *temp;
2280 for (temp = failure_delete_queue; temp; temp = temp->next)
2281 delete_if_ordinary (temp->name);
2284 static void
2285 clear_failure_queue ()
2287 failure_delete_queue = 0;
2290 /* Build a list of search directories from PATHS.
2291 PREFIX is a string to prepend to the list.
2292 If CHECK_DIR_P is nonzero we ensure the directory exists.
2293 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2294 It is also used by the --print-search-dirs flag. */
2296 static char *
2297 build_search_list (paths, prefix, check_dir_p)
2298 struct path_prefix *paths;
2299 const char *prefix;
2300 int check_dir_p;
2302 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2303 int just_suffix_len
2304 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2305 int first_time = TRUE;
2306 struct prefix_list *pprefix;
2308 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2309 obstack_1grow (&collect_obstack, '=');
2311 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2313 int len = strlen (pprefix->prefix);
2315 if (machine_suffix
2316 && (! check_dir_p
2317 || is_directory (pprefix->prefix, machine_suffix, 0)))
2319 if (!first_time)
2320 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2322 first_time = FALSE;
2323 obstack_grow (&collect_obstack, pprefix->prefix, len);
2324 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2327 if (just_machine_suffix
2328 && pprefix->require_machine_suffix == 2
2329 && (! check_dir_p
2330 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2332 if (! first_time)
2333 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2335 first_time = FALSE;
2336 obstack_grow (&collect_obstack, pprefix->prefix, len);
2337 obstack_grow (&collect_obstack, just_machine_suffix,
2338 just_suffix_len);
2341 if (! pprefix->require_machine_suffix)
2343 if (! first_time)
2344 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2346 first_time = FALSE;
2347 obstack_grow (&collect_obstack, pprefix->prefix, len);
2351 obstack_1grow (&collect_obstack, '\0');
2352 return obstack_finish (&collect_obstack);
2355 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2356 for collect. */
2358 static void
2359 putenv_from_prefixes (paths, env_var)
2360 struct path_prefix *paths;
2361 const char *env_var;
2363 putenv (build_search_list (paths, env_var, 1));
2366 /* Check whether NAME can be accessed in MODE. This is like access,
2367 except that it never considers directories to be executable. */
2369 static int
2370 access_check (name, mode)
2371 const char *name;
2372 int mode;
2374 if (mode == X_OK)
2376 struct stat st;
2378 if (stat (name, &st) < 0
2379 || S_ISDIR (st.st_mode))
2380 return -1;
2383 return access (name, mode);
2386 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2387 access to check permissions.
2388 Return 0 if not found, otherwise return its name, allocated with malloc. */
2390 static char *
2391 find_a_file (pprefix, name, mode, multilib)
2392 struct path_prefix *pprefix;
2393 const char *name;
2394 int mode, multilib;
2396 char *temp;
2397 const char *const file_suffix =
2398 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2399 struct prefix_list *pl;
2400 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2401 const char *multilib_name, *multilib_os_name;
2403 #ifdef DEFAULT_ASSEMBLER
2404 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2405 return xstrdup (DEFAULT_ASSEMBLER);
2406 #endif
2408 #ifdef DEFAULT_LINKER
2409 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2410 return xstrdup (DEFAULT_LINKER);
2411 #endif
2413 if (machine_suffix)
2414 len += strlen (machine_suffix);
2416 multilib_name = name;
2417 multilib_os_name = name;
2418 if (multilib && multilib_os_dir)
2420 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2421 int len2 = strlen (multilib_os_dir) + 1;
2423 len += len1 > len2 ? len1 : len2;
2424 if (multilib_dir)
2425 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2426 NULL));
2427 if (strcmp (multilib_os_dir, ".") != 0)
2428 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2429 NULL));
2432 temp = xmalloc (len);
2434 /* Determine the filename to execute (special case for absolute paths). */
2436 if (IS_ABSOLUTE_PATHNAME (name))
2438 if (access (name, mode) == 0)
2440 strcpy (temp, name);
2441 return temp;
2444 else
2445 for (pl = pprefix->plist; pl; pl = pl->next)
2447 const char *this_name
2448 = pl->os_multilib ? multilib_os_name : multilib_name;
2450 if (machine_suffix)
2452 /* Some systems have a suffix for executable files.
2453 So try appending that first. */
2454 if (file_suffix[0] != 0)
2456 strcpy (temp, pl->prefix);
2457 strcat (temp, machine_suffix);
2458 strcat (temp, multilib_name);
2459 strcat (temp, file_suffix);
2460 if (access_check (temp, mode) == 0)
2462 if (pl->used_flag_ptr != 0)
2463 *pl->used_flag_ptr = 1;
2464 return temp;
2468 /* Now try just the multilib_name. */
2469 strcpy (temp, pl->prefix);
2470 strcat (temp, machine_suffix);
2471 strcat (temp, multilib_name);
2472 if (access_check (temp, mode) == 0)
2474 if (pl->used_flag_ptr != 0)
2475 *pl->used_flag_ptr = 1;
2476 return temp;
2480 /* Certain prefixes are tried with just the machine type,
2481 not the version. This is used for finding as, ld, etc. */
2482 if (just_machine_suffix && pl->require_machine_suffix == 2)
2484 /* Some systems have a suffix for executable files.
2485 So try appending that first. */
2486 if (file_suffix[0] != 0)
2488 strcpy (temp, pl->prefix);
2489 strcat (temp, just_machine_suffix);
2490 strcat (temp, multilib_name);
2491 strcat (temp, file_suffix);
2492 if (access_check (temp, mode) == 0)
2494 if (pl->used_flag_ptr != 0)
2495 *pl->used_flag_ptr = 1;
2496 return temp;
2500 strcpy (temp, pl->prefix);
2501 strcat (temp, just_machine_suffix);
2502 strcat (temp, multilib_name);
2503 if (access_check (temp, mode) == 0)
2505 if (pl->used_flag_ptr != 0)
2506 *pl->used_flag_ptr = 1;
2507 return temp;
2511 /* Certain prefixes can't be used without the machine suffix
2512 when the machine or version is explicitly specified. */
2513 if (! pl->require_machine_suffix)
2515 /* Some systems have a suffix for executable files.
2516 So try appending that first. */
2517 if (file_suffix[0] != 0)
2519 strcpy (temp, pl->prefix);
2520 strcat (temp, this_name);
2521 strcat (temp, file_suffix);
2522 if (access_check (temp, mode) == 0)
2524 if (pl->used_flag_ptr != 0)
2525 *pl->used_flag_ptr = 1;
2526 return temp;
2530 strcpy (temp, pl->prefix);
2531 strcat (temp, this_name);
2532 if (access_check (temp, mode) == 0)
2534 if (pl->used_flag_ptr != 0)
2535 *pl->used_flag_ptr = 1;
2536 return temp;
2541 free (temp);
2542 return 0;
2545 /* Ranking of prefixes in the sort list. -B prefixes are put before
2546 all others. */
2548 enum path_prefix_priority
2550 PREFIX_PRIORITY_B_OPT,
2551 PREFIX_PRIORITY_LAST
2554 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2555 order according to PRIORITY. Within each PRIORITY, new entries are
2556 appended.
2558 If WARN is nonzero, we will warn if no file is found
2559 through this prefix. WARN should point to an int
2560 which will be set to 1 if this entry is used.
2562 COMPONENT is the value to be passed to update_path.
2564 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2565 the complete value of machine_suffix.
2566 2 means try both machine_suffix and just_machine_suffix. */
2568 static void
2569 add_prefix (pprefix, prefix, component, priority, require_machine_suffix,
2570 warn, os_multilib)
2571 struct path_prefix *pprefix;
2572 const char *prefix;
2573 const char *component;
2574 /* enum prefix_priority */ int priority;
2575 int require_machine_suffix;
2576 int *warn;
2577 int os_multilib;
2579 struct prefix_list *pl, **prev;
2580 int len;
2582 for (prev = &pprefix->plist;
2583 (*prev) != NULL && (*prev)->priority <= priority;
2584 prev = &(*prev)->next)
2587 /* Keep track of the longest prefix */
2589 prefix = update_path (prefix, component);
2590 len = strlen (prefix);
2591 if (len > pprefix->max_len)
2592 pprefix->max_len = len;
2594 pl = (struct prefix_list *) xmalloc (sizeof (struct prefix_list));
2595 pl->prefix = prefix;
2596 pl->require_machine_suffix = require_machine_suffix;
2597 pl->used_flag_ptr = warn;
2598 pl->priority = priority;
2599 pl->os_multilib = os_multilib;
2600 if (warn)
2601 *warn = 0;
2603 /* Insert after PREV */
2604 pl->next = (*prev);
2605 (*prev) = pl;
2608 /* Same as add_prefix, but prepending target_system_root to prefix. */
2609 static void
2610 add_sysrooted_prefix (pprefix, prefix, component, priority,
2611 require_machine_suffix, warn, os_multilib)
2612 struct path_prefix *pprefix;
2613 const char *prefix;
2614 const char *component;
2615 /* enum prefix_priority */ int priority;
2616 int require_machine_suffix;
2617 int *warn;
2618 int os_multilib;
2620 if (!IS_ABSOLUTE_PATHNAME (prefix))
2621 abort ();
2623 if (target_system_root)
2625 prefix = concat (target_system_root, prefix, NULL);
2626 /* We have to override this because GCC's notion of sysroot
2627 moves along with GCC. */
2628 component = "GCC";
2631 add_prefix (pprefix, prefix, component, priority,
2632 require_machine_suffix, warn, os_multilib);
2635 /* Execute the command specified by the arguments on the current line of spec.
2636 When using pipes, this includes several piped-together commands
2637 with `|' between them.
2639 Return 0 if successful, -1 if failed. */
2641 static int
2642 execute ()
2644 int i;
2645 int n_commands; /* # of command. */
2646 char *string;
2647 struct command
2649 const char *prog; /* program name. */
2650 const char **argv; /* vector of args. */
2651 int pid; /* pid of process for this command. */
2654 struct command *commands; /* each command buffer with above info. */
2656 if (processing_spec_function)
2657 abort ();
2659 /* Count # of piped commands. */
2660 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2661 if (strcmp (argbuf[i], "|") == 0)
2662 n_commands++;
2664 /* Get storage for each command. */
2665 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2667 /* Split argbuf into its separate piped processes,
2668 and record info about each one.
2669 Also search for the programs that are to be run. */
2671 commands[0].prog = argbuf[0]; /* first command. */
2672 commands[0].argv = &argbuf[0];
2673 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2675 if (string)
2676 commands[0].argv[0] = string;
2678 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2679 if (strcmp (argbuf[i], "|") == 0)
2680 { /* each command. */
2681 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2682 fatal ("-pipe not supported");
2683 #endif
2684 argbuf[i] = 0; /* termination of command args. */
2685 commands[n_commands].prog = argbuf[i + 1];
2686 commands[n_commands].argv = &argbuf[i + 1];
2687 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2688 X_OK, 0);
2689 if (string)
2690 commands[n_commands].argv[0] = string;
2691 n_commands++;
2694 argbuf[argbuf_index] = 0;
2696 /* If -v, print what we are about to do, and maybe query. */
2698 if (verbose_flag)
2700 /* For help listings, put a blank line between sub-processes. */
2701 if (print_help_list)
2702 fputc ('\n', stderr);
2704 /* Print each piped command as a separate line. */
2705 for (i = 0; i < n_commands; i++)
2707 const char *const *j;
2709 if (verbose_only_flag)
2711 for (j = commands[i].argv; *j; j++)
2713 const char *p;
2714 fprintf (stderr, " \"");
2715 for (p = *j; *p; ++p)
2717 if (*p == '"' || *p == '\\' || *p == '$')
2718 fputc ('\\', stderr);
2719 fputc (*p, stderr);
2721 fputc ('"', stderr);
2724 else
2725 for (j = commands[i].argv; *j; j++)
2726 fprintf (stderr, " %s", *j);
2728 /* Print a pipe symbol after all but the last command. */
2729 if (i + 1 != n_commands)
2730 fprintf (stderr, " |");
2731 fprintf (stderr, "\n");
2733 fflush (stderr);
2734 if (verbose_only_flag != 0)
2735 return 0;
2736 #ifdef DEBUG
2737 notice ("\nGo ahead? (y or n) ");
2738 fflush (stderr);
2739 i = getchar ();
2740 if (i != '\n')
2741 while (getchar () != '\n')
2744 if (i != 'y' && i != 'Y')
2745 return 0;
2746 #endif /* DEBUG */
2749 #ifdef ENABLE_VALGRIND_CHECKING
2750 /* Run the each command through valgrind. To simplify prepending the
2751 path to valgrind and the option "-q" (for quiet operation unless
2752 something triggers), we allocate a separate argv array. */
2754 for (i = 0; i < n_commands; i++)
2756 const char **argv;
2757 int argc;
2758 int j;
2760 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2763 argv = alloca ((argc + 3) * sizeof (char *));
2765 argv[0] = VALGRIND_PATH;
2766 argv[1] = "-q";
2767 for (j = 2; j < argc + 2; j++)
2768 argv[j] = commands[i].argv[j - 2];
2769 argv[j] = NULL;
2771 commands[i].argv = argv;
2772 commands[i].prog = argv[0];
2774 #endif
2776 /* Run each piped subprocess. */
2778 for (i = 0; i < n_commands; i++)
2780 char *errmsg_fmt, *errmsg_arg;
2781 const char *string = commands[i].argv[0];
2783 /* For some bizarre reason, the second argument of execvp() is
2784 char *const *, not const char *const *. */
2785 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2786 programname, temp_filename,
2787 &errmsg_fmt, &errmsg_arg,
2788 ((i == 0 ? PEXECUTE_FIRST : 0)
2789 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2790 | (string == commands[i].prog
2791 ? PEXECUTE_SEARCH : 0)
2792 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2794 if (commands[i].pid == -1)
2795 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2797 if (string != commands[i].prog)
2798 free ((PTR) string);
2801 execution_count++;
2803 /* Wait for all the subprocesses to finish.
2804 We don't care what order they finish in;
2805 we know that N_COMMANDS waits will get them all.
2806 Ignore subprocesses that we don't know about,
2807 since they can be spawned by the process that exec'ed us. */
2810 int ret_code = 0;
2811 #ifdef HAVE_GETRUSAGE
2812 struct timeval d;
2813 double ut = 0.0, st = 0.0;
2814 #endif
2816 for (i = 0; i < n_commands;)
2818 int j;
2819 int status;
2820 int pid;
2822 pid = pwait (commands[i].pid, &status, 0);
2823 if (pid < 0)
2824 abort ();
2826 #ifdef HAVE_GETRUSAGE
2827 if (report_times)
2829 /* getrusage returns the total resource usage of all children
2830 up to now. Copy the previous values into prus, get the
2831 current statistics, then take the difference. */
2833 prus = rus;
2834 getrusage (RUSAGE_CHILDREN, &rus);
2835 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2836 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2837 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2839 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2840 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2841 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2843 #endif
2845 for (j = 0; j < n_commands; j++)
2846 if (commands[j].pid == pid)
2848 i++;
2849 if (WIFSIGNALED (status))
2851 #ifdef SIGPIPE
2852 /* SIGPIPE is a special case. It happens in -pipe mode
2853 when the compiler dies before the preprocessor is
2854 done, or the assembler dies before the compiler is
2855 done. There's generally been an error already, and
2856 this is just fallout. So don't generate another error
2857 unless we would otherwise have succeeded. */
2858 if (WTERMSIG (status) == SIGPIPE
2859 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2861 else
2862 #endif
2863 fatal ("\
2864 Internal error: %s (program %s)\n\
2865 Please submit a full bug report.\n\
2866 See %s for instructions.",
2867 strsignal (WTERMSIG (status)), commands[j].prog,
2868 bug_report_url);
2869 signal_count++;
2870 ret_code = -1;
2872 else if (WIFEXITED (status)
2873 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2875 if (WEXITSTATUS (status) > greatest_status)
2876 greatest_status = WEXITSTATUS (status);
2877 ret_code = -1;
2879 #ifdef HAVE_GETRUSAGE
2880 if (report_times && ut + st != 0)
2881 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2882 #endif
2883 break;
2886 return ret_code;
2890 /* Find all the switches given to us
2891 and make a vector describing them.
2892 The elements of the vector are strings, one per switch given.
2893 If a switch uses following arguments, then the `part1' field
2894 is the switch itself and the `args' field
2895 is a null-terminated vector containing the following arguments.
2896 The `live_cond' field is:
2897 0 when initialized
2898 1 if the switch is true in a conditional spec,
2899 -1 if false (overridden by a later switch)
2900 -2 if this switch should be ignored (used in %<S)
2901 The `validated' field is nonzero if any spec has looked at this switch;
2902 if it remains zero at the end of the run, it must be meaningless. */
2904 #define SWITCH_OK 0
2905 #define SWITCH_FALSE -1
2906 #define SWITCH_IGNORE -2
2907 #define SWITCH_LIVE 1
2909 struct switchstr
2911 const char *part1;
2912 const char **args;
2913 int live_cond;
2914 unsigned char validated;
2915 unsigned char ordering;
2918 static struct switchstr *switches;
2920 static int n_switches;
2922 struct infile
2924 const char *name;
2925 const char *language;
2928 /* Also a vector of input files specified. */
2930 static struct infile *infiles;
2932 int n_infiles;
2934 /* This counts the number of libraries added by lang_specific_driver, so that
2935 we can tell if there were any user supplied any files or libraries. */
2937 static int added_libraries;
2939 /* And a vector of corresponding output files is made up later. */
2941 const char **outfiles;
2943 /* Used to track if none of the -B paths are used. */
2944 static int warn_B;
2946 /* Gives value to pass as "warn" to add_prefix for standard prefixes. */
2947 static int *warn_std_ptr = 0;
2949 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2951 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2952 is true if we should look for an executable suffix. DO_OBJ
2953 is true if we should look for an object suffix. */
2955 static const char *
2956 convert_filename (name, do_exe, do_obj)
2957 const char *name;
2958 int do_exe ATTRIBUTE_UNUSED;
2959 int do_obj ATTRIBUTE_UNUSED;
2961 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2962 int i;
2963 #endif
2964 int len;
2966 if (name == NULL)
2967 return NULL;
2969 len = strlen (name);
2971 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2972 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2973 if (do_obj && len > 2
2974 && name[len - 2] == '.'
2975 && name[len - 1] == 'o')
2977 obstack_grow (&obstack, name, len - 2);
2978 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2979 name = obstack_finish (&obstack);
2981 #endif
2983 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2984 /* If there is no filetype, make it the executable suffix (which includes
2985 the "."). But don't get confused if we have just "-o". */
2986 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2987 return name;
2989 for (i = len - 1; i >= 0; i--)
2990 if (IS_DIR_SEPARATOR (name[i]))
2991 break;
2993 for (i++; i < len; i++)
2994 if (name[i] == '.')
2995 return name;
2997 obstack_grow (&obstack, name, len);
2998 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2999 strlen (TARGET_EXECUTABLE_SUFFIX));
3000 name = obstack_finish (&obstack);
3001 #endif
3003 return name;
3005 #endif
3007 /* Display the command line switches accepted by gcc. */
3008 static void
3009 display_help ()
3011 printf (_("Usage: %s [options] file...\n"), programname);
3012 fputs (_("Options:\n"), stdout);
3014 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3015 fputs (_(" --help Display this information\n"), stdout);
3016 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3017 if (! verbose_flag)
3018 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3019 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3020 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3021 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3022 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3023 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3024 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3025 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3026 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3027 fputs (_("\
3028 -print-multi-lib Display the mapping between command line options and\n\
3029 multiple library search directories\n"), stdout);
3030 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3031 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3032 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3033 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3034 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3035 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3036 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3037 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3038 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3039 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3040 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3041 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3042 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3043 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3044 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3045 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3046 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3047 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3048 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3049 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3050 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3051 fputs (_("\
3052 -x <language> Specify the language of the following input files\n\
3053 Permissable languages include: c c++ assembler none\n\
3054 'none' means revert to the default behavior of\n\
3055 guessing the language based on the file's extension\n\
3056 "), stdout);
3058 printf (_("\
3059 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3060 passed on to the various sub-processes invoked by %s. In order to pass\n\
3061 other options on to these processes the -W<letter> options must be used.\n\
3062 "), programname);
3064 /* The rest of the options are displayed by invocations of the various
3065 sub-processes. */
3068 static void
3069 add_preprocessor_option (option, len)
3070 const char *option;
3071 int len;
3073 n_preprocessor_options++;
3075 if (! preprocessor_options)
3076 preprocessor_options
3077 = (char **) xmalloc (n_preprocessor_options * sizeof (char *));
3078 else
3079 preprocessor_options
3080 = (char **) xrealloc (preprocessor_options,
3081 n_preprocessor_options * sizeof (char *));
3083 preprocessor_options [n_preprocessor_options - 1] =
3084 save_string (option, len);
3087 static void
3088 add_assembler_option (option, len)
3089 const char *option;
3090 int len;
3092 n_assembler_options++;
3094 if (! assembler_options)
3095 assembler_options
3096 = (char **) xmalloc (n_assembler_options * sizeof (char *));
3097 else
3098 assembler_options
3099 = (char **) xrealloc (assembler_options,
3100 n_assembler_options * sizeof (char *));
3102 assembler_options [n_assembler_options - 1] = save_string (option, len);
3105 static void
3106 add_linker_option (option, len)
3107 const char *option;
3108 int len;
3110 n_linker_options++;
3112 if (! linker_options)
3113 linker_options
3114 = (char **) xmalloc (n_linker_options * sizeof (char *));
3115 else
3116 linker_options
3117 = (char **) xrealloc (linker_options,
3118 n_linker_options * sizeof (char *));
3120 linker_options [n_linker_options - 1] = save_string (option, len);
3123 /* Create the vector `switches' and its contents.
3124 Store its length in `n_switches'. */
3126 static void
3127 process_command (argc, argv)
3128 int argc;
3129 const char *const *argv;
3131 int i;
3132 const char *temp;
3133 char *temp1;
3134 const char *spec_lang = 0;
3135 int last_language_n_infiles;
3136 int have_c = 0;
3137 int have_o = 0;
3138 int lang_n_infiles = 0;
3139 #ifdef MODIFY_TARGET_NAME
3140 int is_modify_target_name;
3141 int j;
3142 #endif
3144 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3146 n_switches = 0;
3147 n_infiles = 0;
3148 added_libraries = 0;
3150 /* Figure compiler version from version string. */
3152 compiler_version = temp1 = xstrdup (version_string);
3154 for (; *temp1; ++temp1)
3156 if (*temp1 == ' ')
3158 *temp1 = '\0';
3159 break;
3163 /* If there is a -V or -b option (or both), process it now, before
3164 trying to interpret the rest of the command line. */
3165 if (argc > 1 && argv[1][0] == '-'
3166 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3168 const char *new_version = DEFAULT_TARGET_VERSION;
3169 const char *new_machine = DEFAULT_TARGET_MACHINE;
3170 const char *progname = argv[0];
3171 char **new_argv;
3172 char *new_argv0;
3173 int baselen;
3175 while (argc > 1 && argv[1][0] == '-'
3176 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3178 char opt = argv[1][1];
3179 const char *arg;
3180 if (argv[1][2] != '\0')
3182 arg = argv[1] + 2;
3183 argc -= 1;
3184 argv += 1;
3186 else if (argc > 2)
3188 arg = argv[2];
3189 argc -= 2;
3190 argv += 2;
3192 else
3193 fatal ("`-%c' option must have argument", opt);
3194 if (opt == 'V')
3195 new_version = arg;
3196 else
3197 new_machine = arg;
3200 for (baselen = strlen (progname); baselen > 0; baselen--)
3201 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3202 break;
3203 new_argv0 = xmemdup (progname, baselen,
3204 baselen + concat_length (new_version, new_machine,
3205 "-gcc-", NULL) + 1);
3206 strcpy (new_argv0 + baselen, new_machine);
3207 strcat (new_argv0, "-gcc-");
3208 strcat (new_argv0, new_version);
3210 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3211 (argc + 1) * sizeof (argv[0]));
3212 new_argv[0] = new_argv0;
3214 execvp (new_argv0, new_argv);
3215 fatal ("couldn't run `%s': %s", new_argv0, xstrerror (errno));
3218 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3219 see if we can create it from the pathname specified in argv[0]. */
3221 #ifndef VMS
3222 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3223 if (!gcc_exec_prefix)
3225 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3226 standard_exec_prefix);
3227 if (gcc_exec_prefix)
3228 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3230 #endif
3232 if (gcc_exec_prefix)
3234 int len = strlen (gcc_exec_prefix);
3236 if (len > (int) sizeof ("/lib/gcc-lib/") - 1
3237 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3239 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc-lib/") + 1;
3240 if (IS_DIR_SEPARATOR (*temp)
3241 && strncmp (temp + 1, "lib", 3) == 0
3242 && IS_DIR_SEPARATOR (temp[4])
3243 && strncmp (temp + 5, "gcc-lib", 7) == 0)
3244 len -= sizeof ("/lib/gcc-lib/") - 1;
3247 set_std_prefix (gcc_exec_prefix, len);
3248 add_prefix (&exec_prefixes, gcc_exec_prefix, "GCC",
3249 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3250 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3251 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3254 /* COMPILER_PATH and LIBRARY_PATH have values
3255 that are lists of directory names with colons. */
3257 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3258 if (temp)
3260 const char *startp, *endp;
3261 char *nstore = (char *) alloca (strlen (temp) + 3);
3263 startp = endp = temp;
3264 while (1)
3266 if (*endp == PATH_SEPARATOR || *endp == 0)
3268 strncpy (nstore, startp, endp - startp);
3269 if (endp == startp)
3270 strcpy (nstore, concat (".", dir_separator_str, NULL));
3271 else if (!IS_DIR_SEPARATOR (endp[-1]))
3273 nstore[endp - startp] = DIR_SEPARATOR;
3274 nstore[endp - startp + 1] = 0;
3276 else
3277 nstore[endp - startp] = 0;
3278 add_prefix (&exec_prefixes, nstore, 0,
3279 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3280 add_prefix (&include_prefixes,
3281 concat (nstore, "include", NULL),
3282 0, PREFIX_PRIORITY_LAST, 0, NULL, 0);
3283 if (*endp == 0)
3284 break;
3285 endp = startp = endp + 1;
3287 else
3288 endp++;
3292 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3293 if (temp && *cross_compile == '0')
3295 const char *startp, *endp;
3296 char *nstore = (char *) alloca (strlen (temp) + 3);
3298 startp = endp = temp;
3299 while (1)
3301 if (*endp == PATH_SEPARATOR || *endp == 0)
3303 strncpy (nstore, startp, endp - startp);
3304 if (endp == startp)
3305 strcpy (nstore, concat (".", dir_separator_str, NULL));
3306 else if (!IS_DIR_SEPARATOR (endp[-1]))
3308 nstore[endp - startp] = DIR_SEPARATOR;
3309 nstore[endp - startp + 1] = 0;
3311 else
3312 nstore[endp - startp] = 0;
3313 add_prefix (&startfile_prefixes, nstore, NULL,
3314 PREFIX_PRIORITY_LAST, 0, NULL, 1);
3315 if (*endp == 0)
3316 break;
3317 endp = startp = endp + 1;
3319 else
3320 endp++;
3324 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3325 GET_ENVIRONMENT (temp, "LPATH");
3326 if (temp && *cross_compile == '0')
3328 const char *startp, *endp;
3329 char *nstore = (char *) alloca (strlen (temp) + 3);
3331 startp = endp = temp;
3332 while (1)
3334 if (*endp == PATH_SEPARATOR || *endp == 0)
3336 strncpy (nstore, startp, endp - startp);
3337 if (endp == startp)
3338 strcpy (nstore, concat (".", dir_separator_str, NULL));
3339 else if (!IS_DIR_SEPARATOR (endp[-1]))
3341 nstore[endp - startp] = DIR_SEPARATOR;
3342 nstore[endp - startp + 1] = 0;
3344 else
3345 nstore[endp - startp] = 0;
3346 add_prefix (&startfile_prefixes, nstore, NULL,
3347 PREFIX_PRIORITY_LAST, 0, NULL, 1);
3348 if (*endp == 0)
3349 break;
3350 endp = startp = endp + 1;
3352 else
3353 endp++;
3357 /* Convert new-style -- options to old-style. */
3358 translate_options (&argc, &argv);
3360 /* Do language-specific adjustment/addition of flags. */
3361 lang_specific_driver (&argc, &argv, &added_libraries);
3363 /* Scan argv twice. Here, the first time, just count how many switches
3364 there will be in their vector, and how many input files in theirs.
3365 Here we also parse the switches that cc itself uses (e.g. -v). */
3367 for (i = 1; i < argc; i++)
3369 if (! strcmp (argv[i], "-dumpspecs"))
3371 struct spec_list *sl;
3372 init_spec ();
3373 for (sl = specs; sl; sl = sl->next)
3374 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3375 if (link_command_spec)
3376 printf ("*link_command:\n%s\n\n", link_command_spec);
3377 exit (0);
3379 else if (! strcmp (argv[i], "-dumpversion"))
3381 printf ("%s\n", spec_version);
3382 exit (0);
3384 else if (! strcmp (argv[i], "-dumpmachine"))
3386 printf ("%s\n", spec_machine);
3387 exit (0);
3389 else if (strcmp (argv[i], "-fversion") == 0)
3391 /* translate_options () has turned --version into -fversion. */
3392 printf (_("%s (GCC) %s\n"), programname, version_string);
3393 fputs (_("Copyright (C) 2002 Free Software Foundation, Inc.\n"),
3394 stdout);
3395 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3396 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3397 stdout);
3398 exit (0);
3400 else if (strcmp (argv[i], "-fhelp") == 0)
3402 /* translate_options () has turned --help into -fhelp. */
3403 print_help_list = 1;
3405 /* We will be passing a dummy file on to the sub-processes. */
3406 n_infiles++;
3407 n_switches++;
3409 /* CPP driver cannot obtain switch from cc1_options. */
3410 if (is_cpp_driver)
3411 add_preprocessor_option ("--help", 6);
3412 add_assembler_option ("--help", 6);
3413 add_linker_option ("--help", 6);
3415 else if (strcmp (argv[i], "-ftarget-help") == 0)
3417 /* translate_options() has turned --target-help into -ftarget-help. */
3418 target_help_flag = 1;
3420 /* We will be passing a dummy file on to the sub-processes. */
3421 n_infiles++;
3422 n_switches++;
3424 /* CPP driver cannot obtain switch from cc1_options. */
3425 if (is_cpp_driver)
3426 add_preprocessor_option ("--target-help", 13);
3427 add_assembler_option ("--target-help", 13);
3428 add_linker_option ("--target-help", 13);
3430 else if (! strcmp (argv[i], "-pass-exit-codes"))
3432 pass_exit_codes = 1;
3433 n_switches++;
3435 else if (! strcmp (argv[i], "-print-search-dirs"))
3436 print_search_dirs = 1;
3437 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3438 print_file_name = "libgcc.a";
3439 else if (! strncmp (argv[i], "-print-file-name=", 17))
3440 print_file_name = argv[i] + 17;
3441 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3442 print_prog_name = argv[i] + 17;
3443 else if (! strcmp (argv[i], "-print-multi-lib"))
3444 print_multi_lib = 1;
3445 else if (! strcmp (argv[i], "-print-multi-directory"))
3446 print_multi_directory = 1;
3447 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3448 print_multi_os_directory = 1;
3449 else if (! strncmp (argv[i], "-Wa,", 4))
3451 int prev, j;
3452 /* Pass the rest of this option to the assembler. */
3454 /* Split the argument at commas. */
3455 prev = 4;
3456 for (j = 4; argv[i][j]; j++)
3457 if (argv[i][j] == ',')
3459 add_assembler_option (argv[i] + prev, j - prev);
3460 prev = j + 1;
3463 /* Record the part after the last comma. */
3464 add_assembler_option (argv[i] + prev, j - prev);
3466 else if (! strncmp (argv[i], "-Wp,", 4))
3468 int prev, j;
3469 /* Pass the rest of this option to the preprocessor. */
3471 /* Split the argument at commas. */
3472 prev = 4;
3473 for (j = 4; argv[i][j]; j++)
3474 if (argv[i][j] == ',')
3476 add_preprocessor_option (argv[i] + prev, j - prev);
3477 prev = j + 1;
3480 /* Record the part after the last comma. */
3481 add_preprocessor_option (argv[i] + prev, j - prev);
3483 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3484 /* The +e options to the C++ front-end. */
3485 n_switches++;
3486 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3488 int j;
3489 /* Split the argument at commas. */
3490 for (j = 3; argv[i][j]; j++)
3491 n_infiles += (argv[i][j] == ',');
3493 else if (strcmp (argv[i], "-Xlinker") == 0)
3495 if (i + 1 == argc)
3496 fatal ("argument to `-Xlinker' is missing");
3498 n_infiles++;
3499 i++;
3501 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3503 if (i + 1 == argc)
3504 fatal ("argument to `-Xpreprocessor' is missing");
3506 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3508 else if (strcmp (argv[i], "-Xassembler") == 0)
3510 if (i + 1 == argc)
3511 fatal ("argument to `-Xassembler' is missing");
3513 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3515 else if (strcmp (argv[i], "-l") == 0)
3517 if (i + 1 == argc)
3518 fatal ("argument to `-l' is missing");
3520 n_infiles++;
3521 i++;
3523 else if (strncmp (argv[i], "-l", 2) == 0)
3524 n_infiles++;
3525 else if (strcmp (argv[i], "-save-temps") == 0)
3527 save_temps_flag = 1;
3528 n_switches++;
3530 else if (strcmp (argv[i], "-specs") == 0)
3532 struct user_specs *user = (struct user_specs *)
3533 xmalloc (sizeof (struct user_specs));
3534 if (++i >= argc)
3535 fatal ("argument to `-specs' is missing");
3537 user->next = (struct user_specs *) 0;
3538 user->filename = argv[i];
3539 if (user_specs_tail)
3540 user_specs_tail->next = user;
3541 else
3542 user_specs_head = user;
3543 user_specs_tail = user;
3545 else if (strncmp (argv[i], "-specs=", 7) == 0)
3547 struct user_specs *user = (struct user_specs *)
3548 xmalloc (sizeof (struct user_specs));
3549 if (strlen (argv[i]) == 7)
3550 fatal ("argument to `-specs=' is missing");
3552 user->next = (struct user_specs *) 0;
3553 user->filename = argv[i] + 7;
3554 if (user_specs_tail)
3555 user_specs_tail->next = user;
3556 else
3557 user_specs_head = user;
3558 user_specs_tail = user;
3560 else if (strcmp (argv[i], "-time") == 0)
3561 report_times = 1;
3562 else if (strcmp (argv[i], "-pipe") == 0)
3564 /* -pipe has to go into the switches array as well as
3565 setting a flag. */
3566 use_pipes = 1;
3567 n_switches++;
3569 else if (strcmp (argv[i], "-###") == 0)
3571 /* This is similar to -v except that there is no execution
3572 of the commands and the echoed arguments are quoted. It
3573 is intended for use in shell scripts to capture the
3574 driver-generated command line. */
3575 verbose_only_flag++;
3576 verbose_flag++;
3578 else if (argv[i][0] == '-' && argv[i][1] != 0)
3580 const char *p = &argv[i][1];
3581 int c = *p;
3583 switch (c)
3585 case 'b':
3586 case 'V':
3587 fatal ("`-%c' must come at the start of the command line", c);
3588 break;
3590 case 'B':
3592 const char *value;
3593 int len;
3595 if (p[1] == 0 && i + 1 == argc)
3596 fatal ("argument to `-B' is missing");
3597 if (p[1] == 0)
3598 value = argv[++i];
3599 else
3600 value = p + 1;
3602 len = strlen (value);
3604 /* Catch the case where the user has forgotten to append a
3605 directory separator to the path. Note, they may be using
3606 -B to add an executable name prefix, eg "i386-elf-", in
3607 order to distinguish between multiple installations of
3608 GCC in the same directory. Hence we must check to see
3609 if appending a directory separator actually makes a
3610 valid directory name. */
3611 if (! IS_DIR_SEPARATOR (value [len - 1])
3612 && is_directory (value, "", 0))
3614 char *tmp = xmalloc (len + 2);
3615 strcpy (tmp, value);
3616 tmp[len] = DIR_SEPARATOR;
3617 tmp[++ len] = 0;
3618 value = tmp;
3621 /* As a kludge, if the arg is "[foo/]stageN/", just
3622 add "[foo/]include" to the include prefix. */
3623 if ((len == 7
3624 || (len > 7
3625 && (IS_DIR_SEPARATOR (value[len - 8]))))
3626 && strncmp (value + len - 7, "stage", 5) == 0
3627 && ISDIGIT (value[len - 2])
3628 && (IS_DIR_SEPARATOR (value[len - 1])))
3630 if (len == 7)
3631 add_prefix (&include_prefixes, "include", NULL,
3632 PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3633 else
3635 char * string = xmalloc (len + 1);
3637 strncpy (string, value, len - 7);
3638 strcpy (string + len - 7, "include");
3639 add_prefix (&include_prefixes, string, NULL,
3640 PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3644 add_prefix (&exec_prefixes, value, NULL,
3645 PREFIX_PRIORITY_B_OPT, 0, &warn_B, 0);
3646 add_prefix (&startfile_prefixes, value, NULL,
3647 PREFIX_PRIORITY_B_OPT, 0, &warn_B, 0);
3648 add_prefix (&include_prefixes, concat (value, "include", NULL),
3649 NULL, PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3650 n_switches++;
3652 break;
3654 case 'v': /* Print our subcommands and print versions. */
3655 n_switches++;
3656 /* If they do anything other than exactly `-v', don't set
3657 verbose_flag; rather, continue on to give the error. */
3658 if (p[1] != 0)
3659 break;
3660 verbose_flag++;
3661 break;
3663 case 'S':
3664 case 'c':
3665 if (p[1] == 0)
3667 have_c = 1;
3668 n_switches++;
3669 break;
3671 goto normal_switch;
3673 case 'o':
3674 have_o = 1;
3675 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3676 if (! have_c)
3678 int skip;
3680 /* Forward scan, just in case -S or -c is specified
3681 after -o. */
3682 int j = i + 1;
3683 if (p[1] == 0)
3684 ++j;
3685 while (j < argc)
3687 if (argv[j][0] == '-')
3689 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3690 && argv[j][2] == 0)
3692 have_c = 1;
3693 break;
3695 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3696 j += skip - (argv[j][2] != 0);
3697 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3698 j += skip;
3700 j++;
3703 #endif
3704 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3705 if (p[1] == 0)
3706 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3707 else
3708 argv[i] = convert_filename (argv[i], ! have_c, 0);
3709 #endif
3710 goto normal_switch;
3712 default:
3713 normal_switch:
3715 #ifdef MODIFY_TARGET_NAME
3716 is_modify_target_name = 0;
3718 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3719 if (! strcmp (argv[i], modify_target[j].sw))
3721 char *new_name
3722 = (char *) xmalloc (strlen (modify_target[j].str)
3723 + strlen (spec_machine));
3724 const char *p, *r;
3725 char *q;
3726 int made_addition = 0;
3728 is_modify_target_name = 1;
3729 for (p = spec_machine, q = new_name; *p != 0; )
3731 if (modify_target[j].add_del == DELETE
3732 && (! strncmp (q, modify_target[j].str,
3733 strlen (modify_target[j].str))))
3734 p += strlen (modify_target[j].str);
3735 else if (modify_target[j].add_del == ADD
3736 && ! made_addition && *p == '-')
3738 for (r = modify_target[j].str; *r != 0; )
3739 *q++ = *r++;
3740 made_addition = 1;
3743 *q++ = *p++;
3746 spec_machine = new_name;
3749 if (is_modify_target_name)
3750 break;
3751 #endif
3753 n_switches++;
3755 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3756 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3757 else if (WORD_SWITCH_TAKES_ARG (p))
3758 i += WORD_SWITCH_TAKES_ARG (p);
3761 else
3763 n_infiles++;
3764 lang_n_infiles++;
3768 if (have_c && have_o && lang_n_infiles > 1)
3769 fatal ("cannot specify -o with -c or -S and multiple compilations");
3771 if ((save_temps_flag || report_times) && use_pipes)
3773 /* -save-temps overrides -pipe, so that temp files are produced */
3774 if (save_temps_flag)
3775 error ("warning: -pipe ignored because -save-temps specified");
3776 /* -time overrides -pipe because we can't get correct stats when
3777 multiple children are running at once. */
3778 else if (report_times)
3779 error ("warning: -pipe ignored because -time specified");
3781 use_pipes = 0;
3784 /* Set up the search paths before we go looking for config files. */
3786 /* These come before the md prefixes so that we will find gcc's subcommands
3787 (such as cpp) rather than those of the host system. */
3788 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3789 as well as trying the machine and the version. */
3790 #ifndef OS2
3791 add_prefix (&exec_prefixes, standard_exec_prefix, "GCC",
3792 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3793 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3794 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3795 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3796 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3797 #endif
3799 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3800 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3801 add_prefix (&startfile_prefixes, standard_exec_prefix_1, "BINUTILS",
3802 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3804 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3805 dir_separator_str, NULL);
3807 /* If tooldir is relative, base it on exec_prefixes. A relative
3808 tooldir lets us move the installed tree as a unit.
3810 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3811 directories, so that we can search both the user specified directory
3812 and the standard place. */
3814 if (!IS_ABSOLUTE_PATHNAME (tooldir_prefix))
3816 if (gcc_exec_prefix)
3818 char *gcc_exec_tooldir_prefix
3819 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3820 spec_version, dir_separator_str, tooldir_prefix, NULL);
3822 add_prefix (&exec_prefixes,
3823 concat (gcc_exec_tooldir_prefix, "bin",
3824 dir_separator_str, NULL),
3825 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 0);
3826 add_prefix (&startfile_prefixes,
3827 concat (gcc_exec_tooldir_prefix, "lib",
3828 dir_separator_str, NULL),
3829 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
3832 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3833 dir_separator_str, spec_version,
3834 dir_separator_str, tooldir_prefix, NULL);
3837 add_prefix (&exec_prefixes,
3838 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3839 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 0);
3840 add_prefix (&startfile_prefixes,
3841 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3842 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
3844 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3845 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3846 then consider it to relocate with the rest of the GCC installation
3847 if GCC_EXEC_PREFIX is set.
3848 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3849 if (target_system_root && gcc_exec_prefix)
3851 char *tmp_prefix = make_relative_prefix (argv[0],
3852 standard_bindir_prefix,
3853 target_system_root);
3854 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3856 target_system_root = tmp_prefix;
3857 target_system_root_changed = 1;
3860 #endif
3862 /* More prefixes are enabled in main, after we read the specs file
3863 and determine whether this is cross-compilation or not. */
3865 /* Then create the space for the vectors and scan again. */
3867 switches = ((struct switchstr *)
3868 xmalloc ((n_switches + 1) * sizeof (struct switchstr)));
3869 infiles = (struct infile *) xmalloc ((n_infiles + 1) * sizeof (struct infile));
3870 n_switches = 0;
3871 n_infiles = 0;
3872 last_language_n_infiles = -1;
3874 /* This, time, copy the text of each switch and store a pointer
3875 to the copy in the vector of switches.
3876 Store all the infiles in their vector. */
3878 for (i = 1; i < argc; i++)
3880 /* Just skip the switches that were handled by the preceding loop. */
3881 #ifdef MODIFY_TARGET_NAME
3882 is_modify_target_name = 0;
3884 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3885 if (! strcmp (argv[i], modify_target[j].sw))
3886 is_modify_target_name = 1;
3888 if (is_modify_target_name)
3890 else
3891 #endif
3892 if (! strncmp (argv[i], "-Wa,", 4))
3894 else if (! strncmp (argv[i], "-Wp,", 4))
3896 else if (! strcmp (argv[i], "-pass-exit-codes"))
3898 else if (! strcmp (argv[i], "-print-search-dirs"))
3900 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3902 else if (! strncmp (argv[i], "-print-file-name=", 17))
3904 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3906 else if (! strcmp (argv[i], "-print-multi-lib"))
3908 else if (! strcmp (argv[i], "-print-multi-directory"))
3910 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3912 else if (! strcmp (argv[i], "-ftarget-help"))
3914 else if (! strcmp (argv[i], "-fhelp"))
3916 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3918 /* Compensate for the +e options to the C++ front-end;
3919 they're there simply for cfront call-compatibility. We do
3920 some magic in default_compilers to pass them down properly.
3921 Note we deliberately start at the `+' here, to avoid passing
3922 -e0 or -e1 down into the linker. */
3923 switches[n_switches].part1 = &argv[i][0];
3924 switches[n_switches].args = 0;
3925 switches[n_switches].live_cond = SWITCH_OK;
3926 switches[n_switches].validated = 0;
3927 n_switches++;
3929 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3931 int prev, j;
3932 /* Split the argument at commas. */
3933 prev = 4;
3934 for (j = 4; argv[i][j]; j++)
3935 if (argv[i][j] == ',')
3937 infiles[n_infiles].language = "*";
3938 infiles[n_infiles++].name
3939 = save_string (argv[i] + prev, j - prev);
3940 prev = j + 1;
3942 /* Record the part after the last comma. */
3943 infiles[n_infiles].language = "*";
3944 infiles[n_infiles++].name = argv[i] + prev;
3946 else if (strcmp (argv[i], "-Xlinker") == 0)
3948 infiles[n_infiles].language = "*";
3949 infiles[n_infiles++].name = argv[++i];
3951 else if (strcmp (argv[i], "-Xassembler") == 0)
3953 infiles[n_infiles].language = "*";
3954 infiles[n_infiles++].name = argv[++i];
3956 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3958 infiles[n_infiles].language = "*";
3959 infiles[n_infiles++].name = argv[++i];
3961 else if (strcmp (argv[i], "-l") == 0)
3962 { /* POSIX allows separation of -l and the lib arg;
3963 canonicalize by concatenating -l with its arg */
3964 infiles[n_infiles].language = "*";
3965 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3967 else if (strncmp (argv[i], "-l", 2) == 0)
3969 infiles[n_infiles].language = "*";
3970 infiles[n_infiles++].name = argv[i];
3972 else if (strcmp (argv[i], "-specs") == 0)
3973 i++;
3974 else if (strncmp (argv[i], "-specs=", 7) == 0)
3976 else if (strcmp (argv[i], "-time") == 0)
3978 else if (strcmp (argv[i], "-###") == 0)
3980 else if (argv[i][0] == '-' && argv[i][1] != 0)
3982 const char *p = &argv[i][1];
3983 int c = *p;
3985 if (c == 'x')
3987 if (p[1] == 0 && i + 1 == argc)
3988 fatal ("argument to `-x' is missing");
3989 if (p[1] == 0)
3990 spec_lang = argv[++i];
3991 else
3992 spec_lang = p + 1;
3993 if (! strcmp (spec_lang, "none"))
3994 /* Suppress the warning if -xnone comes after the last input
3995 file, because alternate command interfaces like g++ might
3996 find it useful to place -xnone after each input file. */
3997 spec_lang = 0;
3998 else
3999 last_language_n_infiles = n_infiles;
4000 continue;
4002 switches[n_switches].part1 = p;
4003 /* Deal with option arguments in separate argv elements. */
4004 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
4005 || WORD_SWITCH_TAKES_ARG (p))
4007 int j = 0;
4008 int n_args = WORD_SWITCH_TAKES_ARG (p);
4010 if (n_args == 0)
4012 /* Count only the option arguments in separate argv elements. */
4013 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4015 if (i + n_args >= argc)
4016 fatal ("argument to `-%s' is missing", p);
4017 switches[n_switches].args
4018 = (const char **) xmalloc ((n_args + 1) * sizeof(const char *));
4019 while (j < n_args)
4020 switches[n_switches].args[j++] = argv[++i];
4021 /* Null-terminate the vector. */
4022 switches[n_switches].args[j] = 0;
4024 else if (strchr (switches_need_spaces, c))
4026 /* On some systems, ld cannot handle some options without
4027 a space. So split the option from its argument. */
4028 char *part1 = (char *) xmalloc (2);
4029 part1[0] = c;
4030 part1[1] = '\0';
4032 switches[n_switches].part1 = part1;
4033 switches[n_switches].args
4034 = (const char **) xmalloc (2 * sizeof (const char *));
4035 switches[n_switches].args[0] = xstrdup (p+1);
4036 switches[n_switches].args[1] = 0;
4038 else
4039 switches[n_switches].args = 0;
4041 switches[n_switches].live_cond = SWITCH_OK;
4042 switches[n_switches].validated = 0;
4043 switches[n_switches].ordering = 0;
4044 /* These are always valid, since gcc.c itself understands them. */
4045 if (!strcmp (p, "save-temps")
4046 || !strcmp (p, "static-libgcc")
4047 || !strcmp (p, "shared-libgcc")
4048 || !strcmp (p, "pipe"))
4049 switches[n_switches].validated = 1;
4050 else
4052 char ch = switches[n_switches].part1[0];
4053 if (ch == 'B')
4054 switches[n_switches].validated = 1;
4056 n_switches++;
4058 else
4060 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4061 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4062 #endif
4064 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4066 perror_with_name (argv[i]);
4067 error_count++;
4069 else
4071 infiles[n_infiles].language = spec_lang;
4072 infiles[n_infiles++].name = argv[i];
4077 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4078 error ("warning: `-x %s' after last input file has no effect", spec_lang);
4080 /* Ensure we only invoke each subprocess once. */
4081 if (target_help_flag || print_help_list)
4083 n_infiles = 1;
4085 /* Create a dummy input file, so that we can pass --target-help on to
4086 the various sub-processes. */
4087 infiles[0].language = "c";
4088 infiles[0].name = "help-dummy";
4090 if (target_help_flag)
4092 switches[n_switches].part1 = "--target-help";
4093 switches[n_switches].args = 0;
4094 switches[n_switches].live_cond = SWITCH_OK;
4095 switches[n_switches].validated = 0;
4097 n_switches++;
4100 if (print_help_list)
4102 switches[n_switches].part1 = "--help";
4103 switches[n_switches].args = 0;
4104 switches[n_switches].live_cond = SWITCH_OK;
4105 switches[n_switches].validated = 0;
4107 n_switches++;
4111 switches[n_switches].part1 = 0;
4112 infiles[n_infiles].name = 0;
4115 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4116 and place that in the environment. */
4118 static void
4119 set_collect_gcc_options ()
4121 int i;
4122 int first_time;
4124 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4125 the compiler. */
4126 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4127 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4129 first_time = TRUE;
4130 for (i = 0; (int) i < n_switches; i++)
4132 const char *const *args;
4133 const char *p, *q;
4134 if (!first_time)
4135 obstack_grow (&collect_obstack, " ", 1);
4137 first_time = FALSE;
4139 /* Ignore elided switches. */
4140 if (switches[i].live_cond == SWITCH_IGNORE)
4141 continue;
4143 obstack_grow (&collect_obstack, "'-", 2);
4144 q = switches[i].part1;
4145 while ((p = strchr (q, '\'')))
4147 obstack_grow (&collect_obstack, q, p - q);
4148 obstack_grow (&collect_obstack, "'\\''", 4);
4149 q = ++p;
4151 obstack_grow (&collect_obstack, q, strlen (q));
4152 obstack_grow (&collect_obstack, "'", 1);
4154 for (args = switches[i].args; args && *args; args++)
4156 obstack_grow (&collect_obstack, " '", 2);
4157 q = *args;
4158 while ((p = strchr (q, '\'')))
4160 obstack_grow (&collect_obstack, q, p - q);
4161 obstack_grow (&collect_obstack, "'\\''", 4);
4162 q = ++p;
4164 obstack_grow (&collect_obstack, q, strlen (q));
4165 obstack_grow (&collect_obstack, "'", 1);
4168 obstack_grow (&collect_obstack, "\0", 1);
4169 putenv (obstack_finish (&collect_obstack));
4172 /* Process a spec string, accumulating and running commands. */
4174 /* These variables describe the input file name.
4175 input_file_number is the index on outfiles of this file,
4176 so that the output file name can be stored for later use by %o.
4177 input_basename is the start of the part of the input file
4178 sans all directory names, and basename_length is the number
4179 of characters starting there excluding the suffix .c or whatever. */
4181 const char *input_filename;
4182 static int input_file_number;
4183 size_t input_filename_length;
4184 static int basename_length;
4185 static int suffixed_basename_length;
4186 static const char *input_basename;
4187 static const char *input_suffix;
4188 static struct stat input_stat;
4189 static int input_stat_set;
4191 /* The compiler used to process the current input file. */
4192 static struct compiler *input_file_compiler;
4194 /* These are variables used within do_spec and do_spec_1. */
4196 /* Nonzero if an arg has been started and not yet terminated
4197 (with space, tab or newline). */
4198 static int arg_going;
4200 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4201 is a temporary file name. */
4202 static int delete_this_arg;
4204 /* Nonzero means %w has been seen; the next arg to be terminated
4205 is the output file name of this compilation. */
4206 static int this_is_output_file;
4208 /* Nonzero means %s has been seen; the next arg to be terminated
4209 is the name of a library file and we should try the standard
4210 search dirs for it. */
4211 static int this_is_library_file;
4213 /* Nonzero means that the input of this command is coming from a pipe. */
4214 static int input_from_pipe;
4216 /* Nonnull means substitute this for any suffix when outputting a switches
4217 arguments. */
4218 static const char *suffix_subst;
4220 /* Process the spec SPEC and run the commands specified therein.
4221 Returns 0 if the spec is successfully processed; -1 if failed. */
4224 do_spec (spec)
4225 const char *spec;
4227 int value;
4229 value = do_spec_2 (spec);
4231 /* Force out any unfinished command.
4232 If -pipe, this forces out the last command if it ended in `|'. */
4233 if (value == 0)
4235 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4236 argbuf_index--;
4238 set_collect_gcc_options ();
4240 if (argbuf_index > 0)
4241 value = execute ();
4244 return value;
4247 static int
4248 do_spec_2 (spec)
4249 const char *spec;
4251 const char *string;
4252 int result;
4254 clear_args ();
4255 arg_going = 0;
4256 delete_this_arg = 0;
4257 this_is_output_file = 0;
4258 this_is_library_file = 0;
4259 input_from_pipe = 0;
4260 suffix_subst = NULL;
4262 result = do_spec_1 (spec, 0, NULL);
4264 /* End any pending argument. */
4265 if (arg_going)
4267 obstack_1grow (&obstack, 0);
4268 string = obstack_finish (&obstack);
4269 if (this_is_library_file)
4270 string = find_file (string);
4271 store_arg (string, delete_this_arg, this_is_output_file);
4272 if (this_is_output_file)
4273 outfiles[input_file_number] = string;
4274 arg_going = 0;
4277 return result;
4281 /* Process the given spec string and add any new options to the end
4282 of the switches/n_switches array. */
4284 static void
4285 do_self_spec (spec)
4286 const char *spec;
4288 do_spec_2 (spec);
4289 do_spec_1 (" ", 0, NULL);
4291 if (argbuf_index > 0)
4293 int i, first;
4295 first = n_switches;
4296 n_switches += argbuf_index;
4297 switches = xrealloc (switches,
4298 sizeof (struct switchstr) * (n_switches + 1));
4300 switches[n_switches] = switches[first];
4301 for (i = 0; i < argbuf_index; i++)
4303 struct switchstr *sw;
4305 /* Each switch should start with '-'. */
4306 if (argbuf[i][0] != '-')
4307 abort ();
4309 sw = &switches[i + first];
4310 sw->part1 = &argbuf[i][1];
4311 sw->args = 0;
4312 sw->live_cond = SWITCH_OK;
4313 sw->validated = 0;
4314 sw->ordering = 0;
4319 /* Process the sub-spec SPEC as a portion of a larger spec.
4320 This is like processing a whole spec except that we do
4321 not initialize at the beginning and we do not supply a
4322 newline by default at the end.
4323 INSWITCH nonzero means don't process %-sequences in SPEC;
4324 in this case, % is treated as an ordinary character.
4325 This is used while substituting switches.
4326 INSWITCH nonzero also causes SPC not to terminate an argument.
4328 Value is zero unless a line was finished
4329 and the command on that line reported an error. */
4331 static int
4332 do_spec_1 (spec, inswitch, soft_matched_part)
4333 const char *spec;
4334 int inswitch;
4335 const char *soft_matched_part;
4337 const char *p = spec;
4338 int c;
4339 int i;
4340 const char *string;
4341 int value;
4343 while ((c = *p++))
4344 /* If substituting a switch, treat all chars like letters.
4345 Otherwise, NL, SPC, TAB and % are special. */
4346 switch (inswitch ? 'a' : c)
4348 case '\n':
4349 /* End of line: finish any pending argument,
4350 then run the pending command if one has been started. */
4351 if (arg_going)
4353 obstack_1grow (&obstack, 0);
4354 string = obstack_finish (&obstack);
4355 if (this_is_library_file)
4356 string = find_file (string);
4357 store_arg (string, delete_this_arg, this_is_output_file);
4358 if (this_is_output_file)
4359 outfiles[input_file_number] = string;
4361 arg_going = 0;
4363 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4365 /* A `|' before the newline means use a pipe here,
4366 but only if -pipe was specified.
4367 Otherwise, execute now and don't pass the `|' as an arg. */
4368 if (use_pipes)
4370 input_from_pipe = 1;
4371 break;
4373 else
4374 argbuf_index--;
4377 set_collect_gcc_options ();
4379 if (argbuf_index > 0)
4381 value = execute ();
4382 if (value)
4383 return value;
4385 /* Reinitialize for a new command, and for a new argument. */
4386 clear_args ();
4387 arg_going = 0;
4388 delete_this_arg = 0;
4389 this_is_output_file = 0;
4390 this_is_library_file = 0;
4391 input_from_pipe = 0;
4392 break;
4394 case '|':
4395 /* End any pending argument. */
4396 if (arg_going)
4398 obstack_1grow (&obstack, 0);
4399 string = obstack_finish (&obstack);
4400 if (this_is_library_file)
4401 string = find_file (string);
4402 store_arg (string, delete_this_arg, this_is_output_file);
4403 if (this_is_output_file)
4404 outfiles[input_file_number] = string;
4407 /* Use pipe */
4408 obstack_1grow (&obstack, c);
4409 arg_going = 1;
4410 break;
4412 case '\t':
4413 case ' ':
4414 /* Space or tab ends an argument if one is pending. */
4415 if (arg_going)
4417 obstack_1grow (&obstack, 0);
4418 string = obstack_finish (&obstack);
4419 if (this_is_library_file)
4420 string = find_file (string);
4421 store_arg (string, delete_this_arg, this_is_output_file);
4422 if (this_is_output_file)
4423 outfiles[input_file_number] = string;
4425 /* Reinitialize for a new argument. */
4426 arg_going = 0;
4427 delete_this_arg = 0;
4428 this_is_output_file = 0;
4429 this_is_library_file = 0;
4430 break;
4432 case '%':
4433 switch (c = *p++)
4435 case 0:
4436 fatal ("invalid specification! Bug in cc");
4438 case 'b':
4439 obstack_grow (&obstack, input_basename, basename_length);
4440 arg_going = 1;
4441 break;
4443 case 'B':
4444 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4445 arg_going = 1;
4446 break;
4448 case 'd':
4449 delete_this_arg = 2;
4450 break;
4452 /* Dump out the directories specified with LIBRARY_PATH,
4453 followed by the absolute directories
4454 that we search for startfiles. */
4455 case 'D':
4457 struct prefix_list *pl = startfile_prefixes.plist;
4458 size_t bufsize = 100;
4459 char *buffer = (char *) xmalloc (bufsize);
4460 int idx;
4462 for (; pl; pl = pl->next)
4464 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4465 /* Used on systems which record the specified -L dirs
4466 and use them to search for dynamic linking. */
4467 /* Relative directories always come from -B,
4468 and it is better not to use them for searching
4469 at run time. In particular, stage1 loses. */
4470 if (!IS_ABSOLUTE_PATHNAME (pl->prefix))
4471 continue;
4472 #endif
4473 /* Try subdirectory if there is one. */
4474 if (multilib_dir != NULL
4475 || (pl->os_multilib && multilib_os_dir != NULL))
4477 const char *multi_dir;
4479 multi_dir = pl->os_multilib ? multilib_os_dir
4480 : multilib_dir;
4481 if (machine_suffix && multilib_dir)
4483 if (strlen (pl->prefix) + strlen (machine_suffix)
4484 >= bufsize)
4485 bufsize = (strlen (pl->prefix)
4486 + strlen (machine_suffix)) * 2 + 1;
4487 buffer = (char *) xrealloc (buffer, bufsize);
4488 strcpy (buffer, pl->prefix);
4489 strcat (buffer, machine_suffix);
4490 if (is_directory (buffer, multilib_dir, 1))
4492 do_spec_1 ("-L", 0, NULL);
4493 #ifdef SPACE_AFTER_L_OPTION
4494 do_spec_1 (" ", 0, NULL);
4495 #endif
4496 do_spec_1 (buffer, 1, NULL);
4497 do_spec_1 (multilib_dir, 1, NULL);
4498 /* Make this a separate argument. */
4499 do_spec_1 (" ", 0, NULL);
4502 if (!pl->require_machine_suffix)
4504 if (is_directory (pl->prefix, multi_dir, 1))
4506 do_spec_1 ("-L", 0, NULL);
4507 #ifdef SPACE_AFTER_L_OPTION
4508 do_spec_1 (" ", 0, NULL);
4509 #endif
4510 do_spec_1 (pl->prefix, 1, NULL);
4511 do_spec_1 (multi_dir, 1, NULL);
4512 /* Make this a separate argument. */
4513 do_spec_1 (" ", 0, NULL);
4517 if (machine_suffix)
4519 if (is_directory (pl->prefix, machine_suffix, 1))
4521 do_spec_1 ("-L", 0, NULL);
4522 #ifdef SPACE_AFTER_L_OPTION
4523 do_spec_1 (" ", 0, NULL);
4524 #endif
4525 do_spec_1 (pl->prefix, 1, NULL);
4526 /* Remove slash from machine_suffix. */
4527 if (strlen (machine_suffix) >= bufsize)
4528 bufsize = strlen (machine_suffix) * 2 + 1;
4529 buffer = (char *) xrealloc (buffer, bufsize);
4530 strcpy (buffer, machine_suffix);
4531 idx = strlen (buffer);
4532 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4533 buffer[idx - 1] = 0;
4534 do_spec_1 (buffer, 1, NULL);
4535 /* Make this a separate argument. */
4536 do_spec_1 (" ", 0, NULL);
4539 if (!pl->require_machine_suffix)
4541 if (is_directory (pl->prefix, "", 1))
4543 do_spec_1 ("-L", 0, NULL);
4544 #ifdef SPACE_AFTER_L_OPTION
4545 do_spec_1 (" ", 0, NULL);
4546 #endif
4547 /* Remove slash from pl->prefix. */
4548 if (strlen (pl->prefix) >= bufsize)
4549 bufsize = strlen (pl->prefix) * 2 + 1;
4550 buffer = (char *) xrealloc (buffer, bufsize);
4551 strcpy (buffer, pl->prefix);
4552 idx = strlen (buffer);
4553 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4554 buffer[idx - 1] = 0;
4555 do_spec_1 (buffer, 1, NULL);
4556 /* Make this a separate argument. */
4557 do_spec_1 (" ", 0, NULL);
4561 free (buffer);
4563 break;
4565 case 'e':
4566 /* %efoo means report an error with `foo' as error message
4567 and don't execute any more commands for this file. */
4569 const char *q = p;
4570 char *buf;
4571 while (*p != 0 && *p != '\n')
4572 p++;
4573 buf = (char *) alloca (p - q + 1);
4574 strncpy (buf, q, p - q);
4575 buf[p - q] = 0;
4576 error ("%s", buf);
4577 return -1;
4579 break;
4580 case 'n':
4581 /* %nfoo means report a notice with `foo' on stderr. */
4583 const char *q = p;
4584 char *buf;
4585 while (*p != 0 && *p != '\n')
4586 p++;
4587 buf = (char *) alloca (p - q + 1);
4588 strncpy (buf, q, p - q);
4589 buf[p - q] = 0;
4590 notice ("%s\n", buf);
4591 if (*p)
4592 p++;
4594 break;
4596 case 'j':
4598 struct stat st;
4600 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4601 defined, and it is not a directory, and it is
4602 writable, use it. Otherwise, treat this like any
4603 other temporary file. */
4605 if ((!save_temps_flag)
4606 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4607 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4609 obstack_grow (&obstack, HOST_BIT_BUCKET,
4610 strlen (HOST_BIT_BUCKET));
4611 delete_this_arg = 0;
4612 arg_going = 1;
4613 break;
4616 goto create_temp_file;
4617 case '|':
4618 if (use_pipes)
4620 obstack_1grow (&obstack, '-');
4621 delete_this_arg = 0;
4622 arg_going = 1;
4624 /* consume suffix */
4625 while (*p == '.' || ISALPHA ((unsigned char) *p))
4626 p++;
4627 if (p[0] == '%' && p[1] == 'O')
4628 p += 2;
4630 break;
4632 goto create_temp_file;
4633 case 'm':
4634 if (use_pipes)
4636 /* consume suffix */
4637 while (*p == '.' || ISALPHA ((unsigned char) *p))
4638 p++;
4639 if (p[0] == '%' && p[1] == 'O')
4640 p += 2;
4642 break;
4644 goto create_temp_file;
4645 case 'g':
4646 case 'u':
4647 case 'U':
4648 create_temp_file:
4650 struct temp_name *t;
4651 int suffix_length;
4652 const char *suffix = p;
4653 char *saved_suffix = NULL;
4655 while (*p == '.' || ISALPHA ((unsigned char) *p))
4656 p++;
4657 suffix_length = p - suffix;
4658 if (p[0] == '%' && p[1] == 'O')
4660 p += 2;
4661 /* We don't support extra suffix characters after %O. */
4662 if (*p == '.' || ISALPHA ((unsigned char) *p))
4663 abort ();
4664 if (suffix_length == 0)
4665 suffix = TARGET_OBJECT_SUFFIX;
4666 else
4668 saved_suffix
4669 = (char *) xmalloc (suffix_length
4670 + strlen (TARGET_OBJECT_SUFFIX));
4671 strncpy (saved_suffix, suffix, suffix_length);
4672 strcpy (saved_suffix + suffix_length,
4673 TARGET_OBJECT_SUFFIX);
4675 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4678 /* If the input_filename has the same suffix specified
4679 for the %g, %u, or %U, and -save-temps is specified,
4680 we could end up using that file as an intermediate
4681 thus clobbering the user's source file (.e.g.,
4682 gcc -save-temps foo.s would clobber foo.s with the
4683 output of cpp0). So check for this condition and
4684 generate a temp file as the intermediate. */
4686 if (save_temps_flag)
4688 temp_filename_length = basename_length + suffix_length;
4689 temp_filename = alloca (temp_filename_length + 1);
4690 strncpy ((char *) temp_filename, input_basename, basename_length);
4691 strncpy ((char *) temp_filename + basename_length, suffix,
4692 suffix_length);
4693 *((char *) temp_filename + temp_filename_length) = '\0';
4694 if (strcmp (temp_filename, input_filename) != 0)
4696 struct stat st_temp;
4698 /* Note, set_input() resets input_stat_set to 0. */
4699 if (input_stat_set == 0)
4701 input_stat_set = stat (input_filename, &input_stat);
4702 if (input_stat_set >= 0)
4703 input_stat_set = 1;
4706 /* If we have the stat for the input_filename
4707 and we can do the stat for the temp_filename
4708 then the they could still refer to the same
4709 file if st_dev/st_ino's are the same. */
4711 if (input_stat_set != 1
4712 || stat (temp_filename, &st_temp) < 0
4713 || input_stat.st_dev != st_temp.st_dev
4714 || input_stat.st_ino != st_temp.st_ino)
4716 temp_filename = save_string (temp_filename,
4717 temp_filename_length + 1);
4718 obstack_grow (&obstack, temp_filename,
4719 temp_filename_length);
4720 arg_going = 1;
4721 delete_this_arg = 0;
4722 break;
4727 /* See if we already have an association of %g/%u/%U and
4728 suffix. */
4729 for (t = temp_names; t; t = t->next)
4730 if (t->length == suffix_length
4731 && strncmp (t->suffix, suffix, suffix_length) == 0
4732 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4733 break;
4735 /* Make a new association if needed. %u and %j
4736 require one. */
4737 if (t == 0 || c == 'u' || c == 'j')
4739 if (t == 0)
4741 t = (struct temp_name *) xmalloc (sizeof (struct temp_name));
4742 t->next = temp_names;
4743 temp_names = t;
4745 t->length = suffix_length;
4746 if (saved_suffix)
4748 t->suffix = saved_suffix;
4749 saved_suffix = NULL;
4751 else
4752 t->suffix = save_string (suffix, suffix_length);
4753 t->unique = (c == 'u' || c == 'U' || c == 'j');
4754 temp_filename = make_temp_file (t->suffix);
4755 temp_filename_length = strlen (temp_filename);
4756 t->filename = temp_filename;
4757 t->filename_length = temp_filename_length;
4760 if (saved_suffix)
4761 free (saved_suffix);
4763 obstack_grow (&obstack, t->filename, t->filename_length);
4764 delete_this_arg = 1;
4766 arg_going = 1;
4767 break;
4769 case 'i':
4770 obstack_grow (&obstack, input_filename, input_filename_length);
4771 arg_going = 1;
4772 break;
4774 case 'I':
4776 struct prefix_list *pl = include_prefixes.plist;
4778 if (gcc_exec_prefix)
4780 do_spec_1 ("-iprefix", 1, NULL);
4781 /* Make this a separate argument. */
4782 do_spec_1 (" ", 0, NULL);
4783 do_spec_1 (gcc_exec_prefix, 1, NULL);
4784 do_spec_1 (" ", 0, NULL);
4787 if (target_system_root_changed)
4789 do_spec_1 ("-isysroot", 1, NULL);
4790 /* Make this a separate argument. */
4791 do_spec_1 (" ", 0, NULL);
4792 do_spec_1 (target_system_root, 1, NULL);
4793 do_spec_1 (" ", 0, NULL);
4796 for (; pl; pl = pl->next)
4798 do_spec_1 ("-isystem", 1, NULL);
4799 /* Make this a separate argument. */
4800 do_spec_1 (" ", 0, NULL);
4801 do_spec_1 (pl->prefix, 1, NULL);
4802 do_spec_1 (" ", 0, NULL);
4805 break;
4807 case 'o':
4809 int max = n_infiles;
4810 max += lang_specific_extra_outfiles;
4812 for (i = 0; i < max; i++)
4813 if (outfiles[i])
4814 store_arg (outfiles[i], 0, 0);
4815 break;
4818 case 'O':
4819 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4820 arg_going = 1;
4821 break;
4823 case 's':
4824 this_is_library_file = 1;
4825 break;
4827 case 'V':
4828 outfiles[input_file_number] = NULL;
4829 break;
4831 case 'w':
4832 this_is_output_file = 1;
4833 break;
4835 case 'W':
4837 int cur_index = argbuf_index;
4838 /* Handle the {...} following the %W. */
4839 if (*p != '{')
4840 abort ();
4841 p = handle_braces (p + 1);
4842 if (p == 0)
4843 return -1;
4844 /* End any pending argument. */
4845 if (arg_going)
4847 obstack_1grow (&obstack, 0);
4848 string = obstack_finish (&obstack);
4849 if (this_is_library_file)
4850 string = find_file (string);
4851 store_arg (string, delete_this_arg, this_is_output_file);
4852 if (this_is_output_file)
4853 outfiles[input_file_number] = string;
4854 arg_going = 0;
4856 /* If any args were output, mark the last one for deletion
4857 on failure. */
4858 if (argbuf_index != cur_index)
4859 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4860 break;
4863 /* %x{OPTION} records OPTION for %X to output. */
4864 case 'x':
4866 const char *p1 = p;
4867 char *string;
4869 /* Skip past the option value and make a copy. */
4870 if (*p != '{')
4871 abort ();
4872 while (*p++ != '}')
4874 string = save_string (p1 + 1, p - p1 - 2);
4876 /* See if we already recorded this option. */
4877 for (i = 0; i < n_linker_options; i++)
4878 if (! strcmp (string, linker_options[i]))
4880 free (string);
4881 return 0;
4884 /* This option is new; add it. */
4885 add_linker_option (string, strlen (string));
4887 break;
4889 /* Dump out the options accumulated previously using %x. */
4890 case 'X':
4891 for (i = 0; i < n_linker_options; i++)
4893 do_spec_1 (linker_options[i], 1, NULL);
4894 /* Make each accumulated option a separate argument. */
4895 do_spec_1 (" ", 0, NULL);
4897 break;
4899 /* Dump out the options accumulated previously using -Wa,. */
4900 case 'Y':
4901 for (i = 0; i < n_assembler_options; i++)
4903 do_spec_1 (assembler_options[i], 1, NULL);
4904 /* Make each accumulated option a separate argument. */
4905 do_spec_1 (" ", 0, NULL);
4907 break;
4909 /* Dump out the options accumulated previously using -Wp,. */
4910 case 'Z':
4911 for (i = 0; i < n_preprocessor_options; i++)
4913 do_spec_1 (preprocessor_options[i], 1, NULL);
4914 /* Make each accumulated option a separate argument. */
4915 do_spec_1 (" ", 0, NULL);
4917 break;
4919 /* Here are digits and numbers that just process
4920 a certain constant string as a spec. */
4922 case '1':
4923 value = do_spec_1 (cc1_spec, 0, NULL);
4924 if (value != 0)
4925 return value;
4926 break;
4928 case '2':
4929 value = do_spec_1 (cc1plus_spec, 0, NULL);
4930 if (value != 0)
4931 return value;
4932 break;
4934 case 'a':
4935 value = do_spec_1 (asm_spec, 0, NULL);
4936 if (value != 0)
4937 return value;
4938 break;
4940 case 'A':
4941 value = do_spec_1 (asm_final_spec, 0, NULL);
4942 if (value != 0)
4943 return value;
4944 break;
4946 case 'C':
4948 const char *const spec
4949 = (input_file_compiler->cpp_spec
4950 ? input_file_compiler->cpp_spec
4951 : cpp_spec);
4952 value = do_spec_1 (spec, 0, NULL);
4953 if (value != 0)
4954 return value;
4956 break;
4958 case 'E':
4959 value = do_spec_1 (endfile_spec, 0, NULL);
4960 if (value != 0)
4961 return value;
4962 break;
4964 case 'l':
4965 value = do_spec_1 (link_spec, 0, NULL);
4966 if (value != 0)
4967 return value;
4968 break;
4970 case 'L':
4971 value = do_spec_1 (lib_spec, 0, NULL);
4972 if (value != 0)
4973 return value;
4974 break;
4976 case 'G':
4977 value = do_spec_1 (libgcc_spec, 0, NULL);
4978 if (value != 0)
4979 return value;
4980 break;
4982 case 'M':
4983 if (multilib_dir && strcmp (multilib_dir, ".") != 0)
4985 char *p;
4986 const char *q;
4987 size_t len;
4989 len = strlen (multilib_dir);
4990 obstack_blank (&obstack, len + 1);
4991 p = obstack_next_free (&obstack) - (len + 1);
4993 *p++ = '_';
4994 for (q = multilib_dir; *q ; ++q, ++p)
4995 *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
4997 break;
4999 case 'p':
5001 char *x = (char *) alloca (strlen (cpp_predefines) + 1);
5002 char *buf = x;
5003 const char *y;
5005 /* Copy all of the -D options in CPP_PREDEFINES into BUF. */
5006 y = cpp_predefines;
5007 while (*y != 0)
5009 if (! strncmp (y, "-D", 2))
5010 /* Copy the whole option. */
5011 while (*y && *y != ' ' && *y != '\t')
5012 *x++ = *y++;
5013 else if (*y == ' ' || *y == '\t')
5014 /* Copy whitespace to the result. */
5015 *x++ = *y++;
5016 /* Don't copy other options. */
5017 else
5018 y++;
5021 *x = 0;
5023 value = do_spec_1 (buf, 0, NULL);
5024 if (value != 0)
5025 return value;
5027 break;
5029 case 'P':
5031 char *x = (char *) alloca (strlen (cpp_predefines) * 4 + 1);
5032 char *buf = x;
5033 const char *y;
5035 /* Copy all of CPP_PREDEFINES into BUF,
5036 but force them all into the reserved name space if they
5037 aren't already there. The reserved name space is all
5038 identifiers beginning with two underscores or with one
5039 underscore and a capital letter. We do the forcing by
5040 adding up to two underscores to the beginning and end
5041 of each symbol. e.g. mips, _mips, mips_, and _mips_ all
5042 become __mips__. */
5043 y = cpp_predefines;
5044 while (*y != 0)
5046 if (! strncmp (y, "-D", 2))
5048 int flag = 0;
5050 *x++ = *y++;
5051 *x++ = *y++;
5053 if (*y != '_'
5054 || (*(y + 1) != '_'
5055 && ! ISUPPER ((unsigned char) *(y + 1))))
5057 /* Stick __ at front of macro name. */
5058 if (*y != '_')
5059 *x++ = '_';
5060 *x++ = '_';
5061 /* Arrange to stick __ at the end as well. */
5062 flag = 1;
5065 /* Copy the macro name. */
5066 while (*y && *y != '=' && *y != ' ' && *y != '\t')
5067 *x++ = *y++;
5069 if (flag)
5071 if (x[-1] != '_')
5073 if (x[-2] != '_')
5074 *x++ = '_';
5075 *x++ = '_';
5079 /* Copy the value given, if any. */
5080 while (*y && *y != ' ' && *y != '\t')
5081 *x++ = *y++;
5083 else if (*y == ' ' || *y == '\t')
5084 /* Copy whitespace to the result. */
5085 *x++ = *y++;
5086 /* Don't copy -A options */
5087 else
5088 y++;
5090 *x++ = ' ';
5092 /* Copy all of CPP_PREDEFINES into BUF,
5093 but put __ after every -D. */
5094 y = cpp_predefines;
5095 while (*y != 0)
5097 if (! strncmp (y, "-D", 2))
5099 y += 2;
5101 if (*y != '_'
5102 || (*(y + 1) != '_'
5103 && ! ISUPPER ((unsigned char) *(y + 1))))
5105 /* Stick -D__ at front of macro name. */
5106 *x++ = '-';
5107 *x++ = 'D';
5108 if (*y != '_')
5109 *x++ = '_';
5110 *x++ = '_';
5112 /* Copy the macro name. */
5113 while (*y && *y != '=' && *y != ' ' && *y != '\t')
5114 *x++ = *y++;
5116 /* Copy the value given, if any. */
5117 while (*y && *y != ' ' && *y != '\t')
5118 *x++ = *y++;
5120 else
5122 /* Do not copy this macro - we have just done it before */
5123 while (*y && *y != ' ' && *y != '\t')
5124 y++;
5127 else if (*y == ' ' || *y == '\t')
5128 /* Copy whitespace to the result. */
5129 *x++ = *y++;
5130 /* Don't copy -A options. */
5131 else
5132 y++;
5134 *x++ = ' ';
5136 /* Copy all of the -A options in CPP_PREDEFINES into BUF. */
5137 y = cpp_predefines;
5138 while (*y != 0)
5140 if (! strncmp (y, "-A", 2))
5141 /* Copy the whole option. */
5142 while (*y && *y != ' ' && *y != '\t')
5143 *x++ = *y++;
5144 else if (*y == ' ' || *y == '\t')
5145 /* Copy whitespace to the result. */
5146 *x++ = *y++;
5147 /* Don't copy other options. */
5148 else
5149 y++;
5152 *x = 0;
5154 value = do_spec_1 (buf, 0, NULL);
5155 if (value != 0)
5156 return value;
5158 break;
5160 case 'R':
5161 /* We assume there is a directory
5162 separator at the end of this string. */
5163 if (target_system_root)
5164 obstack_grow (&obstack, target_system_root,
5165 strlen (target_system_root));
5166 break;
5168 case 'S':
5169 value = do_spec_1 (startfile_spec, 0, NULL);
5170 if (value != 0)
5171 return value;
5172 break;
5174 /* Here we define characters other than letters and digits. */
5176 case '{':
5177 p = handle_braces (p);
5178 if (p == 0)
5179 return -1;
5180 break;
5182 case ':':
5183 p = handle_spec_function (p);
5184 if (p == 0)
5185 return -1;
5186 break;
5188 case '%':
5189 obstack_1grow (&obstack, '%');
5190 break;
5192 case '.':
5194 unsigned len = 0;
5196 while (p[len] && p[len] != ' ' && p[len] != '%')
5197 len++;
5198 suffix_subst = save_string (p - 1, len + 1);
5199 p += len;
5201 break;
5203 /* Henceforth ignore the option(s) matching the pattern
5204 after the %<. */
5205 case '<':
5207 unsigned len = 0;
5208 int have_wildcard = 0;
5209 int i;
5211 while (p[len] && p[len] != ' ' && p[len] != '\t')
5212 len++;
5214 if (p[len-1] == '*')
5215 have_wildcard = 1;
5217 for (i = 0; i < n_switches; i++)
5218 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5219 && (have_wildcard || switches[i].part1[len] == '\0'))
5221 switches[i].live_cond = SWITCH_IGNORE;
5222 switches[i].validated = 1;
5225 p += len;
5227 break;
5229 case '*':
5230 if (soft_matched_part)
5232 do_spec_1 (soft_matched_part, 1, NULL);
5233 do_spec_1 (" ", 0, NULL);
5235 else
5236 /* Catch the case where a spec string contains something like
5237 '%{foo:%*}'. ie there is no * in the pattern on the left
5238 hand side of the :. */
5239 error ("spec failure: '%%*' has not been initialized by pattern match");
5240 break;
5242 /* Process a string found as the value of a spec given by name.
5243 This feature allows individual machine descriptions
5244 to add and use their own specs.
5245 %[...] modifies -D options the way %P does;
5246 %(...) uses the spec unmodified. */
5247 case '[':
5248 error ("warning: use of obsolete %%[ operator in specs");
5249 case '(':
5251 const char *name = p;
5252 struct spec_list *sl;
5253 int len;
5255 /* The string after the S/P is the name of a spec that is to be
5256 processed. */
5257 while (*p && *p != ')' && *p != ']')
5258 p++;
5260 /* See if it's in the list. */
5261 for (len = p - name, sl = specs; sl; sl = sl->next)
5262 if (sl->name_len == len && !strncmp (sl->name, name, len))
5264 name = *(sl->ptr_spec);
5265 #ifdef DEBUG_SPECS
5266 notice ("Processing spec %c%s%c, which is '%s'\n",
5267 c, sl->name, (c == '(') ? ')' : ']', name);
5268 #endif
5269 break;
5272 if (sl)
5274 if (c == '(')
5276 value = do_spec_1 (name, 0, NULL);
5277 if (value != 0)
5278 return value;
5280 else
5282 char *x = (char *) alloca (strlen (name) * 2 + 1);
5283 char *buf = x;
5284 const char *y = name;
5285 int flag = 0;
5287 /* Copy all of NAME into BUF, but put __ after
5288 every -D and at the end of each arg. */
5289 while (1)
5291 if (! strncmp (y, "-D", 2))
5293 *x++ = '-';
5294 *x++ = 'D';
5295 *x++ = '_';
5296 *x++ = '_';
5297 y += 2;
5298 flag = 1;
5299 continue;
5301 else if (flag
5302 && (*y == ' ' || *y == '\t' || *y == '='
5303 || *y == '}' || *y == 0))
5305 *x++ = '_';
5306 *x++ = '_';
5307 flag = 0;
5309 if (*y == 0)
5310 break;
5311 else
5312 *x++ = *y++;
5314 *x = 0;
5316 value = do_spec_1 (buf, 0, NULL);
5317 if (value != 0)
5318 return value;
5322 /* Discard the closing paren or bracket. */
5323 if (*p)
5324 p++;
5326 break;
5328 case 'v':
5330 int c1 = *p++; /* Select first or second version number. */
5331 const char *v = compiler_version;
5332 const char *q;
5333 static const char zeroc = '0';
5335 /* The format of the version string is
5336 ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)? */
5338 /* Ignore leading non-digits. i.e. "foo-" in "foo-2.7.2". */
5339 while (! ISDIGIT (*v))
5340 v++;
5341 if (v > compiler_version && v[-1] != '-')
5342 abort ();
5344 /* If desired, advance to second version number. */
5345 if (c1 >= '2')
5347 /* Set V after the first period. */
5348 while (ISDIGIT (*v))
5349 v++;
5350 if (*v != '.')
5351 abort ();
5352 v++;
5355 /* If desired, advance to third version number.
5356 But don't complain if it's not present */
5357 if (c1 == '3')
5359 /* Set V after the second period. */
5360 while (ISDIGIT (*v))
5361 v++;
5362 if ((*v != 0) && (*v != ' ') && (*v != '.') && (*v != '-'))
5363 abort ();
5364 if (*v != 0)
5365 v++;
5368 /* Set Q at the next period or at the end. */
5369 q = v;
5370 while (ISDIGIT (*q))
5371 q++;
5372 if (*q != 0 && q > v && *q != ' ' && *q != '.' && *q != '-')
5373 abort ();
5375 if (q > v)
5376 /* Put that part into the command. */
5377 obstack_grow (&obstack, v, q - v);
5378 else
5379 /* Default to "0" */
5380 obstack_grow (&obstack, &zeroc, 1);
5381 arg_going = 1;
5383 break;
5385 default:
5386 error ("spec failure: unrecognized spec option '%c'", c);
5387 break;
5389 break;
5391 case '\\':
5392 /* Backslash: treat next character as ordinary. */
5393 c = *p++;
5395 /* fall through */
5396 default:
5397 /* Ordinary character: put it into the current argument. */
5398 obstack_1grow (&obstack, c);
5399 arg_going = 1;
5402 /* End of string. If we are processing a spec function, we need to
5403 end any pending argument. */
5404 if (processing_spec_function && arg_going)
5406 obstack_1grow (&obstack, 0);
5407 string = obstack_finish (&obstack);
5408 if (this_is_library_file)
5409 string = find_file (string);
5410 store_arg (string, delete_this_arg, this_is_output_file);
5411 if (this_is_output_file)
5412 outfiles[input_file_number] = string;
5413 arg_going = 0;
5416 return 0;
5419 /* Look up a spec function. */
5421 static const struct spec_function *
5422 lookup_spec_function (name)
5423 const char *name;
5425 static const struct spec_function * const spec_function_tables[] =
5427 static_spec_functions,
5428 lang_specific_spec_functions,
5430 const struct spec_function *sf;
5431 unsigned int i;
5433 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5435 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5436 if (strcmp (sf->name, name) == 0)
5437 return sf;
5440 return NULL;
5443 /* Evaluate a spec function. */
5445 static const char *
5446 eval_spec_function (func, args)
5447 const char *func, *args;
5449 const struct spec_function *sf;
5450 const char *funcval;
5452 /* Saved spec processing context. */
5453 int save_argbuf_index;
5454 int save_argbuf_length;
5455 const char **save_argbuf;
5457 int save_arg_going;
5458 int save_delete_this_arg;
5459 int save_this_is_output_file;
5460 int save_this_is_library_file;
5461 int save_input_from_pipe;
5462 const char *save_suffix_subst;
5465 sf = lookup_spec_function (func);
5466 if (sf == NULL)
5467 fatal ("unknown spec function `%s'", func);
5469 /* Push the spec processing context. */
5470 save_argbuf_index = argbuf_index;
5471 save_argbuf_length = argbuf_length;
5472 save_argbuf = argbuf;
5474 save_arg_going = arg_going;
5475 save_delete_this_arg = delete_this_arg;
5476 save_this_is_output_file = this_is_output_file;
5477 save_this_is_library_file = this_is_library_file;
5478 save_input_from_pipe = input_from_pipe;
5479 save_suffix_subst = suffix_subst;
5481 /* Create a new spec processing context, and build the function
5482 arguments. */
5484 alloc_args ();
5485 if (do_spec_2 (args) < 0)
5486 fatal ("error in args to spec function `%s'", func);
5488 /* argbuf_index is an index for the next argument to be inserted, and
5489 so contains the count of the args already inserted. */
5491 funcval = (*sf->func) (argbuf_index, argbuf);
5493 /* Pop the spec processing context. */
5494 argbuf_index = save_argbuf_index;
5495 argbuf_length = save_argbuf_length;
5496 free (argbuf);
5497 argbuf = save_argbuf;
5499 arg_going = save_arg_going;
5500 delete_this_arg = save_delete_this_arg;
5501 this_is_output_file = save_this_is_output_file;
5502 this_is_library_file = save_this_is_library_file;
5503 input_from_pipe = save_input_from_pipe;
5504 suffix_subst = save_suffix_subst;
5506 return funcval;
5509 /* Handle a spec function call of the form:
5511 %:function(args)
5513 ARGS is processed as a spec in a separate context and split into an
5514 argument vector in the normal fashion. The function returns a string
5515 containing a spec which we then process in the caller's context, or
5516 NULL if no processing is required. */
5518 static const char *
5519 handle_spec_function (p)
5520 const char *p;
5522 char *func, *args;
5523 const char *endp, *funcval;
5524 int count;
5526 processing_spec_function++;
5528 /* Get the function name. */
5529 for (endp = p; *endp != '\0'; endp++)
5531 if (*endp == '(') /* ) */
5532 break;
5533 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5534 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5535 fatal ("malformed spec function name");
5537 if (*endp != '(') /* ) */
5538 fatal ("no arguments for spec function");
5539 func = save_string (p, endp - p);
5540 p = ++endp;
5542 /* Get the arguments. */
5543 for (count = 0; *endp != '\0'; endp++)
5545 /* ( */
5546 if (*endp == ')')
5548 if (count == 0)
5549 break;
5550 count--;
5552 else if (*endp == '(') /* ) */
5553 count++;
5555 /* ( */
5556 if (*endp != ')')
5557 fatal ("malformed spec function arguments");
5558 args = save_string (p, endp - p);
5559 p = ++endp;
5561 /* p now points to just past the end of the spec function expression. */
5563 funcval = eval_spec_function (func, args);
5564 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5565 p = NULL;
5567 free (func);
5568 free (args);
5570 processing_spec_function--;
5572 return p;
5575 /* Inline subroutine of handle_braces. Returns true if the current
5576 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5577 static inline bool
5578 input_suffix_matches (atom, end_atom)
5579 const char *atom;
5580 const char *end_atom;
5582 return (input_suffix
5583 && !strncmp (input_suffix, atom, end_atom - atom)
5584 && input_suffix[end_atom - atom] == '\0');
5587 /* Inline subroutine of handle_braces. Returns true if a switch
5588 matching the atom bracketed by ATOM and END_ATOM appeared on the
5589 command line. */
5590 static inline bool
5591 switch_matches (atom, end_atom, starred)
5592 const char *atom;
5593 const char *end_atom;
5594 int starred;
5596 int i;
5597 int len = end_atom - atom;
5598 int plen = starred ? len : -1;
5600 for (i = 0; i < n_switches; i++)
5601 if (!strncmp (switches[i].part1, atom, len)
5602 && (starred || switches[i].part1[len] == '\0')
5603 && check_live_switch (i, plen))
5604 return true;
5606 return false;
5609 /* Inline subroutine of handle_braces. Mark all of the switches which
5610 match ATOM (extends to END_ATOM; STARRED indicates whether there
5611 was a star after the atom) for later processing. */
5612 static inline void
5613 mark_matching_switches (atom, end_atom, starred)
5614 const char *atom;
5615 const char *end_atom;
5616 int starred;
5618 int i;
5619 int len = end_atom - atom;
5620 int plen = starred ? len : -1;
5622 for (i = 0; i < n_switches; i++)
5623 if (!strncmp (switches[i].part1, atom, len)
5624 && (starred || switches[i].part1[len] == '\0')
5625 && check_live_switch (i, plen))
5626 switches[i].ordering = 1;
5629 /* Inline subroutine of handle_braces. Process all the currently
5630 marked switches through give_switch, and clear the marks. */
5631 static inline void
5632 process_marked_switches ()
5634 int i;
5636 for (i = 0; i < n_switches; i++)
5637 if (switches[i].ordering == 1)
5639 switches[i].ordering = 0;
5640 give_switch (i, 0);
5644 /* Handle a %{ ... } construct. P points just inside the leading {.
5645 Returns a pointer one past the end of the brace block, or 0
5646 if we call do_spec_1 and that returns -1. */
5648 static const char *
5649 handle_braces (p)
5650 const char *p;
5652 const char *atom, *end_atom;
5653 const char *d_atom = NULL, *d_end_atom = NULL;
5655 bool a_is_suffix;
5656 bool a_is_starred;
5657 bool a_is_negated;
5658 bool a_matched;
5660 bool a_must_be_last = false;
5661 bool ordered_set = false;
5662 bool disjunct_set = false;
5663 bool disj_matched = false;
5664 bool disj_starred = true;
5665 bool n_way_choice = false;
5666 bool n_way_matched = false;
5668 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5672 if (a_must_be_last)
5673 abort ();
5675 /* Scan one "atom" (S in the description above of %{}, possibly
5676 with !, ., or * modifiers). */
5677 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5679 SKIP_WHITE();
5680 if (*p == '!')
5681 p++, a_is_negated = true;
5683 SKIP_WHITE();
5684 if (*p == '.')
5685 p++, a_is_suffix = true;
5687 atom = p;
5688 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5689 || *p == ',' || *p == '.' || *p == '@')
5690 p++;
5691 end_atom = p;
5693 if (*p == '*')
5694 p++, a_is_starred = 1;
5696 SKIP_WHITE();
5697 if (*p == '&' || *p == '}')
5699 /* Substitute the switch(es) indicated by the current atom. */
5700 ordered_set = true;
5701 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5702 || atom == end_atom)
5703 abort ();
5705 mark_matching_switches (atom, end_atom, a_is_starred);
5707 if (*p == '}')
5708 process_marked_switches ();
5710 else if (*p == '|' || *p == ':')
5712 /* Substitute some text if the current atom appears as a switch
5713 or suffix. */
5714 disjunct_set = true;
5715 if (ordered_set)
5716 abort ();
5718 if (atom == end_atom)
5720 if (!n_way_choice || disj_matched || *p == '|'
5721 || a_is_negated || a_is_suffix || a_is_starred)
5722 abort ();
5724 /* An empty term may appear as the last choice of an
5725 N-way choice set; it means "otherwise". */
5726 a_must_be_last = true;
5727 disj_matched = !n_way_matched;
5728 disj_starred = false;
5730 else
5732 if (a_is_suffix && a_is_starred)
5733 abort ();
5735 if (!a_is_starred)
5736 disj_starred = false;
5738 /* Don't bother testing this atom if we already have a
5739 match. */
5740 if (!disj_matched && !n_way_matched)
5742 if (a_is_suffix)
5743 a_matched = input_suffix_matches (atom, end_atom);
5744 else
5745 a_matched = switch_matches (atom, end_atom, a_is_starred);
5747 if (a_matched != a_is_negated)
5749 disj_matched = true;
5750 d_atom = atom;
5751 d_end_atom = end_atom;
5756 if (*p == ':')
5758 /* Found the body, that is, the text to substitute if the
5759 current disjunction matches. */
5760 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5761 disj_matched && !n_way_matched);
5762 if (p == 0)
5763 return 0;
5765 /* If we have an N-way choice, reset state for the next
5766 disjunction. */
5767 if (*p == ';')
5769 n_way_choice = true;
5770 n_way_matched |= disj_matched;
5771 disj_matched = false;
5772 disj_starred = true;
5773 d_atom = d_end_atom = NULL;
5777 else
5778 abort ();
5780 while (*p++ != '}');
5782 return p;
5784 #undef SKIP_WHITE
5787 /* Subroutine of handle_braces. Scan and process a brace substitution body
5788 (X in the description of %{} syntax). P points one past the colon;
5789 ATOM and END_ATOM bracket the first atom which was found to be true
5790 (present) in the current disjunction; STARRED indicates whether all
5791 the atoms in the current disjunction were starred (for syntax validation);
5792 MATCHED indicates whether the disjunction matched or not, and therefore
5793 whether or not the body is to be processed through do_spec_1 or just
5794 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5795 returns -1. */
5797 static const char *
5798 process_brace_body (p, atom, end_atom, starred, matched)
5799 const char *p;
5800 const char *atom;
5801 const char *end_atom;
5802 int starred;
5803 int matched;
5805 const char *body, *end_body;
5806 unsigned int nesting_level;
5807 bool have_subst = false;
5809 /* Locate the closing } or ;, honoring nested braces.
5810 Trim trailing whitespace. */
5811 body = p;
5812 nesting_level = 1;
5813 for (;;)
5815 if (*p == '{')
5816 nesting_level++;
5817 else if (*p == '}')
5819 if (!--nesting_level)
5820 break;
5822 else if (*p == ';' && nesting_level == 1)
5823 break;
5824 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5825 have_subst = true;
5826 else if (*p == '\0')
5827 abort ();
5828 p++;
5831 end_body = p;
5832 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5833 end_body--;
5835 if (have_subst && !starred)
5836 abort ();
5838 if (matched)
5840 /* Copy the substitution body to permanent storage and execute it.
5841 If have_subst is false, this is a simple matter of running the
5842 body through do_spec_1... */
5843 char *string = save_string (body, end_body - body);
5844 if (!have_subst)
5846 if (do_spec_1 (string, 0, NULL) < 0)
5847 return 0;
5849 else
5851 /* ... but if have_subst is true, we have to process the
5852 body once for each matching switch, with %* set to the
5853 variant part of the switch. */
5854 unsigned int hard_match_len = end_atom - atom;
5855 int i;
5857 for (i = 0; i < n_switches; i++)
5858 if (!strncmp (switches[i].part1, atom, hard_match_len)
5859 && check_live_switch (i, hard_match_len))
5861 if (do_spec_1 (string, 0,
5862 &switches[i].part1[hard_match_len]) < 0)
5863 return 0;
5864 /* Pass any arguments this switch has. */
5865 give_switch (i, 1);
5866 suffix_subst = NULL;
5871 return p;
5874 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5875 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5876 spec, or -1 if either exact match or %* is used.
5878 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5879 whose value does not begin with "no-" is obsoleted by the same value
5880 with the "no-", similarly for a switch with the "no-" prefix. */
5882 static int
5883 check_live_switch (switchnum, prefix_length)
5884 int switchnum;
5885 int prefix_length;
5887 const char *name = switches[switchnum].part1;
5888 int i;
5890 /* In the common case of {<at-most-one-letter>*}, a negating
5891 switch would always match, so ignore that case. We will just
5892 send the conflicting switches to the compiler phase. */
5893 if (prefix_length >= 0 && prefix_length <= 1)
5894 return 1;
5896 /* If we already processed this switch and determined if it was
5897 live or not, return our past determination. */
5898 if (switches[switchnum].live_cond != 0)
5899 return switches[switchnum].live_cond > 0;
5901 /* Now search for duplicate in a manner that depends on the name. */
5902 switch (*name)
5904 case 'O':
5905 for (i = switchnum + 1; i < n_switches; i++)
5906 if (switches[i].part1[0] == 'O')
5908 switches[switchnum].validated = 1;
5909 switches[switchnum].live_cond = SWITCH_FALSE;
5910 return 0;
5912 break;
5914 case 'W': case 'f': case 'm':
5915 if (! strncmp (name + 1, "no-", 3))
5917 /* We have Xno-YYY, search for XYYY. */
5918 for (i = switchnum + 1; i < n_switches; i++)
5919 if (switches[i].part1[0] == name[0]
5920 && ! strcmp (&switches[i].part1[1], &name[4]))
5922 switches[switchnum].validated = 1;
5923 switches[switchnum].live_cond = SWITCH_FALSE;
5924 return 0;
5927 else
5929 /* We have XYYY, search for Xno-YYY. */
5930 for (i = switchnum + 1; i < n_switches; i++)
5931 if (switches[i].part1[0] == name[0]
5932 && switches[i].part1[1] == 'n'
5933 && switches[i].part1[2] == 'o'
5934 && switches[i].part1[3] == '-'
5935 && !strcmp (&switches[i].part1[4], &name[1]))
5937 switches[switchnum].validated = 1;
5938 switches[switchnum].live_cond = SWITCH_FALSE;
5939 return 0;
5942 break;
5945 /* Otherwise the switch is live. */
5946 switches[switchnum].live_cond = SWITCH_LIVE;
5947 return 1;
5950 /* Pass a switch to the current accumulating command
5951 in the same form that we received it.
5952 SWITCHNUM identifies the switch; it is an index into
5953 the vector of switches gcc received, which is `switches'.
5954 This cannot fail since it never finishes a command line.
5956 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5958 static void
5959 give_switch (switchnum, omit_first_word)
5960 int switchnum;
5961 int omit_first_word;
5963 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5964 return;
5966 if (!omit_first_word)
5968 do_spec_1 ("-", 0, NULL);
5969 do_spec_1 (switches[switchnum].part1, 1, NULL);
5972 if (switches[switchnum].args != 0)
5974 const char **p;
5975 for (p = switches[switchnum].args; *p; p++)
5977 const char *arg = *p;
5979 do_spec_1 (" ", 0, NULL);
5980 if (suffix_subst)
5982 unsigned length = strlen (arg);
5983 int dot = 0;
5985 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5986 if (arg[length] == '.')
5988 ((char *)arg)[length] = 0;
5989 dot = 1;
5990 break;
5992 do_spec_1 (arg, 1, NULL);
5993 if (dot)
5994 ((char *)arg)[length] = '.';
5995 do_spec_1 (suffix_subst, 1, NULL);
5997 else
5998 do_spec_1 (arg, 1, NULL);
6002 do_spec_1 (" ", 0, NULL);
6003 switches[switchnum].validated = 1;
6006 /* Search for a file named NAME trying various prefixes including the
6007 user's -B prefix and some standard ones.
6008 Return the absolute file name found. If nothing is found, return NAME. */
6010 static const char *
6011 find_file (name)
6012 const char *name;
6014 char *newname;
6016 /* Try multilib_dir if it is defined. */
6017 if (multilib_os_dir != NULL)
6019 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
6021 /* If we don't find it in the multi library dir, then fall
6022 through and look for it in the normal places. */
6023 if (newname != NULL)
6024 return newname;
6027 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
6028 return newname ? newname : name;
6031 /* Determine whether a directory exists. If LINKER, return 0 for
6032 certain fixed names not needed by the linker. If not LINKER, it is
6033 only important to return 0 if the host machine has a small ARG_MAX
6034 limit. */
6036 static int
6037 is_directory (path1, path2, linker)
6038 const char *path1;
6039 const char *path2;
6040 int linker;
6042 int len1 = strlen (path1);
6043 int len2 = strlen (path2);
6044 char *path = (char *) alloca (3 + len1 + len2);
6045 char *cp;
6046 struct stat st;
6048 #ifndef SMALL_ARG_MAX
6049 if (! linker)
6050 return 1;
6051 #endif
6053 /* Construct the path from the two parts. Ensure the string ends with "/.".
6054 The resulting path will be a directory even if the given path is a
6055 symbolic link. */
6056 memcpy (path, path1, len1);
6057 memcpy (path + len1, path2, len2);
6058 cp = path + len1 + len2;
6059 if (!IS_DIR_SEPARATOR (cp[-1]))
6060 *cp++ = DIR_SEPARATOR;
6061 *cp++ = '.';
6062 *cp = '\0';
6064 /* Exclude directories that the linker is known to search. */
6065 if (linker
6066 && ((cp - path == 6
6067 && strcmp (path, concat (dir_separator_str, "lib",
6068 dir_separator_str, ".", NULL)) == 0)
6069 || (cp - path == 10
6070 && strcmp (path, concat (dir_separator_str, "usr",
6071 dir_separator_str, "lib",
6072 dir_separator_str, ".", NULL)) == 0)))
6073 return 0;
6075 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6078 /* Set up the various global variables to indicate that we're processing
6079 the input file named FILENAME. */
6081 void
6082 set_input (filename)
6083 const char *filename;
6085 const char *p;
6087 input_filename = filename;
6088 input_filename_length = strlen (input_filename);
6090 input_basename = input_filename;
6091 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
6092 /* Skip drive name so 'x:foo' is handled properly. */
6093 if (input_basename[1] == ':')
6094 input_basename += 2;
6095 #endif
6096 for (p = input_basename; *p; p++)
6097 if (IS_DIR_SEPARATOR (*p))
6098 input_basename = p + 1;
6100 /* Find a suffix starting with the last period,
6101 and set basename_length to exclude that suffix. */
6102 basename_length = strlen (input_basename);
6103 suffixed_basename_length = basename_length;
6104 p = input_basename + basename_length;
6105 while (p != input_basename && *p != '.')
6106 --p;
6107 if (*p == '.' && p != input_basename)
6109 basename_length = p - input_basename;
6110 input_suffix = p + 1;
6112 else
6113 input_suffix = "";
6115 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6116 we will need to do a stat on the input_filename. The
6117 INPUT_STAT_SET signals that the stat is needed. */
6118 input_stat_set = 0;
6121 /* On fatal signals, delete all the temporary files. */
6123 static void
6124 fatal_error (signum)
6125 int signum;
6127 signal (signum, SIG_DFL);
6128 delete_failure_queue ();
6129 delete_temp_files ();
6130 /* Get the same signal again, this time not handled,
6131 so its normal effect occurs. */
6132 kill (getpid (), signum);
6135 extern int main PARAMS ((int, const char *const *));
6138 main (argc, argv)
6139 int argc;
6140 const char *const *argv;
6142 size_t i;
6143 int value;
6144 int linker_was_run = 0;
6145 int num_linker_inputs = 0;
6146 char *explicit_link_files;
6147 char *specs_file;
6148 const char *p;
6149 struct user_specs *uptr;
6151 p = argv[0] + strlen (argv[0]);
6152 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6153 --p;
6154 programname = p;
6156 xmalloc_set_program_name (programname);
6158 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6159 /* Perform host dependent initialization when needed. */
6160 GCC_DRIVER_HOST_INITIALIZATION;
6161 #endif
6163 gcc_init_libintl ();
6165 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6166 signal (SIGINT, fatal_error);
6167 #ifdef SIGHUP
6168 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6169 signal (SIGHUP, fatal_error);
6170 #endif
6171 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6172 signal (SIGTERM, fatal_error);
6173 #ifdef SIGPIPE
6174 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6175 signal (SIGPIPE, fatal_error);
6176 #endif
6177 #ifdef SIGCHLD
6178 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6179 receive the signal. A different setting is inheritable */
6180 signal (SIGCHLD, SIG_DFL);
6181 #endif
6183 /* Allocate the argument vector. */
6184 alloc_args ();
6186 obstack_init (&obstack);
6188 /* Build multilib_select, et. al from the separate lines that make up each
6189 multilib selection. */
6191 const char *const *q = multilib_raw;
6192 int need_space;
6194 obstack_init (&multilib_obstack);
6195 while ((p = *q++) != (char *) 0)
6196 obstack_grow (&multilib_obstack, p, strlen (p));
6198 obstack_1grow (&multilib_obstack, 0);
6199 multilib_select = obstack_finish (&multilib_obstack);
6201 q = multilib_matches_raw;
6202 while ((p = *q++) != (char *) 0)
6203 obstack_grow (&multilib_obstack, p, strlen (p));
6205 obstack_1grow (&multilib_obstack, 0);
6206 multilib_matches = obstack_finish (&multilib_obstack);
6208 q = multilib_exclusions_raw;
6209 while ((p = *q++) != (char *) 0)
6210 obstack_grow (&multilib_obstack, p, strlen (p));
6212 obstack_1grow (&multilib_obstack, 0);
6213 multilib_exclusions = obstack_finish (&multilib_obstack);
6215 need_space = FALSE;
6216 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6218 if (need_space)
6219 obstack_1grow (&multilib_obstack, ' ');
6220 obstack_grow (&multilib_obstack,
6221 multilib_defaults_raw[i],
6222 strlen (multilib_defaults_raw[i]));
6223 need_space = TRUE;
6226 obstack_1grow (&multilib_obstack, 0);
6227 multilib_defaults = obstack_finish (&multilib_obstack);
6230 /* Set up to remember the pathname of gcc and any options
6231 needed for collect. We use argv[0] instead of programname because
6232 we need the complete pathname. */
6233 obstack_init (&collect_obstack);
6234 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6235 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6236 putenv (obstack_finish (&collect_obstack));
6238 #ifdef INIT_ENVIRONMENT
6239 /* Set up any other necessary machine specific environment variables. */
6240 putenv (INIT_ENVIRONMENT);
6241 #endif
6243 /* Make a table of what switches there are (switches, n_switches).
6244 Make a table of specified input files (infiles, n_infiles).
6245 Decode switches that are handled locally. */
6247 process_command (argc, argv);
6249 /* Initialize the vector of specs to just the default.
6250 This means one element containing 0s, as a terminator. */
6252 compilers = (struct compiler *) xmalloc (sizeof default_compilers);
6253 memcpy ((char *) compilers, (char *) default_compilers,
6254 sizeof default_compilers);
6255 n_compilers = n_default_compilers;
6257 /* Read specs from a file if there is one. */
6259 machine_suffix = concat (spec_machine, dir_separator_str,
6260 spec_version, dir_separator_str, NULL);
6261 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6263 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6264 /* Read the specs file unless it is a default one. */
6265 if (specs_file != 0 && strcmp (specs_file, "specs"))
6266 read_specs (specs_file, TRUE);
6267 else
6268 init_spec ();
6270 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6271 for any override of as, ld and libraries. */
6272 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6273 + strlen (just_machine_suffix)
6274 + sizeof ("specs"));
6276 strcpy (specs_file, standard_exec_prefix);
6277 strcat (specs_file, just_machine_suffix);
6278 strcat (specs_file, "specs");
6279 if (access (specs_file, R_OK) == 0)
6280 read_specs (specs_file, TRUE);
6282 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6283 of the command line. */
6285 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6286 do_self_spec (driver_self_specs[i]);
6288 /* If not cross-compiling, look for executables in the standard
6289 places. */
6290 if (*cross_compile == '0')
6292 if (*md_exec_prefix)
6294 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6295 PREFIX_PRIORITY_LAST, 0, NULL, 0);
6299 /* Look for startfiles in the standard places. */
6300 if (*startfile_prefix_spec != 0
6301 && do_spec_2 (startfile_prefix_spec) == 0
6302 && do_spec_1 (" ", 0, NULL) == 0)
6304 int ndx;
6305 for (ndx = 0; ndx < argbuf_index; ndx++)
6306 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6307 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6309 /* We should eventually get rid of all these and stick to
6310 startfile_prefix_spec exclusively. */
6311 else if (*cross_compile == '0' || target_system_root)
6313 if (*md_exec_prefix)
6314 add_sysrooted_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
6315 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6317 if (*md_startfile_prefix)
6318 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6319 "GCC", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6321 if (*md_startfile_prefix_1)
6322 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6323 "GCC", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6325 /* If standard_startfile_prefix is relative, base it on
6326 standard_exec_prefix. This lets us move the installed tree
6327 as a unit. If GCC_EXEC_PREFIX is defined, base
6328 standard_startfile_prefix on that as well. */
6329 if (IS_ABSOLUTE_PATHNAME (standard_startfile_prefix))
6330 add_sysrooted_prefix (&startfile_prefixes,
6331 standard_startfile_prefix, "BINUTILS",
6332 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6333 else
6335 if (gcc_exec_prefix)
6336 add_prefix (&startfile_prefixes,
6337 concat (gcc_exec_prefix, machine_suffix,
6338 standard_startfile_prefix, NULL),
6339 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
6340 add_prefix (&startfile_prefixes,
6341 concat (standard_exec_prefix,
6342 machine_suffix,
6343 standard_startfile_prefix, NULL),
6344 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
6347 add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_1,
6348 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6349 add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_2,
6350 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6351 #if 0 /* Can cause surprises, and one can use -B./ instead. */
6352 add_prefix (&startfile_prefixes, "./", NULL,
6353 PREFIX_PRIORITY_LAST, 1, NULL, 0);
6354 #endif
6357 /* Process any user specified specs in the order given on the command
6358 line. */
6359 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6361 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6362 R_OK, 0);
6363 read_specs (filename ? filename : uptr->filename, FALSE);
6366 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6367 if (gcc_exec_prefix)
6368 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6369 spec_version, dir_separator_str, NULL);
6371 /* Now we have the specs.
6372 Set the `valid' bits for switches that match anything in any spec. */
6374 validate_all_switches ();
6376 /* Now that we have the switches and the specs, set
6377 the subdirectory based on the options. */
6378 set_multilib_dir ();
6380 /* Warn about any switches that no pass was interested in. */
6382 for (i = 0; (int) i < n_switches; i++)
6383 if (! switches[i].validated)
6384 error ("unrecognized option `-%s'", switches[i].part1);
6386 /* Obey some of the options. */
6388 if (print_search_dirs)
6390 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6391 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6392 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6393 return (0);
6396 if (print_file_name)
6398 printf ("%s\n", find_file (print_file_name));
6399 return (0);
6402 if (print_prog_name)
6404 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6405 printf ("%s\n", (newname ? newname : print_prog_name));
6406 return (0);
6409 if (print_multi_lib)
6411 print_multilib_info ();
6412 return (0);
6415 if (print_multi_directory)
6417 if (multilib_dir == NULL)
6418 printf (".\n");
6419 else
6420 printf ("%s\n", multilib_dir);
6421 return (0);
6424 if (print_multi_os_directory)
6426 if (multilib_os_dir == NULL)
6427 printf (".\n");
6428 else
6429 printf ("%s\n", multilib_os_dir);
6430 return (0);
6433 if (target_help_flag)
6435 /* Print if any target specific options. */
6437 /* We do not exit here. Instead we have created a fake input file
6438 called 'target-dummy' which needs to be compiled, and we pass this
6439 on to the various sub-processes, along with the --target-help
6440 switch. */
6443 if (print_help_list)
6445 display_help ();
6447 if (! verbose_flag)
6449 printf (_("\nFor bug reporting instructions, please see:\n"));
6450 printf ("%s.\n", bug_report_url);
6452 return (0);
6455 /* We do not exit here. Instead we have created a fake input file
6456 called 'help-dummy' which needs to be compiled, and we pass this
6457 on the various sub-processes, along with the --help switch. */
6460 if (verbose_flag)
6462 int n;
6463 const char *thrmod;
6465 notice ("Configured with: %s\n", configuration_arguments);
6467 #ifdef THREAD_MODEL_SPEC
6468 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6469 but there's no point in doing all this processing just to get
6470 thread_model back. */
6471 obstack_init (&obstack);
6472 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6473 obstack_1grow (&obstack, '\0');
6474 thrmod = obstack_finish (&obstack);
6475 #else
6476 thrmod = thread_model;
6477 #endif
6479 notice ("Thread model: %s\n", thrmod);
6481 /* compiler_version is truncated at the first space when initialized
6482 from version string, so truncate version_string at the first space
6483 before comparing. */
6484 for (n = 0; version_string[n]; n++)
6485 if (version_string[n] == ' ')
6486 break;
6488 if (! strncmp (version_string, compiler_version, n)
6489 && compiler_version[n] == 0)
6490 notice ("gcc version %s\n", version_string);
6491 else
6492 notice ("gcc driver version %s executing gcc version %s\n",
6493 version_string, compiler_version);
6495 if (n_infiles == 0)
6496 return (0);
6499 if (n_infiles == added_libraries)
6500 fatal ("no input files");
6502 /* Make a place to record the compiler output file names
6503 that correspond to the input files. */
6505 i = n_infiles;
6506 i += lang_specific_extra_outfiles;
6507 outfiles = (const char **) xcalloc (i, sizeof (char *));
6509 /* Record which files were specified explicitly as link input. */
6511 explicit_link_files = xcalloc (1, n_infiles);
6513 for (i = 0; (int) i < n_infiles; i++)
6515 int this_file_error = 0;
6517 /* Tell do_spec what to substitute for %i. */
6519 input_file_number = i;
6520 set_input (infiles[i].name);
6522 /* Use the same thing in %o, unless cp->spec says otherwise. */
6524 outfiles[i] = input_filename;
6526 /* Figure out which compiler from the file's suffix. */
6528 input_file_compiler
6529 = lookup_compiler (infiles[i].name, input_filename_length,
6530 infiles[i].language);
6532 if (input_file_compiler)
6534 /* Ok, we found an applicable compiler. Run its spec. */
6536 if (input_file_compiler->spec[0] == '#')
6538 error ("%s: %s compiler not installed on this system",
6539 input_filename, &input_file_compiler->spec[1]);
6540 this_file_error = 1;
6542 else
6544 value = do_spec (input_file_compiler->spec);
6545 if (value < 0)
6546 this_file_error = 1;
6550 /* If this file's name does not contain a recognized suffix,
6551 record it as explicit linker input. */
6553 else
6554 explicit_link_files[i] = 1;
6556 /* Clear the delete-on-failure queue, deleting the files in it
6557 if this compilation failed. */
6559 if (this_file_error)
6561 delete_failure_queue ();
6562 error_count++;
6564 /* If this compilation succeeded, don't delete those files later. */
6565 clear_failure_queue ();
6568 /* Reset the output file name to the first input file name, for use
6569 with %b in LINK_SPEC on a target that prefers not to emit a.out
6570 by default. */
6571 if (n_infiles > 0)
6572 set_input (infiles[0].name);
6574 if (error_count == 0)
6576 /* Make sure INPUT_FILE_NUMBER points to first available open
6577 slot. */
6578 input_file_number = n_infiles;
6579 if (lang_specific_pre_link ())
6580 error_count++;
6583 /* Determine if there are any linker input files. */
6584 num_linker_inputs = 0;
6585 for (i = 0; (int) i < n_infiles; i++)
6586 if (explicit_link_files[i] || outfiles[i] != NULL)
6587 num_linker_inputs++;
6589 /* Run ld to link all the compiler output files. */
6591 if (num_linker_inputs > 0 && error_count == 0)
6593 int tmp = execution_count;
6595 /* We'll use ld if we can't find collect2. */
6596 if (! strcmp (linker_name_spec, "collect2"))
6598 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6599 if (s == NULL)
6600 linker_name_spec = "ld";
6602 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6603 for collect. */
6604 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6605 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6607 value = do_spec (link_command_spec);
6608 if (value < 0)
6609 error_count = 1;
6610 linker_was_run = (tmp != execution_count);
6613 /* If options said don't run linker,
6614 complain about input files to be given to the linker. */
6616 if (! linker_was_run && error_count == 0)
6617 for (i = 0; (int) i < n_infiles; i++)
6618 if (explicit_link_files[i])
6619 error ("%s: linker input file unused because linking not done",
6620 outfiles[i]);
6622 /* Delete some or all of the temporary files we made. */
6624 if (error_count)
6625 delete_failure_queue ();
6626 delete_temp_files ();
6628 if (print_help_list)
6630 printf (("\nFor bug reporting instructions, please see:\n"));
6631 printf ("%s\n", bug_report_url);
6634 return (signal_count != 0 ? 2
6635 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6636 : 0);
6639 /* Find the proper compilation spec for the file name NAME,
6640 whose length is LENGTH. LANGUAGE is the specified language,
6641 or 0 if this file is to be passed to the linker. */
6643 static struct compiler *
6644 lookup_compiler (name, length, language)
6645 const char *name;
6646 size_t length;
6647 const char *language;
6649 struct compiler *cp;
6651 /* If this was specified by the user to be a linker input, indicate that. */
6652 if (language != 0 && language[0] == '*')
6653 return 0;
6655 /* Otherwise, look for the language, if one is spec'd. */
6656 if (language != 0)
6658 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6659 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6660 return cp;
6662 error ("language %s not recognized", language);
6663 return 0;
6666 /* Look for a suffix. */
6667 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6669 if (/* The suffix `-' matches only the file name `-'. */
6670 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6671 || (strlen (cp->suffix) < length
6672 /* See if the suffix matches the end of NAME. */
6673 && !strcmp (cp->suffix,
6674 name + length - strlen (cp->suffix))
6676 break;
6679 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6680 /* look again, but case-insensitively this time. */
6681 if (cp < compilers)
6682 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6684 if (/* The suffix `-' matches only the file name `-'. */
6685 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6686 || (strlen (cp->suffix) < length
6687 /* See if the suffix matches the end of NAME. */
6688 && ((!strcmp (cp->suffix,
6689 name + length - strlen (cp->suffix))
6690 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6691 && !strcasecmp (cp->suffix,
6692 name + length - strlen (cp->suffix)))
6694 break;
6696 #endif
6698 if (cp >= compilers)
6700 if (cp->spec[0] != '@')
6701 /* A non-alias entry: return it. */
6702 return cp;
6704 /* An alias entry maps a suffix to a language.
6705 Search for the language; pass 0 for NAME and LENGTH
6706 to avoid infinite recursion if language not found. */
6707 return lookup_compiler (NULL, 0, cp->spec + 1);
6709 return 0;
6712 static char *
6713 save_string (s, len)
6714 const char *s;
6715 int len;
6717 char *result = xmalloc (len + 1);
6719 memcpy (result, s, len);
6720 result[len] = 0;
6721 return result;
6724 void
6725 pfatal_with_name (name)
6726 const char *name;
6728 perror_with_name (name);
6729 delete_temp_files ();
6730 exit (1);
6733 static void
6734 perror_with_name (name)
6735 const char *name;
6737 error ("%s: %s", name, xstrerror (errno));
6740 static void
6741 pfatal_pexecute (errmsg_fmt, errmsg_arg)
6742 const char *errmsg_fmt;
6743 const char *errmsg_arg;
6745 if (errmsg_arg)
6747 int save_errno = errno;
6749 /* Space for trailing '\0' is in %s. */
6750 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6751 sprintf (msg, errmsg_fmt, errmsg_arg);
6752 errmsg_fmt = msg;
6754 errno = save_errno;
6757 pfatal_with_name (errmsg_fmt);
6760 /* Output an error message and exit */
6762 void
6763 fancy_abort ()
6765 fatal ("internal gcc abort");
6768 /* Output an error message and exit */
6770 void
6771 fatal VPARAMS ((const char *msgid, ...))
6773 VA_OPEN (ap, msgid);
6774 VA_FIXEDARG (ap, const char *, msgid);
6776 fprintf (stderr, "%s: ", programname);
6777 vfprintf (stderr, _(msgid), ap);
6778 VA_CLOSE (ap);
6779 fprintf (stderr, "\n");
6780 delete_temp_files ();
6781 exit (1);
6784 void
6785 error VPARAMS ((const char *msgid, ...))
6787 VA_OPEN (ap, msgid);
6788 VA_FIXEDARG (ap, const char *, msgid);
6790 fprintf (stderr, "%s: ", programname);
6791 vfprintf (stderr, _(msgid), ap);
6792 VA_CLOSE (ap);
6794 fprintf (stderr, "\n");
6797 static void
6798 notice VPARAMS ((const char *msgid, ...))
6800 VA_OPEN (ap, msgid);
6801 VA_FIXEDARG (ap, const char *, msgid);
6803 vfprintf (stderr, _(msgid), ap);
6804 VA_CLOSE (ap);
6807 static inline void
6808 validate_switches_from_spec (spec)
6809 const char *spec;
6811 const char *p = spec;
6812 char c;
6813 while ((c = *p++))
6814 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6815 /* We have a switch spec. */
6816 p = validate_switches (p + 1);
6819 static void
6820 validate_all_switches ()
6822 struct compiler *comp;
6823 struct spec_list *spec;
6825 for (comp = compilers; comp->spec; comp++)
6826 validate_switches_from_spec (comp->spec);
6828 /* Look through the linked list of specs read from the specs file. */
6829 for (spec = specs; spec; spec = spec->next)
6830 validate_switches_from_spec (*spec->ptr_spec);
6832 validate_switches_from_spec (link_command_spec);
6835 /* Look at the switch-name that comes after START
6836 and mark as valid all supplied switches that match it. */
6838 static const char *
6839 validate_switches (start)
6840 const char *start;
6842 const char *p = start;
6843 const char *atom;
6844 size_t len;
6845 int i;
6846 bool suffix = false;
6847 bool starred = false;
6849 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6851 next_member:
6852 SKIP_WHITE ();
6854 if (*p == '!')
6855 p++;
6857 SKIP_WHITE ();
6858 if (*p == '.')
6859 suffix = true, p++;
6861 atom = p;
6862 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6863 || *p == ',' || *p == '.' || *p == '@')
6864 p++;
6865 len = p - atom;
6867 if (*p == '*')
6868 starred = true, p++;
6870 SKIP_WHITE ();
6872 if (!suffix)
6874 /* Mark all matching switches as valid. */
6875 for (i = 0; i < n_switches; i++)
6876 if (!strncmp (switches[i].part1, atom, len)
6877 && (starred || switches[i].part1[len] == 0))
6878 switches[i].validated = 1;
6881 if (*p) p++;
6882 if (*p && (p[-1] == '|' || p[-1] == '&'))
6883 goto next_member;
6885 if (*p && p[-1] == ':')
6887 while (*p && *p != ';' && *p != '}')
6889 if (*p == '%')
6891 p++;
6892 if (*p == '{' || *p == '<')
6893 p = validate_switches (p+1);
6894 else if (p[0] == 'W' && p[1] == '{')
6895 p = validate_switches (p+2);
6897 else
6898 p++;
6901 if (*p) p++;
6902 if (*p && p[-1] == ';')
6903 goto next_member;
6906 return p;
6907 #undef SKIP_WHITE
6910 struct mdswitchstr
6912 const char *str;
6913 int len;
6916 static struct mdswitchstr *mdswitches;
6917 static int n_mdswitches;
6919 /* Check whether a particular argument was used. The first time we
6920 canonicalize the switches to keep only the ones we care about. */
6922 static int
6923 used_arg (p, len)
6924 const char *p;
6925 int len;
6927 struct mswitchstr
6929 const char *str;
6930 const char *replace;
6931 int len;
6932 int rep_len;
6935 static struct mswitchstr *mswitches;
6936 static int n_mswitches;
6937 int i, j;
6939 if (!mswitches)
6941 struct mswitchstr *matches;
6942 const char *q;
6943 int cnt = 0;
6945 /* Break multilib_matches into the component strings of string
6946 and replacement string. */
6947 for (q = multilib_matches; *q != '\0'; q++)
6948 if (*q == ';')
6949 cnt++;
6951 matches =
6952 (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
6953 i = 0;
6954 q = multilib_matches;
6955 while (*q != '\0')
6957 matches[i].str = q;
6958 while (*q != ' ')
6960 if (*q == '\0')
6961 abort ();
6962 q++;
6964 matches[i].len = q - matches[i].str;
6966 matches[i].replace = ++q;
6967 while (*q != ';' && *q != '\0')
6969 if (*q == ' ')
6970 abort ();
6971 q++;
6973 matches[i].rep_len = q - matches[i].replace;
6974 i++;
6975 if (*q == ';')
6976 q++;
6979 /* Now build a list of the replacement string for switches that we care
6980 about. Make sure we allocate at least one entry. This prevents
6981 xmalloc from calling fatal, and prevents us from re-executing this
6982 block of code. */
6983 mswitches
6984 = (struct mswitchstr *)
6985 xmalloc (sizeof (struct mswitchstr)
6986 * (n_mdswitches + (n_switches ? n_switches : 1)));
6987 for (i = 0; i < n_switches; i++)
6989 int xlen = strlen (switches[i].part1);
6990 for (j = 0; j < cnt; j++)
6991 if (xlen == matches[j].len
6992 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6994 mswitches[n_mswitches].str = matches[j].replace;
6995 mswitches[n_mswitches].len = matches[j].rep_len;
6996 mswitches[n_mswitches].replace = (char *) 0;
6997 mswitches[n_mswitches].rep_len = 0;
6998 n_mswitches++;
6999 break;
7003 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7004 on the command line nor any options mutually incompatible with
7005 them. */
7006 for (i = 0; i < n_mdswitches; i++)
7008 const char *r;
7010 for (q = multilib_options; *q != '\0'; q++)
7012 while (*q == ' ')
7013 q++;
7015 r = q;
7016 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7017 || strchr (" /", q[mdswitches[i].len]) == NULL)
7019 while (*q != ' ' && *q != '/' && *q != '\0')
7020 q++;
7021 if (*q != '/')
7022 break;
7023 q++;
7026 if (*q != ' ' && *q != '\0')
7028 while (*r != ' ' && *r != '\0')
7030 q = r;
7031 while (*q != ' ' && *q != '/' && *q != '\0')
7032 q++;
7034 if (used_arg (r, q - r))
7035 break;
7037 if (*q != '/')
7039 mswitches[n_mswitches].str = mdswitches[i].str;
7040 mswitches[n_mswitches].len = mdswitches[i].len;
7041 mswitches[n_mswitches].replace = (char *) 0;
7042 mswitches[n_mswitches].rep_len = 0;
7043 n_mswitches++;
7044 break;
7047 r = q + 1;
7049 break;
7055 for (i = 0; i < n_mswitches; i++)
7056 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7057 return 1;
7059 return 0;
7062 static int
7063 default_arg (p, len)
7064 const char *p;
7065 int len;
7067 int i;
7069 for (i = 0; i < n_mdswitches; i++)
7070 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7071 return 1;
7073 return 0;
7076 /* Work out the subdirectory to use based on the options. The format of
7077 multilib_select is a list of elements. Each element is a subdirectory
7078 name followed by a list of options followed by a semicolon. The format
7079 of multilib_exclusions is the same, but without the preceding
7080 directory. First gcc will check the exclusions, if none of the options
7081 beginning with an exclamation point are present, and all of the other
7082 options are present, then we will ignore this completely. Passing
7083 that, gcc will consider each multilib_select in turn using the same
7084 rules for matching the options. If a match is found, that subdirectory
7085 will be used. */
7087 static void
7088 set_multilib_dir ()
7090 const char *p;
7091 unsigned int this_path_len;
7092 const char *this_path, *this_arg;
7093 const char *start, *end;
7094 int not_arg;
7095 int ok, ndfltok, first;
7097 n_mdswitches = 0;
7098 start = multilib_defaults;
7099 while (*start == ' ' || *start == '\t')
7100 start++;
7101 while (*start != '\0')
7103 n_mdswitches++;
7104 while (*start != ' ' && *start != '\t' && *start != '\0')
7105 start++;
7106 while (*start == ' ' || *start == '\t')
7107 start++;
7110 if (n_mdswitches)
7112 int i = 0;
7114 mdswitches
7115 = (struct mdswitchstr *) xmalloc (sizeof (struct mdswitchstr)
7116 * n_mdswitches);
7117 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7119 while (*start == ' ' || *start == '\t')
7120 start++;
7122 if (*start == '\0')
7123 break;
7125 for (end = start + 1;
7126 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7129 obstack_grow (&multilib_obstack, start, end - start);
7130 obstack_1grow (&multilib_obstack, 0);
7131 mdswitches[i].str = obstack_finish (&multilib_obstack);
7132 mdswitches[i++].len = end - start;
7134 if (*end == '\0')
7135 break;
7139 p = multilib_exclusions;
7140 while (*p != '\0')
7142 /* Ignore newlines. */
7143 if (*p == '\n')
7145 ++p;
7146 continue;
7149 /* Check the arguments. */
7150 ok = 1;
7151 while (*p != ';')
7153 if (*p == '\0')
7154 abort ();
7156 if (! ok)
7158 ++p;
7159 continue;
7162 this_arg = p;
7163 while (*p != ' ' && *p != ';')
7165 if (*p == '\0')
7166 abort ();
7167 ++p;
7170 if (*this_arg != '!')
7171 not_arg = 0;
7172 else
7174 not_arg = 1;
7175 ++this_arg;
7178 ok = used_arg (this_arg, p - this_arg);
7179 if (not_arg)
7180 ok = ! ok;
7182 if (*p == ' ')
7183 ++p;
7186 if (ok)
7187 return;
7189 ++p;
7192 first = 1;
7193 p = multilib_select;
7194 while (*p != '\0')
7196 /* Ignore newlines. */
7197 if (*p == '\n')
7199 ++p;
7200 continue;
7203 /* Get the initial path. */
7204 this_path = p;
7205 while (*p != ' ')
7207 if (*p == '\0')
7208 abort ();
7209 ++p;
7211 this_path_len = p - this_path;
7213 /* Check the arguments. */
7214 ok = 1;
7215 ndfltok = 1;
7216 ++p;
7217 while (*p != ';')
7219 if (*p == '\0')
7220 abort ();
7222 if (! ok)
7224 ++p;
7225 continue;
7228 this_arg = p;
7229 while (*p != ' ' && *p != ';')
7231 if (*p == '\0')
7232 abort ();
7233 ++p;
7236 if (*this_arg != '!')
7237 not_arg = 0;
7238 else
7240 not_arg = 1;
7241 ++this_arg;
7244 /* If this is a default argument, we can just ignore it.
7245 This is true even if this_arg begins with '!'. Beginning
7246 with '!' does not mean that this argument is necessarily
7247 inappropriate for this library: it merely means that
7248 there is a more specific library which uses this
7249 argument. If this argument is a default, we need not
7250 consider that more specific library. */
7251 ok = used_arg (this_arg, p - this_arg);
7252 if (not_arg)
7253 ok = ! ok;
7255 if (! ok)
7256 ndfltok = 0;
7258 if (default_arg (this_arg, p - this_arg))
7259 ok = 1;
7261 if (*p == ' ')
7262 ++p;
7265 if (ok && first)
7267 if (this_path_len != 1
7268 || this_path[0] != '.')
7270 char *new_multilib_dir = xmalloc (this_path_len + 1);
7271 char *q;
7273 strncpy (new_multilib_dir, this_path, this_path_len);
7274 new_multilib_dir[this_path_len] = '\0';
7275 q = strchr (new_multilib_dir, ':');
7276 if (q != NULL)
7277 *q = '\0';
7278 multilib_dir = new_multilib_dir;
7280 first = 0;
7283 if (ndfltok)
7285 const char *q = this_path, *end = this_path + this_path_len;
7287 while (q < end && *q != ':')
7288 q++;
7289 if (q < end)
7291 char *new_multilib_os_dir = xmalloc (end - q);
7292 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7293 new_multilib_os_dir[end - q - 1] = '\0';
7294 multilib_os_dir = new_multilib_os_dir;
7295 break;
7299 ++p;
7302 if (multilib_dir == NULL && multilib_os_dir != NULL
7303 && strcmp (multilib_os_dir, ".") == 0)
7305 free ((char *) multilib_os_dir);
7306 multilib_os_dir = NULL;
7308 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7309 multilib_os_dir = multilib_dir;
7312 /* Print out the multiple library subdirectory selection
7313 information. This prints out a series of lines. Each line looks
7314 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7315 required. Only the desired options are printed out, the negative
7316 matches. The options are print without a leading dash. There are
7317 no spaces to make it easy to use the information in the shell.
7318 Each subdirectory is printed only once. This assumes the ordering
7319 generated by the genmultilib script. Also, we leave out ones that match
7320 the exclusions. */
7322 static void
7323 print_multilib_info ()
7325 const char *p = multilib_select;
7326 const char *last_path = 0, *this_path;
7327 int skip;
7328 unsigned int last_path_len = 0;
7330 while (*p != '\0')
7332 skip = 0;
7333 /* Ignore newlines. */
7334 if (*p == '\n')
7336 ++p;
7337 continue;
7340 /* Get the initial path. */
7341 this_path = p;
7342 while (*p != ' ')
7344 if (*p == '\0')
7345 abort ();
7346 ++p;
7349 /* When --disable-multilib was used but target defines
7350 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7351 to find multilib_os_dir, so skip them from output. */
7352 if (this_path[0] == '.' && this_path[1] == ':')
7353 skip = 1;
7355 /* Check for matches with the multilib_exclusions. We don't bother
7356 with the '!' in either list. If any of the exclusion rules match
7357 all of its options with the select rule, we skip it. */
7359 const char *e = multilib_exclusions;
7360 const char *this_arg;
7362 while (*e != '\0')
7364 int m = 1;
7365 /* Ignore newlines. */
7366 if (*e == '\n')
7368 ++e;
7369 continue;
7372 /* Check the arguments. */
7373 while (*e != ';')
7375 const char *q;
7376 int mp = 0;
7378 if (*e == '\0')
7379 abort ();
7381 if (! m)
7383 ++e;
7384 continue;
7387 this_arg = e;
7389 while (*e != ' ' && *e != ';')
7391 if (*e == '\0')
7392 abort ();
7393 ++e;
7396 q = p + 1;
7397 while (*q != ';')
7399 const char *arg;
7400 int len = e - this_arg;
7402 if (*q == '\0')
7403 abort ();
7405 arg = q;
7407 while (*q != ' ' && *q != ';')
7409 if (*q == '\0')
7410 abort ();
7411 ++q;
7414 if (! strncmp (arg, this_arg, (len < q - arg) ? q - arg : len) ||
7415 default_arg (this_arg, e - this_arg))
7417 mp = 1;
7418 break;
7421 if (*q == ' ')
7422 ++q;
7425 if (! mp)
7426 m = 0;
7428 if (*e == ' ')
7429 ++e;
7432 if (m)
7434 skip = 1;
7435 break;
7438 if (*e != '\0')
7439 ++e;
7443 if (! skip)
7445 /* If this is a duplicate, skip it. */
7446 skip = (last_path != 0 && (unsigned int) (p - this_path) == last_path_len
7447 && ! strncmp (last_path, this_path, last_path_len));
7449 last_path = this_path;
7450 last_path_len = p - this_path;
7453 /* If this directory requires any default arguments, we can skip
7454 it. We will already have printed a directory identical to
7455 this one which does not require that default argument. */
7456 if (! skip)
7458 const char *q;
7460 q = p + 1;
7461 while (*q != ';')
7463 const char *arg;
7465 if (*q == '\0')
7466 abort ();
7468 if (*q == '!')
7469 arg = NULL;
7470 else
7471 arg = q;
7473 while (*q != ' ' && *q != ';')
7475 if (*q == '\0')
7476 abort ();
7477 ++q;
7480 if (arg != NULL
7481 && default_arg (arg, q - arg))
7483 skip = 1;
7484 break;
7487 if (*q == ' ')
7488 ++q;
7492 if (! skip)
7494 const char *p1;
7496 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7497 putchar (*p1);
7498 putchar (';');
7501 ++p;
7502 while (*p != ';')
7504 int use_arg;
7506 if (*p == '\0')
7507 abort ();
7509 if (skip)
7511 ++p;
7512 continue;
7515 use_arg = *p != '!';
7517 if (use_arg)
7518 putchar ('@');
7520 while (*p != ' ' && *p != ';')
7522 if (*p == '\0')
7523 abort ();
7524 if (use_arg)
7525 putchar (*p);
7526 ++p;
7529 if (*p == ' ')
7530 ++p;
7533 if (! skip)
7535 /* If there are extra options, print them now. */
7536 if (multilib_extra && *multilib_extra)
7538 int print_at = TRUE;
7539 const char *q;
7541 for (q = multilib_extra; *q != '\0'; q++)
7543 if (*q == ' ')
7544 print_at = TRUE;
7545 else
7547 if (print_at)
7548 putchar ('@');
7549 putchar (*q);
7550 print_at = FALSE;
7555 putchar ('\n');
7558 ++p;
7562 /* if-exists built-in spec function.
7564 Checks to see if the file specified by the absolute pathname in
7565 ARGS exists. Returns that pathname if found.
7567 The usual use for this function is to check for a library file
7568 (whose name has been expanded with %s). */
7570 static const char *
7571 if_exists_spec_function (argc, argv)
7572 int argc;
7573 const char **argv;
7575 /* Must have only one argument. */
7576 if (argc == 1 && IS_ABSOLUTE_PATHNAME (argv[0]) && ! access (argv[0], R_OK))
7577 return argv[0];
7579 return NULL;
7582 /* if-exists-else built-in spec function.
7584 This is like if-exists, but takes an additional argument which
7585 is returned if the first argument does not exist. */
7587 static const char *
7588 if_exists_else_spec_function (argc, argv)
7589 int argc;
7590 const char **argv;
7592 /* Must have exactly two arguments. */
7593 if (argc != 2)
7594 return NULL;
7596 if (IS_ABSOLUTE_PATHNAME (argv[0]) && ! access (argv[0], R_OK))
7597 return argv[0];
7599 return argv[1];