* config/i386/uwin.h: Remove SUBTARGET_PROLOGUE.
[official-gcc.git] / gcc / gcc.c
blobe71a0e85f2f861775c98078cf6541ca0bf0618a9
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 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
452 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
453 and -B options) as necessary.
454 %s current argument is the name of a library or startup file of some sort.
455 Search for that file in a standard list of directories
456 and substitute the full name found.
457 %eSTR Print STR as an error message. STR is terminated by a newline.
458 Use this when inconsistent options are detected.
459 %nSTR Print STR as a notice. STR is terminated by a newline.
460 %x{OPTION} Accumulate an option for %X.
461 %X Output the accumulated linker options specified by compilations.
462 %Y Output the accumulated assembler options specified by compilations.
463 %Z Output the accumulated preprocessor options specified by compilations.
464 %a process ASM_SPEC as a spec.
465 This allows config.h to specify part of the spec for running as.
466 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
467 used here. This can be used to run a post-processor after the
468 assembler has done its job.
469 %D Dump out a -L option for each directory in startfile_prefixes.
470 If multilib_dir is set, extra entries are generated with it affixed.
471 %l process LINK_SPEC as a spec.
472 %L process LIB_SPEC as a spec.
473 %G process LIBGCC_SPEC as a spec.
474 %M output multilib_dir with directory separators replaced with "_";
475 if multilib_dir is not set or is ".", output "".
476 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
477 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
478 %C process CPP_SPEC as a spec.
479 %1 process CC1_SPEC as a spec.
480 %2 process CC1PLUS_SPEC as a spec.
481 %* substitute the variable part of a matched option. (See below.)
482 Note that each comma in the substituted string is replaced by
483 a single space.
484 %<S remove all occurrences of -S from the command line.
485 Note - this command is position dependent. % commands in the
486 spec string before this one will see -S, % commands in the
487 spec string after this one will not.
488 %<S* remove all occurrences of all switches beginning with -S from the
489 command line.
490 %:function(args)
491 Call the named function FUNCTION, passing it ARGS. ARGS is
492 first processed as a nested spec string, then split into an
493 argument vector in the usual fashion. The function returns
494 a string which is processed as if it had appeared literally
495 as part of the current spec.
496 %{S} substitutes the -S switch, if that switch was given to CC.
497 If that switch was not specified, this substitutes nothing.
498 Here S is a metasyntactic variable.
499 %{S*} substitutes all the switches specified to CC whose names start
500 with -S. This is used for -o, -I, etc; switches that take
501 arguments. CC considers `-o foo' as being one switch whose
502 name starts with `o'. %{o*} would substitute this text,
503 including the space; thus, two arguments would be generated.
504 %{S*&T*} likewise, but preserve order of S and T options (the order
505 of S and T in the spec is not significant). Can be any number
506 of ampersand-separated variables; for each the wild card is
507 optional. Useful for CPP as %{D*&U*&A*}.
509 %{S:X} substitutes X, if the -S switch was given to CC.
510 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
511 %{S*:X} substitutes X if one or more switches whose names start
512 with -S was given to CC. Normally X is substituted only
513 once, no matter how many such switches appeared. However,
514 if %* appears somewhere in X, then X will be substituted
515 once for each matching switch, with the %* replaced by the
516 part of that switch that matched the '*'.
517 %{.S:X} substitutes X, if processing a file with suffix S.
518 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
520 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
521 combined with !, ., and * as above binding stronger than the OR.
522 If %* appears in X, all of the alternatives must be starred, and
523 only the first matching alternative is substituted.
524 %{S:X; if S was given to CC, substitutes X;
525 T:Y; else if T was given to CC, substitutes Y;
526 :D} else substitutes D. There can be as many clauses as you need.
527 This may be combined with ., !, |, and * as above.
529 %(Spec) processes a specification defined in a specs file as *Spec:
530 %[Spec] as above, but put __ around -D arguments
532 The conditional text X in a %{S:X} or similar construct may contain
533 other nested % constructs or spaces, or even newlines. They are
534 processed as usual, as described above. Trailing white space in X is
535 ignored. White space may also appear anywhere on the left side of the
536 colon in these constructs, except between . or * and the corresponding
537 word.
539 The -O, -f, -m, and -W switches are handled specifically in these
540 constructs. If another value of -O or the negated form of a -f, -m, or
541 -W switch is found later in the command line, the earlier switch
542 value is ignored, except with {S*} where S is just one letter; this
543 passes all matching options.
545 The character | at the beginning of the predicate text is used to indicate
546 that a command should be piped to the following command, but only if -pipe
547 is specified.
549 Note that it is built into CC which switches take arguments and which
550 do not. You might think it would be useful to generalize this to
551 allow each compiler's spec to say which switches take arguments. But
552 this cannot be done in a consistent fashion. CC cannot even decide
553 which input files have been specified without knowing which switches
554 take arguments, and it must know which input files to compile in order
555 to tell which compilers to run.
557 CC also knows implicitly that arguments starting in `-l' are to be
558 treated as compiler output files, and passed to the linker in their
559 proper position among the other output files. */
561 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
563 /* config.h can define ASM_SPEC to provide extra args to the assembler
564 or extra switch-translations. */
565 #ifndef ASM_SPEC
566 #define ASM_SPEC ""
567 #endif
569 /* config.h can define ASM_FINAL_SPEC to run a post processor after
570 the assembler has run. */
571 #ifndef ASM_FINAL_SPEC
572 #define ASM_FINAL_SPEC ""
573 #endif
575 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
576 or extra switch-translations. */
577 #ifndef CPP_SPEC
578 #define CPP_SPEC ""
579 #endif
581 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
582 or extra switch-translations. */
583 #ifndef CC1_SPEC
584 #define CC1_SPEC ""
585 #endif
587 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
588 or extra switch-translations. */
589 #ifndef CC1PLUS_SPEC
590 #define CC1PLUS_SPEC ""
591 #endif
593 /* config.h can define LINK_SPEC to provide extra args to the linker
594 or extra switch-translations. */
595 #ifndef LINK_SPEC
596 #define LINK_SPEC ""
597 #endif
599 /* config.h can define LIB_SPEC to override the default libraries. */
600 #ifndef LIB_SPEC
601 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
602 #endif
604 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
605 included. */
606 #ifndef LIBGCC_SPEC
607 #if defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
608 /* Have gcc do the search for libgcc.a. */
609 #define LIBGCC_SPEC "libgcc.a%s"
610 #else
611 #define LIBGCC_SPEC "-lgcc"
612 #endif
613 #endif
615 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
616 #ifndef STARTFILE_SPEC
617 #define STARTFILE_SPEC \
618 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
619 #endif
621 /* config.h can define SWITCHES_NEED_SPACES to control which options
622 require spaces between the option and the argument. */
623 #ifndef SWITCHES_NEED_SPACES
624 #define SWITCHES_NEED_SPACES ""
625 #endif
627 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
628 #ifndef ENDFILE_SPEC
629 #define ENDFILE_SPEC ""
630 #endif
632 #ifndef LINKER_NAME
633 #define LINKER_NAME "collect2"
634 #endif
636 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
637 to the assembler. */
638 #ifndef ASM_DEBUG_SPEC
639 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
640 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
641 # define ASM_DEBUG_SPEC \
642 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
643 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
644 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
645 # else
646 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
647 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
648 # endif
649 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
650 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
651 # endif
652 # endif
653 #endif
654 #ifndef ASM_DEBUG_SPEC
655 # define ASM_DEBUG_SPEC ""
656 #endif
658 /* Here is the spec for running the linker, after compiling all files. */
660 /* This is overridable by the target in case they need to specify the
661 -lgcc and -lc order specially, yet not require them to override all
662 of LINK_COMMAND_SPEC. */
663 #ifndef LINK_GCC_C_SEQUENCE_SPEC
664 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
665 #endif
667 #ifndef LINK_PIE_SPEC
668 #ifdef HAVE_LD_PIE
669 #define LINK_PIE_SPEC "%{pie:-pie} "
670 #else
671 #define LINK_PIE_SPEC "%{pie:} "
672 #endif
673 #endif
675 /* -u* was put back because both BSD and SysV seem to support it. */
676 /* %{static:} simply prevents an error message if the target machine
677 doesn't handle -static. */
678 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
679 scripts which exist in user specified directories, or in standard
680 directories. */
681 #ifndef LINK_COMMAND_SPEC
682 #define LINK_COMMAND_SPEC "\
683 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
684 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
685 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
686 %{static:} %{L*} %(link_libgcc) %o %{fprofile-arcs:-lgcov}\
687 %{!nostdlib:%{!nodefaultlibs:%(link_gcc_c_sequence)}}\
688 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
689 #endif
691 #ifndef LINK_LIBGCC_SPEC
692 # ifdef LINK_LIBGCC_SPECIAL
693 /* Don't generate -L options for startfile prefix list. */
694 # define LINK_LIBGCC_SPEC ""
695 # else
696 /* Do generate them. */
697 # define LINK_LIBGCC_SPEC "%D"
698 # endif
699 #endif
701 #ifndef STARTFILE_PREFIX_SPEC
702 # define STARTFILE_PREFIX_SPEC ""
703 #endif
705 static const char *asm_debug;
706 static const char *cpp_spec = CPP_SPEC;
707 static const char *cc1_spec = CC1_SPEC;
708 static const char *cc1plus_spec = CC1PLUS_SPEC;
709 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
710 static const char *asm_spec = ASM_SPEC;
711 static const char *asm_final_spec = ASM_FINAL_SPEC;
712 static const char *link_spec = LINK_SPEC;
713 static const char *lib_spec = LIB_SPEC;
714 static const char *libgcc_spec = LIBGCC_SPEC;
715 static const char *endfile_spec = ENDFILE_SPEC;
716 static const char *startfile_spec = STARTFILE_SPEC;
717 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
718 static const char *linker_name_spec = LINKER_NAME;
719 static const char *link_command_spec = LINK_COMMAND_SPEC;
720 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
721 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
723 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
724 There should be no need to override these in target dependent files,
725 but we need to copy them to the specs file so that newer versions
726 of the GCC driver can correctly drive older tool chains with the
727 appropriate -B options. */
729 /* When cpplib handles traditional preprocessing, get rid of this, and
730 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
731 that we default the front end language better. */
732 static const char *trad_capable_cpp =
733 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
735 /* We don't wrap .d files in %W{} since a missing .d file, and
736 therefore no dependency entry, confuses make into thinking a .o
737 file that happens to exist is up-to-date. */
738 static const char *cpp_unique_options =
739 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
740 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*} %{P} %I\
741 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
742 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
743 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
744 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
745 %{trigraphs} %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
746 %{E|M|MM:%W{o*}}";
748 /* This contains cpp options which are common with cc1_options and are passed
749 only when preprocessing only to avoid duplication. We pass the cc1 spec
750 options to the preprocessor so that it the cc1 spec may manipulate
751 options used to set target flags. Those special target flags settings may
752 in turn cause preprocessor symbols to be defined specially. */
753 static const char *cpp_options =
754 "%(cpp_unique_options) %1 %{m*} %{std*} %{ansi} %{W*&pedantic*} %{w} %{f*}\
755 %{O*} %{undef}";
757 /* This contains cpp options which are not passed when the preprocessor
758 output will be used by another program. */
759 static const char *cpp_debug_options = "%{d*}";
761 /* NB: This is shared amongst all front-ends. */
762 static const char *cc1_options =
763 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
764 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
765 -auxbase%{c|S:%{o*:-strip %*}%{!o*: %b}}%{!c:%{!S: %b}}\
766 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*} %{ansi}\
767 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
768 %{Qn:-fno-ident} %{--help:--help}\
769 %{--target-help:--target-help}\
770 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
771 %{fsyntax-only:-o %j} %{-param*}";
773 static const char *asm_options =
774 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
776 static const char *invoke_as =
777 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
778 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
779 #else
780 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
781 #endif
783 /* Some compilers have limits on line lengths, and the multilib_select
784 and/or multilib_matches strings can be very long, so we build them at
785 run time. */
786 static struct obstack multilib_obstack;
787 static const char *multilib_select;
788 static const char *multilib_matches;
789 static const char *multilib_defaults;
790 static const char *multilib_exclusions;
791 #include "multilib.h"
793 /* Check whether a particular argument is a default argument. */
795 #ifndef MULTILIB_DEFAULTS
796 #define MULTILIB_DEFAULTS { "" }
797 #endif
799 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
801 #ifndef DRIVER_SELF_SPECS
802 #define DRIVER_SELF_SPECS ""
803 #endif
805 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
807 struct user_specs
809 struct user_specs *next;
810 const char *filename;
813 static struct user_specs *user_specs_head, *user_specs_tail;
815 #ifndef SWITCH_TAKES_ARG
816 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
817 #endif
819 #ifndef WORD_SWITCH_TAKES_ARG
820 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
821 #endif
823 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
824 /* This defines which switches stop a full compilation. */
825 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
826 ((CHAR) == 'c' || (CHAR) == 'S')
828 #ifndef SWITCH_CURTAILS_COMPILATION
829 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
830 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
831 #endif
832 #endif
834 /* Record the mapping from file suffixes for compilation specs. */
836 struct compiler
838 const char *suffix; /* Use this compiler for input files
839 whose names end in this suffix. */
841 const char *spec; /* To use this compiler, run this spec. */
843 const char *cpp_spec; /* If non-NULL, substitute this spec
844 for `%C', rather than the usual
845 cpp_spec. */
848 /* Pointer to a vector of `struct compiler' that gives the spec for
849 compiling a file, based on its suffix.
850 A file that does not end in any of these suffixes will be passed
851 unchanged to the loader and nothing else will be done to it.
853 An entry containing two 0s is used to terminate the vector.
855 If multiple entries match a file, the last matching one is used. */
857 static struct compiler *compilers;
859 /* Number of entries in `compilers', not counting the null terminator. */
861 static int n_compilers;
863 /* The default list of file name suffixes and their compilation specs. */
865 static const struct compiler default_compilers[] =
867 /* Add lists of suffixes of known languages here. If those languages
868 were not present when we built the driver, we will hit these copies
869 and be given a more meaningful error than "file not used since
870 linking is not done". */
871 {".m", "#Objective-C", 0}, {".mi", "#Objective-C", 0},
872 {".cc", "#C++", 0}, {".cxx", "#C++", 0}, {".cpp", "#C++", 0},
873 {".cp", "#C++", 0}, {".c++", "#C++", 0}, {".C", "#C++", 0},
874 {".CPP", "#C++", 0}, {".ii", "#C++", 0},
875 {".ads", "#Ada", 0}, {".adb", "#Ada", 0},
876 {".f", "#Fortran", 0}, {".for", "#Fortran", 0}, {".fpp", "#Fortran", 0},
877 {".F", "#Fortran", 0}, {".FOR", "#Fortran", 0}, {".FPP", "#Fortran", 0},
878 {".r", "#Ratfor", 0},
879 {".p", "#Pascal", 0}, {".pas", "#Pascal", 0},
880 {".java", "#Java", 0}, {".class", "#Java", 0},
881 {".zip", "#Java", 0}, {".jar", "#Java", 0},
882 /* Next come the entries for C. */
883 {".c", "@c", 0},
884 {"@c",
885 /* cc1 has an integrated ISO C preprocessor. We should invoke the
886 external preprocessor if -save-temps is given. */
887 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
888 %{!E:%{!M:%{!MM:\
889 %{traditional|ftraditional:\
890 %eGNU C no longer supports -traditional without -E}\
891 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
892 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
893 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
894 %(cc1_options)}\
895 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
896 cc1 %(cpp_unique_options) %(cc1_options)}}}\
897 %{!fsyntax-only:%(invoke_as)}}}}", 0},
898 {"-",
899 "%{!E:%e-E required when input is from standard input}\
900 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0},
901 {".h", "@c-header", 0},
902 {"@c-header",
903 /* cc1 has an integrated ISO C preprocessor. We should invoke the
904 external preprocessor if -save-temps is given. */
905 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
906 %{!E:%{!M:%{!MM:\
907 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
908 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
909 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
910 %(cc1_options)\
911 -o %g.s %{!o*:--output-pch=%i.gch}\
912 %W{o*:--output-pch=%*}%V}\
913 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
914 cc1 %(cpp_unique_options) %(cc1_options)\
915 -o %g.s %{!o*:--output-pch=%i.gch}\
916 %W{o*:--output-pch=%*}%V}}}}}}", 0},
917 {".i", "@cpp-output", 0},
918 {"@cpp-output",
919 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0},
920 {".s", "@assembler", 0},
921 {"@assembler",
922 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0},
923 {".S", "@assembler-with-cpp", 0},
924 {"@assembler-with-cpp",
925 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
926 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
927 %{E|M|MM:%(cpp_debug_options)}\
928 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
929 as %(asm_debug) %(asm_options) %|.s %A }}}}"
930 #else
931 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
932 %{E|M|MM:%(cpp_debug_options)}\
933 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
934 as %(asm_debug) %(asm_options) %m.s %A }}}}"
935 #endif
936 , 0},
938 #include "specs.h"
939 /* Mark end of table */
940 {0, 0, 0}
943 /* Number of elements in default_compilers, not counting the terminator. */
945 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
947 /* A vector of options to give to the linker.
948 These options are accumulated by %x,
949 and substituted into the linker command with %X. */
950 static int n_linker_options;
951 static char **linker_options;
953 /* A vector of options to give to the assembler.
954 These options are accumulated by -Wa,
955 and substituted into the assembler command with %Y. */
956 static int n_assembler_options;
957 static char **assembler_options;
959 /* A vector of options to give to the preprocessor.
960 These options are accumulated by -Wp,
961 and substituted into the preprocessor command with %Z. */
962 static int n_preprocessor_options;
963 static char **preprocessor_options;
965 /* Define how to map long options into short ones. */
967 /* This structure describes one mapping. */
968 struct option_map
970 /* The long option's name. */
971 const char *const name;
972 /* The equivalent short option. */
973 const char *const equivalent;
974 /* Argument info. A string of flag chars; NULL equals no options.
975 a => argument required.
976 o => argument optional.
977 j => join argument to equivalent, making one word.
978 * => require other text after NAME as an argument. */
979 const char *const arg_info;
982 /* This is the table of mappings. Mappings are tried sequentially
983 for each option encountered; the first one that matches, wins. */
985 static const struct option_map option_map[] =
987 {"--all-warnings", "-Wall", 0},
988 {"--ansi", "-ansi", 0},
989 {"--assemble", "-S", 0},
990 {"--assert", "-A", "a"},
991 {"--classpath", "-fclasspath=", "aj"},
992 {"--bootclasspath", "-fbootclasspath=", "aj"},
993 {"--CLASSPATH", "-fclasspath=", "aj"},
994 {"--comments", "-C", 0},
995 {"--comments-in-macros", "-CC", 0},
996 {"--compile", "-c", 0},
997 {"--debug", "-g", "oj"},
998 {"--define-macro", "-D", "aj"},
999 {"--dependencies", "-M", 0},
1000 {"--dump", "-d", "a"},
1001 {"--dumpbase", "-dumpbase", "a"},
1002 {"--entry", "-e", 0},
1003 {"--extra-warnings", "-W", 0},
1004 {"--for-assembler", "-Wa", "a"},
1005 {"--for-linker", "-Xlinker", "a"},
1006 {"--force-link", "-u", "a"},
1007 {"--imacros", "-imacros", "a"},
1008 {"--include", "-include", "a"},
1009 {"--include-barrier", "-I-", 0},
1010 {"--include-directory", "-I", "aj"},
1011 {"--include-directory-after", "-idirafter", "a"},
1012 {"--include-prefix", "-iprefix", "a"},
1013 {"--include-with-prefix", "-iwithprefix", "a"},
1014 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1015 {"--include-with-prefix-after", "-iwithprefix", "a"},
1016 {"--language", "-x", "a"},
1017 {"--library-directory", "-L", "a"},
1018 {"--machine", "-m", "aj"},
1019 {"--machine-", "-m", "*j"},
1020 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1021 {"--no-line-commands", "-P", 0},
1022 {"--no-precompiled-includes", "-noprecomp", 0},
1023 {"--no-standard-includes", "-nostdinc", 0},
1024 {"--no-standard-libraries", "-nostdlib", 0},
1025 {"--no-warnings", "-w", 0},
1026 {"--optimize", "-O", "oj"},
1027 {"--output", "-o", "a"},
1028 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1029 {"--param", "--param", "a"},
1030 {"--pedantic", "-pedantic", 0},
1031 {"--pedantic-errors", "-pedantic-errors", 0},
1032 {"--pie", "-pie", 0},
1033 {"--pipe", "-pipe", 0},
1034 {"--prefix", "-B", "a"},
1035 {"--preprocess", "-E", 0},
1036 {"--print-search-dirs", "-print-search-dirs", 0},
1037 {"--print-file-name", "-print-file-name=", "aj"},
1038 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1039 {"--print-missing-file-dependencies", "-MG", 0},
1040 {"--print-multi-lib", "-print-multi-lib", 0},
1041 {"--print-multi-directory", "-print-multi-directory", 0},
1042 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1043 {"--print-prog-name", "-print-prog-name=", "aj"},
1044 {"--profile", "-p", 0},
1045 {"--profile-blocks", "-a", 0},
1046 {"--quiet", "-q", 0},
1047 {"--resource", "-fcompile-resource=", "aj"},
1048 {"--save-temps", "-save-temps", 0},
1049 {"--shared", "-shared", 0},
1050 {"--silent", "-q", 0},
1051 {"--specs", "-specs=", "aj"},
1052 {"--static", "-static", 0},
1053 {"--std", "-std=", "aj"},
1054 {"--symbolic", "-symbolic", 0},
1055 {"--target", "-b", "a"},
1056 {"--time", "-time", 0},
1057 {"--trace-includes", "-H", 0},
1058 {"--traditional", "-traditional", 0},
1059 {"--traditional-cpp", "-traditional-cpp", 0},
1060 {"--trigraphs", "-trigraphs", 0},
1061 {"--undefine-macro", "-U", "aj"},
1062 {"--use-version", "-V", "a"},
1063 {"--user-dependencies", "-MM", 0},
1064 {"--verbose", "-v", 0},
1065 {"--warn-", "-W", "*j"},
1066 {"--write-dependencies", "-MD", 0},
1067 {"--write-user-dependencies", "-MMD", 0},
1068 {"--", "-f", "*j"}
1072 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1073 static const struct {
1074 const char *const option_found;
1075 const char *const replacements;
1076 } target_option_translations[] =
1078 TARGET_OPTION_TRANSLATE_TABLE,
1079 { 0, 0 }
1081 #endif
1083 /* Translate the options described by *ARGCP and *ARGVP.
1084 Make a new vector and store it back in *ARGVP,
1085 and store its length in *ARGVC. */
1087 static void
1088 translate_options (argcp, argvp)
1089 int *argcp;
1090 const char *const **argvp;
1092 int i;
1093 int argc = *argcp;
1094 const char *const *argv = *argvp;
1095 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1096 const char **newv =
1097 (const char **) xmalloc (newvsize);
1098 int newindex = 0;
1100 i = 0;
1101 newv[newindex++] = argv[i++];
1103 while (i < argc)
1105 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1106 int tott_idx;
1108 for (tott_idx = 0;
1109 target_option_translations[tott_idx].option_found;
1110 tott_idx++)
1112 if (strcmp (target_option_translations[tott_idx].option_found,
1113 argv[i]) == 0)
1115 int spaces = 1;
1116 const char *sp;
1117 char *np;
1119 for (sp = target_option_translations[tott_idx].replacements;
1120 *sp; sp++)
1122 if (*sp == ' ')
1123 spaces ++;
1126 newvsize += spaces * sizeof (const char *);
1127 newv = (const char **) xrealloc (newv, newvsize);
1129 sp = target_option_translations[tott_idx].replacements;
1130 np = xstrdup (sp);
1132 while (1)
1134 while (*np == ' ')
1135 np++;
1136 if (*np == 0)
1137 break;
1138 newv[newindex++] = np;
1139 while (*np != ' ' && *np)
1140 np++;
1141 if (*np == 0)
1142 break;
1143 *np++ = 0;
1146 i ++;
1147 break;
1150 if (target_option_translations[tott_idx].option_found)
1151 continue;
1152 #endif
1154 /* Translate -- options. */
1155 if (argv[i][0] == '-' && argv[i][1] == '-')
1157 size_t j;
1158 /* Find a mapping that applies to this option. */
1159 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1161 size_t optlen = strlen (option_map[j].name);
1162 size_t arglen = strlen (argv[i]);
1163 size_t complen = arglen > optlen ? optlen : arglen;
1164 const char *arginfo = option_map[j].arg_info;
1166 if (arginfo == 0)
1167 arginfo = "";
1169 if (!strncmp (argv[i], option_map[j].name, complen))
1171 const char *arg = 0;
1173 if (arglen < optlen)
1175 size_t k;
1176 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1177 if (strlen (option_map[k].name) >= arglen
1178 && !strncmp (argv[i], option_map[k].name, arglen))
1180 error ("ambiguous abbreviation %s", argv[i]);
1181 break;
1184 if (k != ARRAY_SIZE (option_map))
1185 break;
1188 if (arglen > optlen)
1190 /* If the option has an argument, accept that. */
1191 if (argv[i][optlen] == '=')
1192 arg = argv[i] + optlen + 1;
1194 /* If this mapping requires extra text at end of name,
1195 accept that as "argument". */
1196 else if (strchr (arginfo, '*') != 0)
1197 arg = argv[i] + optlen;
1199 /* Otherwise, extra text at end means mismatch.
1200 Try other mappings. */
1201 else
1202 continue;
1205 else if (strchr (arginfo, '*') != 0)
1207 error ("incomplete `%s' option", option_map[j].name);
1208 break;
1211 /* Handle arguments. */
1212 if (strchr (arginfo, 'a') != 0)
1214 if (arg == 0)
1216 if (i + 1 == argc)
1218 error ("missing argument to `%s' option",
1219 option_map[j].name);
1220 break;
1223 arg = argv[++i];
1226 else if (strchr (arginfo, '*') != 0)
1228 else if (strchr (arginfo, 'o') == 0)
1230 if (arg != 0)
1231 error ("extraneous argument to `%s' option",
1232 option_map[j].name);
1233 arg = 0;
1236 /* Store the translation as one argv elt or as two. */
1237 if (arg != 0 && strchr (arginfo, 'j') != 0)
1238 newv[newindex++] = concat (option_map[j].equivalent, arg,
1239 NULL);
1240 else if (arg != 0)
1242 newv[newindex++] = option_map[j].equivalent;
1243 newv[newindex++] = arg;
1245 else
1246 newv[newindex++] = option_map[j].equivalent;
1248 break;
1251 i++;
1254 /* Handle old-fashioned options--just copy them through,
1255 with their arguments. */
1256 else if (argv[i][0] == '-')
1258 const char *p = argv[i] + 1;
1259 int c = *p;
1260 int nskip = 1;
1262 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1263 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1264 else if (WORD_SWITCH_TAKES_ARG (p))
1265 nskip += WORD_SWITCH_TAKES_ARG (p);
1266 else if ((c == 'B' || c == 'b' || c == 'x')
1267 && p[1] == 0)
1268 nskip += 1;
1269 else if (! strcmp (p, "Xlinker"))
1270 nskip += 1;
1271 else if (! strcmp (p, "Xpreprocessor"))
1272 nskip += 1;
1273 else if (! strcmp (p, "Xassembler"))
1274 nskip += 1;
1276 /* Watch out for an option at the end of the command line that
1277 is missing arguments, and avoid skipping past the end of the
1278 command line. */
1279 if (nskip + i > argc)
1280 nskip = argc - i;
1282 while (nskip > 0)
1284 newv[newindex++] = argv[i++];
1285 nskip--;
1288 else
1289 /* Ordinary operands, or +e options. */
1290 newv[newindex++] = argv[i++];
1293 newv[newindex] = 0;
1295 *argvp = newv;
1296 *argcp = newindex;
1299 static char *
1300 skip_whitespace (p)
1301 char *p;
1303 while (1)
1305 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1306 be considered whitespace. */
1307 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1308 return p + 1;
1309 else if (*p == '\n' || *p == ' ' || *p == '\t')
1310 p++;
1311 else if (*p == '#')
1313 while (*p != '\n')
1314 p++;
1315 p++;
1317 else
1318 break;
1321 return p;
1323 /* Structures to keep track of prefixes to try when looking for files. */
1325 struct prefix_list
1327 const char *prefix; /* String to prepend to the path. */
1328 struct prefix_list *next; /* Next in linked list. */
1329 int require_machine_suffix; /* Don't use without machine_suffix. */
1330 /* 2 means try both machine_suffix and just_machine_suffix. */
1331 int *used_flag_ptr; /* 1 if a file was found with this prefix. */
1332 int priority; /* Sort key - priority within list. */
1333 int os_multilib; /* 1 if OS multilib scheme should be used,
1334 0 for GCC multilib scheme. */
1337 struct path_prefix
1339 struct prefix_list *plist; /* List of prefixes to try */
1340 int max_len; /* Max length of a prefix in PLIST */
1341 const char *name; /* Name of this list (used in config stuff) */
1344 /* List of prefixes to try when looking for executables. */
1346 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1348 /* List of prefixes to try when looking for startup (crt0) files. */
1350 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1352 /* List of prefixes to try when looking for include files. */
1354 static struct path_prefix include_prefixes = { 0, 0, "include" };
1356 /* Suffix to attach to directories searched for commands.
1357 This looks like `MACHINE/VERSION/'. */
1359 static const char *machine_suffix = 0;
1361 /* Suffix to attach to directories searched for commands.
1362 This is just `MACHINE/'. */
1364 static const char *just_machine_suffix = 0;
1366 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1368 static const char *gcc_exec_prefix;
1370 /* Default prefixes to attach to command names. */
1372 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1373 #undef MD_EXEC_PREFIX
1374 #undef MD_STARTFILE_PREFIX
1375 #undef MD_STARTFILE_PREFIX_1
1376 #endif
1378 /* If no prefixes defined, use the null string, which will disable them. */
1379 #ifndef MD_EXEC_PREFIX
1380 #define MD_EXEC_PREFIX ""
1381 #endif
1382 #ifndef MD_STARTFILE_PREFIX
1383 #define MD_STARTFILE_PREFIX ""
1384 #endif
1385 #ifndef MD_STARTFILE_PREFIX_1
1386 #define MD_STARTFILE_PREFIX_1 ""
1387 #endif
1389 /* Supply defaults for the standard prefixes. */
1391 #ifndef STANDARD_EXEC_PREFIX
1392 #define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
1393 #endif
1394 #ifndef STANDARD_STARTFILE_PREFIX
1395 #define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
1396 #endif
1397 #ifndef TOOLDIR_BASE_PREFIX
1398 #define TOOLDIR_BASE_PREFIX "/usr/local/"
1399 #endif
1400 #ifndef STANDARD_BINDIR_PREFIX
1401 #define STANDARD_BINDIR_PREFIX "/usr/local/bin"
1402 #endif
1404 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1405 static const char *const standard_exec_prefix_1 = "/usr/lib/gcc/";
1406 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1408 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1409 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1410 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1411 static const char *const standard_startfile_prefix_1 = "/lib/";
1412 static const char *const standard_startfile_prefix_2 = "/usr/lib/";
1414 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1415 static const char *tooldir_prefix;
1417 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1419 /* Subdirectory to use for locating libraries. Set by
1420 set_multilib_dir based on the compilation options. */
1422 static const char *multilib_dir;
1424 /* Subdirectory to use for locating libraries in OS conventions. Set by
1425 set_multilib_dir based on the compilation options. */
1427 static const char *multilib_os_dir;
1429 /* Structure to keep track of the specs that have been defined so far.
1430 These are accessed using %(specname) or %[specname] in a compiler
1431 or link spec. */
1433 struct spec_list
1435 /* The following 2 fields must be first */
1436 /* to allow EXTRA_SPECS to be initialized */
1437 const char *name; /* name of the spec. */
1438 const char *ptr; /* available ptr if no static pointer */
1440 /* The following fields are not initialized */
1441 /* by EXTRA_SPECS */
1442 const char **ptr_spec; /* pointer to the spec itself. */
1443 struct spec_list *next; /* Next spec in linked list. */
1444 int name_len; /* length of the name */
1445 int alloc_p; /* whether string was allocated */
1448 #define INIT_STATIC_SPEC(NAME,PTR) \
1449 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1451 /* List of statically defined specs. */
1452 static struct spec_list static_specs[] =
1454 INIT_STATIC_SPEC ("asm", &asm_spec),
1455 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1456 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1457 INIT_STATIC_SPEC ("asm_options", &asm_options),
1458 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1459 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1460 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1461 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1462 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1463 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1464 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1465 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1466 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1467 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1468 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1469 INIT_STATIC_SPEC ("link", &link_spec),
1470 INIT_STATIC_SPEC ("lib", &lib_spec),
1471 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1472 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1473 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1474 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1475 INIT_STATIC_SPEC ("version", &compiler_version),
1476 INIT_STATIC_SPEC ("multilib", &multilib_select),
1477 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1478 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1479 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1480 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1481 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1482 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1483 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1484 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1485 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1486 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1487 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1490 #ifdef EXTRA_SPECS /* additional specs needed */
1491 /* Structure to keep track of just the first two args of a spec_list.
1492 That is all that the EXTRA_SPECS macro gives us. */
1493 struct spec_list_1
1495 const char *const name;
1496 const char *const ptr;
1499 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1500 static struct spec_list *extra_specs = (struct spec_list *) 0;
1501 #endif
1503 /* List of dynamically allocates specs that have been defined so far. */
1505 static struct spec_list *specs = (struct spec_list *) 0;
1507 /* List of static spec functions. */
1509 static const struct spec_function static_spec_functions[] =
1511 { "if-exists", if_exists_spec_function },
1512 { "if-exists-else", if_exists_else_spec_function },
1513 { 0, 0 }
1516 static int processing_spec_function;
1518 /* Add appropriate libgcc specs to OBSTACK, taking into account
1519 various permutations of -shared-libgcc, -shared, and such. */
1521 #ifdef ENABLE_SHARED_LIBGCC
1522 static void
1523 init_gcc_specs (obstack, shared_name, static_name, eh_name)
1524 struct obstack *obstack;
1525 const char *shared_name;
1526 const char *static_name;
1527 const char *eh_name;
1529 char *buf;
1531 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1532 "}%{!static:%{!static-libgcc:",
1533 "%{!shared:%{!shared-libgcc:", static_name, " ",
1534 eh_name, "}%{shared-libgcc:", shared_name, " ",
1535 static_name, "}}%{shared:",
1536 #ifdef LINK_EH_SPEC
1537 "%{shared-libgcc:", shared_name,
1538 "}%{!shared-libgcc:", static_name, "}",
1539 #else
1540 shared_name,
1541 #endif
1542 "}}}", NULL);
1544 obstack_grow (obstack, buf, strlen (buf));
1545 free (buf);
1547 #endif /* ENABLE_SHARED_LIBGCC */
1549 /* Initialize the specs lookup routines. */
1551 static void
1552 init_spec ()
1554 struct spec_list *next = (struct spec_list *) 0;
1555 struct spec_list *sl = (struct spec_list *) 0;
1556 int i;
1558 if (specs)
1559 return; /* Already initialized. */
1561 if (verbose_flag)
1562 notice ("Using built-in specs.\n");
1564 #ifdef EXTRA_SPECS
1565 extra_specs = (struct spec_list *)
1566 xcalloc (sizeof (struct spec_list), ARRAY_SIZE (extra_specs_1));
1568 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1570 sl = &extra_specs[i];
1571 sl->name = extra_specs_1[i].name;
1572 sl->ptr = extra_specs_1[i].ptr;
1573 sl->next = next;
1574 sl->name_len = strlen (sl->name);
1575 sl->ptr_spec = &sl->ptr;
1576 next = sl;
1578 #endif
1580 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1581 on ?: in file-scope variable initializations. */
1582 asm_debug = ASM_DEBUG_SPEC;
1584 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1586 sl = &static_specs[i];
1587 sl->next = next;
1588 next = sl;
1591 #ifdef ENABLE_SHARED_LIBGCC
1592 /* ??? If neither -shared-libgcc nor --static-libgcc was
1593 seen, then we should be making an educated guess. Some proposed
1594 heuristics for ELF include:
1596 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1597 program will be doing dynamic loading, which will likely
1598 need the shared libgcc.
1600 (2) If "-ldl", then it's also a fair bet that we're doing
1601 dynamic loading.
1603 (3) For each ET_DYN we're linking against (either through -lfoo
1604 or /some/path/foo.so), check to see whether it or one of
1605 its dependencies depends on a shared libgcc.
1607 (4) If "-shared"
1609 If the runtime is fixed to look for program headers instead
1610 of calling __register_frame_info at all, for each object,
1611 use the shared libgcc if any EH symbol referenced.
1613 If crtstuff is fixed to not invoke __register_frame_info
1614 automatically, for each object, use the shared libgcc if
1615 any non-empty unwind section found.
1617 Doing any of this probably requires invoking an external program to
1618 do the actual object file scanning. */
1620 const char *p = libgcc_spec;
1621 int in_sep = 1;
1623 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1624 when given the proper command line arguments. */
1625 while (*p)
1627 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1629 init_gcc_specs (&obstack,
1630 #ifdef NO_SHARED_LIBGCC_MULTILIB
1631 "-lgcc_s"
1632 #else
1633 "-lgcc_s%M"
1634 #endif
1635 #ifdef USE_LIBUNWIND_EXCEPTIONS
1636 " -lunwind"
1637 #endif
1639 "-lgcc",
1640 "-lgcc_eh");
1641 p += 5;
1642 in_sep = 0;
1644 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1646 /* Ug. We don't know shared library extensions. Hope that
1647 systems that use this form don't do shared libraries. */
1648 init_gcc_specs (&obstack,
1649 #ifdef NO_SHARED_LIBGCC_MULTILIB
1650 "-lgcc_s"
1651 #else
1652 "-lgcc_s%M"
1653 #endif
1655 "libgcc.a%s",
1656 "libgcc_eh.a%s");
1657 p += 10;
1658 in_sep = 0;
1660 else
1662 obstack_1grow (&obstack, *p);
1663 in_sep = (*p == ' ');
1664 p += 1;
1668 obstack_1grow (&obstack, '\0');
1669 libgcc_spec = obstack_finish (&obstack);
1671 #endif
1672 #ifdef USE_AS_TRADITIONAL_FORMAT
1673 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1675 static const char tf[] = "--traditional-format ";
1676 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1677 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1678 asm_spec = obstack_finish (&obstack);
1680 #endif
1681 #ifdef LINK_EH_SPEC
1682 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1683 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1684 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1685 link_spec = obstack_finish (&obstack);
1686 #endif
1688 specs = sl;
1691 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1692 removed; If the spec starts with a + then SPEC is added to the end of the
1693 current spec. */
1695 static void
1696 set_spec (name, spec)
1697 const char *name;
1698 const char *spec;
1700 struct spec_list *sl;
1701 const char *old_spec;
1702 int name_len = strlen (name);
1703 int i;
1705 /* If this is the first call, initialize the statically allocated specs. */
1706 if (!specs)
1708 struct spec_list *next = (struct spec_list *) 0;
1709 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1711 sl = &static_specs[i];
1712 sl->next = next;
1713 next = sl;
1715 specs = sl;
1718 /* See if the spec already exists. */
1719 for (sl = specs; sl; sl = sl->next)
1720 if (name_len == sl->name_len && !strcmp (sl->name, name))
1721 break;
1723 if (!sl)
1725 /* Not found - make it. */
1726 sl = (struct spec_list *) xmalloc (sizeof (struct spec_list));
1727 sl->name = xstrdup (name);
1728 sl->name_len = name_len;
1729 sl->ptr_spec = &sl->ptr;
1730 sl->alloc_p = 0;
1731 *(sl->ptr_spec) = "";
1732 sl->next = specs;
1733 specs = sl;
1736 old_spec = *(sl->ptr_spec);
1737 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1738 ? concat (old_spec, spec + 1, NULL)
1739 : xstrdup (spec));
1741 #ifdef DEBUG_SPECS
1742 if (verbose_flag)
1743 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1744 #endif
1746 /* Free the old spec. */
1747 if (old_spec && sl->alloc_p)
1748 free ((PTR) old_spec);
1750 sl->alloc_p = 1;
1753 /* Accumulate a command (program name and args), and run it. */
1755 /* Vector of pointers to arguments in the current line of specifications. */
1757 static const char **argbuf;
1759 /* Number of elements allocated in argbuf. */
1761 static int argbuf_length;
1763 /* Number of elements in argbuf currently in use (containing args). */
1765 static int argbuf_index;
1767 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1768 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1769 it here. */
1771 static struct temp_name {
1772 const char *suffix; /* suffix associated with the code. */
1773 int length; /* strlen (suffix). */
1774 int unique; /* Indicates whether %g or %u/%U was used. */
1775 const char *filename; /* associated filename. */
1776 int filename_length; /* strlen (filename). */
1777 struct temp_name *next;
1778 } *temp_names;
1780 /* Number of commands executed so far. */
1782 static int execution_count;
1784 /* Number of commands that exited with a signal. */
1786 static int signal_count;
1788 /* Name with which this program was invoked. */
1790 static const char *programname;
1792 /* Allocate the argument vector. */
1794 static void
1795 alloc_args ()
1797 argbuf_length = 10;
1798 argbuf = (const char **) xmalloc (argbuf_length * sizeof (const char *));
1801 /* Clear out the vector of arguments (after a command is executed). */
1803 static void
1804 clear_args ()
1806 argbuf_index = 0;
1809 /* Add one argument to the vector at the end.
1810 This is done when a space is seen or at the end of the line.
1811 If DELETE_ALWAYS is nonzero, the arg is a filename
1812 and the file should be deleted eventually.
1813 If DELETE_FAILURE is nonzero, the arg is a filename
1814 and the file should be deleted if this compilation fails. */
1816 static void
1817 store_arg (arg, delete_always, delete_failure)
1818 const char *arg;
1819 int delete_always, delete_failure;
1821 if (argbuf_index + 1 == argbuf_length)
1822 argbuf
1823 = (const char **) xrealloc (argbuf,
1824 (argbuf_length *= 2) * sizeof (const char *));
1826 argbuf[argbuf_index++] = arg;
1827 argbuf[argbuf_index] = 0;
1829 if (delete_always || delete_failure)
1830 record_temp_file (arg, delete_always, delete_failure);
1833 /* Load specs from a file name named FILENAME, replacing occurrences of
1834 various different types of line-endings, \r\n, \n\r and just \r, with
1835 a single \n. */
1837 static char *
1838 load_specs (filename)
1839 const char *filename;
1841 int desc;
1842 int readlen;
1843 struct stat statbuf;
1844 char *buffer;
1845 char *buffer_p;
1846 char *specs;
1847 char *specs_p;
1849 if (verbose_flag)
1850 notice ("Reading specs from %s\n", filename);
1852 /* Open and stat the file. */
1853 desc = open (filename, O_RDONLY, 0);
1854 if (desc < 0)
1855 pfatal_with_name (filename);
1856 if (stat (filename, &statbuf) < 0)
1857 pfatal_with_name (filename);
1859 /* Read contents of file into BUFFER. */
1860 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1861 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1862 if (readlen < 0)
1863 pfatal_with_name (filename);
1864 buffer[readlen] = 0;
1865 close (desc);
1867 specs = xmalloc (readlen + 1);
1868 specs_p = specs;
1869 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1871 int skip = 0;
1872 char c = *buffer_p;
1873 if (c == '\r')
1875 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1876 skip = 1;
1877 else if (*(buffer_p + 1) == '\n') /* \r\n */
1878 skip = 1;
1879 else /* \r */
1880 c = '\n';
1882 if (! skip)
1883 *specs_p++ = c;
1885 *specs_p = '\0';
1887 free (buffer);
1888 return (specs);
1891 /* Read compilation specs from a file named FILENAME,
1892 replacing the default ones.
1894 A suffix which starts with `*' is a definition for
1895 one of the machine-specific sub-specs. The "suffix" should be
1896 *asm, *cc1, *cpp, *link, *startfile, etc.
1897 The corresponding spec is stored in asm_spec, etc.,
1898 rather than in the `compilers' vector.
1900 Anything invalid in the file is a fatal error. */
1902 static void
1903 read_specs (filename, main_p)
1904 const char *filename;
1905 int main_p;
1907 char *buffer;
1908 char *p;
1910 buffer = load_specs (filename);
1912 /* Scan BUFFER for specs, putting them in the vector. */
1913 p = buffer;
1914 while (1)
1916 char *suffix;
1917 char *spec;
1918 char *in, *out, *p1, *p2, *p3;
1920 /* Advance P in BUFFER to the next nonblank nocomment line. */
1921 p = skip_whitespace (p);
1922 if (*p == 0)
1923 break;
1925 /* Is this a special command that starts with '%'? */
1926 /* Don't allow this for the main specs file, since it would
1927 encourage people to overwrite it. */
1928 if (*p == '%' && !main_p)
1930 p1 = p;
1931 while (*p && *p != '\n')
1932 p++;
1934 /* Skip '\n'. */
1935 p++;
1937 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1938 && (p1[sizeof "%include" - 1] == ' '
1939 || p1[sizeof "%include" - 1] == '\t'))
1941 char *new_filename;
1943 p1 += sizeof ("%include");
1944 while (*p1 == ' ' || *p1 == '\t')
1945 p1++;
1947 if (*p1++ != '<' || p[-2] != '>')
1948 fatal ("specs %%include syntax malformed after %ld characters",
1949 (long) (p1 - buffer + 1));
1951 p[-2] = '\0';
1952 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
1953 read_specs (new_filename ? new_filename : p1, FALSE);
1954 continue;
1956 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1957 && (p1[sizeof "%include_noerr" - 1] == ' '
1958 || p1[sizeof "%include_noerr" - 1] == '\t'))
1960 char *new_filename;
1962 p1 += sizeof "%include_noerr";
1963 while (*p1 == ' ' || *p1 == '\t')
1964 p1++;
1966 if (*p1++ != '<' || p[-2] != '>')
1967 fatal ("specs %%include syntax malformed after %ld characters",
1968 (long) (p1 - buffer + 1));
1970 p[-2] = '\0';
1971 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
1972 if (new_filename)
1973 read_specs (new_filename, FALSE);
1974 else if (verbose_flag)
1975 notice ("could not find specs file %s\n", p1);
1976 continue;
1978 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1979 && (p1[sizeof "%rename" - 1] == ' '
1980 || p1[sizeof "%rename" - 1] == '\t'))
1982 int name_len;
1983 struct spec_list *sl;
1984 struct spec_list *newsl;
1986 /* Get original name. */
1987 p1 += sizeof "%rename";
1988 while (*p1 == ' ' || *p1 == '\t')
1989 p1++;
1991 if (! ISALPHA ((unsigned char) *p1))
1992 fatal ("specs %%rename syntax malformed after %ld characters",
1993 (long) (p1 - buffer));
1995 p2 = p1;
1996 while (*p2 && !ISSPACE ((unsigned char) *p2))
1997 p2++;
1999 if (*p2 != ' ' && *p2 != '\t')
2000 fatal ("specs %%rename syntax malformed after %ld characters",
2001 (long) (p2 - buffer));
2003 name_len = p2 - p1;
2004 *p2++ = '\0';
2005 while (*p2 == ' ' || *p2 == '\t')
2006 p2++;
2008 if (! ISALPHA ((unsigned char) *p2))
2009 fatal ("specs %%rename syntax malformed after %ld characters",
2010 (long) (p2 - buffer));
2012 /* Get new spec name. */
2013 p3 = p2;
2014 while (*p3 && !ISSPACE ((unsigned char) *p3))
2015 p3++;
2017 if (p3 != p - 1)
2018 fatal ("specs %%rename syntax malformed after %ld characters",
2019 (long) (p3 - buffer));
2020 *p3 = '\0';
2022 for (sl = specs; sl; sl = sl->next)
2023 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2024 break;
2026 if (!sl)
2027 fatal ("specs %s spec was not found to be renamed", p1);
2029 if (strcmp (p1, p2) == 0)
2030 continue;
2032 for (newsl = specs; newsl; newsl = newsl->next)
2033 if (strcmp (newsl->name, p2) == 0)
2034 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2035 filename, p1, p2);
2037 if (verbose_flag)
2039 notice ("rename spec %s to %s\n", p1, p2);
2040 #ifdef DEBUG_SPECS
2041 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2042 #endif
2045 set_spec (p2, *(sl->ptr_spec));
2046 if (sl->alloc_p)
2047 free ((PTR) *(sl->ptr_spec));
2049 *(sl->ptr_spec) = "";
2050 sl->alloc_p = 0;
2051 continue;
2053 else
2054 fatal ("specs unknown %% command after %ld characters",
2055 (long) (p1 - buffer));
2058 /* Find the colon that should end the suffix. */
2059 p1 = p;
2060 while (*p1 && *p1 != ':' && *p1 != '\n')
2061 p1++;
2063 /* The colon shouldn't be missing. */
2064 if (*p1 != ':')
2065 fatal ("specs file malformed after %ld characters",
2066 (long) (p1 - buffer));
2068 /* Skip back over trailing whitespace. */
2069 p2 = p1;
2070 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2071 p2--;
2073 /* Copy the suffix to a string. */
2074 suffix = save_string (p, p2 - p);
2075 /* Find the next line. */
2076 p = skip_whitespace (p1 + 1);
2077 if (p[1] == 0)
2078 fatal ("specs file malformed after %ld characters",
2079 (long) (p - buffer));
2081 p1 = p;
2082 /* Find next blank line or end of string. */
2083 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2084 p1++;
2086 /* Specs end at the blank line and do not include the newline. */
2087 spec = save_string (p, p1 - p);
2088 p = p1;
2090 /* Delete backslash-newline sequences from the spec. */
2091 in = spec;
2092 out = spec;
2093 while (*in != 0)
2095 if (in[0] == '\\' && in[1] == '\n')
2096 in += 2;
2097 else if (in[0] == '#')
2098 while (*in && *in != '\n')
2099 in++;
2101 else
2102 *out++ = *in++;
2104 *out = 0;
2106 if (suffix[0] == '*')
2108 if (! strcmp (suffix, "*link_command"))
2109 link_command_spec = spec;
2110 else
2111 set_spec (suffix + 1, spec);
2113 else
2115 /* Add this pair to the vector. */
2116 compilers
2117 = ((struct compiler *)
2118 xrealloc (compilers,
2119 (n_compilers + 2) * sizeof (struct compiler)));
2121 compilers[n_compilers].suffix = suffix;
2122 compilers[n_compilers].spec = spec;
2123 n_compilers++;
2124 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2127 if (*suffix == 0)
2128 link_command_spec = spec;
2131 if (link_command_spec == 0)
2132 fatal ("spec file has no spec for linking");
2135 /* Record the names of temporary files we tell compilers to write,
2136 and delete them at the end of the run. */
2138 /* This is the common prefix we use to make temp file names.
2139 It is chosen once for each run of this program.
2140 It is substituted into a spec by %g or %j.
2141 Thus, all temp file names contain this prefix.
2142 In practice, all temp file names start with this prefix.
2144 This prefix comes from the envvar TMPDIR if it is defined;
2145 otherwise, from the P_tmpdir macro if that is defined;
2146 otherwise, in /usr/tmp or /tmp;
2147 or finally the current directory if all else fails. */
2149 static const char *temp_filename;
2151 /* Length of the prefix. */
2153 static int temp_filename_length;
2155 /* Define the list of temporary files to delete. */
2157 struct temp_file
2159 const char *name;
2160 struct temp_file *next;
2163 /* Queue of files to delete on success or failure of compilation. */
2164 static struct temp_file *always_delete_queue;
2165 /* Queue of files to delete on failure of compilation. */
2166 static struct temp_file *failure_delete_queue;
2168 /* Record FILENAME as a file to be deleted automatically.
2169 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2170 otherwise delete it in any case.
2171 FAIL_DELETE nonzero means delete it if a compilation step fails;
2172 otherwise delete it in any case. */
2174 void
2175 record_temp_file (filename, always_delete, fail_delete)
2176 const char *filename;
2177 int always_delete;
2178 int fail_delete;
2180 char *const name = xstrdup (filename);
2182 if (always_delete)
2184 struct temp_file *temp;
2185 for (temp = always_delete_queue; temp; temp = temp->next)
2186 if (! strcmp (name, temp->name))
2187 goto already1;
2189 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2190 temp->next = always_delete_queue;
2191 temp->name = name;
2192 always_delete_queue = temp;
2194 already1:;
2197 if (fail_delete)
2199 struct temp_file *temp;
2200 for (temp = failure_delete_queue; temp; temp = temp->next)
2201 if (! strcmp (name, temp->name))
2202 goto already2;
2204 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2205 temp->next = failure_delete_queue;
2206 temp->name = name;
2207 failure_delete_queue = temp;
2209 already2:;
2213 /* Delete all the temporary files whose names we previously recorded. */
2215 static void
2216 delete_if_ordinary (name)
2217 const char *name;
2219 struct stat st;
2220 #ifdef DEBUG
2221 int i, c;
2223 printf ("Delete %s? (y or n) ", name);
2224 fflush (stdout);
2225 i = getchar ();
2226 if (i != '\n')
2227 while ((c = getchar ()) != '\n' && c != EOF)
2230 if (i == 'y' || i == 'Y')
2231 #endif /* DEBUG */
2232 if (stat (name, &st) >= 0 && S_ISREG (st.st_mode))
2233 if (unlink (name) < 0)
2234 if (verbose_flag)
2235 perror_with_name (name);
2238 static void
2239 delete_temp_files ()
2241 struct temp_file *temp;
2243 for (temp = always_delete_queue; temp; temp = temp->next)
2244 delete_if_ordinary (temp->name);
2245 always_delete_queue = 0;
2248 /* Delete all the files to be deleted on error. */
2250 static void
2251 delete_failure_queue ()
2253 struct temp_file *temp;
2255 for (temp = failure_delete_queue; temp; temp = temp->next)
2256 delete_if_ordinary (temp->name);
2259 static void
2260 clear_failure_queue ()
2262 failure_delete_queue = 0;
2265 /* Build a list of search directories from PATHS.
2266 PREFIX is a string to prepend to the list.
2267 If CHECK_DIR_P is nonzero we ensure the directory exists.
2268 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2269 It is also used by the --print-search-dirs flag. */
2271 static char *
2272 build_search_list (paths, prefix, check_dir_p)
2273 struct path_prefix *paths;
2274 const char *prefix;
2275 int check_dir_p;
2277 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2278 int just_suffix_len
2279 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2280 int first_time = TRUE;
2281 struct prefix_list *pprefix;
2283 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2284 obstack_1grow (&collect_obstack, '=');
2286 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2288 int len = strlen (pprefix->prefix);
2290 if (machine_suffix
2291 && (! check_dir_p
2292 || is_directory (pprefix->prefix, machine_suffix, 0)))
2294 if (!first_time)
2295 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2297 first_time = FALSE;
2298 obstack_grow (&collect_obstack, pprefix->prefix, len);
2299 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2302 if (just_machine_suffix
2303 && pprefix->require_machine_suffix == 2
2304 && (! check_dir_p
2305 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2307 if (! first_time)
2308 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2310 first_time = FALSE;
2311 obstack_grow (&collect_obstack, pprefix->prefix, len);
2312 obstack_grow (&collect_obstack, just_machine_suffix,
2313 just_suffix_len);
2316 if (! pprefix->require_machine_suffix)
2318 if (! first_time)
2319 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2321 first_time = FALSE;
2322 obstack_grow (&collect_obstack, pprefix->prefix, len);
2326 obstack_1grow (&collect_obstack, '\0');
2327 return obstack_finish (&collect_obstack);
2330 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2331 for collect. */
2333 static void
2334 putenv_from_prefixes (paths, env_var)
2335 struct path_prefix *paths;
2336 const char *env_var;
2338 putenv (build_search_list (paths, env_var, 1));
2341 /* Check whether NAME can be accessed in MODE. This is like access,
2342 except that it never considers directories to be executable. */
2344 static int
2345 access_check (name, mode)
2346 const char *name;
2347 int mode;
2349 if (mode == X_OK)
2351 struct stat st;
2353 if (stat (name, &st) < 0
2354 || S_ISDIR (st.st_mode))
2355 return -1;
2358 return access (name, mode);
2361 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2362 access to check permissions.
2363 Return 0 if not found, otherwise return its name, allocated with malloc. */
2365 static char *
2366 find_a_file (pprefix, name, mode, multilib)
2367 struct path_prefix *pprefix;
2368 const char *name;
2369 int mode, multilib;
2371 char *temp;
2372 const char *const file_suffix =
2373 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2374 struct prefix_list *pl;
2375 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2376 const char *multilib_name, *multilib_os_name;
2378 #ifdef DEFAULT_ASSEMBLER
2379 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2380 return xstrdup (DEFAULT_ASSEMBLER);
2381 #endif
2383 #ifdef DEFAULT_LINKER
2384 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2385 return xstrdup (DEFAULT_LINKER);
2386 #endif
2388 if (machine_suffix)
2389 len += strlen (machine_suffix);
2391 multilib_name = name;
2392 multilib_os_name = name;
2393 if (multilib && multilib_os_dir)
2395 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2396 int len2 = strlen (multilib_os_dir) + 1;
2398 len += len1 > len2 ? len1 : len2;
2399 if (multilib_dir)
2400 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2401 NULL));
2402 if (strcmp (multilib_os_dir, ".") != 0)
2403 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2404 NULL));
2407 temp = xmalloc (len);
2409 /* Determine the filename to execute (special case for absolute paths). */
2411 if (IS_ABSOLUTE_PATHNAME (name))
2413 if (access (name, mode) == 0)
2415 strcpy (temp, name);
2416 return temp;
2419 else
2420 for (pl = pprefix->plist; pl; pl = pl->next)
2422 const char *this_name
2423 = pl->os_multilib ? multilib_os_name : multilib_name;
2425 if (machine_suffix)
2427 /* Some systems have a suffix for executable files.
2428 So try appending that first. */
2429 if (file_suffix[0] != 0)
2431 strcpy (temp, pl->prefix);
2432 strcat (temp, machine_suffix);
2433 strcat (temp, multilib_name);
2434 strcat (temp, file_suffix);
2435 if (access_check (temp, mode) == 0)
2437 if (pl->used_flag_ptr != 0)
2438 *pl->used_flag_ptr = 1;
2439 return temp;
2443 /* Now try just the multilib_name. */
2444 strcpy (temp, pl->prefix);
2445 strcat (temp, machine_suffix);
2446 strcat (temp, multilib_name);
2447 if (access_check (temp, mode) == 0)
2449 if (pl->used_flag_ptr != 0)
2450 *pl->used_flag_ptr = 1;
2451 return temp;
2455 /* Certain prefixes are tried with just the machine type,
2456 not the version. This is used for finding as, ld, etc. */
2457 if (just_machine_suffix && pl->require_machine_suffix == 2)
2459 /* Some systems have a suffix for executable files.
2460 So try appending that first. */
2461 if (file_suffix[0] != 0)
2463 strcpy (temp, pl->prefix);
2464 strcat (temp, just_machine_suffix);
2465 strcat (temp, multilib_name);
2466 strcat (temp, file_suffix);
2467 if (access_check (temp, mode) == 0)
2469 if (pl->used_flag_ptr != 0)
2470 *pl->used_flag_ptr = 1;
2471 return temp;
2475 strcpy (temp, pl->prefix);
2476 strcat (temp, just_machine_suffix);
2477 strcat (temp, multilib_name);
2478 if (access_check (temp, mode) == 0)
2480 if (pl->used_flag_ptr != 0)
2481 *pl->used_flag_ptr = 1;
2482 return temp;
2486 /* Certain prefixes can't be used without the machine suffix
2487 when the machine or version is explicitly specified. */
2488 if (! pl->require_machine_suffix)
2490 /* Some systems have a suffix for executable files.
2491 So try appending that first. */
2492 if (file_suffix[0] != 0)
2494 strcpy (temp, pl->prefix);
2495 strcat (temp, this_name);
2496 strcat (temp, file_suffix);
2497 if (access_check (temp, mode) == 0)
2499 if (pl->used_flag_ptr != 0)
2500 *pl->used_flag_ptr = 1;
2501 return temp;
2505 strcpy (temp, pl->prefix);
2506 strcat (temp, this_name);
2507 if (access_check (temp, mode) == 0)
2509 if (pl->used_flag_ptr != 0)
2510 *pl->used_flag_ptr = 1;
2511 return temp;
2516 free (temp);
2517 return 0;
2520 /* Ranking of prefixes in the sort list. -B prefixes are put before
2521 all others. */
2523 enum path_prefix_priority
2525 PREFIX_PRIORITY_B_OPT,
2526 PREFIX_PRIORITY_LAST
2529 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2530 order according to PRIORITY. Within each PRIORITY, new entries are
2531 appended.
2533 If WARN is nonzero, we will warn if no file is found
2534 through this prefix. WARN should point to an int
2535 which will be set to 1 if this entry is used.
2537 COMPONENT is the value to be passed to update_path.
2539 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2540 the complete value of machine_suffix.
2541 2 means try both machine_suffix and just_machine_suffix. */
2543 static void
2544 add_prefix (pprefix, prefix, component, priority, require_machine_suffix,
2545 warn, os_multilib)
2546 struct path_prefix *pprefix;
2547 const char *prefix;
2548 const char *component;
2549 /* enum prefix_priority */ int priority;
2550 int require_machine_suffix;
2551 int *warn;
2552 int os_multilib;
2554 struct prefix_list *pl, **prev;
2555 int len;
2557 for (prev = &pprefix->plist;
2558 (*prev) != NULL && (*prev)->priority <= priority;
2559 prev = &(*prev)->next)
2562 /* Keep track of the longest prefix */
2564 prefix = update_path (prefix, component);
2565 len = strlen (prefix);
2566 if (len > pprefix->max_len)
2567 pprefix->max_len = len;
2569 pl = (struct prefix_list *) xmalloc (sizeof (struct prefix_list));
2570 pl->prefix = prefix;
2571 pl->require_machine_suffix = require_machine_suffix;
2572 pl->used_flag_ptr = warn;
2573 pl->priority = priority;
2574 pl->os_multilib = os_multilib;
2575 if (warn)
2576 *warn = 0;
2578 /* Insert after PREV */
2579 pl->next = (*prev);
2580 (*prev) = pl;
2583 /* Same as add_prefix, but prepending target_system_root to prefix. */
2584 static void
2585 add_sysrooted_prefix (pprefix, prefix, component, priority,
2586 require_machine_suffix, warn, os_multilib)
2587 struct path_prefix *pprefix;
2588 const char *prefix;
2589 const char *component;
2590 /* enum prefix_priority */ int priority;
2591 int require_machine_suffix;
2592 int *warn;
2593 int os_multilib;
2595 if (!IS_ABSOLUTE_PATHNAME (prefix))
2596 abort ();
2598 if (target_system_root)
2600 prefix = concat (target_system_root, prefix, NULL);
2601 /* We have to override this because GCC's notion of sysroot
2602 moves along with GCC. */
2603 component = "GCC";
2606 add_prefix (pprefix, prefix, component, priority,
2607 require_machine_suffix, warn, os_multilib);
2610 /* Execute the command specified by the arguments on the current line of spec.
2611 When using pipes, this includes several piped-together commands
2612 with `|' between them.
2614 Return 0 if successful, -1 if failed. */
2616 static int
2617 execute ()
2619 int i;
2620 int n_commands; /* # of command. */
2621 char *string;
2622 struct command
2624 const char *prog; /* program name. */
2625 const char **argv; /* vector of args. */
2626 int pid; /* pid of process for this command. */
2629 struct command *commands; /* each command buffer with above info. */
2631 if (processing_spec_function)
2632 abort ();
2634 /* Count # of piped commands. */
2635 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2636 if (strcmp (argbuf[i], "|") == 0)
2637 n_commands++;
2639 /* Get storage for each command. */
2640 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2642 /* Split argbuf into its separate piped processes,
2643 and record info about each one.
2644 Also search for the programs that are to be run. */
2646 commands[0].prog = argbuf[0]; /* first command. */
2647 commands[0].argv = &argbuf[0];
2648 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2650 if (string)
2651 commands[0].argv[0] = string;
2653 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2654 if (strcmp (argbuf[i], "|") == 0)
2655 { /* each command. */
2656 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2657 fatal ("-pipe not supported");
2658 #endif
2659 argbuf[i] = 0; /* termination of command args. */
2660 commands[n_commands].prog = argbuf[i + 1];
2661 commands[n_commands].argv = &argbuf[i + 1];
2662 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2663 X_OK, 0);
2664 if (string)
2665 commands[n_commands].argv[0] = string;
2666 n_commands++;
2669 argbuf[argbuf_index] = 0;
2671 /* If -v, print what we are about to do, and maybe query. */
2673 if (verbose_flag)
2675 /* For help listings, put a blank line between sub-processes. */
2676 if (print_help_list)
2677 fputc ('\n', stderr);
2679 /* Print each piped command as a separate line. */
2680 for (i = 0; i < n_commands; i++)
2682 const char *const *j;
2684 if (verbose_only_flag)
2686 for (j = commands[i].argv; *j; j++)
2688 const char *p;
2689 fprintf (stderr, " \"");
2690 for (p = *j; *p; ++p)
2692 if (*p == '"' || *p == '\\' || *p == '$')
2693 fputc ('\\', stderr);
2694 fputc (*p, stderr);
2696 fputc ('"', stderr);
2699 else
2700 for (j = commands[i].argv; *j; j++)
2701 fprintf (stderr, " %s", *j);
2703 /* Print a pipe symbol after all but the last command. */
2704 if (i + 1 != n_commands)
2705 fprintf (stderr, " |");
2706 fprintf (stderr, "\n");
2708 fflush (stderr);
2709 if (verbose_only_flag != 0)
2710 return 0;
2711 #ifdef DEBUG
2712 notice ("\nGo ahead? (y or n) ");
2713 fflush (stderr);
2714 i = getchar ();
2715 if (i != '\n')
2716 while (getchar () != '\n')
2719 if (i != 'y' && i != 'Y')
2720 return 0;
2721 #endif /* DEBUG */
2724 #ifdef ENABLE_VALGRIND_CHECKING
2725 /* Run the each command through valgrind. To simplify prepending the
2726 path to valgrind and the option "-q" (for quiet operation unless
2727 something triggers), we allocate a separate argv array. */
2729 for (i = 0; i < n_commands; i++)
2731 const char **argv;
2732 int argc;
2733 int j;
2735 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2738 argv = alloca ((argc + 3) * sizeof (char *));
2740 argv[0] = VALGRIND_PATH;
2741 argv[1] = "-q";
2742 for (j = 2; j < argc + 2; j++)
2743 argv[j] = commands[i].argv[j - 2];
2744 argv[j] = NULL;
2746 commands[i].argv = argv;
2747 commands[i].prog = argv[0];
2749 #endif
2751 /* Run each piped subprocess. */
2753 for (i = 0; i < n_commands; i++)
2755 char *errmsg_fmt, *errmsg_arg;
2756 const char *string = commands[i].argv[0];
2758 /* For some bizarre reason, the second argument of execvp() is
2759 char *const *, not const char *const *. */
2760 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2761 programname, temp_filename,
2762 &errmsg_fmt, &errmsg_arg,
2763 ((i == 0 ? PEXECUTE_FIRST : 0)
2764 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2765 | (string == commands[i].prog
2766 ? PEXECUTE_SEARCH : 0)
2767 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2769 if (commands[i].pid == -1)
2770 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2772 if (string != commands[i].prog)
2773 free ((PTR) string);
2776 execution_count++;
2778 /* Wait for all the subprocesses to finish.
2779 We don't care what order they finish in;
2780 we know that N_COMMANDS waits will get them all.
2781 Ignore subprocesses that we don't know about,
2782 since they can be spawned by the process that exec'ed us. */
2785 int ret_code = 0;
2786 #ifdef HAVE_GETRUSAGE
2787 struct timeval d;
2788 double ut = 0.0, st = 0.0;
2789 #endif
2791 for (i = 0; i < n_commands;)
2793 int j;
2794 int status;
2795 int pid;
2797 pid = pwait (commands[i].pid, &status, 0);
2798 if (pid < 0)
2799 abort ();
2801 #ifdef HAVE_GETRUSAGE
2802 if (report_times)
2804 /* getrusage returns the total resource usage of all children
2805 up to now. Copy the previous values into prus, get the
2806 current statistics, then take the difference. */
2808 prus = rus;
2809 getrusage (RUSAGE_CHILDREN, &rus);
2810 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2811 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2812 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2814 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2815 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2816 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2818 #endif
2820 for (j = 0; j < n_commands; j++)
2821 if (commands[j].pid == pid)
2823 i++;
2824 if (WIFSIGNALED (status))
2826 #ifdef SIGPIPE
2827 /* SIGPIPE is a special case. It happens in -pipe mode
2828 when the compiler dies before the preprocessor is
2829 done, or the assembler dies before the compiler is
2830 done. There's generally been an error already, and
2831 this is just fallout. So don't generate another error
2832 unless we would otherwise have succeeded. */
2833 if (WTERMSIG (status) == SIGPIPE
2834 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2836 else
2837 #endif
2838 fatal ("\
2839 Internal error: %s (program %s)\n\
2840 Please submit a full bug report.\n\
2841 See %s for instructions.",
2842 strsignal (WTERMSIG (status)), commands[j].prog,
2843 bug_report_url);
2844 signal_count++;
2845 ret_code = -1;
2847 else if (WIFEXITED (status)
2848 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2850 if (WEXITSTATUS (status) > greatest_status)
2851 greatest_status = WEXITSTATUS (status);
2852 ret_code = -1;
2854 #ifdef HAVE_GETRUSAGE
2855 if (report_times && ut + st != 0)
2856 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2857 #endif
2858 break;
2861 return ret_code;
2865 /* Find all the switches given to us
2866 and make a vector describing them.
2867 The elements of the vector are strings, one per switch given.
2868 If a switch uses following arguments, then the `part1' field
2869 is the switch itself and the `args' field
2870 is a null-terminated vector containing the following arguments.
2871 The `live_cond' field is:
2872 0 when initialized
2873 1 if the switch is true in a conditional spec,
2874 -1 if false (overridden by a later switch)
2875 -2 if this switch should be ignored (used in %<S)
2876 The `validated' field is nonzero if any spec has looked at this switch;
2877 if it remains zero at the end of the run, it must be meaningless. */
2879 #define SWITCH_OK 0
2880 #define SWITCH_FALSE -1
2881 #define SWITCH_IGNORE -2
2882 #define SWITCH_LIVE 1
2884 struct switchstr
2886 const char *part1;
2887 const char **args;
2888 int live_cond;
2889 unsigned char validated;
2890 unsigned char ordering;
2893 static struct switchstr *switches;
2895 static int n_switches;
2897 struct infile
2899 const char *name;
2900 const char *language;
2903 /* Also a vector of input files specified. */
2905 static struct infile *infiles;
2907 int n_infiles;
2909 /* This counts the number of libraries added by lang_specific_driver, so that
2910 we can tell if there were any user supplied any files or libraries. */
2912 static int added_libraries;
2914 /* And a vector of corresponding output files is made up later. */
2916 const char **outfiles;
2918 /* Used to track if none of the -B paths are used. */
2919 static int warn_B;
2921 /* Gives value to pass as "warn" to add_prefix for standard prefixes. */
2922 static int *warn_std_ptr = 0;
2924 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2926 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2927 is true if we should look for an executable suffix. DO_OBJ
2928 is true if we should look for an object suffix. */
2930 static const char *
2931 convert_filename (name, do_exe, do_obj)
2932 const char *name;
2933 int do_exe ATTRIBUTE_UNUSED;
2934 int do_obj ATTRIBUTE_UNUSED;
2936 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2937 int i;
2938 #endif
2939 int len;
2941 if (name == NULL)
2942 return NULL;
2944 len = strlen (name);
2946 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2947 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2948 if (do_obj && len > 2
2949 && name[len - 2] == '.'
2950 && name[len - 1] == 'o')
2952 obstack_grow (&obstack, name, len - 2);
2953 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2954 name = obstack_finish (&obstack);
2956 #endif
2958 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2959 /* If there is no filetype, make it the executable suffix (which includes
2960 the "."). But don't get confused if we have just "-o". */
2961 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2962 return name;
2964 for (i = len - 1; i >= 0; i--)
2965 if (IS_DIR_SEPARATOR (name[i]))
2966 break;
2968 for (i++; i < len; i++)
2969 if (name[i] == '.')
2970 return name;
2972 obstack_grow (&obstack, name, len);
2973 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2974 strlen (TARGET_EXECUTABLE_SUFFIX));
2975 name = obstack_finish (&obstack);
2976 #endif
2978 return name;
2980 #endif
2982 /* Display the command line switches accepted by gcc. */
2983 static void
2984 display_help ()
2986 printf (_("Usage: %s [options] file...\n"), programname);
2987 fputs (_("Options:\n"), stdout);
2989 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
2990 fputs (_(" --help Display this information\n"), stdout);
2991 fputs (_(" --target-help Display target specific command line options\n"), stdout);
2992 if (! verbose_flag)
2993 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2994 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
2995 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
2996 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
2997 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
2998 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
2999 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3000 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3001 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3002 fputs (_("\
3003 -print-multi-lib Display the mapping between command line options and\n\
3004 multiple library search directories\n"), stdout);
3005 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3006 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3007 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3008 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3009 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3010 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3011 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3012 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3013 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3014 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3015 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3016 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3017 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3018 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3019 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3020 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3021 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3022 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3023 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3024 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3025 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3026 fputs (_("\
3027 -x <language> Specify the language of the following input files\n\
3028 Permissible languages include: c c++ assembler none\n\
3029 'none' means revert to the default behavior of\n\
3030 guessing the language based on the file's extension\n\
3031 "), stdout);
3033 printf (_("\
3034 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3035 passed on to the various sub-processes invoked by %s. In order to pass\n\
3036 other options on to these processes the -W<letter> options must be used.\n\
3037 "), programname);
3039 /* The rest of the options are displayed by invocations of the various
3040 sub-processes. */
3043 static void
3044 add_preprocessor_option (option, len)
3045 const char *option;
3046 int len;
3048 n_preprocessor_options++;
3050 if (! preprocessor_options)
3051 preprocessor_options
3052 = (char **) xmalloc (n_preprocessor_options * sizeof (char *));
3053 else
3054 preprocessor_options
3055 = (char **) xrealloc (preprocessor_options,
3056 n_preprocessor_options * sizeof (char *));
3058 preprocessor_options [n_preprocessor_options - 1] =
3059 save_string (option, len);
3062 static void
3063 add_assembler_option (option, len)
3064 const char *option;
3065 int len;
3067 n_assembler_options++;
3069 if (! assembler_options)
3070 assembler_options
3071 = (char **) xmalloc (n_assembler_options * sizeof (char *));
3072 else
3073 assembler_options
3074 = (char **) xrealloc (assembler_options,
3075 n_assembler_options * sizeof (char *));
3077 assembler_options [n_assembler_options - 1] = save_string (option, len);
3080 static void
3081 add_linker_option (option, len)
3082 const char *option;
3083 int len;
3085 n_linker_options++;
3087 if (! linker_options)
3088 linker_options
3089 = (char **) xmalloc (n_linker_options * sizeof (char *));
3090 else
3091 linker_options
3092 = (char **) xrealloc (linker_options,
3093 n_linker_options * sizeof (char *));
3095 linker_options [n_linker_options - 1] = save_string (option, len);
3098 /* Create the vector `switches' and its contents.
3099 Store its length in `n_switches'. */
3101 static void
3102 process_command (argc, argv)
3103 int argc;
3104 const char *const *argv;
3106 int i;
3107 const char *temp;
3108 char *temp1;
3109 const char *spec_lang = 0;
3110 int last_language_n_infiles;
3111 int have_c = 0;
3112 int have_o = 0;
3113 int lang_n_infiles = 0;
3114 #ifdef MODIFY_TARGET_NAME
3115 int is_modify_target_name;
3116 int j;
3117 #endif
3119 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3121 n_switches = 0;
3122 n_infiles = 0;
3123 added_libraries = 0;
3125 /* Figure compiler version from version string. */
3127 compiler_version = temp1 = xstrdup (version_string);
3129 for (; *temp1; ++temp1)
3131 if (*temp1 == ' ')
3133 *temp1 = '\0';
3134 break;
3138 /* If there is a -V or -b option (or both), process it now, before
3139 trying to interpret the rest of the command line. */
3140 if (argc > 1 && argv[1][0] == '-'
3141 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3143 const char *new_version = DEFAULT_TARGET_VERSION;
3144 const char *new_machine = DEFAULT_TARGET_MACHINE;
3145 const char *progname = argv[0];
3146 char **new_argv;
3147 char *new_argv0;
3148 int baselen;
3150 while (argc > 1 && argv[1][0] == '-'
3151 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3153 char opt = argv[1][1];
3154 const char *arg;
3155 if (argv[1][2] != '\0')
3157 arg = argv[1] + 2;
3158 argc -= 1;
3159 argv += 1;
3161 else if (argc > 2)
3163 arg = argv[2];
3164 argc -= 2;
3165 argv += 2;
3167 else
3168 fatal ("`-%c' option must have argument", opt);
3169 if (opt == 'V')
3170 new_version = arg;
3171 else
3172 new_machine = arg;
3175 for (baselen = strlen (progname); baselen > 0; baselen--)
3176 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3177 break;
3178 new_argv0 = xmemdup (progname, baselen,
3179 baselen + concat_length (new_version, new_machine,
3180 "-gcc-", NULL) + 1);
3181 strcpy (new_argv0 + baselen, new_machine);
3182 strcat (new_argv0, "-gcc-");
3183 strcat (new_argv0, new_version);
3185 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3186 (argc + 1) * sizeof (argv[0]));
3187 new_argv[0] = new_argv0;
3189 execvp (new_argv0, new_argv);
3190 fatal ("couldn't run `%s': %s", new_argv0, xstrerror (errno));
3193 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3194 see if we can create it from the pathname specified in argv[0]. */
3196 #ifndef VMS
3197 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3198 if (!gcc_exec_prefix)
3200 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3201 standard_exec_prefix);
3202 if (gcc_exec_prefix)
3203 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3205 #endif
3207 if (gcc_exec_prefix)
3209 int len = strlen (gcc_exec_prefix);
3211 if (len > (int) sizeof ("/lib/gcc-lib/") - 1
3212 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3214 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc-lib/") + 1;
3215 if (IS_DIR_SEPARATOR (*temp)
3216 && strncmp (temp + 1, "lib", 3) == 0
3217 && IS_DIR_SEPARATOR (temp[4])
3218 && strncmp (temp + 5, "gcc-lib", 7) == 0)
3219 len -= sizeof ("/lib/gcc-lib/") - 1;
3222 set_std_prefix (gcc_exec_prefix, len);
3223 add_prefix (&exec_prefixes, gcc_exec_prefix, "GCC",
3224 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3225 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3226 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3229 /* COMPILER_PATH and LIBRARY_PATH have values
3230 that are lists of directory names with colons. */
3232 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3233 if (temp)
3235 const char *startp, *endp;
3236 char *nstore = (char *) alloca (strlen (temp) + 3);
3238 startp = endp = temp;
3239 while (1)
3241 if (*endp == PATH_SEPARATOR || *endp == 0)
3243 strncpy (nstore, startp, endp - startp);
3244 if (endp == startp)
3245 strcpy (nstore, concat (".", dir_separator_str, NULL));
3246 else if (!IS_DIR_SEPARATOR (endp[-1]))
3248 nstore[endp - startp] = DIR_SEPARATOR;
3249 nstore[endp - startp + 1] = 0;
3251 else
3252 nstore[endp - startp] = 0;
3253 add_prefix (&exec_prefixes, nstore, 0,
3254 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3255 add_prefix (&include_prefixes,
3256 concat (nstore, "include", NULL),
3257 0, PREFIX_PRIORITY_LAST, 0, NULL, 0);
3258 if (*endp == 0)
3259 break;
3260 endp = startp = endp + 1;
3262 else
3263 endp++;
3267 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3268 if (temp && *cross_compile == '0')
3270 const char *startp, *endp;
3271 char *nstore = (char *) alloca (strlen (temp) + 3);
3273 startp = endp = temp;
3274 while (1)
3276 if (*endp == PATH_SEPARATOR || *endp == 0)
3278 strncpy (nstore, startp, endp - startp);
3279 if (endp == startp)
3280 strcpy (nstore, concat (".", dir_separator_str, NULL));
3281 else if (!IS_DIR_SEPARATOR (endp[-1]))
3283 nstore[endp - startp] = DIR_SEPARATOR;
3284 nstore[endp - startp + 1] = 0;
3286 else
3287 nstore[endp - startp] = 0;
3288 add_prefix (&startfile_prefixes, nstore, NULL,
3289 PREFIX_PRIORITY_LAST, 0, NULL, 1);
3290 if (*endp == 0)
3291 break;
3292 endp = startp = endp + 1;
3294 else
3295 endp++;
3299 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3300 GET_ENVIRONMENT (temp, "LPATH");
3301 if (temp && *cross_compile == '0')
3303 const char *startp, *endp;
3304 char *nstore = (char *) alloca (strlen (temp) + 3);
3306 startp = endp = temp;
3307 while (1)
3309 if (*endp == PATH_SEPARATOR || *endp == 0)
3311 strncpy (nstore, startp, endp - startp);
3312 if (endp == startp)
3313 strcpy (nstore, concat (".", dir_separator_str, NULL));
3314 else if (!IS_DIR_SEPARATOR (endp[-1]))
3316 nstore[endp - startp] = DIR_SEPARATOR;
3317 nstore[endp - startp + 1] = 0;
3319 else
3320 nstore[endp - startp] = 0;
3321 add_prefix (&startfile_prefixes, nstore, NULL,
3322 PREFIX_PRIORITY_LAST, 0, NULL, 1);
3323 if (*endp == 0)
3324 break;
3325 endp = startp = endp + 1;
3327 else
3328 endp++;
3332 /* Convert new-style -- options to old-style. */
3333 translate_options (&argc, &argv);
3335 /* Do language-specific adjustment/addition of flags. */
3336 lang_specific_driver (&argc, &argv, &added_libraries);
3338 /* Scan argv twice. Here, the first time, just count how many switches
3339 there will be in their vector, and how many input files in theirs.
3340 Here we also parse the switches that cc itself uses (e.g. -v). */
3342 for (i = 1; i < argc; i++)
3344 if (! strcmp (argv[i], "-dumpspecs"))
3346 struct spec_list *sl;
3347 init_spec ();
3348 for (sl = specs; sl; sl = sl->next)
3349 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3350 if (link_command_spec)
3351 printf ("*link_command:\n%s\n\n", link_command_spec);
3352 exit (0);
3354 else if (! strcmp (argv[i], "-dumpversion"))
3356 printf ("%s\n", spec_version);
3357 exit (0);
3359 else if (! strcmp (argv[i], "-dumpmachine"))
3361 printf ("%s\n", spec_machine);
3362 exit (0);
3364 else if (strcmp (argv[i], "-fversion") == 0)
3366 /* translate_options () has turned --version into -fversion. */
3367 printf (_("%s (GCC) %s\n"), programname, version_string);
3368 fputs (_("Copyright (C) 2003 Free Software Foundation, Inc.\n"),
3369 stdout);
3370 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3371 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3372 stdout);
3373 exit (0);
3375 else if (strcmp (argv[i], "-fhelp") == 0)
3377 /* translate_options () has turned --help into -fhelp. */
3378 print_help_list = 1;
3380 /* We will be passing a dummy file on to the sub-processes. */
3381 n_infiles++;
3382 n_switches++;
3384 /* CPP driver cannot obtain switch from cc1_options. */
3385 if (is_cpp_driver)
3386 add_preprocessor_option ("--help", 6);
3387 add_assembler_option ("--help", 6);
3388 add_linker_option ("--help", 6);
3390 else if (strcmp (argv[i], "-ftarget-help") == 0)
3392 /* translate_options() has turned --target-help into -ftarget-help. */
3393 target_help_flag = 1;
3395 /* We will be passing a dummy file on to the sub-processes. */
3396 n_infiles++;
3397 n_switches++;
3399 /* CPP driver cannot obtain switch from cc1_options. */
3400 if (is_cpp_driver)
3401 add_preprocessor_option ("--target-help", 13);
3402 add_assembler_option ("--target-help", 13);
3403 add_linker_option ("--target-help", 13);
3405 else if (! strcmp (argv[i], "-pass-exit-codes"))
3407 pass_exit_codes = 1;
3408 n_switches++;
3410 else if (! strcmp (argv[i], "-print-search-dirs"))
3411 print_search_dirs = 1;
3412 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3413 print_file_name = "libgcc.a";
3414 else if (! strncmp (argv[i], "-print-file-name=", 17))
3415 print_file_name = argv[i] + 17;
3416 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3417 print_prog_name = argv[i] + 17;
3418 else if (! strcmp (argv[i], "-print-multi-lib"))
3419 print_multi_lib = 1;
3420 else if (! strcmp (argv[i], "-print-multi-directory"))
3421 print_multi_directory = 1;
3422 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3423 print_multi_os_directory = 1;
3424 else if (! strncmp (argv[i], "-Wa,", 4))
3426 int prev, j;
3427 /* Pass the rest of this option to the assembler. */
3429 /* Split the argument at commas. */
3430 prev = 4;
3431 for (j = 4; argv[i][j]; j++)
3432 if (argv[i][j] == ',')
3434 add_assembler_option (argv[i] + prev, j - prev);
3435 prev = j + 1;
3438 /* Record the part after the last comma. */
3439 add_assembler_option (argv[i] + prev, j - prev);
3441 else if (! strncmp (argv[i], "-Wp,", 4))
3443 int prev, j;
3444 /* Pass the rest of this option to the preprocessor. */
3446 /* Split the argument at commas. */
3447 prev = 4;
3448 for (j = 4; argv[i][j]; j++)
3449 if (argv[i][j] == ',')
3451 add_preprocessor_option (argv[i] + prev, j - prev);
3452 prev = j + 1;
3455 /* Record the part after the last comma. */
3456 add_preprocessor_option (argv[i] + prev, j - prev);
3458 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3459 /* The +e options to the C++ front-end. */
3460 n_switches++;
3461 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3463 int j;
3464 /* Split the argument at commas. */
3465 for (j = 3; argv[i][j]; j++)
3466 n_infiles += (argv[i][j] == ',');
3468 else if (strcmp (argv[i], "-Xlinker") == 0)
3470 if (i + 1 == argc)
3471 fatal ("argument to `-Xlinker' is missing");
3473 n_infiles++;
3474 i++;
3476 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3478 if (i + 1 == argc)
3479 fatal ("argument to `-Xpreprocessor' is missing");
3481 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3483 else if (strcmp (argv[i], "-Xassembler") == 0)
3485 if (i + 1 == argc)
3486 fatal ("argument to `-Xassembler' is missing");
3488 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3490 else if (strcmp (argv[i], "-l") == 0)
3492 if (i + 1 == argc)
3493 fatal ("argument to `-l' is missing");
3495 n_infiles++;
3496 i++;
3498 else if (strncmp (argv[i], "-l", 2) == 0)
3499 n_infiles++;
3500 else if (strcmp (argv[i], "-save-temps") == 0)
3502 save_temps_flag = 1;
3503 n_switches++;
3505 else if (strcmp (argv[i], "-specs") == 0)
3507 struct user_specs *user = (struct user_specs *)
3508 xmalloc (sizeof (struct user_specs));
3509 if (++i >= argc)
3510 fatal ("argument to `-specs' is missing");
3512 user->next = (struct user_specs *) 0;
3513 user->filename = argv[i];
3514 if (user_specs_tail)
3515 user_specs_tail->next = user;
3516 else
3517 user_specs_head = user;
3518 user_specs_tail = user;
3520 else if (strncmp (argv[i], "-specs=", 7) == 0)
3522 struct user_specs *user = (struct user_specs *)
3523 xmalloc (sizeof (struct user_specs));
3524 if (strlen (argv[i]) == 7)
3525 fatal ("argument to `-specs=' is missing");
3527 user->next = (struct user_specs *) 0;
3528 user->filename = argv[i] + 7;
3529 if (user_specs_tail)
3530 user_specs_tail->next = user;
3531 else
3532 user_specs_head = user;
3533 user_specs_tail = user;
3535 else if (strcmp (argv[i], "-time") == 0)
3536 report_times = 1;
3537 else if (strcmp (argv[i], "-pipe") == 0)
3539 /* -pipe has to go into the switches array as well as
3540 setting a flag. */
3541 use_pipes = 1;
3542 n_switches++;
3544 else if (strcmp (argv[i], "-###") == 0)
3546 /* This is similar to -v except that there is no execution
3547 of the commands and the echoed arguments are quoted. It
3548 is intended for use in shell scripts to capture the
3549 driver-generated command line. */
3550 verbose_only_flag++;
3551 verbose_flag++;
3553 else if (argv[i][0] == '-' && argv[i][1] != 0)
3555 const char *p = &argv[i][1];
3556 int c = *p;
3558 switch (c)
3560 case 'b':
3561 case 'V':
3562 fatal ("`-%c' must come at the start of the command line", c);
3563 break;
3565 case 'B':
3567 const char *value;
3568 int len;
3570 if (p[1] == 0 && i + 1 == argc)
3571 fatal ("argument to `-B' is missing");
3572 if (p[1] == 0)
3573 value = argv[++i];
3574 else
3575 value = p + 1;
3577 len = strlen (value);
3579 /* Catch the case where the user has forgotten to append a
3580 directory separator to the path. Note, they may be using
3581 -B to add an executable name prefix, eg "i386-elf-", in
3582 order to distinguish between multiple installations of
3583 GCC in the same directory. Hence we must check to see
3584 if appending a directory separator actually makes a
3585 valid directory name. */
3586 if (! IS_DIR_SEPARATOR (value [len - 1])
3587 && is_directory (value, "", 0))
3589 char *tmp = xmalloc (len + 2);
3590 strcpy (tmp, value);
3591 tmp[len] = DIR_SEPARATOR;
3592 tmp[++ len] = 0;
3593 value = tmp;
3596 /* As a kludge, if the arg is "[foo/]stageN/", just
3597 add "[foo/]include" to the include prefix. */
3598 if ((len == 7
3599 || (len > 7
3600 && (IS_DIR_SEPARATOR (value[len - 8]))))
3601 && strncmp (value + len - 7, "stage", 5) == 0
3602 && ISDIGIT (value[len - 2])
3603 && (IS_DIR_SEPARATOR (value[len - 1])))
3605 if (len == 7)
3606 add_prefix (&include_prefixes, "include", NULL,
3607 PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3608 else
3610 char * string = xmalloc (len + 1);
3612 strncpy (string, value, len - 7);
3613 strcpy (string + len - 7, "include");
3614 add_prefix (&include_prefixes, string, NULL,
3615 PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3619 add_prefix (&exec_prefixes, value, NULL,
3620 PREFIX_PRIORITY_B_OPT, 0, &warn_B, 0);
3621 add_prefix (&startfile_prefixes, value, NULL,
3622 PREFIX_PRIORITY_B_OPT, 0, &warn_B, 0);
3623 add_prefix (&include_prefixes, concat (value, "include", NULL),
3624 NULL, PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3625 n_switches++;
3627 break;
3629 case 'v': /* Print our subcommands and print versions. */
3630 n_switches++;
3631 /* If they do anything other than exactly `-v', don't set
3632 verbose_flag; rather, continue on to give the error. */
3633 if (p[1] != 0)
3634 break;
3635 verbose_flag++;
3636 break;
3638 case 'S':
3639 case 'c':
3640 if (p[1] == 0)
3642 have_c = 1;
3643 n_switches++;
3644 break;
3646 goto normal_switch;
3648 case 'o':
3649 have_o = 1;
3650 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3651 if (! have_c)
3653 int skip;
3655 /* Forward scan, just in case -S or -c is specified
3656 after -o. */
3657 int j = i + 1;
3658 if (p[1] == 0)
3659 ++j;
3660 while (j < argc)
3662 if (argv[j][0] == '-')
3664 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3665 && argv[j][2] == 0)
3667 have_c = 1;
3668 break;
3670 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3671 j += skip - (argv[j][2] != 0);
3672 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3673 j += skip;
3675 j++;
3678 #endif
3679 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3680 if (p[1] == 0)
3681 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3682 else
3683 argv[i] = convert_filename (argv[i], ! have_c, 0);
3684 #endif
3685 goto normal_switch;
3687 default:
3688 normal_switch:
3690 #ifdef MODIFY_TARGET_NAME
3691 is_modify_target_name = 0;
3693 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3694 if (! strcmp (argv[i], modify_target[j].sw))
3696 char *new_name
3697 = (char *) xmalloc (strlen (modify_target[j].str)
3698 + strlen (spec_machine));
3699 const char *p, *r;
3700 char *q;
3701 int made_addition = 0;
3703 is_modify_target_name = 1;
3704 for (p = spec_machine, q = new_name; *p != 0; )
3706 if (modify_target[j].add_del == DELETE
3707 && (! strncmp (q, modify_target[j].str,
3708 strlen (modify_target[j].str))))
3709 p += strlen (modify_target[j].str);
3710 else if (modify_target[j].add_del == ADD
3711 && ! made_addition && *p == '-')
3713 for (r = modify_target[j].str; *r != 0; )
3714 *q++ = *r++;
3715 made_addition = 1;
3718 *q++ = *p++;
3721 spec_machine = new_name;
3724 if (is_modify_target_name)
3725 break;
3726 #endif
3728 n_switches++;
3730 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3731 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3732 else if (WORD_SWITCH_TAKES_ARG (p))
3733 i += WORD_SWITCH_TAKES_ARG (p);
3736 else
3738 n_infiles++;
3739 lang_n_infiles++;
3743 if (have_c && have_o && lang_n_infiles > 1)
3744 fatal ("cannot specify -o with -c or -S and multiple compilations");
3746 if ((save_temps_flag || report_times) && use_pipes)
3748 /* -save-temps overrides -pipe, so that temp files are produced */
3749 if (save_temps_flag)
3750 error ("warning: -pipe ignored because -save-temps specified");
3751 /* -time overrides -pipe because we can't get correct stats when
3752 multiple children are running at once. */
3753 else if (report_times)
3754 error ("warning: -pipe ignored because -time specified");
3756 use_pipes = 0;
3759 /* Set up the search paths before we go looking for config files. */
3761 /* These come before the md prefixes so that we will find gcc's subcommands
3762 (such as cpp) rather than those of the host system. */
3763 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3764 as well as trying the machine and the version. */
3765 #ifndef OS2
3766 add_prefix (&exec_prefixes, standard_exec_prefix, "GCC",
3767 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3768 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3769 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3770 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3771 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3772 #endif
3774 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3775 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3776 add_prefix (&startfile_prefixes, standard_exec_prefix_1, "BINUTILS",
3777 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3779 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3780 dir_separator_str, NULL);
3782 /* If tooldir is relative, base it on exec_prefixes. A relative
3783 tooldir lets us move the installed tree as a unit.
3785 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3786 directories, so that we can search both the user specified directory
3787 and the standard place. */
3789 if (!IS_ABSOLUTE_PATHNAME (tooldir_prefix))
3791 if (gcc_exec_prefix)
3793 char *gcc_exec_tooldir_prefix
3794 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3795 spec_version, dir_separator_str, tooldir_prefix, NULL);
3797 add_prefix (&exec_prefixes,
3798 concat (gcc_exec_tooldir_prefix, "bin",
3799 dir_separator_str, NULL),
3800 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 0);
3801 add_prefix (&startfile_prefixes,
3802 concat (gcc_exec_tooldir_prefix, "lib",
3803 dir_separator_str, NULL),
3804 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
3807 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3808 dir_separator_str, spec_version,
3809 dir_separator_str, tooldir_prefix, NULL);
3812 add_prefix (&exec_prefixes,
3813 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3814 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 0);
3815 add_prefix (&startfile_prefixes,
3816 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3817 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
3819 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3820 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3821 then consider it to relocate with the rest of the GCC installation
3822 if GCC_EXEC_PREFIX is set.
3823 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3824 if (target_system_root && gcc_exec_prefix)
3826 char *tmp_prefix = make_relative_prefix (argv[0],
3827 standard_bindir_prefix,
3828 target_system_root);
3829 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3831 target_system_root = tmp_prefix;
3832 target_system_root_changed = 1;
3835 #endif
3837 /* More prefixes are enabled in main, after we read the specs file
3838 and determine whether this is cross-compilation or not. */
3840 /* Then create the space for the vectors and scan again. */
3842 switches = ((struct switchstr *)
3843 xmalloc ((n_switches + 1) * sizeof (struct switchstr)));
3844 infiles = (struct infile *) xmalloc ((n_infiles + 1) * sizeof (struct infile));
3845 n_switches = 0;
3846 n_infiles = 0;
3847 last_language_n_infiles = -1;
3849 /* This, time, copy the text of each switch and store a pointer
3850 to the copy in the vector of switches.
3851 Store all the infiles in their vector. */
3853 for (i = 1; i < argc; i++)
3855 /* Just skip the switches that were handled by the preceding loop. */
3856 #ifdef MODIFY_TARGET_NAME
3857 is_modify_target_name = 0;
3859 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3860 if (! strcmp (argv[i], modify_target[j].sw))
3861 is_modify_target_name = 1;
3863 if (is_modify_target_name)
3865 else
3866 #endif
3867 if (! strncmp (argv[i], "-Wa,", 4))
3869 else if (! strncmp (argv[i], "-Wp,", 4))
3871 else if (! strcmp (argv[i], "-pass-exit-codes"))
3873 else if (! strcmp (argv[i], "-print-search-dirs"))
3875 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3877 else if (! strncmp (argv[i], "-print-file-name=", 17))
3879 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3881 else if (! strcmp (argv[i], "-print-multi-lib"))
3883 else if (! strcmp (argv[i], "-print-multi-directory"))
3885 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3887 else if (! strcmp (argv[i], "-ftarget-help"))
3889 else if (! strcmp (argv[i], "-fhelp"))
3891 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3893 /* Compensate for the +e options to the C++ front-end;
3894 they're there simply for cfront call-compatibility. We do
3895 some magic in default_compilers to pass them down properly.
3896 Note we deliberately start at the `+' here, to avoid passing
3897 -e0 or -e1 down into the linker. */
3898 switches[n_switches].part1 = &argv[i][0];
3899 switches[n_switches].args = 0;
3900 switches[n_switches].live_cond = SWITCH_OK;
3901 switches[n_switches].validated = 0;
3902 n_switches++;
3904 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3906 int prev, j;
3907 /* Split the argument at commas. */
3908 prev = 4;
3909 for (j = 4; argv[i][j]; j++)
3910 if (argv[i][j] == ',')
3912 infiles[n_infiles].language = "*";
3913 infiles[n_infiles++].name
3914 = save_string (argv[i] + prev, j - prev);
3915 prev = j + 1;
3917 /* Record the part after the last comma. */
3918 infiles[n_infiles].language = "*";
3919 infiles[n_infiles++].name = argv[i] + prev;
3921 else if (strcmp (argv[i], "-Xlinker") == 0)
3923 infiles[n_infiles].language = "*";
3924 infiles[n_infiles++].name = argv[++i];
3926 else if (strcmp (argv[i], "-Xassembler") == 0)
3928 infiles[n_infiles].language = "*";
3929 infiles[n_infiles++].name = argv[++i];
3931 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3933 infiles[n_infiles].language = "*";
3934 infiles[n_infiles++].name = argv[++i];
3936 else if (strcmp (argv[i], "-l") == 0)
3937 { /* POSIX allows separation of -l and the lib arg;
3938 canonicalize by concatenating -l with its arg */
3939 infiles[n_infiles].language = "*";
3940 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3942 else if (strncmp (argv[i], "-l", 2) == 0)
3944 infiles[n_infiles].language = "*";
3945 infiles[n_infiles++].name = argv[i];
3947 else if (strcmp (argv[i], "-specs") == 0)
3948 i++;
3949 else if (strncmp (argv[i], "-specs=", 7) == 0)
3951 else if (strcmp (argv[i], "-time") == 0)
3953 else if (strcmp (argv[i], "-###") == 0)
3955 else if (argv[i][0] == '-' && argv[i][1] != 0)
3957 const char *p = &argv[i][1];
3958 int c = *p;
3960 if (c == 'x')
3962 if (p[1] == 0 && i + 1 == argc)
3963 fatal ("argument to `-x' is missing");
3964 if (p[1] == 0)
3965 spec_lang = argv[++i];
3966 else
3967 spec_lang = p + 1;
3968 if (! strcmp (spec_lang, "none"))
3969 /* Suppress the warning if -xnone comes after the last input
3970 file, because alternate command interfaces like g++ might
3971 find it useful to place -xnone after each input file. */
3972 spec_lang = 0;
3973 else
3974 last_language_n_infiles = n_infiles;
3975 continue;
3977 switches[n_switches].part1 = p;
3978 /* Deal with option arguments in separate argv elements. */
3979 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
3980 || WORD_SWITCH_TAKES_ARG (p))
3982 int j = 0;
3983 int n_args = WORD_SWITCH_TAKES_ARG (p);
3985 if (n_args == 0)
3987 /* Count only the option arguments in separate argv elements. */
3988 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
3990 if (i + n_args >= argc)
3991 fatal ("argument to `-%s' is missing", p);
3992 switches[n_switches].args
3993 = (const char **) xmalloc ((n_args + 1) * sizeof(const char *));
3994 while (j < n_args)
3995 switches[n_switches].args[j++] = argv[++i];
3996 /* Null-terminate the vector. */
3997 switches[n_switches].args[j] = 0;
3999 else if (strchr (switches_need_spaces, c))
4001 /* On some systems, ld cannot handle some options without
4002 a space. So split the option from its argument. */
4003 char *part1 = (char *) xmalloc (2);
4004 part1[0] = c;
4005 part1[1] = '\0';
4007 switches[n_switches].part1 = part1;
4008 switches[n_switches].args
4009 = (const char **) xmalloc (2 * sizeof (const char *));
4010 switches[n_switches].args[0] = xstrdup (p+1);
4011 switches[n_switches].args[1] = 0;
4013 else
4014 switches[n_switches].args = 0;
4016 switches[n_switches].live_cond = SWITCH_OK;
4017 switches[n_switches].validated = 0;
4018 switches[n_switches].ordering = 0;
4019 /* These are always valid, since gcc.c itself understands them. */
4020 if (!strcmp (p, "save-temps")
4021 || !strcmp (p, "static-libgcc")
4022 || !strcmp (p, "shared-libgcc")
4023 || !strcmp (p, "pipe"))
4024 switches[n_switches].validated = 1;
4025 else
4027 char ch = switches[n_switches].part1[0];
4028 if (ch == 'B')
4029 switches[n_switches].validated = 1;
4031 n_switches++;
4033 else
4035 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4036 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4037 #endif
4039 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4041 perror_with_name (argv[i]);
4042 error_count++;
4044 else
4046 infiles[n_infiles].language = spec_lang;
4047 infiles[n_infiles++].name = argv[i];
4052 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4053 error ("warning: `-x %s' after last input file has no effect", spec_lang);
4055 /* Ensure we only invoke each subprocess once. */
4056 if (target_help_flag || print_help_list)
4058 n_infiles = 1;
4060 /* Create a dummy input file, so that we can pass --target-help on to
4061 the various sub-processes. */
4062 infiles[0].language = "c";
4063 infiles[0].name = "help-dummy";
4065 if (target_help_flag)
4067 switches[n_switches].part1 = "--target-help";
4068 switches[n_switches].args = 0;
4069 switches[n_switches].live_cond = SWITCH_OK;
4070 switches[n_switches].validated = 0;
4072 n_switches++;
4075 if (print_help_list)
4077 switches[n_switches].part1 = "--help";
4078 switches[n_switches].args = 0;
4079 switches[n_switches].live_cond = SWITCH_OK;
4080 switches[n_switches].validated = 0;
4082 n_switches++;
4086 switches[n_switches].part1 = 0;
4087 infiles[n_infiles].name = 0;
4090 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4091 and place that in the environment. */
4093 static void
4094 set_collect_gcc_options ()
4096 int i;
4097 int first_time;
4099 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4100 the compiler. */
4101 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4102 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4104 first_time = TRUE;
4105 for (i = 0; (int) i < n_switches; i++)
4107 const char *const *args;
4108 const char *p, *q;
4109 if (!first_time)
4110 obstack_grow (&collect_obstack, " ", 1);
4112 first_time = FALSE;
4114 /* Ignore elided switches. */
4115 if (switches[i].live_cond == SWITCH_IGNORE)
4116 continue;
4118 obstack_grow (&collect_obstack, "'-", 2);
4119 q = switches[i].part1;
4120 while ((p = strchr (q, '\'')))
4122 obstack_grow (&collect_obstack, q, p - q);
4123 obstack_grow (&collect_obstack, "'\\''", 4);
4124 q = ++p;
4126 obstack_grow (&collect_obstack, q, strlen (q));
4127 obstack_grow (&collect_obstack, "'", 1);
4129 for (args = switches[i].args; args && *args; args++)
4131 obstack_grow (&collect_obstack, " '", 2);
4132 q = *args;
4133 while ((p = strchr (q, '\'')))
4135 obstack_grow (&collect_obstack, q, p - q);
4136 obstack_grow (&collect_obstack, "'\\''", 4);
4137 q = ++p;
4139 obstack_grow (&collect_obstack, q, strlen (q));
4140 obstack_grow (&collect_obstack, "'", 1);
4143 obstack_grow (&collect_obstack, "\0", 1);
4144 putenv (obstack_finish (&collect_obstack));
4147 /* Process a spec string, accumulating and running commands. */
4149 /* These variables describe the input file name.
4150 input_file_number is the index on outfiles of this file,
4151 so that the output file name can be stored for later use by %o.
4152 input_basename is the start of the part of the input file
4153 sans all directory names, and basename_length is the number
4154 of characters starting there excluding the suffix .c or whatever. */
4156 static const char *input_filename;
4157 static int input_file_number;
4158 size_t input_filename_length;
4159 static int basename_length;
4160 static int suffixed_basename_length;
4161 static const char *input_basename;
4162 static const char *input_suffix;
4163 static struct stat input_stat;
4164 static int input_stat_set;
4166 /* The compiler used to process the current input file. */
4167 static struct compiler *input_file_compiler;
4169 /* These are variables used within do_spec and do_spec_1. */
4171 /* Nonzero if an arg has been started and not yet terminated
4172 (with space, tab or newline). */
4173 static int arg_going;
4175 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4176 is a temporary file name. */
4177 static int delete_this_arg;
4179 /* Nonzero means %w has been seen; the next arg to be terminated
4180 is the output file name of this compilation. */
4181 static int this_is_output_file;
4183 /* Nonzero means %s has been seen; the next arg to be terminated
4184 is the name of a library file and we should try the standard
4185 search dirs for it. */
4186 static int this_is_library_file;
4188 /* Nonzero means that the input of this command is coming from a pipe. */
4189 static int input_from_pipe;
4191 /* Nonnull means substitute this for any suffix when outputting a switches
4192 arguments. */
4193 static const char *suffix_subst;
4195 /* Process the spec SPEC and run the commands specified therein.
4196 Returns 0 if the spec is successfully processed; -1 if failed. */
4199 do_spec (spec)
4200 const char *spec;
4202 int value;
4204 value = do_spec_2 (spec);
4206 /* Force out any unfinished command.
4207 If -pipe, this forces out the last command if it ended in `|'. */
4208 if (value == 0)
4210 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4211 argbuf_index--;
4213 set_collect_gcc_options ();
4215 if (argbuf_index > 0)
4216 value = execute ();
4219 return value;
4222 static int
4223 do_spec_2 (spec)
4224 const char *spec;
4226 const char *string;
4227 int result;
4229 clear_args ();
4230 arg_going = 0;
4231 delete_this_arg = 0;
4232 this_is_output_file = 0;
4233 this_is_library_file = 0;
4234 input_from_pipe = 0;
4235 suffix_subst = NULL;
4237 result = do_spec_1 (spec, 0, NULL);
4239 /* End any pending argument. */
4240 if (arg_going)
4242 obstack_1grow (&obstack, 0);
4243 string = obstack_finish (&obstack);
4244 if (this_is_library_file)
4245 string = find_file (string);
4246 store_arg (string, delete_this_arg, this_is_output_file);
4247 if (this_is_output_file)
4248 outfiles[input_file_number] = string;
4249 arg_going = 0;
4252 return result;
4256 /* Process the given spec string and add any new options to the end
4257 of the switches/n_switches array. */
4259 static void
4260 do_self_spec (spec)
4261 const char *spec;
4263 do_spec_2 (spec);
4264 do_spec_1 (" ", 0, NULL);
4266 if (argbuf_index > 0)
4268 int i, first;
4270 first = n_switches;
4271 n_switches += argbuf_index;
4272 switches = xrealloc (switches,
4273 sizeof (struct switchstr) * (n_switches + 1));
4275 switches[n_switches] = switches[first];
4276 for (i = 0; i < argbuf_index; i++)
4278 struct switchstr *sw;
4280 /* Each switch should start with '-'. */
4281 if (argbuf[i][0] != '-')
4282 abort ();
4284 sw = &switches[i + first];
4285 sw->part1 = &argbuf[i][1];
4286 sw->args = 0;
4287 sw->live_cond = SWITCH_OK;
4288 sw->validated = 0;
4289 sw->ordering = 0;
4294 /* Process the sub-spec SPEC as a portion of a larger spec.
4295 This is like processing a whole spec except that we do
4296 not initialize at the beginning and we do not supply a
4297 newline by default at the end.
4298 INSWITCH nonzero means don't process %-sequences in SPEC;
4299 in this case, % is treated as an ordinary character.
4300 This is used while substituting switches.
4301 INSWITCH nonzero also causes SPC not to terminate an argument.
4303 Value is zero unless a line was finished
4304 and the command on that line reported an error. */
4306 static int
4307 do_spec_1 (spec, inswitch, soft_matched_part)
4308 const char *spec;
4309 int inswitch;
4310 const char *soft_matched_part;
4312 const char *p = spec;
4313 int c;
4314 int i;
4315 const char *string;
4316 int value;
4318 while ((c = *p++))
4319 /* If substituting a switch, treat all chars like letters.
4320 Otherwise, NL, SPC, TAB and % are special. */
4321 switch (inswitch ? 'a' : c)
4323 case '\n':
4324 /* End of line: finish any pending argument,
4325 then run the pending command if one has been started. */
4326 if (arg_going)
4328 obstack_1grow (&obstack, 0);
4329 string = obstack_finish (&obstack);
4330 if (this_is_library_file)
4331 string = find_file (string);
4332 store_arg (string, delete_this_arg, this_is_output_file);
4333 if (this_is_output_file)
4334 outfiles[input_file_number] = string;
4336 arg_going = 0;
4338 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4340 /* A `|' before the newline means use a pipe here,
4341 but only if -pipe was specified.
4342 Otherwise, execute now and don't pass the `|' as an arg. */
4343 if (use_pipes)
4345 input_from_pipe = 1;
4346 break;
4348 else
4349 argbuf_index--;
4352 set_collect_gcc_options ();
4354 if (argbuf_index > 0)
4356 value = execute ();
4357 if (value)
4358 return value;
4360 /* Reinitialize for a new command, and for a new argument. */
4361 clear_args ();
4362 arg_going = 0;
4363 delete_this_arg = 0;
4364 this_is_output_file = 0;
4365 this_is_library_file = 0;
4366 input_from_pipe = 0;
4367 break;
4369 case '|':
4370 /* End any pending argument. */
4371 if (arg_going)
4373 obstack_1grow (&obstack, 0);
4374 string = obstack_finish (&obstack);
4375 if (this_is_library_file)
4376 string = find_file (string);
4377 store_arg (string, delete_this_arg, this_is_output_file);
4378 if (this_is_output_file)
4379 outfiles[input_file_number] = string;
4382 /* Use pipe */
4383 obstack_1grow (&obstack, c);
4384 arg_going = 1;
4385 break;
4387 case '\t':
4388 case ' ':
4389 /* Space or tab ends an argument if one is pending. */
4390 if (arg_going)
4392 obstack_1grow (&obstack, 0);
4393 string = obstack_finish (&obstack);
4394 if (this_is_library_file)
4395 string = find_file (string);
4396 store_arg (string, delete_this_arg, this_is_output_file);
4397 if (this_is_output_file)
4398 outfiles[input_file_number] = string;
4400 /* Reinitialize for a new argument. */
4401 arg_going = 0;
4402 delete_this_arg = 0;
4403 this_is_output_file = 0;
4404 this_is_library_file = 0;
4405 break;
4407 case '%':
4408 switch (c = *p++)
4410 case 0:
4411 fatal ("invalid specification! Bug in cc");
4413 case 'b':
4414 obstack_grow (&obstack, input_basename, basename_length);
4415 arg_going = 1;
4416 break;
4418 case 'B':
4419 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4420 arg_going = 1;
4421 break;
4423 case 'd':
4424 delete_this_arg = 2;
4425 break;
4427 /* Dump out the directories specified with LIBRARY_PATH,
4428 followed by the absolute directories
4429 that we search for startfiles. */
4430 case 'D':
4432 struct prefix_list *pl = startfile_prefixes.plist;
4433 size_t bufsize = 100;
4434 char *buffer = (char *) xmalloc (bufsize);
4435 int idx;
4437 for (; pl; pl = pl->next)
4439 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4440 /* Used on systems which record the specified -L dirs
4441 and use them to search for dynamic linking. */
4442 /* Relative directories always come from -B,
4443 and it is better not to use them for searching
4444 at run time. In particular, stage1 loses. */
4445 if (!IS_ABSOLUTE_PATHNAME (pl->prefix))
4446 continue;
4447 #endif
4448 /* Try subdirectory if there is one. */
4449 if (multilib_dir != NULL
4450 || (pl->os_multilib && multilib_os_dir != NULL))
4452 const char *multi_dir;
4454 multi_dir = pl->os_multilib ? multilib_os_dir
4455 : multilib_dir;
4456 if (machine_suffix && multilib_dir)
4458 if (strlen (pl->prefix) + strlen (machine_suffix)
4459 >= bufsize)
4460 bufsize = (strlen (pl->prefix)
4461 + strlen (machine_suffix)) * 2 + 1;
4462 buffer = (char *) xrealloc (buffer, bufsize);
4463 strcpy (buffer, pl->prefix);
4464 strcat (buffer, machine_suffix);
4465 if (is_directory (buffer, multilib_dir, 1))
4467 do_spec_1 ("-L", 0, NULL);
4468 #ifdef SPACE_AFTER_L_OPTION
4469 do_spec_1 (" ", 0, NULL);
4470 #endif
4471 do_spec_1 (buffer, 1, NULL);
4472 do_spec_1 (multilib_dir, 1, NULL);
4473 /* Make this a separate argument. */
4474 do_spec_1 (" ", 0, NULL);
4477 if (!pl->require_machine_suffix)
4479 if (is_directory (pl->prefix, multi_dir, 1))
4481 do_spec_1 ("-L", 0, NULL);
4482 #ifdef SPACE_AFTER_L_OPTION
4483 do_spec_1 (" ", 0, NULL);
4484 #endif
4485 do_spec_1 (pl->prefix, 1, NULL);
4486 do_spec_1 (multi_dir, 1, NULL);
4487 /* Make this a separate argument. */
4488 do_spec_1 (" ", 0, NULL);
4492 if (machine_suffix)
4494 if (is_directory (pl->prefix, machine_suffix, 1))
4496 do_spec_1 ("-L", 0, NULL);
4497 #ifdef SPACE_AFTER_L_OPTION
4498 do_spec_1 (" ", 0, NULL);
4499 #endif
4500 do_spec_1 (pl->prefix, 1, NULL);
4501 /* Remove slash from machine_suffix. */
4502 if (strlen (machine_suffix) >= bufsize)
4503 bufsize = strlen (machine_suffix) * 2 + 1;
4504 buffer = (char *) xrealloc (buffer, bufsize);
4505 strcpy (buffer, machine_suffix);
4506 idx = strlen (buffer);
4507 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4508 buffer[idx - 1] = 0;
4509 do_spec_1 (buffer, 1, NULL);
4510 /* Make this a separate argument. */
4511 do_spec_1 (" ", 0, NULL);
4514 if (!pl->require_machine_suffix)
4516 if (is_directory (pl->prefix, "", 1))
4518 do_spec_1 ("-L", 0, NULL);
4519 #ifdef SPACE_AFTER_L_OPTION
4520 do_spec_1 (" ", 0, NULL);
4521 #endif
4522 /* Remove slash from pl->prefix. */
4523 if (strlen (pl->prefix) >= bufsize)
4524 bufsize = strlen (pl->prefix) * 2 + 1;
4525 buffer = (char *) xrealloc (buffer, bufsize);
4526 strcpy (buffer, pl->prefix);
4527 idx = strlen (buffer);
4528 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4529 buffer[idx - 1] = 0;
4530 do_spec_1 (buffer, 1, NULL);
4531 /* Make this a separate argument. */
4532 do_spec_1 (" ", 0, NULL);
4536 free (buffer);
4538 break;
4540 case 'e':
4541 /* %efoo means report an error with `foo' as error message
4542 and don't execute any more commands for this file. */
4544 const char *q = p;
4545 char *buf;
4546 while (*p != 0 && *p != '\n')
4547 p++;
4548 buf = (char *) alloca (p - q + 1);
4549 strncpy (buf, q, p - q);
4550 buf[p - q] = 0;
4551 error ("%s", buf);
4552 return -1;
4554 break;
4555 case 'n':
4556 /* %nfoo means report a notice with `foo' on stderr. */
4558 const char *q = p;
4559 char *buf;
4560 while (*p != 0 && *p != '\n')
4561 p++;
4562 buf = (char *) alloca (p - q + 1);
4563 strncpy (buf, q, p - q);
4564 buf[p - q] = 0;
4565 notice ("%s\n", buf);
4566 if (*p)
4567 p++;
4569 break;
4571 case 'j':
4573 struct stat st;
4575 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4576 defined, and it is not a directory, and it is
4577 writable, use it. Otherwise, treat this like any
4578 other temporary file. */
4580 if ((!save_temps_flag)
4581 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4582 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4584 obstack_grow (&obstack, HOST_BIT_BUCKET,
4585 strlen (HOST_BIT_BUCKET));
4586 delete_this_arg = 0;
4587 arg_going = 1;
4588 break;
4591 goto create_temp_file;
4592 case '|':
4593 if (use_pipes)
4595 obstack_1grow (&obstack, '-');
4596 delete_this_arg = 0;
4597 arg_going = 1;
4599 /* consume suffix */
4600 while (*p == '.' || ISALPHA ((unsigned char) *p))
4601 p++;
4602 if (p[0] == '%' && p[1] == 'O')
4603 p += 2;
4605 break;
4607 goto create_temp_file;
4608 case 'm':
4609 if (use_pipes)
4611 /* consume suffix */
4612 while (*p == '.' || ISALPHA ((unsigned char) *p))
4613 p++;
4614 if (p[0] == '%' && p[1] == 'O')
4615 p += 2;
4617 break;
4619 goto create_temp_file;
4620 case 'g':
4621 case 'u':
4622 case 'U':
4623 create_temp_file:
4625 struct temp_name *t;
4626 int suffix_length;
4627 const char *suffix = p;
4628 char *saved_suffix = NULL;
4630 while (*p == '.' || ISALPHA ((unsigned char) *p))
4631 p++;
4632 suffix_length = p - suffix;
4633 if (p[0] == '%' && p[1] == 'O')
4635 p += 2;
4636 /* We don't support extra suffix characters after %O. */
4637 if (*p == '.' || ISALPHA ((unsigned char) *p))
4638 abort ();
4639 if (suffix_length == 0)
4640 suffix = TARGET_OBJECT_SUFFIX;
4641 else
4643 saved_suffix
4644 = (char *) xmalloc (suffix_length
4645 + strlen (TARGET_OBJECT_SUFFIX));
4646 strncpy (saved_suffix, suffix, suffix_length);
4647 strcpy (saved_suffix + suffix_length,
4648 TARGET_OBJECT_SUFFIX);
4650 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4653 /* If the input_filename has the same suffix specified
4654 for the %g, %u, or %U, and -save-temps is specified,
4655 we could end up using that file as an intermediate
4656 thus clobbering the user's source file (.e.g.,
4657 gcc -save-temps foo.s would clobber foo.s with the
4658 output of cpp0). So check for this condition and
4659 generate a temp file as the intermediate. */
4661 if (save_temps_flag)
4663 temp_filename_length = basename_length + suffix_length;
4664 temp_filename = alloca (temp_filename_length + 1);
4665 strncpy ((char *) temp_filename, input_basename, basename_length);
4666 strncpy ((char *) temp_filename + basename_length, suffix,
4667 suffix_length);
4668 *((char *) temp_filename + temp_filename_length) = '\0';
4669 if (strcmp (temp_filename, input_filename) != 0)
4671 struct stat st_temp;
4673 /* Note, set_input() resets input_stat_set to 0. */
4674 if (input_stat_set == 0)
4676 input_stat_set = stat (input_filename, &input_stat);
4677 if (input_stat_set >= 0)
4678 input_stat_set = 1;
4681 /* If we have the stat for the input_filename
4682 and we can do the stat for the temp_filename
4683 then the they could still refer to the same
4684 file if st_dev/st_ino's are the same. */
4686 if (input_stat_set != 1
4687 || stat (temp_filename, &st_temp) < 0
4688 || input_stat.st_dev != st_temp.st_dev
4689 || input_stat.st_ino != st_temp.st_ino)
4691 temp_filename = save_string (temp_filename,
4692 temp_filename_length + 1);
4693 obstack_grow (&obstack, temp_filename,
4694 temp_filename_length);
4695 arg_going = 1;
4696 delete_this_arg = 0;
4697 break;
4702 /* See if we already have an association of %g/%u/%U and
4703 suffix. */
4704 for (t = temp_names; t; t = t->next)
4705 if (t->length == suffix_length
4706 && strncmp (t->suffix, suffix, suffix_length) == 0
4707 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4708 break;
4710 /* Make a new association if needed. %u and %j
4711 require one. */
4712 if (t == 0 || c == 'u' || c == 'j')
4714 if (t == 0)
4716 t = (struct temp_name *) xmalloc (sizeof (struct temp_name));
4717 t->next = temp_names;
4718 temp_names = t;
4720 t->length = suffix_length;
4721 if (saved_suffix)
4723 t->suffix = saved_suffix;
4724 saved_suffix = NULL;
4726 else
4727 t->suffix = save_string (suffix, suffix_length);
4728 t->unique = (c == 'u' || c == 'U' || c == 'j');
4729 temp_filename = make_temp_file (t->suffix);
4730 temp_filename_length = strlen (temp_filename);
4731 t->filename = temp_filename;
4732 t->filename_length = temp_filename_length;
4735 if (saved_suffix)
4736 free (saved_suffix);
4738 obstack_grow (&obstack, t->filename, t->filename_length);
4739 delete_this_arg = 1;
4741 arg_going = 1;
4742 break;
4744 case 'i':
4745 obstack_grow (&obstack, input_filename, input_filename_length);
4746 arg_going = 1;
4747 break;
4749 case 'I':
4751 struct prefix_list *pl = include_prefixes.plist;
4753 if (gcc_exec_prefix)
4755 do_spec_1 ("-iprefix", 1, NULL);
4756 /* Make this a separate argument. */
4757 do_spec_1 (" ", 0, NULL);
4758 do_spec_1 (gcc_exec_prefix, 1, NULL);
4759 do_spec_1 (" ", 0, NULL);
4762 if (target_system_root_changed)
4764 do_spec_1 ("-isysroot", 1, NULL);
4765 /* Make this a separate argument. */
4766 do_spec_1 (" ", 0, NULL);
4767 do_spec_1 (target_system_root, 1, NULL);
4768 do_spec_1 (" ", 0, NULL);
4771 for (; pl; pl = pl->next)
4773 do_spec_1 ("-isystem", 1, NULL);
4774 /* Make this a separate argument. */
4775 do_spec_1 (" ", 0, NULL);
4776 do_spec_1 (pl->prefix, 1, NULL);
4777 do_spec_1 (" ", 0, NULL);
4780 break;
4782 case 'o':
4784 int max = n_infiles;
4785 max += lang_specific_extra_outfiles;
4787 for (i = 0; i < max; i++)
4788 if (outfiles[i])
4789 store_arg (outfiles[i], 0, 0);
4790 break;
4793 case 'O':
4794 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4795 arg_going = 1;
4796 break;
4798 case 's':
4799 this_is_library_file = 1;
4800 break;
4802 case 'V':
4803 outfiles[input_file_number] = NULL;
4804 break;
4806 case 'w':
4807 this_is_output_file = 1;
4808 break;
4810 case 'W':
4812 int cur_index = argbuf_index;
4813 /* Handle the {...} following the %W. */
4814 if (*p != '{')
4815 abort ();
4816 p = handle_braces (p + 1);
4817 if (p == 0)
4818 return -1;
4819 /* End any pending argument. */
4820 if (arg_going)
4822 obstack_1grow (&obstack, 0);
4823 string = obstack_finish (&obstack);
4824 if (this_is_library_file)
4825 string = find_file (string);
4826 store_arg (string, delete_this_arg, this_is_output_file);
4827 if (this_is_output_file)
4828 outfiles[input_file_number] = string;
4829 arg_going = 0;
4831 /* If any args were output, mark the last one for deletion
4832 on failure. */
4833 if (argbuf_index != cur_index)
4834 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4835 break;
4838 /* %x{OPTION} records OPTION for %X to output. */
4839 case 'x':
4841 const char *p1 = p;
4842 char *string;
4844 /* Skip past the option value and make a copy. */
4845 if (*p != '{')
4846 abort ();
4847 while (*p++ != '}')
4849 string = save_string (p1 + 1, p - p1 - 2);
4851 /* See if we already recorded this option. */
4852 for (i = 0; i < n_linker_options; i++)
4853 if (! strcmp (string, linker_options[i]))
4855 free (string);
4856 return 0;
4859 /* This option is new; add it. */
4860 add_linker_option (string, strlen (string));
4862 break;
4864 /* Dump out the options accumulated previously using %x. */
4865 case 'X':
4866 for (i = 0; i < n_linker_options; i++)
4868 do_spec_1 (linker_options[i], 1, NULL);
4869 /* Make each accumulated option a separate argument. */
4870 do_spec_1 (" ", 0, NULL);
4872 break;
4874 /* Dump out the options accumulated previously using -Wa,. */
4875 case 'Y':
4876 for (i = 0; i < n_assembler_options; i++)
4878 do_spec_1 (assembler_options[i], 1, NULL);
4879 /* Make each accumulated option a separate argument. */
4880 do_spec_1 (" ", 0, NULL);
4882 break;
4884 /* Dump out the options accumulated previously using -Wp,. */
4885 case 'Z':
4886 for (i = 0; i < n_preprocessor_options; i++)
4888 do_spec_1 (preprocessor_options[i], 1, NULL);
4889 /* Make each accumulated option a separate argument. */
4890 do_spec_1 (" ", 0, NULL);
4892 break;
4894 /* Here are digits and numbers that just process
4895 a certain constant string as a spec. */
4897 case '1':
4898 value = do_spec_1 (cc1_spec, 0, NULL);
4899 if (value != 0)
4900 return value;
4901 break;
4903 case '2':
4904 value = do_spec_1 (cc1plus_spec, 0, NULL);
4905 if (value != 0)
4906 return value;
4907 break;
4909 case 'a':
4910 value = do_spec_1 (asm_spec, 0, NULL);
4911 if (value != 0)
4912 return value;
4913 break;
4915 case 'A':
4916 value = do_spec_1 (asm_final_spec, 0, NULL);
4917 if (value != 0)
4918 return value;
4919 break;
4921 case 'C':
4923 const char *const spec
4924 = (input_file_compiler->cpp_spec
4925 ? input_file_compiler->cpp_spec
4926 : cpp_spec);
4927 value = do_spec_1 (spec, 0, NULL);
4928 if (value != 0)
4929 return value;
4931 break;
4933 case 'E':
4934 value = do_spec_1 (endfile_spec, 0, NULL);
4935 if (value != 0)
4936 return value;
4937 break;
4939 case 'l':
4940 value = do_spec_1 (link_spec, 0, NULL);
4941 if (value != 0)
4942 return value;
4943 break;
4945 case 'L':
4946 value = do_spec_1 (lib_spec, 0, NULL);
4947 if (value != 0)
4948 return value;
4949 break;
4951 case 'G':
4952 value = do_spec_1 (libgcc_spec, 0, NULL);
4953 if (value != 0)
4954 return value;
4955 break;
4957 case 'M':
4958 if (multilib_dir && strcmp (multilib_dir, ".") != 0)
4960 char *p;
4961 const char *q;
4962 size_t len;
4964 len = strlen (multilib_dir);
4965 obstack_blank (&obstack, len + 1);
4966 p = obstack_next_free (&obstack) - (len + 1);
4968 *p++ = '_';
4969 for (q = multilib_dir; *q ; ++q, ++p)
4970 *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
4972 break;
4974 case 'R':
4975 /* We assume there is a directory
4976 separator at the end of this string. */
4977 if (target_system_root)
4978 obstack_grow (&obstack, target_system_root,
4979 strlen (target_system_root));
4980 break;
4982 case 'S':
4983 value = do_spec_1 (startfile_spec, 0, NULL);
4984 if (value != 0)
4985 return value;
4986 break;
4988 /* Here we define characters other than letters and digits. */
4990 case '{':
4991 p = handle_braces (p);
4992 if (p == 0)
4993 return -1;
4994 break;
4996 case ':':
4997 p = handle_spec_function (p);
4998 if (p == 0)
4999 return -1;
5000 break;
5002 case '%':
5003 obstack_1grow (&obstack, '%');
5004 break;
5006 case '.':
5008 unsigned len = 0;
5010 while (p[len] && p[len] != ' ' && p[len] != '%')
5011 len++;
5012 suffix_subst = save_string (p - 1, len + 1);
5013 p += len;
5015 break;
5017 /* Henceforth ignore the option(s) matching the pattern
5018 after the %<. */
5019 case '<':
5021 unsigned len = 0;
5022 int have_wildcard = 0;
5023 int i;
5025 while (p[len] && p[len] != ' ' && p[len] != '\t')
5026 len++;
5028 if (p[len-1] == '*')
5029 have_wildcard = 1;
5031 for (i = 0; i < n_switches; i++)
5032 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5033 && (have_wildcard || switches[i].part1[len] == '\0'))
5035 switches[i].live_cond = SWITCH_IGNORE;
5036 switches[i].validated = 1;
5039 p += len;
5041 break;
5043 case '*':
5044 if (soft_matched_part)
5046 do_spec_1 (soft_matched_part, 1, NULL);
5047 do_spec_1 (" ", 0, NULL);
5049 else
5050 /* Catch the case where a spec string contains something like
5051 '%{foo:%*}'. ie there is no * in the pattern on the left
5052 hand side of the :. */
5053 error ("spec failure: '%%*' has not been initialized by pattern match");
5054 break;
5056 /* Process a string found as the value of a spec given by name.
5057 This feature allows individual machine descriptions
5058 to add and use their own specs.
5059 %[...] modifies -D options the way %P does;
5060 %(...) uses the spec unmodified. */
5061 case '[':
5062 error ("warning: use of obsolete %%[ operator in specs");
5063 case '(':
5065 const char *name = p;
5066 struct spec_list *sl;
5067 int len;
5069 /* The string after the S/P is the name of a spec that is to be
5070 processed. */
5071 while (*p && *p != ')' && *p != ']')
5072 p++;
5074 /* See if it's in the list. */
5075 for (len = p - name, sl = specs; sl; sl = sl->next)
5076 if (sl->name_len == len && !strncmp (sl->name, name, len))
5078 name = *(sl->ptr_spec);
5079 #ifdef DEBUG_SPECS
5080 notice ("Processing spec %c%s%c, which is '%s'\n",
5081 c, sl->name, (c == '(') ? ')' : ']', name);
5082 #endif
5083 break;
5086 if (sl)
5088 if (c == '(')
5090 value = do_spec_1 (name, 0, NULL);
5091 if (value != 0)
5092 return value;
5094 else
5096 char *x = (char *) alloca (strlen (name) * 2 + 1);
5097 char *buf = x;
5098 const char *y = name;
5099 int flag = 0;
5101 /* Copy all of NAME into BUF, but put __ after
5102 every -D and at the end of each arg. */
5103 while (1)
5105 if (! strncmp (y, "-D", 2))
5107 *x++ = '-';
5108 *x++ = 'D';
5109 *x++ = '_';
5110 *x++ = '_';
5111 y += 2;
5112 flag = 1;
5113 continue;
5115 else if (flag
5116 && (*y == ' ' || *y == '\t' || *y == '='
5117 || *y == '}' || *y == 0))
5119 *x++ = '_';
5120 *x++ = '_';
5121 flag = 0;
5123 if (*y == 0)
5124 break;
5125 else
5126 *x++ = *y++;
5128 *x = 0;
5130 value = do_spec_1 (buf, 0, NULL);
5131 if (value != 0)
5132 return value;
5136 /* Discard the closing paren or bracket. */
5137 if (*p)
5138 p++;
5140 break;
5142 default:
5143 error ("spec failure: unrecognized spec option '%c'", c);
5144 break;
5146 break;
5148 case '\\':
5149 /* Backslash: treat next character as ordinary. */
5150 c = *p++;
5152 /* fall through */
5153 default:
5154 /* Ordinary character: put it into the current argument. */
5155 obstack_1grow (&obstack, c);
5156 arg_going = 1;
5159 /* End of string. If we are processing a spec function, we need to
5160 end any pending argument. */
5161 if (processing_spec_function && arg_going)
5163 obstack_1grow (&obstack, 0);
5164 string = obstack_finish (&obstack);
5165 if (this_is_library_file)
5166 string = find_file (string);
5167 store_arg (string, delete_this_arg, this_is_output_file);
5168 if (this_is_output_file)
5169 outfiles[input_file_number] = string;
5170 arg_going = 0;
5173 return 0;
5176 /* Look up a spec function. */
5178 static const struct spec_function *
5179 lookup_spec_function (name)
5180 const char *name;
5182 static const struct spec_function * const spec_function_tables[] =
5184 static_spec_functions,
5185 lang_specific_spec_functions,
5187 const struct spec_function *sf;
5188 unsigned int i;
5190 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5192 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5193 if (strcmp (sf->name, name) == 0)
5194 return sf;
5197 return NULL;
5200 /* Evaluate a spec function. */
5202 static const char *
5203 eval_spec_function (func, args)
5204 const char *func, *args;
5206 const struct spec_function *sf;
5207 const char *funcval;
5209 /* Saved spec processing context. */
5210 int save_argbuf_index;
5211 int save_argbuf_length;
5212 const char **save_argbuf;
5214 int save_arg_going;
5215 int save_delete_this_arg;
5216 int save_this_is_output_file;
5217 int save_this_is_library_file;
5218 int save_input_from_pipe;
5219 const char *save_suffix_subst;
5222 sf = lookup_spec_function (func);
5223 if (sf == NULL)
5224 fatal ("unknown spec function `%s'", func);
5226 /* Push the spec processing context. */
5227 save_argbuf_index = argbuf_index;
5228 save_argbuf_length = argbuf_length;
5229 save_argbuf = argbuf;
5231 save_arg_going = arg_going;
5232 save_delete_this_arg = delete_this_arg;
5233 save_this_is_output_file = this_is_output_file;
5234 save_this_is_library_file = this_is_library_file;
5235 save_input_from_pipe = input_from_pipe;
5236 save_suffix_subst = suffix_subst;
5238 /* Create a new spec processing context, and build the function
5239 arguments. */
5241 alloc_args ();
5242 if (do_spec_2 (args) < 0)
5243 fatal ("error in args to spec function `%s'", func);
5245 /* argbuf_index is an index for the next argument to be inserted, and
5246 so contains the count of the args already inserted. */
5248 funcval = (*sf->func) (argbuf_index, argbuf);
5250 /* Pop the spec processing context. */
5251 argbuf_index = save_argbuf_index;
5252 argbuf_length = save_argbuf_length;
5253 free (argbuf);
5254 argbuf = save_argbuf;
5256 arg_going = save_arg_going;
5257 delete_this_arg = save_delete_this_arg;
5258 this_is_output_file = save_this_is_output_file;
5259 this_is_library_file = save_this_is_library_file;
5260 input_from_pipe = save_input_from_pipe;
5261 suffix_subst = save_suffix_subst;
5263 return funcval;
5266 /* Handle a spec function call of the form:
5268 %:function(args)
5270 ARGS is processed as a spec in a separate context and split into an
5271 argument vector in the normal fashion. The function returns a string
5272 containing a spec which we then process in the caller's context, or
5273 NULL if no processing is required. */
5275 static const char *
5276 handle_spec_function (p)
5277 const char *p;
5279 char *func, *args;
5280 const char *endp, *funcval;
5281 int count;
5283 processing_spec_function++;
5285 /* Get the function name. */
5286 for (endp = p; *endp != '\0'; endp++)
5288 if (*endp == '(') /* ) */
5289 break;
5290 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5291 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5292 fatal ("malformed spec function name");
5294 if (*endp != '(') /* ) */
5295 fatal ("no arguments for spec function");
5296 func = save_string (p, endp - p);
5297 p = ++endp;
5299 /* Get the arguments. */
5300 for (count = 0; *endp != '\0'; endp++)
5302 /* ( */
5303 if (*endp == ')')
5305 if (count == 0)
5306 break;
5307 count--;
5309 else if (*endp == '(') /* ) */
5310 count++;
5312 /* ( */
5313 if (*endp != ')')
5314 fatal ("malformed spec function arguments");
5315 args = save_string (p, endp - p);
5316 p = ++endp;
5318 /* p now points to just past the end of the spec function expression. */
5320 funcval = eval_spec_function (func, args);
5321 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5322 p = NULL;
5324 free (func);
5325 free (args);
5327 processing_spec_function--;
5329 return p;
5332 /* Inline subroutine of handle_braces. Returns true if the current
5333 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5334 static inline bool
5335 input_suffix_matches (atom, end_atom)
5336 const char *atom;
5337 const char *end_atom;
5339 return (input_suffix
5340 && !strncmp (input_suffix, atom, end_atom - atom)
5341 && input_suffix[end_atom - atom] == '\0');
5344 /* Inline subroutine of handle_braces. Returns true if a switch
5345 matching the atom bracketed by ATOM and END_ATOM appeared on the
5346 command line. */
5347 static inline bool
5348 switch_matches (atom, end_atom, starred)
5349 const char *atom;
5350 const char *end_atom;
5351 int starred;
5353 int i;
5354 int len = end_atom - atom;
5355 int plen = starred ? len : -1;
5357 for (i = 0; i < n_switches; i++)
5358 if (!strncmp (switches[i].part1, atom, len)
5359 && (starred || switches[i].part1[len] == '\0')
5360 && check_live_switch (i, plen))
5361 return true;
5363 return false;
5366 /* Inline subroutine of handle_braces. Mark all of the switches which
5367 match ATOM (extends to END_ATOM; STARRED indicates whether there
5368 was a star after the atom) for later processing. */
5369 static inline void
5370 mark_matching_switches (atom, end_atom, starred)
5371 const char *atom;
5372 const char *end_atom;
5373 int starred;
5375 int i;
5376 int len = end_atom - atom;
5377 int plen = starred ? len : -1;
5379 for (i = 0; i < n_switches; i++)
5380 if (!strncmp (switches[i].part1, atom, len)
5381 && (starred || switches[i].part1[len] == '\0')
5382 && check_live_switch (i, plen))
5383 switches[i].ordering = 1;
5386 /* Inline subroutine of handle_braces. Process all the currently
5387 marked switches through give_switch, and clear the marks. */
5388 static inline void
5389 process_marked_switches ()
5391 int i;
5393 for (i = 0; i < n_switches; i++)
5394 if (switches[i].ordering == 1)
5396 switches[i].ordering = 0;
5397 give_switch (i, 0);
5401 /* Handle a %{ ... } construct. P points just inside the leading {.
5402 Returns a pointer one past the end of the brace block, or 0
5403 if we call do_spec_1 and that returns -1. */
5405 static const char *
5406 handle_braces (p)
5407 const char *p;
5409 const char *atom, *end_atom;
5410 const char *d_atom = NULL, *d_end_atom = NULL;
5412 bool a_is_suffix;
5413 bool a_is_starred;
5414 bool a_is_negated;
5415 bool a_matched;
5417 bool a_must_be_last = false;
5418 bool ordered_set = false;
5419 bool disjunct_set = false;
5420 bool disj_matched = false;
5421 bool disj_starred = true;
5422 bool n_way_choice = false;
5423 bool n_way_matched = false;
5425 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5429 if (a_must_be_last)
5430 abort ();
5432 /* Scan one "atom" (S in the description above of %{}, possibly
5433 with !, ., or * modifiers). */
5434 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5436 SKIP_WHITE();
5437 if (*p == '!')
5438 p++, a_is_negated = true;
5440 SKIP_WHITE();
5441 if (*p == '.')
5442 p++, a_is_suffix = true;
5444 atom = p;
5445 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5446 || *p == ',' || *p == '.' || *p == '@')
5447 p++;
5448 end_atom = p;
5450 if (*p == '*')
5451 p++, a_is_starred = 1;
5453 SKIP_WHITE();
5454 if (*p == '&' || *p == '}')
5456 /* Substitute the switch(es) indicated by the current atom. */
5457 ordered_set = true;
5458 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5459 || atom == end_atom)
5460 abort ();
5462 mark_matching_switches (atom, end_atom, a_is_starred);
5464 if (*p == '}')
5465 process_marked_switches ();
5467 else if (*p == '|' || *p == ':')
5469 /* Substitute some text if the current atom appears as a switch
5470 or suffix. */
5471 disjunct_set = true;
5472 if (ordered_set)
5473 abort ();
5475 if (atom == end_atom)
5477 if (!n_way_choice || disj_matched || *p == '|'
5478 || a_is_negated || a_is_suffix || a_is_starred)
5479 abort ();
5481 /* An empty term may appear as the last choice of an
5482 N-way choice set; it means "otherwise". */
5483 a_must_be_last = true;
5484 disj_matched = !n_way_matched;
5485 disj_starred = false;
5487 else
5489 if (a_is_suffix && a_is_starred)
5490 abort ();
5492 if (!a_is_starred)
5493 disj_starred = false;
5495 /* Don't bother testing this atom if we already have a
5496 match. */
5497 if (!disj_matched && !n_way_matched)
5499 if (a_is_suffix)
5500 a_matched = input_suffix_matches (atom, end_atom);
5501 else
5502 a_matched = switch_matches (atom, end_atom, a_is_starred);
5504 if (a_matched != a_is_negated)
5506 disj_matched = true;
5507 d_atom = atom;
5508 d_end_atom = end_atom;
5513 if (*p == ':')
5515 /* Found the body, that is, the text to substitute if the
5516 current disjunction matches. */
5517 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5518 disj_matched && !n_way_matched);
5519 if (p == 0)
5520 return 0;
5522 /* If we have an N-way choice, reset state for the next
5523 disjunction. */
5524 if (*p == ';')
5526 n_way_choice = true;
5527 n_way_matched |= disj_matched;
5528 disj_matched = false;
5529 disj_starred = true;
5530 d_atom = d_end_atom = NULL;
5534 else
5535 abort ();
5537 while (*p++ != '}');
5539 return p;
5541 #undef SKIP_WHITE
5544 /* Subroutine of handle_braces. Scan and process a brace substitution body
5545 (X in the description of %{} syntax). P points one past the colon;
5546 ATOM and END_ATOM bracket the first atom which was found to be true
5547 (present) in the current disjunction; STARRED indicates whether all
5548 the atoms in the current disjunction were starred (for syntax validation);
5549 MATCHED indicates whether the disjunction matched or not, and therefore
5550 whether or not the body is to be processed through do_spec_1 or just
5551 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5552 returns -1. */
5554 static const char *
5555 process_brace_body (p, atom, end_atom, starred, matched)
5556 const char *p;
5557 const char *atom;
5558 const char *end_atom;
5559 int starred;
5560 int matched;
5562 const char *body, *end_body;
5563 unsigned int nesting_level;
5564 bool have_subst = false;
5566 /* Locate the closing } or ;, honoring nested braces.
5567 Trim trailing whitespace. */
5568 body = p;
5569 nesting_level = 1;
5570 for (;;)
5572 if (*p == '{')
5573 nesting_level++;
5574 else if (*p == '}')
5576 if (!--nesting_level)
5577 break;
5579 else if (*p == ';' && nesting_level == 1)
5580 break;
5581 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5582 have_subst = true;
5583 else if (*p == '\0')
5584 abort ();
5585 p++;
5588 end_body = p;
5589 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5590 end_body--;
5592 if (have_subst && !starred)
5593 abort ();
5595 if (matched)
5597 /* Copy the substitution body to permanent storage and execute it.
5598 If have_subst is false, this is a simple matter of running the
5599 body through do_spec_1... */
5600 char *string = save_string (body, end_body - body);
5601 if (!have_subst)
5603 if (do_spec_1 (string, 0, NULL) < 0)
5604 return 0;
5606 else
5608 /* ... but if have_subst is true, we have to process the
5609 body once for each matching switch, with %* set to the
5610 variant part of the switch. */
5611 unsigned int hard_match_len = end_atom - atom;
5612 int i;
5614 for (i = 0; i < n_switches; i++)
5615 if (!strncmp (switches[i].part1, atom, hard_match_len)
5616 && check_live_switch (i, hard_match_len))
5618 if (do_spec_1 (string, 0,
5619 &switches[i].part1[hard_match_len]) < 0)
5620 return 0;
5621 /* Pass any arguments this switch has. */
5622 give_switch (i, 1);
5623 suffix_subst = NULL;
5628 return p;
5631 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5632 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5633 spec, or -1 if either exact match or %* is used.
5635 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5636 whose value does not begin with "no-" is obsoleted by the same value
5637 with the "no-", similarly for a switch with the "no-" prefix. */
5639 static int
5640 check_live_switch (switchnum, prefix_length)
5641 int switchnum;
5642 int prefix_length;
5644 const char *name = switches[switchnum].part1;
5645 int i;
5647 /* In the common case of {<at-most-one-letter>*}, a negating
5648 switch would always match, so ignore that case. We will just
5649 send the conflicting switches to the compiler phase. */
5650 if (prefix_length >= 0 && prefix_length <= 1)
5651 return 1;
5653 /* If we already processed this switch and determined if it was
5654 live or not, return our past determination. */
5655 if (switches[switchnum].live_cond != 0)
5656 return switches[switchnum].live_cond > 0;
5658 /* Now search for duplicate in a manner that depends on the name. */
5659 switch (*name)
5661 case 'O':
5662 for (i = switchnum + 1; i < n_switches; i++)
5663 if (switches[i].part1[0] == 'O')
5665 switches[switchnum].validated = 1;
5666 switches[switchnum].live_cond = SWITCH_FALSE;
5667 return 0;
5669 break;
5671 case 'W': case 'f': case 'm':
5672 if (! strncmp (name + 1, "no-", 3))
5674 /* We have Xno-YYY, search for XYYY. */
5675 for (i = switchnum + 1; i < n_switches; i++)
5676 if (switches[i].part1[0] == name[0]
5677 && ! strcmp (&switches[i].part1[1], &name[4]))
5679 switches[switchnum].validated = 1;
5680 switches[switchnum].live_cond = SWITCH_FALSE;
5681 return 0;
5684 else
5686 /* We have XYYY, search for Xno-YYY. */
5687 for (i = switchnum + 1; i < n_switches; i++)
5688 if (switches[i].part1[0] == name[0]
5689 && switches[i].part1[1] == 'n'
5690 && switches[i].part1[2] == 'o'
5691 && switches[i].part1[3] == '-'
5692 && !strcmp (&switches[i].part1[4], &name[1]))
5694 switches[switchnum].validated = 1;
5695 switches[switchnum].live_cond = SWITCH_FALSE;
5696 return 0;
5699 break;
5702 /* Otherwise the switch is live. */
5703 switches[switchnum].live_cond = SWITCH_LIVE;
5704 return 1;
5707 /* Pass a switch to the current accumulating command
5708 in the same form that we received it.
5709 SWITCHNUM identifies the switch; it is an index into
5710 the vector of switches gcc received, which is `switches'.
5711 This cannot fail since it never finishes a command line.
5713 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5715 static void
5716 give_switch (switchnum, omit_first_word)
5717 int switchnum;
5718 int omit_first_word;
5720 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5721 return;
5723 if (!omit_first_word)
5725 do_spec_1 ("-", 0, NULL);
5726 do_spec_1 (switches[switchnum].part1, 1, NULL);
5729 if (switches[switchnum].args != 0)
5731 const char **p;
5732 for (p = switches[switchnum].args; *p; p++)
5734 const char *arg = *p;
5736 do_spec_1 (" ", 0, NULL);
5737 if (suffix_subst)
5739 unsigned length = strlen (arg);
5740 int dot = 0;
5742 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5743 if (arg[length] == '.')
5745 ((char *)arg)[length] = 0;
5746 dot = 1;
5747 break;
5749 do_spec_1 (arg, 1, NULL);
5750 if (dot)
5751 ((char *)arg)[length] = '.';
5752 do_spec_1 (suffix_subst, 1, NULL);
5754 else
5755 do_spec_1 (arg, 1, NULL);
5759 do_spec_1 (" ", 0, NULL);
5760 switches[switchnum].validated = 1;
5763 /* Search for a file named NAME trying various prefixes including the
5764 user's -B prefix and some standard ones.
5765 Return the absolute file name found. If nothing is found, return NAME. */
5767 static const char *
5768 find_file (name)
5769 const char *name;
5771 char *newname;
5773 /* Try multilib_dir if it is defined. */
5774 if (multilib_os_dir != NULL)
5776 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
5778 /* If we don't find it in the multi library dir, then fall
5779 through and look for it in the normal places. */
5780 if (newname != NULL)
5781 return newname;
5784 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
5785 return newname ? newname : name;
5788 /* Determine whether a directory exists. If LINKER, return 0 for
5789 certain fixed names not needed by the linker. If not LINKER, it is
5790 only important to return 0 if the host machine has a small ARG_MAX
5791 limit. */
5793 static int
5794 is_directory (path1, path2, linker)
5795 const char *path1;
5796 const char *path2;
5797 int linker;
5799 int len1 = strlen (path1);
5800 int len2 = strlen (path2);
5801 char *path = (char *) alloca (3 + len1 + len2);
5802 char *cp;
5803 struct stat st;
5805 #ifndef SMALL_ARG_MAX
5806 if (! linker)
5807 return 1;
5808 #endif
5810 /* Construct the path from the two parts. Ensure the string ends with "/.".
5811 The resulting path will be a directory even if the given path is a
5812 symbolic link. */
5813 memcpy (path, path1, len1);
5814 memcpy (path + len1, path2, len2);
5815 cp = path + len1 + len2;
5816 if (!IS_DIR_SEPARATOR (cp[-1]))
5817 *cp++ = DIR_SEPARATOR;
5818 *cp++ = '.';
5819 *cp = '\0';
5821 /* Exclude directories that the linker is known to search. */
5822 if (linker
5823 && ((cp - path == 6
5824 && strcmp (path, concat (dir_separator_str, "lib",
5825 dir_separator_str, ".", NULL)) == 0)
5826 || (cp - path == 10
5827 && strcmp (path, concat (dir_separator_str, "usr",
5828 dir_separator_str, "lib",
5829 dir_separator_str, ".", NULL)) == 0)))
5830 return 0;
5832 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5835 /* Set up the various global variables to indicate that we're processing
5836 the input file named FILENAME. */
5838 void
5839 set_input (filename)
5840 const char *filename;
5842 const char *p;
5844 input_filename = filename;
5845 input_filename_length = strlen (input_filename);
5847 input_basename = input_filename;
5848 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5849 /* Skip drive name so 'x:foo' is handled properly. */
5850 if (input_basename[1] == ':')
5851 input_basename += 2;
5852 #endif
5853 for (p = input_basename; *p; p++)
5854 if (IS_DIR_SEPARATOR (*p))
5855 input_basename = p + 1;
5857 /* Find a suffix starting with the last period,
5858 and set basename_length to exclude that suffix. */
5859 basename_length = strlen (input_basename);
5860 suffixed_basename_length = basename_length;
5861 p = input_basename + basename_length;
5862 while (p != input_basename && *p != '.')
5863 --p;
5864 if (*p == '.' && p != input_basename)
5866 basename_length = p - input_basename;
5867 input_suffix = p + 1;
5869 else
5870 input_suffix = "";
5872 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5873 we will need to do a stat on the input_filename. The
5874 INPUT_STAT_SET signals that the stat is needed. */
5875 input_stat_set = 0;
5878 /* On fatal signals, delete all the temporary files. */
5880 static void
5881 fatal_error (signum)
5882 int signum;
5884 signal (signum, SIG_DFL);
5885 delete_failure_queue ();
5886 delete_temp_files ();
5887 /* Get the same signal again, this time not handled,
5888 so its normal effect occurs. */
5889 kill (getpid (), signum);
5892 extern int main PARAMS ((int, const char *const *));
5895 main (argc, argv)
5896 int argc;
5897 const char *const *argv;
5899 size_t i;
5900 int value;
5901 int linker_was_run = 0;
5902 int num_linker_inputs = 0;
5903 char *explicit_link_files;
5904 char *specs_file;
5905 const char *p;
5906 struct user_specs *uptr;
5908 p = argv[0] + strlen (argv[0]);
5909 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
5910 --p;
5911 programname = p;
5913 xmalloc_set_program_name (programname);
5915 #ifdef GCC_DRIVER_HOST_INITIALIZATION
5916 /* Perform host dependent initialization when needed. */
5917 GCC_DRIVER_HOST_INITIALIZATION;
5918 #endif
5920 gcc_init_libintl ();
5922 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
5923 signal (SIGINT, fatal_error);
5924 #ifdef SIGHUP
5925 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
5926 signal (SIGHUP, fatal_error);
5927 #endif
5928 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
5929 signal (SIGTERM, fatal_error);
5930 #ifdef SIGPIPE
5931 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
5932 signal (SIGPIPE, fatal_error);
5933 #endif
5934 #ifdef SIGCHLD
5935 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
5936 receive the signal. A different setting is inheritable */
5937 signal (SIGCHLD, SIG_DFL);
5938 #endif
5940 /* Allocate the argument vector. */
5941 alloc_args ();
5943 obstack_init (&obstack);
5945 /* Build multilib_select, et. al from the separate lines that make up each
5946 multilib selection. */
5948 const char *const *q = multilib_raw;
5949 int need_space;
5951 obstack_init (&multilib_obstack);
5952 while ((p = *q++) != (char *) 0)
5953 obstack_grow (&multilib_obstack, p, strlen (p));
5955 obstack_1grow (&multilib_obstack, 0);
5956 multilib_select = obstack_finish (&multilib_obstack);
5958 q = multilib_matches_raw;
5959 while ((p = *q++) != (char *) 0)
5960 obstack_grow (&multilib_obstack, p, strlen (p));
5962 obstack_1grow (&multilib_obstack, 0);
5963 multilib_matches = obstack_finish (&multilib_obstack);
5965 q = multilib_exclusions_raw;
5966 while ((p = *q++) != (char *) 0)
5967 obstack_grow (&multilib_obstack, p, strlen (p));
5969 obstack_1grow (&multilib_obstack, 0);
5970 multilib_exclusions = obstack_finish (&multilib_obstack);
5972 need_space = FALSE;
5973 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
5975 if (need_space)
5976 obstack_1grow (&multilib_obstack, ' ');
5977 obstack_grow (&multilib_obstack,
5978 multilib_defaults_raw[i],
5979 strlen (multilib_defaults_raw[i]));
5980 need_space = TRUE;
5983 obstack_1grow (&multilib_obstack, 0);
5984 multilib_defaults = obstack_finish (&multilib_obstack);
5987 /* Set up to remember the pathname of gcc and any options
5988 needed for collect. We use argv[0] instead of programname because
5989 we need the complete pathname. */
5990 obstack_init (&collect_obstack);
5991 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
5992 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
5993 putenv (obstack_finish (&collect_obstack));
5995 #ifdef INIT_ENVIRONMENT
5996 /* Set up any other necessary machine specific environment variables. */
5997 putenv (INIT_ENVIRONMENT);
5998 #endif
6000 /* Make a table of what switches there are (switches, n_switches).
6001 Make a table of specified input files (infiles, n_infiles).
6002 Decode switches that are handled locally. */
6004 process_command (argc, argv);
6006 /* Initialize the vector of specs to just the default.
6007 This means one element containing 0s, as a terminator. */
6009 compilers = (struct compiler *) xmalloc (sizeof default_compilers);
6010 memcpy ((char *) compilers, (char *) default_compilers,
6011 sizeof default_compilers);
6012 n_compilers = n_default_compilers;
6014 /* Read specs from a file if there is one. */
6016 machine_suffix = concat (spec_machine, dir_separator_str,
6017 spec_version, dir_separator_str, NULL);
6018 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6020 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6021 /* Read the specs file unless it is a default one. */
6022 if (specs_file != 0 && strcmp (specs_file, "specs"))
6023 read_specs (specs_file, TRUE);
6024 else
6025 init_spec ();
6027 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6028 for any override of as, ld and libraries. */
6029 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6030 + strlen (just_machine_suffix)
6031 + sizeof ("specs"));
6033 strcpy (specs_file, standard_exec_prefix);
6034 strcat (specs_file, just_machine_suffix);
6035 strcat (specs_file, "specs");
6036 if (access (specs_file, R_OK) == 0)
6037 read_specs (specs_file, TRUE);
6039 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6040 of the command line. */
6042 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6043 do_self_spec (driver_self_specs[i]);
6045 /* If not cross-compiling, look for executables in the standard
6046 places. */
6047 if (*cross_compile == '0')
6049 if (*md_exec_prefix)
6051 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6052 PREFIX_PRIORITY_LAST, 0, NULL, 0);
6056 /* Look for startfiles in the standard places. */
6057 if (*startfile_prefix_spec != 0
6058 && do_spec_2 (startfile_prefix_spec) == 0
6059 && do_spec_1 (" ", 0, NULL) == 0)
6061 int ndx;
6062 for (ndx = 0; ndx < argbuf_index; ndx++)
6063 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6064 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6066 /* We should eventually get rid of all these and stick to
6067 startfile_prefix_spec exclusively. */
6068 else if (*cross_compile == '0' || target_system_root)
6070 if (*md_exec_prefix)
6071 add_sysrooted_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
6072 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6074 if (*md_startfile_prefix)
6075 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6076 "GCC", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6078 if (*md_startfile_prefix_1)
6079 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6080 "GCC", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6082 /* If standard_startfile_prefix is relative, base it on
6083 standard_exec_prefix. This lets us move the installed tree
6084 as a unit. If GCC_EXEC_PREFIX is defined, base
6085 standard_startfile_prefix on that as well. */
6086 if (IS_ABSOLUTE_PATHNAME (standard_startfile_prefix))
6087 add_sysrooted_prefix (&startfile_prefixes,
6088 standard_startfile_prefix, "BINUTILS",
6089 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6090 else
6092 if (gcc_exec_prefix)
6093 add_prefix (&startfile_prefixes,
6094 concat (gcc_exec_prefix, machine_suffix,
6095 standard_startfile_prefix, NULL),
6096 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
6097 add_prefix (&startfile_prefixes,
6098 concat (standard_exec_prefix,
6099 machine_suffix,
6100 standard_startfile_prefix, NULL),
6101 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
6104 add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_1,
6105 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6106 add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_2,
6107 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6108 #if 0 /* Can cause surprises, and one can use -B./ instead. */
6109 add_prefix (&startfile_prefixes, "./", NULL,
6110 PREFIX_PRIORITY_LAST, 1, NULL, 0);
6111 #endif
6114 /* Process any user specified specs in the order given on the command
6115 line. */
6116 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6118 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6119 R_OK, 0);
6120 read_specs (filename ? filename : uptr->filename, FALSE);
6123 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6124 if (gcc_exec_prefix)
6125 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6126 spec_version, dir_separator_str, NULL);
6128 /* Now we have the specs.
6129 Set the `valid' bits for switches that match anything in any spec. */
6131 validate_all_switches ();
6133 /* Now that we have the switches and the specs, set
6134 the subdirectory based on the options. */
6135 set_multilib_dir ();
6137 /* Warn about any switches that no pass was interested in. */
6139 for (i = 0; (int) i < n_switches; i++)
6140 if (! switches[i].validated)
6141 error ("unrecognized option `-%s'", switches[i].part1);
6143 /* Obey some of the options. */
6145 if (print_search_dirs)
6147 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6148 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6149 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6150 return (0);
6153 if (print_file_name)
6155 printf ("%s\n", find_file (print_file_name));
6156 return (0);
6159 if (print_prog_name)
6161 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6162 printf ("%s\n", (newname ? newname : print_prog_name));
6163 return (0);
6166 if (print_multi_lib)
6168 print_multilib_info ();
6169 return (0);
6172 if (print_multi_directory)
6174 if (multilib_dir == NULL)
6175 printf (".\n");
6176 else
6177 printf ("%s\n", multilib_dir);
6178 return (0);
6181 if (print_multi_os_directory)
6183 if (multilib_os_dir == NULL)
6184 printf (".\n");
6185 else
6186 printf ("%s\n", multilib_os_dir);
6187 return (0);
6190 if (target_help_flag)
6192 /* Print if any target specific options. */
6194 /* We do not exit here. Instead we have created a fake input file
6195 called 'target-dummy' which needs to be compiled, and we pass this
6196 on to the various sub-processes, along with the --target-help
6197 switch. */
6200 if (print_help_list)
6202 display_help ();
6204 if (! verbose_flag)
6206 printf (_("\nFor bug reporting instructions, please see:\n"));
6207 printf ("%s.\n", bug_report_url);
6209 return (0);
6212 /* We do not exit here. Instead we have created a fake input file
6213 called 'help-dummy' which needs to be compiled, and we pass this
6214 on the various sub-processes, along with the --help switch. */
6217 if (verbose_flag)
6219 int n;
6220 const char *thrmod;
6222 notice ("Configured with: %s\n", configuration_arguments);
6224 #ifdef THREAD_MODEL_SPEC
6225 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6226 but there's no point in doing all this processing just to get
6227 thread_model back. */
6228 obstack_init (&obstack);
6229 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6230 obstack_1grow (&obstack, '\0');
6231 thrmod = obstack_finish (&obstack);
6232 #else
6233 thrmod = thread_model;
6234 #endif
6236 notice ("Thread model: %s\n", thrmod);
6238 /* compiler_version is truncated at the first space when initialized
6239 from version string, so truncate version_string at the first space
6240 before comparing. */
6241 for (n = 0; version_string[n]; n++)
6242 if (version_string[n] == ' ')
6243 break;
6245 if (! strncmp (version_string, compiler_version, n)
6246 && compiler_version[n] == 0)
6247 notice ("gcc version %s\n", version_string);
6248 else
6249 notice ("gcc driver version %s executing gcc version %s\n",
6250 version_string, compiler_version);
6252 if (n_infiles == 0)
6253 return (0);
6256 if (n_infiles == added_libraries)
6257 fatal ("no input files");
6259 /* Make a place to record the compiler output file names
6260 that correspond to the input files. */
6262 i = n_infiles;
6263 i += lang_specific_extra_outfiles;
6264 outfiles = (const char **) xcalloc (i, sizeof (char *));
6266 /* Record which files were specified explicitly as link input. */
6268 explicit_link_files = xcalloc (1, n_infiles);
6270 for (i = 0; (int) i < n_infiles; i++)
6272 int this_file_error = 0;
6274 /* Tell do_spec what to substitute for %i. */
6276 input_file_number = i;
6277 set_input (infiles[i].name);
6279 /* Use the same thing in %o, unless cp->spec says otherwise. */
6281 outfiles[i] = input_filename;
6283 /* Figure out which compiler from the file's suffix. */
6285 input_file_compiler
6286 = lookup_compiler (infiles[i].name, input_filename_length,
6287 infiles[i].language);
6289 if (input_file_compiler)
6291 /* Ok, we found an applicable compiler. Run its spec. */
6293 if (input_file_compiler->spec[0] == '#')
6295 error ("%s: %s compiler not installed on this system",
6296 input_filename, &input_file_compiler->spec[1]);
6297 this_file_error = 1;
6299 else
6301 value = do_spec (input_file_compiler->spec);
6302 if (value < 0)
6303 this_file_error = 1;
6307 /* If this file's name does not contain a recognized suffix,
6308 record it as explicit linker input. */
6310 else
6311 explicit_link_files[i] = 1;
6313 /* Clear the delete-on-failure queue, deleting the files in it
6314 if this compilation failed. */
6316 if (this_file_error)
6318 delete_failure_queue ();
6319 error_count++;
6321 /* If this compilation succeeded, don't delete those files later. */
6322 clear_failure_queue ();
6325 /* Reset the output file name to the first input file name, for use
6326 with %b in LINK_SPEC on a target that prefers not to emit a.out
6327 by default. */
6328 if (n_infiles > 0)
6329 set_input (infiles[0].name);
6331 if (error_count == 0)
6333 /* Make sure INPUT_FILE_NUMBER points to first available open
6334 slot. */
6335 input_file_number = n_infiles;
6336 if (lang_specific_pre_link ())
6337 error_count++;
6340 /* Determine if there are any linker input files. */
6341 num_linker_inputs = 0;
6342 for (i = 0; (int) i < n_infiles; i++)
6343 if (explicit_link_files[i] || outfiles[i] != NULL)
6344 num_linker_inputs++;
6346 /* Run ld to link all the compiler output files. */
6348 if (num_linker_inputs > 0 && error_count == 0)
6350 int tmp = execution_count;
6352 /* We'll use ld if we can't find collect2. */
6353 if (! strcmp (linker_name_spec, "collect2"))
6355 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6356 if (s == NULL)
6357 linker_name_spec = "ld";
6359 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6360 for collect. */
6361 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6362 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6364 value = do_spec (link_command_spec);
6365 if (value < 0)
6366 error_count = 1;
6367 linker_was_run = (tmp != execution_count);
6370 /* If options said don't run linker,
6371 complain about input files to be given to the linker. */
6373 if (! linker_was_run && error_count == 0)
6374 for (i = 0; (int) i < n_infiles; i++)
6375 if (explicit_link_files[i])
6376 error ("%s: linker input file unused because linking not done",
6377 outfiles[i]);
6379 /* Delete some or all of the temporary files we made. */
6381 if (error_count)
6382 delete_failure_queue ();
6383 delete_temp_files ();
6385 if (print_help_list)
6387 printf (("\nFor bug reporting instructions, please see:\n"));
6388 printf ("%s\n", bug_report_url);
6391 return (signal_count != 0 ? 2
6392 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6393 : 0);
6396 /* Find the proper compilation spec for the file name NAME,
6397 whose length is LENGTH. LANGUAGE is the specified language,
6398 or 0 if this file is to be passed to the linker. */
6400 static struct compiler *
6401 lookup_compiler (name, length, language)
6402 const char *name;
6403 size_t length;
6404 const char *language;
6406 struct compiler *cp;
6408 /* If this was specified by the user to be a linker input, indicate that. */
6409 if (language != 0 && language[0] == '*')
6410 return 0;
6412 /* Otherwise, look for the language, if one is spec'd. */
6413 if (language != 0)
6415 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6416 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6417 return cp;
6419 error ("language %s not recognized", language);
6420 return 0;
6423 /* Look for a suffix. */
6424 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6426 if (/* The suffix `-' matches only the file name `-'. */
6427 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6428 || (strlen (cp->suffix) < length
6429 /* See if the suffix matches the end of NAME. */
6430 && !strcmp (cp->suffix,
6431 name + length - strlen (cp->suffix))
6433 break;
6436 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6437 /* look again, but case-insensitively this time. */
6438 if (cp < compilers)
6439 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6441 if (/* The suffix `-' matches only the file name `-'. */
6442 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6443 || (strlen (cp->suffix) < length
6444 /* See if the suffix matches the end of NAME. */
6445 && ((!strcmp (cp->suffix,
6446 name + length - strlen (cp->suffix))
6447 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6448 && !strcasecmp (cp->suffix,
6449 name + length - strlen (cp->suffix)))
6451 break;
6453 #endif
6455 if (cp >= compilers)
6457 if (cp->spec[0] != '@')
6458 /* A non-alias entry: return it. */
6459 return cp;
6461 /* An alias entry maps a suffix to a language.
6462 Search for the language; pass 0 for NAME and LENGTH
6463 to avoid infinite recursion if language not found. */
6464 return lookup_compiler (NULL, 0, cp->spec + 1);
6466 return 0;
6469 static char *
6470 save_string (s, len)
6471 const char *s;
6472 int len;
6474 char *result = xmalloc (len + 1);
6476 memcpy (result, s, len);
6477 result[len] = 0;
6478 return result;
6481 void
6482 pfatal_with_name (name)
6483 const char *name;
6485 perror_with_name (name);
6486 delete_temp_files ();
6487 exit (1);
6490 static void
6491 perror_with_name (name)
6492 const char *name;
6494 error ("%s: %s", name, xstrerror (errno));
6497 static void
6498 pfatal_pexecute (errmsg_fmt, errmsg_arg)
6499 const char *errmsg_fmt;
6500 const char *errmsg_arg;
6502 if (errmsg_arg)
6504 int save_errno = errno;
6506 /* Space for trailing '\0' is in %s. */
6507 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6508 sprintf (msg, errmsg_fmt, errmsg_arg);
6509 errmsg_fmt = msg;
6511 errno = save_errno;
6514 pfatal_with_name (errmsg_fmt);
6517 /* Output an error message and exit */
6519 void
6520 fancy_abort ()
6522 fatal ("internal gcc abort");
6525 /* Output an error message and exit */
6527 void
6528 fatal (const char *msgid, ...)
6530 va_list ap;
6532 va_start (ap, msgid);
6534 fprintf (stderr, "%s: ", programname);
6535 vfprintf (stderr, _(msgid), ap);
6536 va_end (ap);
6537 fprintf (stderr, "\n");
6538 delete_temp_files ();
6539 exit (1);
6542 void
6543 error (const char *msgid, ...)
6545 va_list ap;
6547 va_start (ap, msgid);
6548 fprintf (stderr, "%s: ", programname);
6549 vfprintf (stderr, _(msgid), ap);
6550 va_end (ap);
6552 fprintf (stderr, "\n");
6555 static void
6556 notice (const char *msgid, ...)
6558 va_list ap;
6560 va_start (ap, msgid);
6561 vfprintf (stderr, _(msgid), ap);
6562 va_end (ap);
6565 static inline void
6566 validate_switches_from_spec (spec)
6567 const char *spec;
6569 const char *p = spec;
6570 char c;
6571 while ((c = *p++))
6572 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6573 /* We have a switch spec. */
6574 p = validate_switches (p + 1);
6577 static void
6578 validate_all_switches ()
6580 struct compiler *comp;
6581 struct spec_list *spec;
6583 for (comp = compilers; comp->spec; comp++)
6584 validate_switches_from_spec (comp->spec);
6586 /* Look through the linked list of specs read from the specs file. */
6587 for (spec = specs; spec; spec = spec->next)
6588 validate_switches_from_spec (*spec->ptr_spec);
6590 validate_switches_from_spec (link_command_spec);
6593 /* Look at the switch-name that comes after START
6594 and mark as valid all supplied switches that match it. */
6596 static const char *
6597 validate_switches (start)
6598 const char *start;
6600 const char *p = start;
6601 const char *atom;
6602 size_t len;
6603 int i;
6604 bool suffix = false;
6605 bool starred = false;
6607 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6609 next_member:
6610 SKIP_WHITE ();
6612 if (*p == '!')
6613 p++;
6615 SKIP_WHITE ();
6616 if (*p == '.')
6617 suffix = true, p++;
6619 atom = p;
6620 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6621 || *p == ',' || *p == '.' || *p == '@')
6622 p++;
6623 len = p - atom;
6625 if (*p == '*')
6626 starred = true, p++;
6628 SKIP_WHITE ();
6630 if (!suffix)
6632 /* Mark all matching switches as valid. */
6633 for (i = 0; i < n_switches; i++)
6634 if (!strncmp (switches[i].part1, atom, len)
6635 && (starred || switches[i].part1[len] == 0))
6636 switches[i].validated = 1;
6639 if (*p) p++;
6640 if (*p && (p[-1] == '|' || p[-1] == '&'))
6641 goto next_member;
6643 if (*p && p[-1] == ':')
6645 while (*p && *p != ';' && *p != '}')
6647 if (*p == '%')
6649 p++;
6650 if (*p == '{' || *p == '<')
6651 p = validate_switches (p+1);
6652 else if (p[0] == 'W' && p[1] == '{')
6653 p = validate_switches (p+2);
6655 else
6656 p++;
6659 if (*p) p++;
6660 if (*p && p[-1] == ';')
6661 goto next_member;
6664 return p;
6665 #undef SKIP_WHITE
6668 struct mdswitchstr
6670 const char *str;
6671 int len;
6674 static struct mdswitchstr *mdswitches;
6675 static int n_mdswitches;
6677 /* Check whether a particular argument was used. The first time we
6678 canonicalize the switches to keep only the ones we care about. */
6680 static int
6681 used_arg (p, len)
6682 const char *p;
6683 int len;
6685 struct mswitchstr
6687 const char *str;
6688 const char *replace;
6689 int len;
6690 int rep_len;
6693 static struct mswitchstr *mswitches;
6694 static int n_mswitches;
6695 int i, j;
6697 if (!mswitches)
6699 struct mswitchstr *matches;
6700 const char *q;
6701 int cnt = 0;
6703 /* Break multilib_matches into the component strings of string
6704 and replacement string. */
6705 for (q = multilib_matches; *q != '\0'; q++)
6706 if (*q == ';')
6707 cnt++;
6709 matches =
6710 (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
6711 i = 0;
6712 q = multilib_matches;
6713 while (*q != '\0')
6715 matches[i].str = q;
6716 while (*q != ' ')
6718 if (*q == '\0')
6719 abort ();
6720 q++;
6722 matches[i].len = q - matches[i].str;
6724 matches[i].replace = ++q;
6725 while (*q != ';' && *q != '\0')
6727 if (*q == ' ')
6728 abort ();
6729 q++;
6731 matches[i].rep_len = q - matches[i].replace;
6732 i++;
6733 if (*q == ';')
6734 q++;
6737 /* Now build a list of the replacement string for switches that we care
6738 about. Make sure we allocate at least one entry. This prevents
6739 xmalloc from calling fatal, and prevents us from re-executing this
6740 block of code. */
6741 mswitches
6742 = (struct mswitchstr *)
6743 xmalloc (sizeof (struct mswitchstr)
6744 * (n_mdswitches + (n_switches ? n_switches : 1)));
6745 for (i = 0; i < n_switches; i++)
6747 int xlen = strlen (switches[i].part1);
6748 for (j = 0; j < cnt; j++)
6749 if (xlen == matches[j].len
6750 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6752 mswitches[n_mswitches].str = matches[j].replace;
6753 mswitches[n_mswitches].len = matches[j].rep_len;
6754 mswitches[n_mswitches].replace = (char *) 0;
6755 mswitches[n_mswitches].rep_len = 0;
6756 n_mswitches++;
6757 break;
6761 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
6762 on the command line nor any options mutually incompatible with
6763 them. */
6764 for (i = 0; i < n_mdswitches; i++)
6766 const char *r;
6768 for (q = multilib_options; *q != '\0'; q++)
6770 while (*q == ' ')
6771 q++;
6773 r = q;
6774 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
6775 || strchr (" /", q[mdswitches[i].len]) == NULL)
6777 while (*q != ' ' && *q != '/' && *q != '\0')
6778 q++;
6779 if (*q != '/')
6780 break;
6781 q++;
6784 if (*q != ' ' && *q != '\0')
6786 while (*r != ' ' && *r != '\0')
6788 q = r;
6789 while (*q != ' ' && *q != '/' && *q != '\0')
6790 q++;
6792 if (used_arg (r, q - r))
6793 break;
6795 if (*q != '/')
6797 mswitches[n_mswitches].str = mdswitches[i].str;
6798 mswitches[n_mswitches].len = mdswitches[i].len;
6799 mswitches[n_mswitches].replace = (char *) 0;
6800 mswitches[n_mswitches].rep_len = 0;
6801 n_mswitches++;
6802 break;
6805 r = q + 1;
6807 break;
6813 for (i = 0; i < n_mswitches; i++)
6814 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
6815 return 1;
6817 return 0;
6820 static int
6821 default_arg (p, len)
6822 const char *p;
6823 int len;
6825 int i;
6827 for (i = 0; i < n_mdswitches; i++)
6828 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
6829 return 1;
6831 return 0;
6834 /* Work out the subdirectory to use based on the options. The format of
6835 multilib_select is a list of elements. Each element is a subdirectory
6836 name followed by a list of options followed by a semicolon. The format
6837 of multilib_exclusions is the same, but without the preceding
6838 directory. First gcc will check the exclusions, if none of the options
6839 beginning with an exclamation point are present, and all of the other
6840 options are present, then we will ignore this completely. Passing
6841 that, gcc will consider each multilib_select in turn using the same
6842 rules for matching the options. If a match is found, that subdirectory
6843 will be used. */
6845 static void
6846 set_multilib_dir ()
6848 const char *p;
6849 unsigned int this_path_len;
6850 const char *this_path, *this_arg;
6851 const char *start, *end;
6852 int not_arg;
6853 int ok, ndfltok, first;
6855 n_mdswitches = 0;
6856 start = multilib_defaults;
6857 while (*start == ' ' || *start == '\t')
6858 start++;
6859 while (*start != '\0')
6861 n_mdswitches++;
6862 while (*start != ' ' && *start != '\t' && *start != '\0')
6863 start++;
6864 while (*start == ' ' || *start == '\t')
6865 start++;
6868 if (n_mdswitches)
6870 int i = 0;
6872 mdswitches
6873 = (struct mdswitchstr *) xmalloc (sizeof (struct mdswitchstr)
6874 * n_mdswitches);
6875 for (start = multilib_defaults; *start != '\0'; start = end + 1)
6877 while (*start == ' ' || *start == '\t')
6878 start++;
6880 if (*start == '\0')
6881 break;
6883 for (end = start + 1;
6884 *end != ' ' && *end != '\t' && *end != '\0'; end++)
6887 obstack_grow (&multilib_obstack, start, end - start);
6888 obstack_1grow (&multilib_obstack, 0);
6889 mdswitches[i].str = obstack_finish (&multilib_obstack);
6890 mdswitches[i++].len = end - start;
6892 if (*end == '\0')
6893 break;
6897 p = multilib_exclusions;
6898 while (*p != '\0')
6900 /* Ignore newlines. */
6901 if (*p == '\n')
6903 ++p;
6904 continue;
6907 /* Check the arguments. */
6908 ok = 1;
6909 while (*p != ';')
6911 if (*p == '\0')
6912 abort ();
6914 if (! ok)
6916 ++p;
6917 continue;
6920 this_arg = p;
6921 while (*p != ' ' && *p != ';')
6923 if (*p == '\0')
6924 abort ();
6925 ++p;
6928 if (*this_arg != '!')
6929 not_arg = 0;
6930 else
6932 not_arg = 1;
6933 ++this_arg;
6936 ok = used_arg (this_arg, p - this_arg);
6937 if (not_arg)
6938 ok = ! ok;
6940 if (*p == ' ')
6941 ++p;
6944 if (ok)
6945 return;
6947 ++p;
6950 first = 1;
6951 p = multilib_select;
6952 while (*p != '\0')
6954 /* Ignore newlines. */
6955 if (*p == '\n')
6957 ++p;
6958 continue;
6961 /* Get the initial path. */
6962 this_path = p;
6963 while (*p != ' ')
6965 if (*p == '\0')
6966 abort ();
6967 ++p;
6969 this_path_len = p - this_path;
6971 /* Check the arguments. */
6972 ok = 1;
6973 ndfltok = 1;
6974 ++p;
6975 while (*p != ';')
6977 if (*p == '\0')
6978 abort ();
6980 if (! ok)
6982 ++p;
6983 continue;
6986 this_arg = p;
6987 while (*p != ' ' && *p != ';')
6989 if (*p == '\0')
6990 abort ();
6991 ++p;
6994 if (*this_arg != '!')
6995 not_arg = 0;
6996 else
6998 not_arg = 1;
6999 ++this_arg;
7002 /* If this is a default argument, we can just ignore it.
7003 This is true even if this_arg begins with '!'. Beginning
7004 with '!' does not mean that this argument is necessarily
7005 inappropriate for this library: it merely means that
7006 there is a more specific library which uses this
7007 argument. If this argument is a default, we need not
7008 consider that more specific library. */
7009 ok = used_arg (this_arg, p - this_arg);
7010 if (not_arg)
7011 ok = ! ok;
7013 if (! ok)
7014 ndfltok = 0;
7016 if (default_arg (this_arg, p - this_arg))
7017 ok = 1;
7019 if (*p == ' ')
7020 ++p;
7023 if (ok && first)
7025 if (this_path_len != 1
7026 || this_path[0] != '.')
7028 char *new_multilib_dir = xmalloc (this_path_len + 1);
7029 char *q;
7031 strncpy (new_multilib_dir, this_path, this_path_len);
7032 new_multilib_dir[this_path_len] = '\0';
7033 q = strchr (new_multilib_dir, ':');
7034 if (q != NULL)
7035 *q = '\0';
7036 multilib_dir = new_multilib_dir;
7038 first = 0;
7041 if (ndfltok)
7043 const char *q = this_path, *end = this_path + this_path_len;
7045 while (q < end && *q != ':')
7046 q++;
7047 if (q < end)
7049 char *new_multilib_os_dir = xmalloc (end - q);
7050 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7051 new_multilib_os_dir[end - q - 1] = '\0';
7052 multilib_os_dir = new_multilib_os_dir;
7053 break;
7057 ++p;
7060 if (multilib_dir == NULL && multilib_os_dir != NULL
7061 && strcmp (multilib_os_dir, ".") == 0)
7063 free ((char *) multilib_os_dir);
7064 multilib_os_dir = NULL;
7066 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7067 multilib_os_dir = multilib_dir;
7070 /* Print out the multiple library subdirectory selection
7071 information. This prints out a series of lines. Each line looks
7072 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7073 required. Only the desired options are printed out, the negative
7074 matches. The options are print without a leading dash. There are
7075 no spaces to make it easy to use the information in the shell.
7076 Each subdirectory is printed only once. This assumes the ordering
7077 generated by the genmultilib script. Also, we leave out ones that match
7078 the exclusions. */
7080 static void
7081 print_multilib_info ()
7083 const char *p = multilib_select;
7084 const char *last_path = 0, *this_path;
7085 int skip;
7086 unsigned int last_path_len = 0;
7088 while (*p != '\0')
7090 skip = 0;
7091 /* Ignore newlines. */
7092 if (*p == '\n')
7094 ++p;
7095 continue;
7098 /* Get the initial path. */
7099 this_path = p;
7100 while (*p != ' ')
7102 if (*p == '\0')
7103 abort ();
7104 ++p;
7107 /* When --disable-multilib was used but target defines
7108 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7109 to find multilib_os_dir, so skip them from output. */
7110 if (this_path[0] == '.' && this_path[1] == ':')
7111 skip = 1;
7113 /* Check for matches with the multilib_exclusions. We don't bother
7114 with the '!' in either list. If any of the exclusion rules match
7115 all of its options with the select rule, we skip it. */
7117 const char *e = multilib_exclusions;
7118 const char *this_arg;
7120 while (*e != '\0')
7122 int m = 1;
7123 /* Ignore newlines. */
7124 if (*e == '\n')
7126 ++e;
7127 continue;
7130 /* Check the arguments. */
7131 while (*e != ';')
7133 const char *q;
7134 int mp = 0;
7136 if (*e == '\0')
7137 abort ();
7139 if (! m)
7141 ++e;
7142 continue;
7145 this_arg = e;
7147 while (*e != ' ' && *e != ';')
7149 if (*e == '\0')
7150 abort ();
7151 ++e;
7154 q = p + 1;
7155 while (*q != ';')
7157 const char *arg;
7158 int len = e - this_arg;
7160 if (*q == '\0')
7161 abort ();
7163 arg = q;
7165 while (*q != ' ' && *q != ';')
7167 if (*q == '\0')
7168 abort ();
7169 ++q;
7172 if (! strncmp (arg, this_arg, (len < q - arg) ? q - arg : len) ||
7173 default_arg (this_arg, e - this_arg))
7175 mp = 1;
7176 break;
7179 if (*q == ' ')
7180 ++q;
7183 if (! mp)
7184 m = 0;
7186 if (*e == ' ')
7187 ++e;
7190 if (m)
7192 skip = 1;
7193 break;
7196 if (*e != '\0')
7197 ++e;
7201 if (! skip)
7203 /* If this is a duplicate, skip it. */
7204 skip = (last_path != 0 && (unsigned int) (p - this_path) == last_path_len
7205 && ! strncmp (last_path, this_path, last_path_len));
7207 last_path = this_path;
7208 last_path_len = p - this_path;
7211 /* If this directory requires any default arguments, we can skip
7212 it. We will already have printed a directory identical to
7213 this one which does not require that default argument. */
7214 if (! skip)
7216 const char *q;
7218 q = p + 1;
7219 while (*q != ';')
7221 const char *arg;
7223 if (*q == '\0')
7224 abort ();
7226 if (*q == '!')
7227 arg = NULL;
7228 else
7229 arg = q;
7231 while (*q != ' ' && *q != ';')
7233 if (*q == '\0')
7234 abort ();
7235 ++q;
7238 if (arg != NULL
7239 && default_arg (arg, q - arg))
7241 skip = 1;
7242 break;
7245 if (*q == ' ')
7246 ++q;
7250 if (! skip)
7252 const char *p1;
7254 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7255 putchar (*p1);
7256 putchar (';');
7259 ++p;
7260 while (*p != ';')
7262 int use_arg;
7264 if (*p == '\0')
7265 abort ();
7267 if (skip)
7269 ++p;
7270 continue;
7273 use_arg = *p != '!';
7275 if (use_arg)
7276 putchar ('@');
7278 while (*p != ' ' && *p != ';')
7280 if (*p == '\0')
7281 abort ();
7282 if (use_arg)
7283 putchar (*p);
7284 ++p;
7287 if (*p == ' ')
7288 ++p;
7291 if (! skip)
7293 /* If there are extra options, print them now. */
7294 if (multilib_extra && *multilib_extra)
7296 int print_at = TRUE;
7297 const char *q;
7299 for (q = multilib_extra; *q != '\0'; q++)
7301 if (*q == ' ')
7302 print_at = TRUE;
7303 else
7305 if (print_at)
7306 putchar ('@');
7307 putchar (*q);
7308 print_at = FALSE;
7313 putchar ('\n');
7316 ++p;
7320 /* if-exists built-in spec function.
7322 Checks to see if the file specified by the absolute pathname in
7323 ARGS exists. Returns that pathname if found.
7325 The usual use for this function is to check for a library file
7326 (whose name has been expanded with %s). */
7328 static const char *
7329 if_exists_spec_function (argc, argv)
7330 int argc;
7331 const char **argv;
7333 /* Must have only one argument. */
7334 if (argc == 1 && IS_ABSOLUTE_PATHNAME (argv[0]) && ! access (argv[0], R_OK))
7335 return argv[0];
7337 return NULL;
7340 /* if-exists-else built-in spec function.
7342 This is like if-exists, but takes an additional argument which
7343 is returned if the first argument does not exist. */
7345 static const char *
7346 if_exists_else_spec_function (argc, argv)
7347 int argc;
7348 const char **argv;
7350 /* Must have exactly two arguments. */
7351 if (argc != 2)
7352 return NULL;
7354 if (IS_ABSOLUTE_PATHNAME (argv[0]) && ! access (argv[0], R_OK))
7355 return argv[0];
7357 return argv[1];