Merge from mainline (gomp-merge-2005-02-26).
[official-gcc.git] / gcc / gcc.c
blob1a9cc5005d6f95d6f016745ccf9c9f526a264207
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation,
4 Inc.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2, or (at your option) any later
11 version.
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING. If not, write to the Free
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
21 02111-1307, USA.
23 This paragraph is here to try to keep Sun CC from dying.
24 The number of chars here seems crucial!!!! */
26 /* This program is the user interface to the C compiler and possibly to
27 other compilers. It is used because compilation is a complicated procedure
28 which involves running several programs and passing temporary files between
29 them, forwarding the users switches to those programs selectively,
30 and deleting the temporary files at the end.
32 CC recognizes how to compile each input file by suffixes in the file names.
33 Once it knows which kind of compilation to perform, the procedure for
34 compilation is specified by a string called a "spec". */
36 /* A Short Introduction to Adding a Command-Line Option.
38 Before adding a command-line option, consider if it is really
39 necessary. Each additional command-line option adds complexity and
40 is difficult to remove in subsequent versions.
42 In the following, consider adding the command-line argument
43 `--bar'.
45 1. Each command-line option is specified in the specs file. The
46 notation is described below in the comment entitled "The Specs
47 Language". Read it.
49 2. In this file, add an entry to "option_map" equating the long
50 `--' argument version and any shorter, single letter version. Read
51 the comments in the declaration of "struct option_map" for an
52 explanation. Do not omit the first `-'.
54 3. Look in the "specs" file to determine which program or option
55 list should be given the argument, e.g., "cc1_options". Add the
56 appropriate syntax for the shorter option version to the
57 corresponding "const char *" entry in this file. Omit the first
58 `-' from the option. For example, use `-bar', rather than `--bar'.
60 4. If the argument takes an argument, e.g., `--baz argument1',
61 modify either DEFAULT_SWITCH_TAKES_ARG or
62 DEFAULT_WORD_SWITCH_TAKES_ARG in this file. Omit the first `-'
63 from `--baz'.
65 5. Document the option in this file's display_help(). If the
66 option is passed to a subprogram, modify its corresponding
67 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
68 instead.
70 6. Compile and test. Make sure that your new specs file is being
71 read. For example, use a debugger to investigate the value of
72 "specs_file" in main(). */
74 #include "config.h"
75 #include "system.h"
76 #include "coretypes.h"
77 #include "multilib.h" /* before tm.h */
78 #include "tm.h"
79 #include <signal.h>
80 #if ! defined( SIGCHLD ) && defined( SIGCLD )
81 # define SIGCHLD SIGCLD
82 #endif
83 #include "obstack.h"
84 #include "intl.h"
85 #include "prefix.h"
86 #include "gcc.h"
87 #include "flags.h"
89 #ifdef HAVE_SYS_RESOURCE_H
90 #include <sys/resource.h>
91 #endif
92 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
93 extern int getrusage (int, struct rusage *);
94 #endif
96 /* By default there is no special suffix for target executables. */
97 /* FIXME: when autoconf is fixed, remove the host check - dj */
98 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
99 #define HAVE_TARGET_EXECUTABLE_SUFFIX
100 #endif
102 /* By default there is no special suffix for host executables. */
103 #ifdef HOST_EXECUTABLE_SUFFIX
104 #define HAVE_HOST_EXECUTABLE_SUFFIX
105 #else
106 #define HOST_EXECUTABLE_SUFFIX ""
107 #endif
109 /* By default, the suffix for target object files is ".o". */
110 #ifdef TARGET_OBJECT_SUFFIX
111 #define HAVE_TARGET_OBJECT_SUFFIX
112 #else
113 #define TARGET_OBJECT_SUFFIX ".o"
114 #endif
116 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
118 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
119 #ifndef LIBRARY_PATH_ENV
120 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
121 #endif
123 #ifndef HAVE_KILL
124 #define kill(p,s) raise(s)
125 #endif
127 /* If a stage of compilation returns an exit status >= 1,
128 compilation of that file ceases. */
130 #define MIN_FATAL_STATUS 1
132 /* Flag set by cppspec.c to 1. */
133 int is_cpp_driver;
135 /* Flag saying to pass the greatest exit code returned by a sub-process
136 to the calling program. */
137 static int pass_exit_codes;
139 /* Definition of string containing the arguments given to configure. */
140 #include "configargs.h"
142 /* Flag saying to print the directories gcc will search through looking for
143 programs, libraries, etc. */
145 static int print_search_dirs;
147 /* Flag saying to print the full filename of this file
148 as found through our usual search mechanism. */
150 static const char *print_file_name = NULL;
152 /* As print_file_name, but search for executable file. */
154 static const char *print_prog_name = NULL;
156 /* Flag saying to print the relative path we'd use to
157 find libgcc.a given the current compiler flags. */
159 static int print_multi_directory;
161 /* Flag saying to print the relative path we'd use to
162 find OS libraries given the current compiler flags. */
164 static int print_multi_os_directory;
166 /* Flag saying to print the list of subdirectories and
167 compiler flags used to select them in a standard form. */
169 static int print_multi_lib;
171 /* Flag saying to print the command line options understood by gcc and its
172 sub-processes. */
174 static int print_help_list;
176 /* Flag indicating whether we should print the command and arguments */
178 static int verbose_flag;
180 /* Flag indicating whether we should ONLY print the command and
181 arguments (like verbose_flag) without executing the command.
182 Displayed arguments are quoted so that the generated command
183 line is suitable for execution. This is intended for use in
184 shell scripts to capture the driver-generated command line. */
185 static int verbose_only_flag;
187 /* Flag indicating to print target specific command line options. */
189 static int target_help_flag;
191 /* Flag indicating whether we should report subprocess execution times
192 (if this is supported by the system - see pexecute.c). */
194 static int report_times;
196 /* Nonzero means place this string before uses of /, so that include
197 and library files can be found in an alternate location. */
199 #ifdef TARGET_SYSTEM_ROOT
200 static const char *target_system_root = TARGET_SYSTEM_ROOT;
201 #else
202 static const char *target_system_root = 0;
203 #endif
205 /* Nonzero means pass the updated target_system_root to the compiler. */
207 static int target_system_root_changed;
209 /* Nonzero means append this string to target_system_root. */
211 static const char *target_sysroot_suffix = 0;
213 /* Nonzero means append this string to target_system_root for headers. */
215 static const char *target_sysroot_hdrs_suffix = 0;
217 /* Nonzero means write "temp" files in source directory
218 and use the source file's name in them, and don't delete them. */
220 static int save_temps_flag;
222 /* Nonzero means pass multiple source files to the compiler at one time. */
224 static int combine_flag = 0;
226 /* Nonzero means use pipes to communicate between subprocesses.
227 Overridden by either of the above two flags. */
229 static int use_pipes;
231 /* The compiler version. */
233 static const char *compiler_version;
235 /* The target version specified with -V */
237 static const char *const spec_version = DEFAULT_TARGET_VERSION;
239 /* The target machine specified with -b. */
241 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
243 /* Nonzero if cross-compiling.
244 When -b is used, the value comes from the `specs' file. */
246 #ifdef CROSS_COMPILE
247 static const char *cross_compile = "1";
248 #else
249 static const char *cross_compile = "0";
250 #endif
252 #ifdef MODIFY_TARGET_NAME
254 /* Information on how to alter the target name based on a command-line
255 switch. The only case we support now is simply appending or deleting a
256 string to or from the end of the first part of the configuration name. */
258 static const struct modify_target
260 const char *const sw;
261 const enum add_del {ADD, DELETE} add_del;
262 const char *const str;
264 modify_target[] = MODIFY_TARGET_NAME;
265 #endif
267 /* The number of errors that have occurred; the link phase will not be
268 run if this is nonzero. */
269 static int error_count = 0;
271 /* Greatest exit code of sub-processes that has been encountered up to
272 now. */
273 static int greatest_status = 1;
275 /* This is the obstack which we use to allocate many strings. */
277 static struct obstack obstack;
279 /* This is the obstack to build an environment variable to pass to
280 collect2 that describes all of the relevant switches of what to
281 pass the compiler in building the list of pointers to constructors
282 and destructors. */
284 static struct obstack collect_obstack;
286 /* These structs are used to collect resource usage information for
287 subprocesses. */
288 #ifdef HAVE_GETRUSAGE
289 static struct rusage rus, prus;
290 #endif
292 /* Forward declaration for prototypes. */
293 struct path_prefix;
294 struct prefix_list;
296 static void init_spec (void);
297 static void store_arg (const char *, int, int);
298 static char *load_specs (const char *);
299 static void read_specs (const char *, int);
300 static void set_spec (const char *, const char *);
301 static struct compiler *lookup_compiler (const char *, size_t, const char *);
302 static char *build_search_list (struct path_prefix *, const char *, int);
303 static void putenv_from_prefixes (struct path_prefix *, const char *);
304 static int access_check (const char *, int);
305 static char *find_a_file (struct path_prefix *, const char *, int, int);
306 static void add_prefix (struct path_prefix *, const char *, const char *,
307 int, int, int);
308 static void add_sysrooted_prefix (struct path_prefix *, const char *,
309 const char *, int, int, int);
310 static void translate_options (int *, const char *const **);
311 static char *skip_whitespace (char *);
312 static void delete_if_ordinary (const char *);
313 static void delete_temp_files (void);
314 static void delete_failure_queue (void);
315 static void clear_failure_queue (void);
316 static int check_live_switch (int, int);
317 static const char *handle_braces (const char *);
318 static inline bool input_suffix_matches (const char *, const char *);
319 static inline bool switch_matches (const char *, const char *, int);
320 static inline void mark_matching_switches (const char *, const char *, int);
321 static inline void process_marked_switches (void);
322 static const char *process_brace_body (const char *, const char *, const char *, int, int);
323 static const struct spec_function *lookup_spec_function (const char *);
324 static const char *eval_spec_function (const char *, const char *);
325 static const char *handle_spec_function (const char *);
326 static char *save_string (const char *, int);
327 static void set_collect_gcc_options (void);
328 static void do_spec_path (struct prefix_list *, const char *, int, int, int, const char *, const char *);
329 static int do_spec_1 (const char *, int, const char *);
330 static int do_spec_2 (const char *);
331 static void do_option_spec (const char *, const char *);
332 static void do_self_spec (const char *);
333 static const char *find_file (const char *);
334 static int is_directory (const char *, const char *, int);
335 static const char *validate_switches (const char *);
336 static void validate_all_switches (void);
337 static inline void validate_switches_from_spec (const char *);
338 static void give_switch (int, int);
339 static int used_arg (const char *, int);
340 static int default_arg (const char *, int);
341 static void set_multilib_dir (void);
342 static void print_multilib_info (void);
343 static void perror_with_name (const char *);
344 static void pfatal_pexecute (const char *, const char *) ATTRIBUTE_NORETURN;
345 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
346 static void display_help (void);
347 static void add_preprocessor_option (const char *, int);
348 static void add_assembler_option (const char *, int);
349 static void add_linker_option (const char *, int);
350 static void process_command (int, const char **);
351 static int execute (void);
352 static void alloc_args (void);
353 static void clear_args (void);
354 static void fatal_error (int);
355 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
356 static void init_gcc_specs (struct obstack *, const char *, const char *,
357 const char *);
358 #endif
359 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
360 static const char *convert_filename (const char *, int, int);
361 #endif
363 static const char *if_exists_spec_function (int, const char **);
364 static const char *if_exists_else_spec_function (int, const char **);
365 static const char *replace_outfile_spec_function (int, const char **);
367 /* The Specs Language
369 Specs are strings containing lines, each of which (if not blank)
370 is made up of a program name, and arguments separated by spaces.
371 The program name must be exact and start from root, since no path
372 is searched and it is unreliable to depend on the current working directory.
373 Redirection of input or output is not supported; the subprograms must
374 accept filenames saying what files to read and write.
376 In addition, the specs can contain %-sequences to substitute variable text
377 or for conditional text. Here is a table of all defined %-sequences.
378 Note that spaces are not generated automatically around the results of
379 expanding these sequences; therefore, you can concatenate them together
380 or with constant text in a single argument.
382 %% substitute one % into the program name or argument.
383 %i substitute the name of the input file being processed.
384 %b substitute the basename of the input file being processed.
385 This is the substring up to (and not including) the last period
386 and not including the directory.
387 %B same as %b, but include the file suffix (text after the last period).
388 %gSUFFIX
389 substitute a file name that has suffix SUFFIX and is chosen
390 once per compilation, and mark the argument a la %d. To reduce
391 exposure to denial-of-service attacks, the file name is now
392 chosen in a way that is hard to predict even when previously
393 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
394 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
395 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
396 had been pre-processed. Previously, %g was simply substituted
397 with a file name chosen once per compilation, without regard
398 to any appended suffix (which was therefore treated just like
399 ordinary text), making such attacks more likely to succeed.
400 %|SUFFIX
401 like %g, but if -pipe is in effect, expands simply to "-".
402 %mSUFFIX
403 like %g, but if -pipe is in effect, expands to nothing. (We have both
404 %| and %m to accommodate differences between system assemblers; see
405 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
406 %uSUFFIX
407 like %g, but generates a new temporary file name even if %uSUFFIX
408 was already seen.
409 %USUFFIX
410 substitutes the last file name generated with %uSUFFIX, generating a
411 new one if there is no such last file name. In the absence of any
412 %uSUFFIX, this is just like %gSUFFIX, except they don't share
413 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
414 would involve the generation of two distinct file names, one
415 for each `%g.s' and another for each `%U.s'. Previously, %U was
416 simply substituted with a file name chosen for the previous %u,
417 without regard to any appended suffix.
418 %jSUFFIX
419 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
420 writable, and if save-temps is off; otherwise, substitute the name
421 of a temporary file, just like %u. This temporary file is not
422 meant for communication between processes, but rather as a junk
423 disposal mechanism.
424 %.SUFFIX
425 substitutes .SUFFIX for the suffixes of a matched switch's args when
426 it is subsequently output with %*. SUFFIX is terminated by the next
427 space or %.
428 %d marks the argument containing or following the %d as a
429 temporary file name, so that that file will be deleted if CC exits
430 successfully. Unlike %g, this contributes no text to the argument.
431 %w marks the argument containing or following the %w as the
432 "output file" of this compilation. This puts the argument
433 into the sequence of arguments that %o will substitute later.
434 %V indicates that this compilation produces no "output file".
435 %W{...}
436 like %{...} but mark last argument supplied within
437 as a file to be deleted on failure.
438 %o substitutes the names of all the output files, with spaces
439 automatically placed around them. You should write spaces
440 around the %o as well or the results are undefined.
441 %o is for use in the specs for running the linker.
442 Input files whose names have no recognized suffix are not compiled
443 at all, but they are included among the output files, so they will
444 be linked.
445 %O substitutes the suffix for object files. Note that this is
446 handled specially when it immediately follows %g, %u, or %U
447 (with or without a suffix argument) because of the need for
448 those to form complete file names. The handling is such that
449 %O is treated exactly as if it had already been substituted,
450 except that %g, %u, and %U do not currently support additional
451 SUFFIX characters following %O as they would following, for
452 example, `.o'.
453 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
454 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
455 and -B options) as necessary.
456 %s current argument is the name of a library or startup file of some sort.
457 Search for that file in a standard list of directories
458 and substitute the full name found.
459 %eSTR Print STR as an error message. STR is terminated by a newline.
460 Use this when inconsistent options are detected.
461 %nSTR Print STR as a notice. STR is terminated by a newline.
462 %x{OPTION} Accumulate an option for %X.
463 %X Output the accumulated linker options specified by compilations.
464 %Y Output the accumulated assembler options specified by compilations.
465 %Z Output the accumulated preprocessor options specified by compilations.
466 %a process ASM_SPEC as a spec.
467 This allows config.h to specify part of the spec for running as.
468 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
469 used here. This can be used to run a post-processor after the
470 assembler has done its job.
471 %D Dump out a -L option for each directory in startfile_prefixes.
472 If multilib_dir is set, extra entries are generated with it affixed.
473 %l process LINK_SPEC as a spec.
474 %L process LIB_SPEC as a spec.
475 %G process LIBGCC_SPEC as a spec.
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 /* mudflap specs */
605 #ifndef MFWRAP_SPEC
606 /* XXX: valid only for GNU ld */
607 /* XXX: should exactly match hooks provided by libmudflap.a */
608 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
609 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
610 --wrap=mmap --wrap=munmap --wrap=alloca\
611 } %{fmudflapth: --wrap=pthread_create --wrap=pthread_join --wrap=pthread_exit\
612 }} %{fmudflap|fmudflapth: --wrap=main}"
613 #endif
614 #ifndef MFLIB_SPEC
615 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
616 #endif
618 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
619 included. */
620 #ifndef LIBGCC_SPEC
621 #if defined(REAL_LIBGCC_SPEC)
622 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
623 #elif defined(LINK_LIBGCC_SPECIAL_1)
624 /* Have gcc do the search for libgcc.a. */
625 #define LIBGCC_SPEC "libgcc.a%s"
626 #else
627 #define LIBGCC_SPEC "-lgcc"
628 #endif
629 #endif
631 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
632 #ifndef STARTFILE_SPEC
633 #define STARTFILE_SPEC \
634 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
635 #endif
637 /* config.h can define SWITCHES_NEED_SPACES to control which options
638 require spaces between the option and the argument. */
639 #ifndef SWITCHES_NEED_SPACES
640 #define SWITCHES_NEED_SPACES ""
641 #endif
643 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
644 #ifndef ENDFILE_SPEC
645 #define ENDFILE_SPEC ""
646 #endif
648 #ifndef LINKER_NAME
649 #define LINKER_NAME "collect2"
650 #endif
652 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
653 to the assembler. */
654 #ifndef ASM_DEBUG_SPEC
655 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
656 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
657 # define ASM_DEBUG_SPEC \
658 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
659 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
660 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
661 # else
662 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
663 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
664 # endif
665 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
666 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
667 # endif
668 # endif
669 #endif
670 #ifndef ASM_DEBUG_SPEC
671 # define ASM_DEBUG_SPEC ""
672 #endif
674 /* Here is the spec for running the linker, after compiling all files. */
676 /* This is overridable by the target in case they need to specify the
677 -lgcc and -lc order specially, yet not require them to override all
678 of LINK_COMMAND_SPEC. */
679 #ifndef LINK_GCC_C_SEQUENCE_SPEC
680 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
681 #endif
683 #ifndef LINK_PIE_SPEC
684 #ifdef HAVE_LD_PIE
685 #define LINK_PIE_SPEC "%{pie:-pie} "
686 #else
687 #define LINK_PIE_SPEC "%{pie:} "
688 #endif
689 #endif
691 /* -u* was put back because both BSD and SysV seem to support it. */
692 /* %{static:} simply prevents an error message if the target machine
693 doesn't handle -static. */
694 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
695 scripts which exist in user specified directories, or in standard
696 directories. */
697 #ifndef LINK_COMMAND_SPEC
698 #define LINK_COMMAND_SPEC "\
699 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
700 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
701 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
702 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o %(mflib)\
703 %{fprofile-arcs|fprofile-generate:-lgcov}\
704 %{!nostdlib:%{!nodefaultlibs:%(link_gcc_c_sequence)}}\
705 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
706 #endif
708 #ifndef LINK_LIBGCC_SPEC
709 /* Generate -L options for startfile prefix list. */
710 # define LINK_LIBGCC_SPEC "%D"
711 #endif
713 #ifndef STARTFILE_PREFIX_SPEC
714 # define STARTFILE_PREFIX_SPEC ""
715 #endif
717 #ifndef SYSROOT_SUFFIX_SPEC
718 # define SYSROOT_SUFFIX_SPEC ""
719 #endif
721 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
722 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
723 #endif
725 static const char *asm_debug;
726 static const char *cpp_spec = CPP_SPEC;
727 static const char *cc1_spec = CC1_SPEC;
728 static const char *cc1plus_spec = CC1PLUS_SPEC;
729 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
730 static const char *asm_spec = ASM_SPEC;
731 static const char *asm_final_spec = ASM_FINAL_SPEC;
732 static const char *link_spec = LINK_SPEC;
733 static const char *lib_spec = LIB_SPEC;
734 static const char *mfwrap_spec = MFWRAP_SPEC;
735 static const char *mflib_spec = MFLIB_SPEC;
736 static const char *libgcc_spec = LIBGCC_SPEC;
737 static const char *endfile_spec = ENDFILE_SPEC;
738 static const char *startfile_spec = STARTFILE_SPEC;
739 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
740 static const char *linker_name_spec = LINKER_NAME;
741 static const char *link_command_spec = LINK_COMMAND_SPEC;
742 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
743 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
744 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
745 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
747 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
748 There should be no need to override these in target dependent files,
749 but we need to copy them to the specs file so that newer versions
750 of the GCC driver can correctly drive older tool chains with the
751 appropriate -B options. */
753 /* When cpplib handles traditional preprocessing, get rid of this, and
754 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
755 that we default the front end language better. */
756 static const char *trad_capable_cpp =
757 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
759 /* We don't wrap .d files in %W{} since a missing .d file, and
760 therefore no dependency entry, confuses make into thinking a .o
761 file that happens to exist is up-to-date. */
762 static const char *cpp_unique_options =
763 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
764 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
765 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
766 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
767 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
768 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
769 %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
770 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
771 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
772 %{E|M|MM:%W{o*}}";
774 /* This contains cpp options which are common with cc1_options and are passed
775 only when preprocessing only to avoid duplication. We pass the cc1 spec
776 options to the preprocessor so that it the cc1 spec may manipulate
777 options used to set target flags. Those special target flags settings may
778 in turn cause preprocessor symbols to be defined specially. */
779 static const char *cpp_options =
780 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
781 %{f*} %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*}\
782 %{undef} %{save-temps:-fpch-preprocess}";
784 /* This contains cpp options which are not passed when the preprocessor
785 output will be used by another program. */
786 static const char *cpp_debug_options = "%{d*}";
788 /* NB: This is shared amongst all front-ends. */
789 static const char *cc1_options =
790 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
791 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
792 %{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}%{!c:%{!S:-auxbase %b}}\
793 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
794 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
795 %{Qn:-fno-ident} %{--help:--help}\
796 %{--target-help:--target-help}\
797 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
798 %{fsyntax-only:-o %j} %{-param*}\
799 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}";
801 static const char *asm_options =
802 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
804 static const char *invoke_as =
805 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
806 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
807 #else
808 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
809 #endif
811 /* Some compilers have limits on line lengths, and the multilib_select
812 and/or multilib_matches strings can be very long, so we build them at
813 run time. */
814 static struct obstack multilib_obstack;
815 static const char *multilib_select;
816 static const char *multilib_matches;
817 static const char *multilib_defaults;
818 static const char *multilib_exclusions;
820 /* Check whether a particular argument is a default argument. */
822 #ifndef MULTILIB_DEFAULTS
823 #define MULTILIB_DEFAULTS { "" }
824 #endif
826 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
828 #ifndef DRIVER_SELF_SPECS
829 #define DRIVER_SELF_SPECS ""
830 #endif
832 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
834 #ifndef OPTION_DEFAULT_SPECS
835 #define OPTION_DEFAULT_SPECS { "", "" }
836 #endif
838 struct default_spec
840 const char *name;
841 const char *spec;
844 static const struct default_spec
845 option_default_specs[] = { OPTION_DEFAULT_SPECS };
847 struct user_specs
849 struct user_specs *next;
850 const char *filename;
853 static struct user_specs *user_specs_head, *user_specs_tail;
855 #ifndef SWITCH_TAKES_ARG
856 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
857 #endif
859 #ifndef WORD_SWITCH_TAKES_ARG
860 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
861 #endif
863 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
864 /* This defines which switches stop a full compilation. */
865 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
866 ((CHAR) == 'c' || (CHAR) == 'S')
868 #ifndef SWITCH_CURTAILS_COMPILATION
869 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
870 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
871 #endif
872 #endif
874 /* Record the mapping from file suffixes for compilation specs. */
876 struct compiler
878 const char *suffix; /* Use this compiler for input files
879 whose names end in this suffix. */
881 const char *spec; /* To use this compiler, run this spec. */
883 const char *cpp_spec; /* If non-NULL, substitute this spec
884 for `%C', rather than the usual
885 cpp_spec. */
886 const int combinable; /* If nonzero, compiler can deal with
887 multiple source files at once (IMA). */
888 const int needs_preprocessing; /* If nonzero, source files need to
889 be run through a preprocessor. */
892 /* Pointer to a vector of `struct compiler' that gives the spec for
893 compiling a file, based on its suffix.
894 A file that does not end in any of these suffixes will be passed
895 unchanged to the loader and nothing else will be done to it.
897 An entry containing two 0s is used to terminate the vector.
899 If multiple entries match a file, the last matching one is used. */
901 static struct compiler *compilers;
903 /* Number of entries in `compilers', not counting the null terminator. */
905 static int n_compilers;
907 /* The default list of file name suffixes and their compilation specs. */
909 static const struct compiler default_compilers[] =
911 /* Add lists of suffixes of known languages here. If those languages
912 were not present when we built the driver, we will hit these copies
913 and be given a more meaningful error than "file not used since
914 linking is not done". */
915 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
916 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
917 {".mii", "#Objective-C++", 0, 0, 0},
918 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
919 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
920 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
921 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
922 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
923 {".f", "#Fortran", 0, 0, 0}, {".for", "#Fortran", 0, 0, 0},
924 {".F", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
925 {".FPP", "#Fortran", 0, 0, 0},
926 {".f90", "#Fortran 95", 0, 0, 0}, {".f95", "#Fortran 95", 0, 0, 0},
927 {".fpp", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
928 {".FOR", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
929 {".r", "#Ratfor", 0, 0, 0},
930 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
931 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
932 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
933 /* Next come the entries for C. */
934 {".c", "@c", 0, 1, 1},
935 {"@c",
936 /* cc1 has an integrated ISO C preprocessor. We should invoke the
937 external preprocessor if -save-temps is given. */
938 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
939 %{!E:%{!M:%{!MM:\
940 %{traditional|ftraditional:\
941 %eGNU C no longer supports -traditional without -E}\
942 %{!combine:\
943 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
944 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
945 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
946 %(cc1_options)}\
947 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
948 cc1 %(cpp_unique_options) %(cc1_options)}}}\
949 %{!fsyntax-only:%(invoke_as)}} \
950 %{combine:\
951 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
952 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i}}\
953 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
954 cc1 %(cpp_unique_options) %(cc1_options)}}\
955 %{!fsyntax-only:%(invoke_as)}}}}}}", 0, 1, 1},
956 {"-",
957 "%{!E:%e-E required when input is from standard input}\
958 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
959 {".h", "@c-header", 0, 0, 0},
960 {"@c-header",
961 /* cc1 has an integrated ISO C preprocessor. We should invoke the
962 external preprocessor if -save-temps is given. */
963 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
964 %{!E:%{!M:%{!MM:\
965 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
966 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
967 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
968 %(cc1_options)\
969 -o %g.s %{!o*:--output-pch=%i.gch}\
970 %W{o*:--output-pch=%*}%V}\
971 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
972 cc1 %(cpp_unique_options) %(cc1_options)\
973 -o %g.s %{!o*:--output-pch=%i.gch}\
974 %W{o*:--output-pch=%*}%V}}}}}}", 0, 0, 0},
975 {".i", "@cpp-output", 0, 1, 0},
976 {"@cpp-output",
977 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
978 {".s", "@assembler", 0, 1, 0},
979 {"@assembler",
980 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
981 {".S", "@assembler-with-cpp", 0, 1, 0},
982 {"@assembler-with-cpp",
983 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
984 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
985 %{E|M|MM:%(cpp_debug_options)}\
986 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
987 as %(asm_debug) %(asm_options) %|.s %A }}}}"
988 #else
989 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
990 %{E|M|MM:%(cpp_debug_options)}\
991 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
992 as %(asm_debug) %(asm_options) %m.s %A }}}}"
993 #endif
994 , 0, 1, 0},
996 #include "specs.h"
997 /* Mark end of table. */
998 {0, 0, 0, 0, 0}
1001 /* Number of elements in default_compilers, not counting the terminator. */
1003 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1005 /* A vector of options to give to the linker.
1006 These options are accumulated by %x,
1007 and substituted into the linker command with %X. */
1008 static int n_linker_options;
1009 static char **linker_options;
1011 /* A vector of options to give to the assembler.
1012 These options are accumulated by -Wa,
1013 and substituted into the assembler command with %Y. */
1014 static int n_assembler_options;
1015 static char **assembler_options;
1017 /* A vector of options to give to the preprocessor.
1018 These options are accumulated by -Wp,
1019 and substituted into the preprocessor command with %Z. */
1020 static int n_preprocessor_options;
1021 static char **preprocessor_options;
1023 /* Define how to map long options into short ones. */
1025 /* This structure describes one mapping. */
1026 struct option_map
1028 /* The long option's name. */
1029 const char *const name;
1030 /* The equivalent short option. */
1031 const char *const equivalent;
1032 /* Argument info. A string of flag chars; NULL equals no options.
1033 a => argument required.
1034 o => argument optional.
1035 j => join argument to equivalent, making one word.
1036 * => require other text after NAME as an argument. */
1037 const char *const arg_info;
1040 /* This is the table of mappings. Mappings are tried sequentially
1041 for each option encountered; the first one that matches, wins. */
1043 static const struct option_map option_map[] =
1045 {"--all-warnings", "-Wall", 0},
1046 {"--ansi", "-ansi", 0},
1047 {"--assemble", "-S", 0},
1048 {"--assert", "-A", "a"},
1049 {"--classpath", "-fclasspath=", "aj"},
1050 {"--bootclasspath", "-fbootclasspath=", "aj"},
1051 {"--CLASSPATH", "-fclasspath=", "aj"},
1052 {"--combine", "-combine", 0},
1053 {"--comments", "-C", 0},
1054 {"--comments-in-macros", "-CC", 0},
1055 {"--compile", "-c", 0},
1056 {"--debug", "-g", "oj"},
1057 {"--define-macro", "-D", "aj"},
1058 {"--dependencies", "-M", 0},
1059 {"--dump", "-d", "a"},
1060 {"--dumpbase", "-dumpbase", "a"},
1061 {"--encoding", "-fencoding=", "aj"},
1062 {"--entry", "-e", 0},
1063 {"--extra-warnings", "-W", 0},
1064 {"--extdirs", "-fextdirs=", "aj"},
1065 {"--for-assembler", "-Wa", "a"},
1066 {"--for-linker", "-Xlinker", "a"},
1067 {"--force-link", "-u", "a"},
1068 {"--imacros", "-imacros", "a"},
1069 {"--include", "-include", "a"},
1070 {"--include-barrier", "-I-", 0},
1071 {"--include-directory", "-I", "aj"},
1072 {"--include-directory-after", "-idirafter", "a"},
1073 {"--include-prefix", "-iprefix", "a"},
1074 {"--include-with-prefix", "-iwithprefix", "a"},
1075 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1076 {"--include-with-prefix-after", "-iwithprefix", "a"},
1077 {"--language", "-x", "a"},
1078 {"--library-directory", "-L", "a"},
1079 {"--machine", "-m", "aj"},
1080 {"--machine-", "-m", "*j"},
1081 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1082 {"--no-line-commands", "-P", 0},
1083 {"--no-precompiled-includes", "-noprecomp", 0},
1084 {"--no-standard-includes", "-nostdinc", 0},
1085 {"--no-standard-libraries", "-nostdlib", 0},
1086 {"--no-warnings", "-w", 0},
1087 {"--optimize", "-O", "oj"},
1088 {"--output", "-o", "a"},
1089 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1090 {"--param", "--param", "a"},
1091 {"--pass-exit-codes", "-pass-exit-codes", 0},
1092 {"--pedantic", "-pedantic", 0},
1093 {"--pedantic-errors", "-pedantic-errors", 0},
1094 {"--pie", "-pie", 0},
1095 {"--pipe", "-pipe", 0},
1096 {"--prefix", "-B", "a"},
1097 {"--preprocess", "-E", 0},
1098 {"--print-search-dirs", "-print-search-dirs", 0},
1099 {"--print-file-name", "-print-file-name=", "aj"},
1100 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1101 {"--print-missing-file-dependencies", "-MG", 0},
1102 {"--print-multi-lib", "-print-multi-lib", 0},
1103 {"--print-multi-directory", "-print-multi-directory", 0},
1104 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1105 {"--print-prog-name", "-print-prog-name=", "aj"},
1106 {"--profile", "-p", 0},
1107 {"--profile-blocks", "-a", 0},
1108 {"--quiet", "-q", 0},
1109 {"--resource", "-fcompile-resource=", "aj"},
1110 {"--save-temps", "-save-temps", 0},
1111 {"--shared", "-shared", 0},
1112 {"--silent", "-q", 0},
1113 {"--specs", "-specs=", "aj"},
1114 {"--static", "-static", 0},
1115 {"--std", "-std=", "aj"},
1116 {"--symbolic", "-symbolic", 0},
1117 {"--time", "-time", 0},
1118 {"--trace-includes", "-H", 0},
1119 {"--traditional", "-traditional", 0},
1120 {"--traditional-cpp", "-traditional-cpp", 0},
1121 {"--trigraphs", "-trigraphs", 0},
1122 {"--undefine-macro", "-U", "aj"},
1123 {"--user-dependencies", "-MM", 0},
1124 {"--verbose", "-v", 0},
1125 {"--warn-", "-W", "*j"},
1126 {"--write-dependencies", "-MD", 0},
1127 {"--write-user-dependencies", "-MMD", 0},
1128 {"--", "-f", "*j"}
1132 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1133 static const struct {
1134 const char *const option_found;
1135 const char *const replacements;
1136 } target_option_translations[] =
1138 TARGET_OPTION_TRANSLATE_TABLE,
1139 { 0, 0 }
1141 #endif
1143 /* Translate the options described by *ARGCP and *ARGVP.
1144 Make a new vector and store it back in *ARGVP,
1145 and store its length in *ARGVC. */
1147 static void
1148 translate_options (int *argcp, const char *const **argvp)
1150 int i;
1151 int argc = *argcp;
1152 const char *const *argv = *argvp;
1153 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1154 const char **newv = xmalloc (newvsize);
1155 int newindex = 0;
1157 i = 0;
1158 newv[newindex++] = argv[i++];
1160 while (i < argc)
1162 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1163 int tott_idx;
1165 for (tott_idx = 0;
1166 target_option_translations[tott_idx].option_found;
1167 tott_idx++)
1169 if (strcmp (target_option_translations[tott_idx].option_found,
1170 argv[i]) == 0)
1172 int spaces = 1;
1173 const char *sp;
1174 char *np;
1176 for (sp = target_option_translations[tott_idx].replacements;
1177 *sp; sp++)
1179 if (*sp == ' ')
1180 spaces ++;
1183 newvsize += spaces * sizeof (const char *);
1184 newv = xrealloc (newv, newvsize);
1186 sp = target_option_translations[tott_idx].replacements;
1187 np = xstrdup (sp);
1189 while (1)
1191 while (*np == ' ')
1192 np++;
1193 if (*np == 0)
1194 break;
1195 newv[newindex++] = np;
1196 while (*np != ' ' && *np)
1197 np++;
1198 if (*np == 0)
1199 break;
1200 *np++ = 0;
1203 i ++;
1204 break;
1207 if (target_option_translations[tott_idx].option_found)
1208 continue;
1209 #endif
1211 /* Translate -- options. */
1212 if (argv[i][0] == '-' && argv[i][1] == '-')
1214 size_t j;
1215 /* Find a mapping that applies to this option. */
1216 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1218 size_t optlen = strlen (option_map[j].name);
1219 size_t arglen = strlen (argv[i]);
1220 size_t complen = arglen > optlen ? optlen : arglen;
1221 const char *arginfo = option_map[j].arg_info;
1223 if (arginfo == 0)
1224 arginfo = "";
1226 if (!strncmp (argv[i], option_map[j].name, complen))
1228 const char *arg = 0;
1230 if (arglen < optlen)
1232 size_t k;
1233 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1234 if (strlen (option_map[k].name) >= arglen
1235 && !strncmp (argv[i], option_map[k].name, arglen))
1237 error ("ambiguous abbreviation %s", argv[i]);
1238 break;
1241 if (k != ARRAY_SIZE (option_map))
1242 break;
1245 if (arglen > optlen)
1247 /* If the option has an argument, accept that. */
1248 if (argv[i][optlen] == '=')
1249 arg = argv[i] + optlen + 1;
1251 /* If this mapping requires extra text at end of name,
1252 accept that as "argument". */
1253 else if (strchr (arginfo, '*') != 0)
1254 arg = argv[i] + optlen;
1256 /* Otherwise, extra text at end means mismatch.
1257 Try other mappings. */
1258 else
1259 continue;
1262 else if (strchr (arginfo, '*') != 0)
1264 error ("incomplete '%s' option", option_map[j].name);
1265 break;
1268 /* Handle arguments. */
1269 if (strchr (arginfo, 'a') != 0)
1271 if (arg == 0)
1273 if (i + 1 == argc)
1275 error ("missing argument to '%s' option",
1276 option_map[j].name);
1277 break;
1280 arg = argv[++i];
1283 else if (strchr (arginfo, '*') != 0)
1285 else if (strchr (arginfo, 'o') == 0)
1287 if (arg != 0)
1288 error ("extraneous argument to '%s' option",
1289 option_map[j].name);
1290 arg = 0;
1293 /* Store the translation as one argv elt or as two. */
1294 if (arg != 0 && strchr (arginfo, 'j') != 0)
1295 newv[newindex++] = concat (option_map[j].equivalent, arg,
1296 NULL);
1297 else if (arg != 0)
1299 newv[newindex++] = option_map[j].equivalent;
1300 newv[newindex++] = arg;
1302 else
1303 newv[newindex++] = option_map[j].equivalent;
1305 break;
1308 i++;
1311 /* Handle old-fashioned options--just copy them through,
1312 with their arguments. */
1313 else if (argv[i][0] == '-')
1315 const char *p = argv[i] + 1;
1316 int c = *p;
1317 int nskip = 1;
1319 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1320 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1321 else if (WORD_SWITCH_TAKES_ARG (p))
1322 nskip += WORD_SWITCH_TAKES_ARG (p);
1323 else if ((c == 'B' || c == 'b' || c == 'x')
1324 && p[1] == 0)
1325 nskip += 1;
1326 else if (! strcmp (p, "Xlinker"))
1327 nskip += 1;
1328 else if (! strcmp (p, "Xpreprocessor"))
1329 nskip += 1;
1330 else if (! strcmp (p, "Xassembler"))
1331 nskip += 1;
1333 /* Watch out for an option at the end of the command line that
1334 is missing arguments, and avoid skipping past the end of the
1335 command line. */
1336 if (nskip + i > argc)
1337 nskip = argc - i;
1339 while (nskip > 0)
1341 newv[newindex++] = argv[i++];
1342 nskip--;
1345 else
1346 /* Ordinary operands, or +e options. */
1347 newv[newindex++] = argv[i++];
1350 newv[newindex] = 0;
1352 *argvp = newv;
1353 *argcp = newindex;
1356 static char *
1357 skip_whitespace (char *p)
1359 while (1)
1361 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1362 be considered whitespace. */
1363 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1364 return p + 1;
1365 else if (*p == '\n' || *p == ' ' || *p == '\t')
1366 p++;
1367 else if (*p == '#')
1369 while (*p != '\n')
1370 p++;
1371 p++;
1373 else
1374 break;
1377 return p;
1379 /* Structures to keep track of prefixes to try when looking for files. */
1381 struct prefix_list
1383 const char *prefix; /* String to prepend to the path. */
1384 struct prefix_list *next; /* Next in linked list. */
1385 int require_machine_suffix; /* Don't use without machine_suffix. */
1386 /* 2 means try both machine_suffix and just_machine_suffix. */
1387 int priority; /* Sort key - priority within list. */
1388 int os_multilib; /* 1 if OS multilib scheme should be used,
1389 0 for GCC multilib scheme. */
1392 struct path_prefix
1394 struct prefix_list *plist; /* List of prefixes to try */
1395 int max_len; /* Max length of a prefix in PLIST */
1396 const char *name; /* Name of this list (used in config stuff) */
1399 /* List of prefixes to try when looking for executables. */
1401 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1403 /* List of prefixes to try when looking for startup (crt0) files. */
1405 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1407 /* List of prefixes to try when looking for include files. */
1409 static struct path_prefix include_prefixes = { 0, 0, "include" };
1411 /* Suffix to attach to directories searched for commands.
1412 This looks like `MACHINE/VERSION/'. */
1414 static const char *machine_suffix = 0;
1416 /* Suffix to attach to directories searched for commands.
1417 This is just `MACHINE/'. */
1419 static const char *just_machine_suffix = 0;
1421 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1423 static const char *gcc_exec_prefix;
1425 /* Adjusted value of standard_libexec_prefix. */
1427 static const char *gcc_libexec_prefix;
1429 /* Default prefixes to attach to command names. */
1431 #ifndef STANDARD_STARTFILE_PREFIX_1
1432 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1433 #endif
1434 #ifndef STANDARD_STARTFILE_PREFIX_2
1435 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1436 #endif
1438 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1439 #undef MD_EXEC_PREFIX
1440 #undef MD_STARTFILE_PREFIX
1441 #undef MD_STARTFILE_PREFIX_1
1442 #endif
1444 /* If no prefixes defined, use the null string, which will disable them. */
1445 #ifndef MD_EXEC_PREFIX
1446 #define MD_EXEC_PREFIX ""
1447 #endif
1448 #ifndef MD_STARTFILE_PREFIX
1449 #define MD_STARTFILE_PREFIX ""
1450 #endif
1451 #ifndef MD_STARTFILE_PREFIX_1
1452 #define MD_STARTFILE_PREFIX_1 ""
1453 #endif
1455 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1456 static const char *const standard_exec_prefix_1 = "/usr/libexec/gcc/";
1457 static const char *const standard_exec_prefix_2 = "/usr/lib/gcc/";
1458 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1460 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1461 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1462 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1463 static const char *const standard_startfile_prefix_1
1464 = STANDARD_STARTFILE_PREFIX_1;
1465 static const char *const standard_startfile_prefix_2
1466 = STANDARD_STARTFILE_PREFIX_2;
1468 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1469 static const char *tooldir_prefix;
1471 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1473 static const char *standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1475 /* Subdirectory to use for locating libraries. Set by
1476 set_multilib_dir based on the compilation options. */
1478 static const char *multilib_dir;
1480 /* Subdirectory to use for locating libraries in OS conventions. Set by
1481 set_multilib_dir based on the compilation options. */
1483 static const char *multilib_os_dir;
1485 /* Structure to keep track of the specs that have been defined so far.
1486 These are accessed using %(specname) or %[specname] in a compiler
1487 or link spec. */
1489 struct spec_list
1491 /* The following 2 fields must be first */
1492 /* to allow EXTRA_SPECS to be initialized */
1493 const char *name; /* name of the spec. */
1494 const char *ptr; /* available ptr if no static pointer */
1496 /* The following fields are not initialized */
1497 /* by EXTRA_SPECS */
1498 const char **ptr_spec; /* pointer to the spec itself. */
1499 struct spec_list *next; /* Next spec in linked list. */
1500 int name_len; /* length of the name */
1501 int alloc_p; /* whether string was allocated */
1504 #define INIT_STATIC_SPEC(NAME,PTR) \
1505 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1507 /* List of statically defined specs. */
1508 static struct spec_list static_specs[] =
1510 INIT_STATIC_SPEC ("asm", &asm_spec),
1511 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1512 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1513 INIT_STATIC_SPEC ("asm_options", &asm_options),
1514 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1515 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1516 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1517 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1518 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1519 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1520 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1521 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1522 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1523 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1524 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1525 INIT_STATIC_SPEC ("link", &link_spec),
1526 INIT_STATIC_SPEC ("lib", &lib_spec),
1527 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1528 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1529 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1530 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1531 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1532 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1533 INIT_STATIC_SPEC ("version", &compiler_version),
1534 INIT_STATIC_SPEC ("multilib", &multilib_select),
1535 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1536 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1537 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1538 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1539 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1540 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1541 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1542 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1543 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1544 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1545 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1546 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1547 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1550 #ifdef EXTRA_SPECS /* additional specs needed */
1551 /* Structure to keep track of just the first two args of a spec_list.
1552 That is all that the EXTRA_SPECS macro gives us. */
1553 struct spec_list_1
1555 const char *const name;
1556 const char *const ptr;
1559 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1560 static struct spec_list *extra_specs = (struct spec_list *) 0;
1561 #endif
1563 /* List of dynamically allocates specs that have been defined so far. */
1565 static struct spec_list *specs = (struct spec_list *) 0;
1567 /* List of static spec functions. */
1569 static const struct spec_function static_spec_functions[] =
1571 { "if-exists", if_exists_spec_function },
1572 { "if-exists-else", if_exists_else_spec_function },
1573 { "replace-outfile", replace_outfile_spec_function },
1574 { 0, 0 }
1577 static int processing_spec_function;
1579 /* Add appropriate libgcc specs to OBSTACK, taking into account
1580 various permutations of -shared-libgcc, -shared, and such. */
1582 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1584 #ifndef USE_LD_AS_NEEDED
1585 #define USE_LD_AS_NEEDED 0
1586 #endif
1588 static void
1589 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1590 const char *static_name, const char *eh_name)
1592 char *buf;
1594 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1595 "}%{!static:%{!static-libgcc:",
1596 #if USE_LD_AS_NEEDED
1597 "%{!shared-libgcc:", static_name,
1598 " --as-needed ", shared_name, " --no-as-needed}"
1599 "%{shared-libgcc:", shared_name, "%{!shared: ", static_name,
1600 "}",
1601 #else
1602 "%{!shared:%{!shared-libgcc:", static_name, " ",
1603 eh_name, "}%{shared-libgcc:", shared_name, " ",
1604 static_name, "}}%{shared:",
1605 #ifdef LINK_EH_SPEC
1606 "%{shared-libgcc:", shared_name,
1607 "}%{!shared-libgcc:", static_name, "}",
1608 #else
1609 shared_name,
1610 #endif
1611 #endif
1612 "}}}", NULL);
1614 obstack_grow (obstack, buf, strlen (buf));
1615 free (buf);
1617 #endif /* ENABLE_SHARED_LIBGCC */
1619 /* Initialize the specs lookup routines. */
1621 static void
1622 init_spec (void)
1624 struct spec_list *next = (struct spec_list *) 0;
1625 struct spec_list *sl = (struct spec_list *) 0;
1626 int i;
1628 if (specs)
1629 return; /* Already initialized. */
1631 if (verbose_flag)
1632 notice ("Using built-in specs.\n");
1634 #ifdef EXTRA_SPECS
1635 extra_specs = xcalloc (sizeof (struct spec_list),
1636 ARRAY_SIZE (extra_specs_1));
1638 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1640 sl = &extra_specs[i];
1641 sl->name = extra_specs_1[i].name;
1642 sl->ptr = extra_specs_1[i].ptr;
1643 sl->next = next;
1644 sl->name_len = strlen (sl->name);
1645 sl->ptr_spec = &sl->ptr;
1646 next = sl;
1648 #endif
1650 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1651 on ?: in file-scope variable initializations. */
1652 asm_debug = ASM_DEBUG_SPEC;
1654 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1656 sl = &static_specs[i];
1657 sl->next = next;
1658 next = sl;
1661 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1662 /* ??? If neither -shared-libgcc nor --static-libgcc was
1663 seen, then we should be making an educated guess. Some proposed
1664 heuristics for ELF include:
1666 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1667 program will be doing dynamic loading, which will likely
1668 need the shared libgcc.
1670 (2) If "-ldl", then it's also a fair bet that we're doing
1671 dynamic loading.
1673 (3) For each ET_DYN we're linking against (either through -lfoo
1674 or /some/path/foo.so), check to see whether it or one of
1675 its dependencies depends on a shared libgcc.
1677 (4) If "-shared"
1679 If the runtime is fixed to look for program headers instead
1680 of calling __register_frame_info at all, for each object,
1681 use the shared libgcc if any EH symbol referenced.
1683 If crtstuff is fixed to not invoke __register_frame_info
1684 automatically, for each object, use the shared libgcc if
1685 any non-empty unwind section found.
1687 Doing any of this probably requires invoking an external program to
1688 do the actual object file scanning. */
1690 const char *p = libgcc_spec;
1691 int in_sep = 1;
1693 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1694 when given the proper command line arguments. */
1695 while (*p)
1697 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1699 init_gcc_specs (&obstack,
1700 "-lgcc_s"
1701 #ifdef USE_LIBUNWIND_EXCEPTIONS
1702 " -lunwind"
1703 #endif
1705 "-lgcc",
1706 "-lgcc_eh"
1707 #ifdef USE_LIBUNWIND_EXCEPTIONS
1708 # ifdef HAVE_LD_STATIC_DYNAMIC
1709 " %{!static:-Bstatic} -lunwind %{!static:-Bdynamic}"
1710 # else
1711 " -lunwind"
1712 # endif
1713 #endif
1716 p += 5;
1717 in_sep = 0;
1719 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1721 /* Ug. We don't know shared library extensions. Hope that
1722 systems that use this form don't do shared libraries. */
1723 init_gcc_specs (&obstack,
1724 "-lgcc_s",
1725 "libgcc.a%s",
1726 "libgcc_eh.a%s"
1727 #ifdef USE_LIBUNWIND_EXCEPTIONS
1728 " -lunwind"
1729 #endif
1731 p += 10;
1732 in_sep = 0;
1734 else
1736 obstack_1grow (&obstack, *p);
1737 in_sep = (*p == ' ');
1738 p += 1;
1742 obstack_1grow (&obstack, '\0');
1743 libgcc_spec = obstack_finish (&obstack);
1745 #endif
1746 #ifdef USE_AS_TRADITIONAL_FORMAT
1747 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1749 static const char tf[] = "--traditional-format ";
1750 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1751 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1752 asm_spec = obstack_finish (&obstack);
1754 #endif
1755 #ifdef LINK_EH_SPEC
1756 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1757 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1758 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1759 link_spec = obstack_finish (&obstack);
1760 #endif
1762 specs = sl;
1765 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1766 removed; If the spec starts with a + then SPEC is added to the end of the
1767 current spec. */
1769 static void
1770 set_spec (const char *name, const char *spec)
1772 struct spec_list *sl;
1773 const char *old_spec;
1774 int name_len = strlen (name);
1775 int i;
1777 /* If this is the first call, initialize the statically allocated specs. */
1778 if (!specs)
1780 struct spec_list *next = (struct spec_list *) 0;
1781 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1783 sl = &static_specs[i];
1784 sl->next = next;
1785 next = sl;
1787 specs = sl;
1790 /* See if the spec already exists. */
1791 for (sl = specs; sl; sl = sl->next)
1792 if (name_len == sl->name_len && !strcmp (sl->name, name))
1793 break;
1795 if (!sl)
1797 /* Not found - make it. */
1798 sl = xmalloc (sizeof (struct spec_list));
1799 sl->name = xstrdup (name);
1800 sl->name_len = name_len;
1801 sl->ptr_spec = &sl->ptr;
1802 sl->alloc_p = 0;
1803 *(sl->ptr_spec) = "";
1804 sl->next = specs;
1805 specs = sl;
1808 old_spec = *(sl->ptr_spec);
1809 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1810 ? concat (old_spec, spec + 1, NULL)
1811 : xstrdup (spec));
1813 #ifdef DEBUG_SPECS
1814 if (verbose_flag)
1815 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1816 #endif
1818 /* Free the old spec. */
1819 if (old_spec && sl->alloc_p)
1820 free ((void *) old_spec);
1822 sl->alloc_p = 1;
1825 /* Accumulate a command (program name and args), and run it. */
1827 /* Vector of pointers to arguments in the current line of specifications. */
1829 static const char **argbuf;
1831 /* Number of elements allocated in argbuf. */
1833 static int argbuf_length;
1835 /* Number of elements in argbuf currently in use (containing args). */
1837 static int argbuf_index;
1839 /* Position in the argbuf array containing the name of the output file
1840 (the value associated with the "-o" flag). */
1842 static int have_o_argbuf_index = 0;
1844 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1845 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1846 it here. */
1848 static struct temp_name {
1849 const char *suffix; /* suffix associated with the code. */
1850 int length; /* strlen (suffix). */
1851 int unique; /* Indicates whether %g or %u/%U was used. */
1852 const char *filename; /* associated filename. */
1853 int filename_length; /* strlen (filename). */
1854 struct temp_name *next;
1855 } *temp_names;
1857 /* Number of commands executed so far. */
1859 static int execution_count;
1861 /* Number of commands that exited with a signal. */
1863 static int signal_count;
1865 /* Name with which this program was invoked. */
1867 static const char *programname;
1869 /* Allocate the argument vector. */
1871 static void
1872 alloc_args (void)
1874 argbuf_length = 10;
1875 argbuf = xmalloc (argbuf_length * sizeof (const char *));
1878 /* Clear out the vector of arguments (after a command is executed). */
1880 static void
1881 clear_args (void)
1883 argbuf_index = 0;
1886 /* Add one argument to the vector at the end.
1887 This is done when a space is seen or at the end of the line.
1888 If DELETE_ALWAYS is nonzero, the arg is a filename
1889 and the file should be deleted eventually.
1890 If DELETE_FAILURE is nonzero, the arg is a filename
1891 and the file should be deleted if this compilation fails. */
1893 static void
1894 store_arg (const char *arg, int delete_always, int delete_failure)
1896 if (argbuf_index + 1 == argbuf_length)
1897 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1899 argbuf[argbuf_index++] = arg;
1900 argbuf[argbuf_index] = 0;
1902 if (strcmp (arg, "-o") == 0)
1903 have_o_argbuf_index = argbuf_index;
1904 if (delete_always || delete_failure)
1905 record_temp_file (arg, delete_always, delete_failure);
1908 /* Load specs from a file name named FILENAME, replacing occurrences of
1909 various different types of line-endings, \r\n, \n\r and just \r, with
1910 a single \n. */
1912 static char *
1913 load_specs (const char *filename)
1915 int desc;
1916 int readlen;
1917 struct stat statbuf;
1918 char *buffer;
1919 char *buffer_p;
1920 char *specs;
1921 char *specs_p;
1923 if (verbose_flag)
1924 notice ("Reading specs from %s\n", filename);
1926 /* Open and stat the file. */
1927 desc = open (filename, O_RDONLY, 0);
1928 if (desc < 0)
1929 pfatal_with_name (filename);
1930 if (stat (filename, &statbuf) < 0)
1931 pfatal_with_name (filename);
1933 /* Read contents of file into BUFFER. */
1934 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1935 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1936 if (readlen < 0)
1937 pfatal_with_name (filename);
1938 buffer[readlen] = 0;
1939 close (desc);
1941 specs = xmalloc (readlen + 1);
1942 specs_p = specs;
1943 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1945 int skip = 0;
1946 char c = *buffer_p;
1947 if (c == '\r')
1949 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1950 skip = 1;
1951 else if (*(buffer_p + 1) == '\n') /* \r\n */
1952 skip = 1;
1953 else /* \r */
1954 c = '\n';
1956 if (! skip)
1957 *specs_p++ = c;
1959 *specs_p = '\0';
1961 free (buffer);
1962 return (specs);
1965 /* Read compilation specs from a file named FILENAME,
1966 replacing the default ones.
1968 A suffix which starts with `*' is a definition for
1969 one of the machine-specific sub-specs. The "suffix" should be
1970 *asm, *cc1, *cpp, *link, *startfile, etc.
1971 The corresponding spec is stored in asm_spec, etc.,
1972 rather than in the `compilers' vector.
1974 Anything invalid in the file is a fatal error. */
1976 static void
1977 read_specs (const char *filename, int main_p)
1979 char *buffer;
1980 char *p;
1982 buffer = load_specs (filename);
1984 /* Scan BUFFER for specs, putting them in the vector. */
1985 p = buffer;
1986 while (1)
1988 char *suffix;
1989 char *spec;
1990 char *in, *out, *p1, *p2, *p3;
1992 /* Advance P in BUFFER to the next nonblank nocomment line. */
1993 p = skip_whitespace (p);
1994 if (*p == 0)
1995 break;
1997 /* Is this a special command that starts with '%'? */
1998 /* Don't allow this for the main specs file, since it would
1999 encourage people to overwrite it. */
2000 if (*p == '%' && !main_p)
2002 p1 = p;
2003 while (*p && *p != '\n')
2004 p++;
2006 /* Skip '\n'. */
2007 p++;
2009 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2010 && (p1[sizeof "%include" - 1] == ' '
2011 || p1[sizeof "%include" - 1] == '\t'))
2013 char *new_filename;
2015 p1 += sizeof ("%include");
2016 while (*p1 == ' ' || *p1 == '\t')
2017 p1++;
2019 if (*p1++ != '<' || p[-2] != '>')
2020 fatal ("specs %%include syntax malformed after %ld characters",
2021 (long) (p1 - buffer + 1));
2023 p[-2] = '\0';
2024 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2025 read_specs (new_filename ? new_filename : p1, FALSE);
2026 continue;
2028 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2029 && (p1[sizeof "%include_noerr" - 1] == ' '
2030 || p1[sizeof "%include_noerr" - 1] == '\t'))
2032 char *new_filename;
2034 p1 += sizeof "%include_noerr";
2035 while (*p1 == ' ' || *p1 == '\t')
2036 p1++;
2038 if (*p1++ != '<' || p[-2] != '>')
2039 fatal ("specs %%include syntax malformed after %ld characters",
2040 (long) (p1 - buffer + 1));
2042 p[-2] = '\0';
2043 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2044 if (new_filename)
2045 read_specs (new_filename, FALSE);
2046 else if (verbose_flag)
2047 notice ("could not find specs file %s\n", p1);
2048 continue;
2050 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2051 && (p1[sizeof "%rename" - 1] == ' '
2052 || p1[sizeof "%rename" - 1] == '\t'))
2054 int name_len;
2055 struct spec_list *sl;
2056 struct spec_list *newsl;
2058 /* Get original name. */
2059 p1 += sizeof "%rename";
2060 while (*p1 == ' ' || *p1 == '\t')
2061 p1++;
2063 if (! ISALPHA ((unsigned char) *p1))
2064 fatal ("specs %%rename syntax malformed after %ld characters",
2065 (long) (p1 - buffer));
2067 p2 = p1;
2068 while (*p2 && !ISSPACE ((unsigned char) *p2))
2069 p2++;
2071 if (*p2 != ' ' && *p2 != '\t')
2072 fatal ("specs %%rename syntax malformed after %ld characters",
2073 (long) (p2 - buffer));
2075 name_len = p2 - p1;
2076 *p2++ = '\0';
2077 while (*p2 == ' ' || *p2 == '\t')
2078 p2++;
2080 if (! ISALPHA ((unsigned char) *p2))
2081 fatal ("specs %%rename syntax malformed after %ld characters",
2082 (long) (p2 - buffer));
2084 /* Get new spec name. */
2085 p3 = p2;
2086 while (*p3 && !ISSPACE ((unsigned char) *p3))
2087 p3++;
2089 if (p3 != p - 1)
2090 fatal ("specs %%rename syntax malformed after %ld characters",
2091 (long) (p3 - buffer));
2092 *p3 = '\0';
2094 for (sl = specs; sl; sl = sl->next)
2095 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2096 break;
2098 if (!sl)
2099 fatal ("specs %s spec was not found to be renamed", p1);
2101 if (strcmp (p1, p2) == 0)
2102 continue;
2104 for (newsl = specs; newsl; newsl = newsl->next)
2105 if (strcmp (newsl->name, p2) == 0)
2106 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2107 filename, p1, p2);
2109 if (verbose_flag)
2111 notice ("rename spec %s to %s\n", p1, p2);
2112 #ifdef DEBUG_SPECS
2113 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2114 #endif
2117 set_spec (p2, *(sl->ptr_spec));
2118 if (sl->alloc_p)
2119 free ((void *) *(sl->ptr_spec));
2121 *(sl->ptr_spec) = "";
2122 sl->alloc_p = 0;
2123 continue;
2125 else
2126 fatal ("specs unknown %% command after %ld characters",
2127 (long) (p1 - buffer));
2130 /* Find the colon that should end the suffix. */
2131 p1 = p;
2132 while (*p1 && *p1 != ':' && *p1 != '\n')
2133 p1++;
2135 /* The colon shouldn't be missing. */
2136 if (*p1 != ':')
2137 fatal ("specs file malformed after %ld characters",
2138 (long) (p1 - buffer));
2140 /* Skip back over trailing whitespace. */
2141 p2 = p1;
2142 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2143 p2--;
2145 /* Copy the suffix to a string. */
2146 suffix = save_string (p, p2 - p);
2147 /* Find the next line. */
2148 p = skip_whitespace (p1 + 1);
2149 if (p[1] == 0)
2150 fatal ("specs file malformed after %ld characters",
2151 (long) (p - buffer));
2153 p1 = p;
2154 /* Find next blank line or end of string. */
2155 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2156 p1++;
2158 /* Specs end at the blank line and do not include the newline. */
2159 spec = save_string (p, p1 - p);
2160 p = p1;
2162 /* Delete backslash-newline sequences from the spec. */
2163 in = spec;
2164 out = spec;
2165 while (*in != 0)
2167 if (in[0] == '\\' && in[1] == '\n')
2168 in += 2;
2169 else if (in[0] == '#')
2170 while (*in && *in != '\n')
2171 in++;
2173 else
2174 *out++ = *in++;
2176 *out = 0;
2178 if (suffix[0] == '*')
2180 if (! strcmp (suffix, "*link_command"))
2181 link_command_spec = spec;
2182 else
2183 set_spec (suffix + 1, spec);
2185 else
2187 /* Add this pair to the vector. */
2188 compilers
2189 = xrealloc (compilers,
2190 (n_compilers + 2) * sizeof (struct compiler));
2192 compilers[n_compilers].suffix = suffix;
2193 compilers[n_compilers].spec = spec;
2194 n_compilers++;
2195 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2198 if (*suffix == 0)
2199 link_command_spec = spec;
2202 if (link_command_spec == 0)
2203 fatal ("spec file has no spec for linking");
2206 /* Record the names of temporary files we tell compilers to write,
2207 and delete them at the end of the run. */
2209 /* This is the common prefix we use to make temp file names.
2210 It is chosen once for each run of this program.
2211 It is substituted into a spec by %g or %j.
2212 Thus, all temp file names contain this prefix.
2213 In practice, all temp file names start with this prefix.
2215 This prefix comes from the envvar TMPDIR if it is defined;
2216 otherwise, from the P_tmpdir macro if that is defined;
2217 otherwise, in /usr/tmp or /tmp;
2218 or finally the current directory if all else fails. */
2220 static const char *temp_filename;
2222 /* Length of the prefix. */
2224 static int temp_filename_length;
2226 /* Define the list of temporary files to delete. */
2228 struct temp_file
2230 const char *name;
2231 struct temp_file *next;
2234 /* Queue of files to delete on success or failure of compilation. */
2235 static struct temp_file *always_delete_queue;
2236 /* Queue of files to delete on failure of compilation. */
2237 static struct temp_file *failure_delete_queue;
2239 /* Record FILENAME as a file to be deleted automatically.
2240 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2241 otherwise delete it in any case.
2242 FAIL_DELETE nonzero means delete it if a compilation step fails;
2243 otherwise delete it in any case. */
2245 void
2246 record_temp_file (const char *filename, int always_delete, int fail_delete)
2248 char *const name = xstrdup (filename);
2250 if (always_delete)
2252 struct temp_file *temp;
2253 for (temp = always_delete_queue; temp; temp = temp->next)
2254 if (! strcmp (name, temp->name))
2255 goto already1;
2257 temp = xmalloc (sizeof (struct temp_file));
2258 temp->next = always_delete_queue;
2259 temp->name = name;
2260 always_delete_queue = temp;
2262 already1:;
2265 if (fail_delete)
2267 struct temp_file *temp;
2268 for (temp = failure_delete_queue; temp; temp = temp->next)
2269 if (! strcmp (name, temp->name))
2270 goto already2;
2272 temp = xmalloc (sizeof (struct temp_file));
2273 temp->next = failure_delete_queue;
2274 temp->name = name;
2275 failure_delete_queue = temp;
2277 already2:;
2281 /* Delete all the temporary files whose names we previously recorded. */
2283 #ifndef DELETE_IF_ORDINARY
2284 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2285 do \
2287 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2288 if (unlink (NAME) < 0) \
2289 if (VERBOSE_FLAG) \
2290 perror_with_name (NAME); \
2291 } while (0)
2292 #endif
2294 static void
2295 delete_if_ordinary (const char *name)
2297 struct stat st;
2298 #ifdef DEBUG
2299 int i, c;
2301 printf ("Delete %s? (y or n) ", name);
2302 fflush (stdout);
2303 i = getchar ();
2304 if (i != '\n')
2305 while ((c = getchar ()) != '\n' && c != EOF)
2308 if (i == 'y' || i == 'Y')
2309 #endif /* DEBUG */
2310 DELETE_IF_ORDINARY (name, st, verbose_flag);
2313 static void
2314 delete_temp_files (void)
2316 struct temp_file *temp;
2318 for (temp = always_delete_queue; temp; temp = temp->next)
2319 delete_if_ordinary (temp->name);
2320 always_delete_queue = 0;
2323 /* Delete all the files to be deleted on error. */
2325 static void
2326 delete_failure_queue (void)
2328 struct temp_file *temp;
2330 for (temp = failure_delete_queue; temp; temp = temp->next)
2331 delete_if_ordinary (temp->name);
2334 static void
2335 clear_failure_queue (void)
2337 failure_delete_queue = 0;
2340 /* Build a list of search directories from PATHS.
2341 PREFIX is a string to prepend to the list.
2342 If CHECK_DIR_P is nonzero we ensure the directory exists.
2343 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2344 It is also used by the --print-search-dirs flag. */
2346 static char *
2347 build_search_list (struct path_prefix *paths, const char *prefix,
2348 int check_dir_p)
2350 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2351 int just_suffix_len
2352 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2353 int first_time = TRUE;
2354 struct prefix_list *pprefix;
2356 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2357 obstack_1grow (&collect_obstack, '=');
2359 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2361 int len = strlen (pprefix->prefix);
2363 if (machine_suffix
2364 && (! check_dir_p
2365 || is_directory (pprefix->prefix, machine_suffix, 0)))
2367 if (!first_time)
2368 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2370 first_time = FALSE;
2371 obstack_grow (&collect_obstack, pprefix->prefix, len);
2372 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2375 if (just_machine_suffix
2376 && pprefix->require_machine_suffix == 2
2377 && (! check_dir_p
2378 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2380 if (! first_time)
2381 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2383 first_time = FALSE;
2384 obstack_grow (&collect_obstack, pprefix->prefix, len);
2385 obstack_grow (&collect_obstack, just_machine_suffix,
2386 just_suffix_len);
2389 if (! pprefix->require_machine_suffix)
2391 if (! first_time)
2392 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2394 first_time = FALSE;
2395 obstack_grow (&collect_obstack, pprefix->prefix, len);
2399 obstack_1grow (&collect_obstack, '\0');
2400 return obstack_finish (&collect_obstack);
2403 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2404 for collect. */
2406 static void
2407 putenv_from_prefixes (struct path_prefix *paths, const char *env_var)
2409 putenv (build_search_list (paths, env_var, 1));
2412 /* Check whether NAME can be accessed in MODE. This is like access,
2413 except that it never considers directories to be executable. */
2415 static int
2416 access_check (const char *name, int mode)
2418 if (mode == X_OK)
2420 struct stat st;
2422 if (stat (name, &st) < 0
2423 || S_ISDIR (st.st_mode))
2424 return -1;
2427 return access (name, mode);
2430 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2431 access to check permissions.
2432 Return 0 if not found, otherwise return its name, allocated with malloc. */
2434 static char *
2435 find_a_file (struct path_prefix *pprefix, const char *name, int mode,
2436 int multilib)
2438 char *temp;
2439 const char *const file_suffix =
2440 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2441 struct prefix_list *pl;
2442 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2443 const char *multilib_name, *multilib_os_name;
2445 #ifdef DEFAULT_ASSEMBLER
2446 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2447 return xstrdup (DEFAULT_ASSEMBLER);
2448 #endif
2450 #ifdef DEFAULT_LINKER
2451 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2452 return xstrdup (DEFAULT_LINKER);
2453 #endif
2455 if (machine_suffix)
2456 len += strlen (machine_suffix);
2458 multilib_name = name;
2459 multilib_os_name = name;
2460 if (multilib && multilib_os_dir)
2462 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2463 int len2 = strlen (multilib_os_dir) + 1;
2465 len += len1 > len2 ? len1 : len2;
2466 if (multilib_dir)
2467 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2468 NULL));
2469 if (strcmp (multilib_os_dir, ".") != 0)
2470 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2471 NULL));
2474 temp = xmalloc (len);
2476 /* Determine the filename to execute (special case for absolute paths). */
2478 if (IS_ABSOLUTE_PATH (name))
2480 if (access (name, mode) == 0)
2482 strcpy (temp, name);
2483 return temp;
2486 else
2487 for (pl = pprefix->plist; pl; pl = pl->next)
2489 const char *this_name
2490 = pl->os_multilib ? multilib_os_name : multilib_name;
2492 if (machine_suffix)
2494 /* Some systems have a suffix for executable files.
2495 So try appending that first. */
2496 if (file_suffix[0] != 0)
2498 strcpy (temp, pl->prefix);
2499 strcat (temp, machine_suffix);
2500 strcat (temp, multilib_name);
2501 strcat (temp, file_suffix);
2502 if (access_check (temp, mode) == 0)
2503 return temp;
2506 /* Now try just the multilib_name. */
2507 strcpy (temp, pl->prefix);
2508 strcat (temp, machine_suffix);
2509 strcat (temp, multilib_name);
2510 if (access_check (temp, mode) == 0)
2511 return temp;
2514 /* Certain prefixes are tried with just the machine type,
2515 not the version. This is used for finding as, ld, etc. */
2516 if (just_machine_suffix && pl->require_machine_suffix == 2)
2518 /* Some systems have a suffix for executable files.
2519 So try appending that first. */
2520 if (file_suffix[0] != 0)
2522 strcpy (temp, pl->prefix);
2523 strcat (temp, just_machine_suffix);
2524 strcat (temp, multilib_name);
2525 strcat (temp, file_suffix);
2526 if (access_check (temp, mode) == 0)
2527 return temp;
2530 strcpy (temp, pl->prefix);
2531 strcat (temp, just_machine_suffix);
2532 strcat (temp, multilib_name);
2533 if (access_check (temp, mode) == 0)
2534 return temp;
2537 /* Certain prefixes can't be used without the machine suffix
2538 when the machine or version is explicitly specified. */
2539 if (! pl->require_machine_suffix)
2541 /* Some systems have a suffix for executable files.
2542 So try appending that first. */
2543 if (file_suffix[0] != 0)
2545 strcpy (temp, pl->prefix);
2546 strcat (temp, this_name);
2547 strcat (temp, file_suffix);
2548 if (access_check (temp, mode) == 0)
2549 return temp;
2552 strcpy (temp, pl->prefix);
2553 strcat (temp, this_name);
2554 if (access_check (temp, mode) == 0)
2555 return temp;
2559 free (temp);
2560 return 0;
2563 /* Ranking of prefixes in the sort list. -B prefixes are put before
2564 all others. */
2566 enum path_prefix_priority
2568 PREFIX_PRIORITY_B_OPT,
2569 PREFIX_PRIORITY_LAST
2572 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2573 order according to PRIORITY. Within each PRIORITY, new entries are
2574 appended.
2576 If WARN is nonzero, we will warn if no file is found
2577 through this prefix. WARN should point to an int
2578 which will be set to 1 if this entry is used.
2580 COMPONENT is the value to be passed to update_path.
2582 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2583 the complete value of machine_suffix.
2584 2 means try both machine_suffix and just_machine_suffix. */
2586 static void
2587 add_prefix (struct path_prefix *pprefix, const char *prefix,
2588 const char *component, /* enum prefix_priority */ int priority,
2589 int require_machine_suffix, int os_multilib)
2591 struct prefix_list *pl, **prev;
2592 int len;
2594 for (prev = &pprefix->plist;
2595 (*prev) != NULL && (*prev)->priority <= priority;
2596 prev = &(*prev)->next)
2599 /* Keep track of the longest prefix. */
2601 prefix = update_path (prefix, component);
2602 len = strlen (prefix);
2603 if (len > pprefix->max_len)
2604 pprefix->max_len = len;
2606 pl = xmalloc (sizeof (struct prefix_list));
2607 pl->prefix = prefix;
2608 pl->require_machine_suffix = require_machine_suffix;
2609 pl->priority = priority;
2610 pl->os_multilib = os_multilib;
2612 /* Insert after PREV. */
2613 pl->next = (*prev);
2614 (*prev) = pl;
2617 /* Same as add_prefix, but prepending target_system_root to prefix. */
2618 static void
2619 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2620 const char *component,
2621 /* enum prefix_priority */ int priority,
2622 int require_machine_suffix, int os_multilib)
2624 if (!IS_ABSOLUTE_PATH (prefix))
2625 fatal ("system path '%s' is not absolute", prefix);
2627 if (target_system_root)
2629 if (target_sysroot_suffix)
2630 prefix = concat (target_sysroot_suffix, prefix, NULL);
2631 prefix = concat (target_system_root, prefix, NULL);
2633 /* We have to override this because GCC's notion of sysroot
2634 moves along with GCC. */
2635 component = "GCC";
2638 add_prefix (pprefix, prefix, component, priority,
2639 require_machine_suffix, os_multilib);
2642 /* Execute the command specified by the arguments on the current line of spec.
2643 When using pipes, this includes several piped-together commands
2644 with `|' between them.
2646 Return 0 if successful, -1 if failed. */
2648 static int
2649 execute (void)
2651 int i;
2652 int n_commands; /* # of command. */
2653 char *string;
2654 struct command
2656 const char *prog; /* program name. */
2657 const char **argv; /* vector of args. */
2658 int pid; /* pid of process for this command. */
2661 struct command *commands; /* each command buffer with above info. */
2663 gcc_assert (!processing_spec_function);
2665 /* Count # of piped commands. */
2666 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2667 if (strcmp (argbuf[i], "|") == 0)
2668 n_commands++;
2670 /* Get storage for each command. */
2671 commands = alloca (n_commands * sizeof (struct command));
2673 /* Split argbuf into its separate piped processes,
2674 and record info about each one.
2675 Also search for the programs that are to be run. */
2677 commands[0].prog = argbuf[0]; /* first command. */
2678 commands[0].argv = &argbuf[0];
2679 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2681 if (string)
2682 commands[0].argv[0] = string;
2684 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2685 if (strcmp (argbuf[i], "|") == 0)
2686 { /* each command. */
2687 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2688 fatal ("-pipe not supported");
2689 #endif
2690 argbuf[i] = 0; /* termination of command args. */
2691 commands[n_commands].prog = argbuf[i + 1];
2692 commands[n_commands].argv = &argbuf[i + 1];
2693 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2694 X_OK, 0);
2695 if (string)
2696 commands[n_commands].argv[0] = string;
2697 n_commands++;
2700 argbuf[argbuf_index] = 0;
2702 /* If -v, print what we are about to do, and maybe query. */
2704 if (verbose_flag)
2706 /* For help listings, put a blank line between sub-processes. */
2707 if (print_help_list)
2708 fputc ('\n', stderr);
2710 /* Print each piped command as a separate line. */
2711 for (i = 0; i < n_commands; i++)
2713 const char *const *j;
2715 if (verbose_only_flag)
2717 for (j = commands[i].argv; *j; j++)
2719 const char *p;
2720 fprintf (stderr, " \"");
2721 for (p = *j; *p; ++p)
2723 if (*p == '"' || *p == '\\' || *p == '$')
2724 fputc ('\\', stderr);
2725 fputc (*p, stderr);
2727 fputc ('"', stderr);
2730 else
2731 for (j = commands[i].argv; *j; j++)
2732 fprintf (stderr, " %s", *j);
2734 /* Print a pipe symbol after all but the last command. */
2735 if (i + 1 != n_commands)
2736 fprintf (stderr, " |");
2737 fprintf (stderr, "\n");
2739 fflush (stderr);
2740 if (verbose_only_flag != 0)
2742 /* verbose_only_flag should act as if the spec was
2743 executed, so increment execution_count before
2744 returning. This prevents spurious warnings about
2745 unused linker input files, etc. */
2746 execution_count++;
2747 return 0;
2749 #ifdef DEBUG
2750 notice ("\nGo ahead? (y or n) ");
2751 fflush (stderr);
2752 i = getchar ();
2753 if (i != '\n')
2754 while (getchar () != '\n')
2757 if (i != 'y' && i != 'Y')
2758 return 0;
2759 #endif /* DEBUG */
2762 #ifdef ENABLE_VALGRIND_CHECKING
2763 /* Run the each command through valgrind. To simplify prepending the
2764 path to valgrind and the option "-q" (for quiet operation unless
2765 something triggers), we allocate a separate argv array. */
2767 for (i = 0; i < n_commands; i++)
2769 const char **argv;
2770 int argc;
2771 int j;
2773 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2776 argv = alloca ((argc + 3) * sizeof (char *));
2778 argv[0] = VALGRIND_PATH;
2779 argv[1] = "-q";
2780 for (j = 2; j < argc + 2; j++)
2781 argv[j] = commands[i].argv[j - 2];
2782 argv[j] = NULL;
2784 commands[i].argv = argv;
2785 commands[i].prog = argv[0];
2787 #endif
2789 /* Run each piped subprocess. */
2791 for (i = 0; i < n_commands; i++)
2793 char *errmsg_fmt, *errmsg_arg;
2794 const char *string = commands[i].argv[0];
2796 /* For some bizarre reason, the second argument of execvp() is
2797 char *const *, not const char *const *. */
2798 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2799 programname, temp_filename,
2800 &errmsg_fmt, &errmsg_arg,
2801 ((i == 0 ? PEXECUTE_FIRST : 0)
2802 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2803 | (string == commands[i].prog
2804 ? PEXECUTE_SEARCH : 0)
2805 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2807 if (commands[i].pid == -1)
2808 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2810 if (string != commands[i].prog)
2811 free ((void *) string);
2814 execution_count++;
2816 /* Wait for all the subprocesses to finish.
2817 We don't care what order they finish in;
2818 we know that N_COMMANDS waits will get them all.
2819 Ignore subprocesses that we don't know about,
2820 since they can be spawned by the process that exec'ed us. */
2823 int ret_code = 0;
2824 #ifdef HAVE_GETRUSAGE
2825 struct timeval d;
2826 double ut = 0.0, st = 0.0;
2827 #endif
2829 for (i = 0; i < n_commands;)
2831 int j;
2832 int status;
2833 int pid;
2835 pid = pwait (commands[i].pid, &status, 0);
2836 gcc_assert (pid >= 0);
2838 #ifdef HAVE_GETRUSAGE
2839 if (report_times)
2841 /* getrusage returns the total resource usage of all children
2842 up to now. Copy the previous values into prus, get the
2843 current statistics, then take the difference. */
2845 prus = rus;
2846 getrusage (RUSAGE_CHILDREN, &rus);
2847 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2848 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2849 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2851 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2852 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2853 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2855 #endif
2857 for (j = 0; j < n_commands; j++)
2858 if (commands[j].pid == pid)
2860 i++;
2861 if (WIFSIGNALED (status))
2863 #ifdef SIGPIPE
2864 /* SIGPIPE is a special case. It happens in -pipe mode
2865 when the compiler dies before the preprocessor is
2866 done, or the assembler dies before the compiler is
2867 done. There's generally been an error already, and
2868 this is just fallout. So don't generate another error
2869 unless we would otherwise have succeeded. */
2870 if (WTERMSIG (status) == SIGPIPE
2871 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2873 else
2874 #endif
2875 fatal ("\
2876 Internal error: %s (program %s)\n\
2877 Please submit a full bug report.\n\
2878 See %s for instructions.",
2879 strsignal (WTERMSIG (status)), commands[j].prog,
2880 bug_report_url);
2881 signal_count++;
2882 ret_code = -1;
2884 else if (WIFEXITED (status)
2885 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2887 if (WEXITSTATUS (status) > greatest_status)
2888 greatest_status = WEXITSTATUS (status);
2889 ret_code = -1;
2891 #ifdef HAVE_GETRUSAGE
2892 if (report_times && ut + st != 0)
2893 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2894 #endif
2895 break;
2898 return ret_code;
2902 /* Find all the switches given to us
2903 and make a vector describing them.
2904 The elements of the vector are strings, one per switch given.
2905 If a switch uses following arguments, then the `part1' field
2906 is the switch itself and the `args' field
2907 is a null-terminated vector containing the following arguments.
2908 The `live_cond' field is:
2909 0 when initialized
2910 1 if the switch is true in a conditional spec,
2911 -1 if false (overridden by a later switch)
2912 -2 if this switch should be ignored (used in %<S)
2913 The `validated' field is nonzero if any spec has looked at this switch;
2914 if it remains zero at the end of the run, it must be meaningless. */
2916 #define SWITCH_OK 0
2917 #define SWITCH_FALSE -1
2918 #define SWITCH_IGNORE -2
2919 #define SWITCH_LIVE 1
2921 struct switchstr
2923 const char *part1;
2924 const char **args;
2925 int live_cond;
2926 unsigned char validated;
2927 unsigned char ordering;
2930 static struct switchstr *switches;
2932 static int n_switches;
2934 struct infile
2936 const char *name;
2937 const char *language;
2938 struct compiler *incompiler;
2939 bool compiled;
2940 bool preprocessed;
2943 /* Also a vector of input files specified. */
2945 static struct infile *infiles;
2947 int n_infiles;
2949 /* True if multiple input files are being compiled to a single
2950 assembly file. */
2952 static bool combine_inputs;
2954 /* This counts the number of libraries added by lang_specific_driver, so that
2955 we can tell if there were any user supplied any files or libraries. */
2957 static int added_libraries;
2959 /* And a vector of corresponding output files is made up later. */
2961 const char **outfiles;
2963 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2965 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2966 is true if we should look for an executable suffix. DO_OBJ
2967 is true if we should look for an object suffix. */
2969 static const char *
2970 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2971 int do_obj ATTRIBUTE_UNUSED)
2973 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2974 int i;
2975 #endif
2976 int len;
2978 if (name == NULL)
2979 return NULL;
2981 len = strlen (name);
2983 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2984 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2985 if (do_obj && len > 2
2986 && name[len - 2] == '.'
2987 && name[len - 1] == 'o')
2989 obstack_grow (&obstack, name, len - 2);
2990 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2991 name = obstack_finish (&obstack);
2993 #endif
2995 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2996 /* If there is no filetype, make it the executable suffix (which includes
2997 the "."). But don't get confused if we have just "-o". */
2998 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2999 return name;
3001 for (i = len - 1; i >= 0; i--)
3002 if (IS_DIR_SEPARATOR (name[i]))
3003 break;
3005 for (i++; i < len; i++)
3006 if (name[i] == '.')
3007 return name;
3009 obstack_grow (&obstack, name, len);
3010 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3011 strlen (TARGET_EXECUTABLE_SUFFIX));
3012 name = obstack_finish (&obstack);
3013 #endif
3015 return name;
3017 #endif
3019 /* Display the command line switches accepted by gcc. */
3020 static void
3021 display_help (void)
3023 printf (_("Usage: %s [options] file...\n"), programname);
3024 fputs (_("Options:\n"), stdout);
3026 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3027 fputs (_(" --help Display this information\n"), stdout);
3028 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3029 if (! verbose_flag)
3030 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3031 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3032 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3033 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3034 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3035 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3036 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3037 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3038 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3039 fputs (_("\
3040 -print-multi-lib Display the mapping between command line options and\n\
3041 multiple library search directories\n"), stdout);
3042 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3043 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3044 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3045 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3046 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3047 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3048 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3049 fputs (_(" -combine Pass multiple source files to compiler at once\n"), stdout);
3050 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3051 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3052 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3053 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3054 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3055 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3056 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3057 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3058 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3059 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3060 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3061 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3062 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3063 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3064 fputs (_("\
3065 -x <language> Specify the language of the following input files\n\
3066 Permissible languages include: c c++ assembler none\n\
3067 'none' means revert to the default behavior of\n\
3068 guessing the language based on the file's extension\n\
3069 "), stdout);
3071 printf (_("\
3072 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3073 passed on to the various sub-processes invoked by %s. In order to pass\n\
3074 other options on to these processes the -W<letter> options must be used.\n\
3075 "), programname);
3077 /* The rest of the options are displayed by invocations of the various
3078 sub-processes. */
3081 static void
3082 add_preprocessor_option (const char *option, int len)
3084 n_preprocessor_options++;
3086 if (! preprocessor_options)
3087 preprocessor_options = xmalloc (n_preprocessor_options * sizeof (char *));
3088 else
3089 preprocessor_options = xrealloc (preprocessor_options,
3090 n_preprocessor_options * sizeof (char *));
3092 preprocessor_options [n_preprocessor_options - 1] =
3093 save_string (option, len);
3096 static void
3097 add_assembler_option (const char *option, int len)
3099 n_assembler_options++;
3101 if (! assembler_options)
3102 assembler_options = xmalloc (n_assembler_options * sizeof (char *));
3103 else
3104 assembler_options = xrealloc (assembler_options,
3105 n_assembler_options * sizeof (char *));
3107 assembler_options [n_assembler_options - 1] = save_string (option, len);
3110 static void
3111 add_linker_option (const char *option, int len)
3113 n_linker_options++;
3115 if (! linker_options)
3116 linker_options = xmalloc (n_linker_options * sizeof (char *));
3117 else
3118 linker_options = xrealloc (linker_options,
3119 n_linker_options * sizeof (char *));
3121 linker_options [n_linker_options - 1] = save_string (option, len);
3124 /* Create the vector `switches' and its contents.
3125 Store its length in `n_switches'. */
3127 static void
3128 process_command (int argc, const char **argv)
3130 int i;
3131 const char *temp;
3132 char *temp1;
3133 const char *spec_lang = 0;
3134 int last_language_n_infiles;
3135 int have_c = 0;
3136 int lang_n_infiles = 0;
3137 #ifdef MODIFY_TARGET_NAME
3138 int is_modify_target_name;
3139 int j;
3140 #endif
3142 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3144 n_switches = 0;
3145 n_infiles = 0;
3146 added_libraries = 0;
3148 /* Figure compiler version from version string. */
3150 compiler_version = temp1 = xstrdup (version_string);
3152 for (; *temp1; ++temp1)
3154 if (*temp1 == ' ')
3156 *temp1 = '\0';
3157 break;
3161 /* If there is a -V or -b option (or both), process it now, before
3162 trying to interpret the rest of the command line. */
3163 if (argc > 1 && argv[1][0] == '-'
3164 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3166 const char *new_version = DEFAULT_TARGET_VERSION;
3167 const char *new_machine = DEFAULT_TARGET_MACHINE;
3168 const char *progname = argv[0];
3169 char **new_argv;
3170 char *new_argv0;
3171 int baselen;
3173 while (argc > 1 && argv[1][0] == '-'
3174 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3176 char opt = argv[1][1];
3177 const char *arg;
3178 if (argv[1][2] != '\0')
3180 arg = argv[1] + 2;
3181 argc -= 1;
3182 argv += 1;
3184 else if (argc > 2)
3186 arg = argv[2];
3187 argc -= 2;
3188 argv += 2;
3190 else
3191 fatal ("'-%c' option must have argument", opt);
3192 if (opt == 'V')
3193 new_version = arg;
3194 else
3195 new_machine = arg;
3198 for (baselen = strlen (progname); baselen > 0; baselen--)
3199 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3200 break;
3201 new_argv0 = xmemdup (progname, baselen,
3202 baselen + concat_length (new_version, new_machine,
3203 "-gcc-", NULL) + 1);
3204 strcpy (new_argv0 + baselen, new_machine);
3205 strcat (new_argv0, "-gcc-");
3206 strcat (new_argv0, new_version);
3208 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3209 (argc + 1) * sizeof (argv[0]));
3210 new_argv[0] = new_argv0;
3212 execvp (new_argv0, new_argv);
3213 fatal ("couldn't run '%s': %s", new_argv0, xstrerror (errno));
3216 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3217 see if we can create it from the pathname specified in argv[0]. */
3219 gcc_libexec_prefix = standard_libexec_prefix;
3220 #ifndef VMS
3221 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3222 if (!gcc_exec_prefix)
3224 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3225 standard_exec_prefix);
3226 gcc_libexec_prefix = make_relative_prefix (argv[0],
3227 standard_bindir_prefix,
3228 standard_libexec_prefix);
3229 if (gcc_exec_prefix)
3230 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3232 else
3233 gcc_libexec_prefix = make_relative_prefix (gcc_exec_prefix,
3234 standard_exec_prefix,
3235 standard_libexec_prefix);
3236 #else
3237 #endif
3239 if (gcc_exec_prefix)
3241 int len = strlen (gcc_exec_prefix);
3243 if (len > (int) sizeof ("/lib/gcc/") - 1
3244 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3246 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3247 if (IS_DIR_SEPARATOR (*temp)
3248 && strncmp (temp + 1, "lib", 3) == 0
3249 && IS_DIR_SEPARATOR (temp[4])
3250 && strncmp (temp + 5, "gcc", 3) == 0)
3251 len -= sizeof ("/lib/gcc/") - 1;
3254 set_std_prefix (gcc_exec_prefix, len);
3255 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3256 PREFIX_PRIORITY_LAST, 0, 0);
3257 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3258 PREFIX_PRIORITY_LAST, 0, 0);
3261 /* COMPILER_PATH and LIBRARY_PATH have values
3262 that are lists of directory names with colons. */
3264 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3265 if (temp)
3267 const char *startp, *endp;
3268 char *nstore = alloca (strlen (temp) + 3);
3270 startp = endp = temp;
3271 while (1)
3273 if (*endp == PATH_SEPARATOR || *endp == 0)
3275 strncpy (nstore, startp, endp - startp);
3276 if (endp == startp)
3277 strcpy (nstore, concat (".", dir_separator_str, NULL));
3278 else if (!IS_DIR_SEPARATOR (endp[-1]))
3280 nstore[endp - startp] = DIR_SEPARATOR;
3281 nstore[endp - startp + 1] = 0;
3283 else
3284 nstore[endp - startp] = 0;
3285 add_prefix (&exec_prefixes, nstore, 0,
3286 PREFIX_PRIORITY_LAST, 0, 0);
3287 add_prefix (&include_prefixes, nstore, 0,
3288 PREFIX_PRIORITY_LAST, 0, 0);
3289 if (*endp == 0)
3290 break;
3291 endp = startp = endp + 1;
3293 else
3294 endp++;
3298 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3299 if (temp && *cross_compile == '0')
3301 const char *startp, *endp;
3302 char *nstore = alloca (strlen (temp) + 3);
3304 startp = endp = temp;
3305 while (1)
3307 if (*endp == PATH_SEPARATOR || *endp == 0)
3309 strncpy (nstore, startp, endp - startp);
3310 if (endp == startp)
3311 strcpy (nstore, concat (".", dir_separator_str, NULL));
3312 else if (!IS_DIR_SEPARATOR (endp[-1]))
3314 nstore[endp - startp] = DIR_SEPARATOR;
3315 nstore[endp - startp + 1] = 0;
3317 else
3318 nstore[endp - startp] = 0;
3319 add_prefix (&startfile_prefixes, nstore, NULL,
3320 PREFIX_PRIORITY_LAST, 0, 1);
3321 if (*endp == 0)
3322 break;
3323 endp = startp = endp + 1;
3325 else
3326 endp++;
3330 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3331 GET_ENVIRONMENT (temp, "LPATH");
3332 if (temp && *cross_compile == '0')
3334 const char *startp, *endp;
3335 char *nstore = alloca (strlen (temp) + 3);
3337 startp = endp = temp;
3338 while (1)
3340 if (*endp == PATH_SEPARATOR || *endp == 0)
3342 strncpy (nstore, startp, endp - startp);
3343 if (endp == startp)
3344 strcpy (nstore, concat (".", dir_separator_str, NULL));
3345 else if (!IS_DIR_SEPARATOR (endp[-1]))
3347 nstore[endp - startp] = DIR_SEPARATOR;
3348 nstore[endp - startp + 1] = 0;
3350 else
3351 nstore[endp - startp] = 0;
3352 add_prefix (&startfile_prefixes, nstore, NULL,
3353 PREFIX_PRIORITY_LAST, 0, 1);
3354 if (*endp == 0)
3355 break;
3356 endp = startp = endp + 1;
3358 else
3359 endp++;
3363 /* Convert new-style -- options to old-style. */
3364 translate_options (&argc, (const char *const **) &argv);
3366 /* Do language-specific adjustment/addition of flags. */
3367 lang_specific_driver (&argc, (const char *const **) &argv, &added_libraries);
3369 /* Scan argv twice. Here, the first time, just count how many switches
3370 there will be in their vector, and how many input files in theirs.
3371 Here we also parse the switches that cc itself uses (e.g. -v). */
3373 for (i = 1; i < argc; i++)
3375 if (! strcmp (argv[i], "-dumpspecs"))
3377 struct spec_list *sl;
3378 init_spec ();
3379 for (sl = specs; sl; sl = sl->next)
3380 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3381 if (link_command_spec)
3382 printf ("*link_command:\n%s\n\n", link_command_spec);
3383 exit (0);
3385 else if (! strcmp (argv[i], "-dumpversion"))
3387 printf ("%s\n", spec_version);
3388 exit (0);
3390 else if (! strcmp (argv[i], "-dumpmachine"))
3392 printf ("%s\n", spec_machine);
3393 exit (0);
3395 else if (strcmp (argv[i], "-fversion") == 0)
3397 /* translate_options () has turned --version into -fversion. */
3398 printf (_("%s (GCC) %s\n"), programname, version_string);
3399 printf ("Copyright %s 2005 Free Software Foundation, Inc.\n",
3400 _("(C)"));
3401 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3402 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3403 stdout);
3404 exit (0);
3406 else if (strcmp (argv[i], "-fhelp") == 0)
3408 /* translate_options () has turned --help into -fhelp. */
3409 print_help_list = 1;
3411 /* We will be passing a dummy file on to the sub-processes. */
3412 n_infiles++;
3413 n_switches++;
3415 /* CPP driver cannot obtain switch from cc1_options. */
3416 if (is_cpp_driver)
3417 add_preprocessor_option ("--help", 6);
3418 add_assembler_option ("--help", 6);
3419 add_linker_option ("--help", 6);
3421 else if (strcmp (argv[i], "-ftarget-help") == 0)
3423 /* translate_options() has turned --target-help into -ftarget-help. */
3424 target_help_flag = 1;
3426 /* We will be passing a dummy file on to the sub-processes. */
3427 n_infiles++;
3428 n_switches++;
3430 /* CPP driver cannot obtain switch from cc1_options. */
3431 if (is_cpp_driver)
3432 add_preprocessor_option ("--target-help", 13);
3433 add_assembler_option ("--target-help", 13);
3434 add_linker_option ("--target-help", 13);
3436 else if (! strcmp (argv[i], "-pass-exit-codes"))
3438 pass_exit_codes = 1;
3439 n_switches++;
3441 else if (! strcmp (argv[i], "-print-search-dirs"))
3442 print_search_dirs = 1;
3443 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3444 print_file_name = "libgcc.a";
3445 else if (! strncmp (argv[i], "-print-file-name=", 17))
3446 print_file_name = argv[i] + 17;
3447 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3448 print_prog_name = argv[i] + 17;
3449 else if (! strcmp (argv[i], "-print-multi-lib"))
3450 print_multi_lib = 1;
3451 else if (! strcmp (argv[i], "-print-multi-directory"))
3452 print_multi_directory = 1;
3453 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3454 print_multi_os_directory = 1;
3455 else if (! strncmp (argv[i], "-Wa,", 4))
3457 int prev, j;
3458 /* Pass the rest of this option to the assembler. */
3460 /* Split the argument at commas. */
3461 prev = 4;
3462 for (j = 4; argv[i][j]; j++)
3463 if (argv[i][j] == ',')
3465 add_assembler_option (argv[i] + prev, j - prev);
3466 prev = j + 1;
3469 /* Record the part after the last comma. */
3470 add_assembler_option (argv[i] + prev, j - prev);
3472 else if (! strncmp (argv[i], "-Wp,", 4))
3474 int prev, j;
3475 /* Pass the rest of this option to the preprocessor. */
3477 /* Split the argument at commas. */
3478 prev = 4;
3479 for (j = 4; argv[i][j]; j++)
3480 if (argv[i][j] == ',')
3482 add_preprocessor_option (argv[i] + prev, j - prev);
3483 prev = j + 1;
3486 /* Record the part after the last comma. */
3487 add_preprocessor_option (argv[i] + prev, j - prev);
3489 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3490 /* The +e options to the C++ front-end. */
3491 n_switches++;
3492 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3494 int j;
3495 /* Split the argument at commas. */
3496 for (j = 3; argv[i][j]; j++)
3497 n_infiles += (argv[i][j] == ',');
3499 else if (strcmp (argv[i], "-Xlinker") == 0)
3501 if (i + 1 == argc)
3502 fatal ("argument to '-Xlinker' is missing");
3504 n_infiles++;
3505 i++;
3507 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3509 if (i + 1 == argc)
3510 fatal ("argument to '-Xpreprocessor' is missing");
3512 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3514 else if (strcmp (argv[i], "-Xassembler") == 0)
3516 if (i + 1 == argc)
3517 fatal ("argument to '-Xassembler' is missing");
3519 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3521 else if (strcmp (argv[i], "-l") == 0)
3523 if (i + 1 == argc)
3524 fatal ("argument to '-l' is missing");
3526 n_infiles++;
3527 i++;
3529 else if (strncmp (argv[i], "-l", 2) == 0)
3530 n_infiles++;
3531 else if (strcmp (argv[i], "-save-temps") == 0)
3533 save_temps_flag = 1;
3534 n_switches++;
3536 else if (strcmp (argv[i], "-combine") == 0)
3538 combine_flag = 1;
3539 n_switches++;
3541 else if (strcmp (argv[i], "-specs") == 0)
3543 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3544 if (++i >= argc)
3545 fatal ("argument to '-specs' is missing");
3547 user->next = (struct user_specs *) 0;
3548 user->filename = argv[i];
3549 if (user_specs_tail)
3550 user_specs_tail->next = user;
3551 else
3552 user_specs_head = user;
3553 user_specs_tail = user;
3555 else if (strncmp (argv[i], "-specs=", 7) == 0)
3557 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3558 if (strlen (argv[i]) == 7)
3559 fatal ("argument to '-specs=' is missing");
3561 user->next = (struct user_specs *) 0;
3562 user->filename = argv[i] + 7;
3563 if (user_specs_tail)
3564 user_specs_tail->next = user;
3565 else
3566 user_specs_head = user;
3567 user_specs_tail = user;
3569 else if (strcmp (argv[i], "-time") == 0)
3570 report_times = 1;
3571 else if (strcmp (argv[i], "-pipe") == 0)
3573 /* -pipe has to go into the switches array as well as
3574 setting a flag. */
3575 use_pipes = 1;
3576 n_switches++;
3578 else if (strcmp (argv[i], "-###") == 0)
3580 /* This is similar to -v except that there is no execution
3581 of the commands and the echoed arguments are quoted. It
3582 is intended for use in shell scripts to capture the
3583 driver-generated command line. */
3584 verbose_only_flag++;
3585 verbose_flag++;
3587 else if (argv[i][0] == '-' && argv[i][1] != 0)
3589 const char *p = &argv[i][1];
3590 int c = *p;
3592 switch (c)
3594 case 'b':
3595 case 'V':
3596 fatal ("'-%c' must come at the start of the command line", c);
3597 break;
3599 case 'B':
3601 const char *value;
3602 int len;
3604 if (p[1] == 0 && i + 1 == argc)
3605 fatal ("argument to '-B' is missing");
3606 if (p[1] == 0)
3607 value = argv[++i];
3608 else
3609 value = p + 1;
3611 len = strlen (value);
3613 /* Catch the case where the user has forgotten to append a
3614 directory separator to the path. Note, they may be using
3615 -B to add an executable name prefix, eg "i386-elf-", in
3616 order to distinguish between multiple installations of
3617 GCC in the same directory. Hence we must check to see
3618 if appending a directory separator actually makes a
3619 valid directory name. */
3620 if (! IS_DIR_SEPARATOR (value [len - 1])
3621 && is_directory (value, "", 0))
3623 char *tmp = xmalloc (len + 2);
3624 strcpy (tmp, value);
3625 tmp[len] = DIR_SEPARATOR;
3626 tmp[++ len] = 0;
3627 value = tmp;
3630 /* As a kludge, if the arg is "[foo/]stageN/", just
3631 add "[foo/]include" to the include prefix. */
3632 if ((len == 7
3633 || (len > 7
3634 && (IS_DIR_SEPARATOR (value[len - 8]))))
3635 && strncmp (value + len - 7, "stage", 5) == 0
3636 && ISDIGIT (value[len - 2])
3637 && (IS_DIR_SEPARATOR (value[len - 1])))
3639 if (len == 7)
3640 add_prefix (&include_prefixes, "./", NULL,
3641 PREFIX_PRIORITY_B_OPT, 0, 0);
3642 else
3644 char *string = xmalloc (len - 6);
3645 memcpy (string, value, len - 7);
3646 string[len - 7] = 0;
3647 add_prefix (&include_prefixes, string, NULL,
3648 PREFIX_PRIORITY_B_OPT, 0, 0);
3652 add_prefix (&exec_prefixes, value, NULL,
3653 PREFIX_PRIORITY_B_OPT, 0, 0);
3654 add_prefix (&startfile_prefixes, value, NULL,
3655 PREFIX_PRIORITY_B_OPT, 0, 0);
3656 add_prefix (&include_prefixes, value, NULL,
3657 PREFIX_PRIORITY_B_OPT, 0, 0);
3658 n_switches++;
3660 break;
3662 case 'v': /* Print our subcommands and print versions. */
3663 n_switches++;
3664 /* If they do anything other than exactly `-v', don't set
3665 verbose_flag; rather, continue on to give the error. */
3666 if (p[1] != 0)
3667 break;
3668 verbose_flag++;
3669 break;
3671 case 'S':
3672 case 'c':
3673 if (p[1] == 0)
3675 have_c = 1;
3676 n_switches++;
3677 break;
3679 goto normal_switch;
3681 case 'o':
3682 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3683 if (! have_c)
3685 int skip;
3687 /* Forward scan, just in case -S or -c is specified
3688 after -o. */
3689 int j = i + 1;
3690 if (p[1] == 0)
3691 ++j;
3692 while (j < argc)
3694 if (argv[j][0] == '-')
3696 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3697 && argv[j][2] == 0)
3699 have_c = 1;
3700 break;
3702 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3703 j += skip - (argv[j][2] != 0);
3704 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3705 j += skip;
3707 j++;
3710 #endif
3711 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3712 if (p[1] == 0)
3713 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3714 else
3715 argv[i] = convert_filename (argv[i], ! have_c, 0);
3716 #endif
3717 goto normal_switch;
3719 default:
3720 normal_switch:
3722 #ifdef MODIFY_TARGET_NAME
3723 is_modify_target_name = 0;
3725 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3726 if (! strcmp (argv[i], modify_target[j].sw))
3728 char *new_name = xmalloc (strlen (modify_target[j].str)
3729 + strlen (spec_machine));
3730 const char *p, *r;
3731 char *q;
3732 int made_addition = 0;
3734 is_modify_target_name = 1;
3735 for (p = spec_machine, q = new_name; *p != 0; )
3737 if (modify_target[j].add_del == DELETE
3738 && (! strncmp (q, modify_target[j].str,
3739 strlen (modify_target[j].str))))
3740 p += strlen (modify_target[j].str);
3741 else if (modify_target[j].add_del == ADD
3742 && ! made_addition && *p == '-')
3744 for (r = modify_target[j].str; *r != 0; )
3745 *q++ = *r++;
3746 made_addition = 1;
3749 *q++ = *p++;
3752 spec_machine = new_name;
3755 if (is_modify_target_name)
3756 break;
3757 #endif
3759 n_switches++;
3761 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3762 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3763 else if (WORD_SWITCH_TAKES_ARG (p))
3764 i += WORD_SWITCH_TAKES_ARG (p);
3767 else
3769 n_infiles++;
3770 lang_n_infiles++;
3774 if ((save_temps_flag || report_times) && use_pipes)
3776 /* -save-temps overrides -pipe, so that temp files are produced */
3777 if (save_temps_flag)
3778 error ("warning: -pipe ignored because -save-temps specified");
3779 /* -time overrides -pipe because we can't get correct stats when
3780 multiple children are running at once. */
3781 else if (report_times)
3782 error ("warning: -pipe ignored because -time specified");
3784 use_pipes = 0;
3787 /* Set up the search paths before we go looking for config files. */
3789 /* These come before the md prefixes so that we will find gcc's subcommands
3790 (such as cpp) rather than those of the host system. */
3791 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3792 as well as trying the machine and the version. */
3793 #ifndef OS2
3794 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3795 PREFIX_PRIORITY_LAST, 1, 0);
3796 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3797 PREFIX_PRIORITY_LAST, 2, 0);
3798 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3799 PREFIX_PRIORITY_LAST, 2, 0);
3800 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3801 PREFIX_PRIORITY_LAST, 2, 0);
3802 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
3803 PREFIX_PRIORITY_LAST, 2, 0);
3804 #endif
3806 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3807 PREFIX_PRIORITY_LAST, 1, 0);
3808 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
3809 PREFIX_PRIORITY_LAST, 1, 0);
3811 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3812 dir_separator_str, NULL);
3814 /* If tooldir is relative, base it on exec_prefixes. A relative
3815 tooldir lets us move the installed tree as a unit.
3817 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3818 directories, so that we can search both the user specified directory
3819 and the standard place. */
3821 if (!IS_ABSOLUTE_PATH (tooldir_prefix))
3823 if (gcc_exec_prefix)
3825 char *gcc_exec_tooldir_prefix
3826 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3827 spec_version, dir_separator_str, tooldir_prefix, NULL);
3829 add_prefix (&exec_prefixes,
3830 concat (gcc_exec_tooldir_prefix, "bin",
3831 dir_separator_str, NULL),
3832 NULL, PREFIX_PRIORITY_LAST, 0, 0);
3833 add_prefix (&startfile_prefixes,
3834 concat (gcc_exec_tooldir_prefix, "lib",
3835 dir_separator_str, NULL),
3836 NULL, PREFIX_PRIORITY_LAST, 0, 1);
3839 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3840 dir_separator_str, spec_version,
3841 dir_separator_str, tooldir_prefix, NULL);
3844 add_prefix (&exec_prefixes,
3845 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3846 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3847 add_prefix (&startfile_prefixes,
3848 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3849 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3851 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3852 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3853 then consider it to relocate with the rest of the GCC installation
3854 if GCC_EXEC_PREFIX is set.
3855 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3856 if (target_system_root && gcc_exec_prefix)
3858 char *tmp_prefix = make_relative_prefix (argv[0],
3859 standard_bindir_prefix,
3860 target_system_root);
3861 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3863 target_system_root = tmp_prefix;
3864 target_system_root_changed = 1;
3867 #endif
3869 /* More prefixes are enabled in main, after we read the specs file
3870 and determine whether this is cross-compilation or not. */
3872 /* Then create the space for the vectors and scan again. */
3874 switches = xmalloc ((n_switches + 1) * sizeof (struct switchstr));
3875 infiles = xmalloc ((n_infiles + 1) * sizeof (struct infile));
3876 n_switches = 0;
3877 n_infiles = 0;
3878 last_language_n_infiles = -1;
3880 /* This, time, copy the text of each switch and store a pointer
3881 to the copy in the vector of switches.
3882 Store all the infiles in their vector. */
3884 for (i = 1; i < argc; i++)
3886 /* Just skip the switches that were handled by the preceding loop. */
3887 #ifdef MODIFY_TARGET_NAME
3888 is_modify_target_name = 0;
3890 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3891 if (! strcmp (argv[i], modify_target[j].sw))
3892 is_modify_target_name = 1;
3894 if (is_modify_target_name)
3896 else
3897 #endif
3898 if (! strncmp (argv[i], "-Wa,", 4))
3900 else if (! strncmp (argv[i], "-Wp,", 4))
3902 else if (! strcmp (argv[i], "-pass-exit-codes"))
3904 else if (! strcmp (argv[i], "-print-search-dirs"))
3906 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3908 else if (! strncmp (argv[i], "-print-file-name=", 17))
3910 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3912 else if (! strcmp (argv[i], "-print-multi-lib"))
3914 else if (! strcmp (argv[i], "-print-multi-directory"))
3916 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3918 else if (! strcmp (argv[i], "-ftarget-help"))
3920 else if (! strcmp (argv[i], "-fhelp"))
3922 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3924 /* Compensate for the +e options to the C++ front-end;
3925 they're there simply for cfront call-compatibility. We do
3926 some magic in default_compilers to pass them down properly.
3927 Note we deliberately start at the `+' here, to avoid passing
3928 -e0 or -e1 down into the linker. */
3929 switches[n_switches].part1 = &argv[i][0];
3930 switches[n_switches].args = 0;
3931 switches[n_switches].live_cond = SWITCH_OK;
3932 switches[n_switches].validated = 0;
3933 n_switches++;
3935 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3937 int prev, j;
3938 /* Split the argument at commas. */
3939 prev = 4;
3940 for (j = 4; argv[i][j]; j++)
3941 if (argv[i][j] == ',')
3943 infiles[n_infiles].language = "*";
3944 infiles[n_infiles++].name
3945 = save_string (argv[i] + prev, j - prev);
3946 prev = j + 1;
3948 /* Record the part after the last comma. */
3949 infiles[n_infiles].language = "*";
3950 infiles[n_infiles++].name = argv[i] + prev;
3952 else if (strcmp (argv[i], "-Xlinker") == 0)
3954 infiles[n_infiles].language = "*";
3955 infiles[n_infiles++].name = argv[++i];
3957 else if (strcmp (argv[i], "-Xassembler") == 0)
3959 infiles[n_infiles].language = "*";
3960 infiles[n_infiles++].name = argv[++i];
3962 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3964 infiles[n_infiles].language = "*";
3965 infiles[n_infiles++].name = argv[++i];
3967 else if (strcmp (argv[i], "-l") == 0)
3968 { /* POSIX allows separation of -l and the lib arg;
3969 canonicalize by concatenating -l with its arg */
3970 infiles[n_infiles].language = "*";
3971 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3973 else if (strncmp (argv[i], "-l", 2) == 0)
3975 infiles[n_infiles].language = "*";
3976 infiles[n_infiles++].name = argv[i];
3978 else if (strcmp (argv[i], "-specs") == 0)
3979 i++;
3980 else if (strncmp (argv[i], "-specs=", 7) == 0)
3982 else if (strcmp (argv[i], "-time") == 0)
3984 else if (strcmp (argv[i], "-###") == 0)
3986 else if (argv[i][0] == '-' && argv[i][1] != 0)
3988 const char *p = &argv[i][1];
3989 int c = *p;
3991 if (c == 'x')
3993 if (p[1] == 0 && i + 1 == argc)
3994 fatal ("argument to '-x' is missing");
3995 if (p[1] == 0)
3996 spec_lang = argv[++i];
3997 else
3998 spec_lang = p + 1;
3999 if (! strcmp (spec_lang, "none"))
4000 /* Suppress the warning if -xnone comes after the last input
4001 file, because alternate command interfaces like g++ might
4002 find it useful to place -xnone after each input file. */
4003 spec_lang = 0;
4004 else
4005 last_language_n_infiles = n_infiles;
4006 continue;
4008 switches[n_switches].part1 = p;
4009 /* Deal with option arguments in separate argv elements. */
4010 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
4011 || WORD_SWITCH_TAKES_ARG (p))
4013 int j = 0;
4014 int n_args = WORD_SWITCH_TAKES_ARG (p);
4016 if (n_args == 0)
4018 /* Count only the option arguments in separate argv elements. */
4019 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4021 if (i + n_args >= argc)
4022 fatal ("argument to '-%s' is missing", p);
4023 switches[n_switches].args
4024 = xmalloc ((n_args + 1) * sizeof(const char *));
4025 while (j < n_args)
4026 switches[n_switches].args[j++] = argv[++i];
4027 /* Null-terminate the vector. */
4028 switches[n_switches].args[j] = 0;
4030 else if (strchr (switches_need_spaces, c))
4032 /* On some systems, ld cannot handle some options without
4033 a space. So split the option from its argument. */
4034 char *part1 = xmalloc (2);
4035 part1[0] = c;
4036 part1[1] = '\0';
4038 switches[n_switches].part1 = part1;
4039 switches[n_switches].args = xmalloc (2 * sizeof (const char *));
4040 switches[n_switches].args[0] = xstrdup (p+1);
4041 switches[n_switches].args[1] = 0;
4043 else
4044 switches[n_switches].args = 0;
4046 switches[n_switches].live_cond = SWITCH_OK;
4047 switches[n_switches].validated = 0;
4048 switches[n_switches].ordering = 0;
4049 /* These are always valid, since gcc.c itself understands them. */
4050 if (!strcmp (p, "save-temps")
4051 || !strcmp (p, "static-libgcc")
4052 || !strcmp (p, "shared-libgcc")
4053 || !strcmp (p, "pipe"))
4054 switches[n_switches].validated = 1;
4055 else
4057 char ch = switches[n_switches].part1[0];
4058 if (ch == 'B')
4059 switches[n_switches].validated = 1;
4061 n_switches++;
4063 else
4065 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4066 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4067 #endif
4069 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4071 perror_with_name (argv[i]);
4072 error_count++;
4074 else
4076 infiles[n_infiles].language = spec_lang;
4077 infiles[n_infiles++].name = argv[i];
4082 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4083 error ("warning: '-x %s' after last input file has no effect", spec_lang);
4085 /* Ensure we only invoke each subprocess once. */
4086 if (target_help_flag || print_help_list)
4088 n_infiles = 1;
4090 /* Create a dummy input file, so that we can pass --target-help on to
4091 the various sub-processes. */
4092 infiles[0].language = "c";
4093 infiles[0].name = "help-dummy";
4095 if (target_help_flag)
4097 switches[n_switches].part1 = "--target-help";
4098 switches[n_switches].args = 0;
4099 switches[n_switches].live_cond = SWITCH_OK;
4100 switches[n_switches].validated = 0;
4102 n_switches++;
4105 if (print_help_list)
4107 switches[n_switches].part1 = "--help";
4108 switches[n_switches].args = 0;
4109 switches[n_switches].live_cond = SWITCH_OK;
4110 switches[n_switches].validated = 0;
4112 n_switches++;
4116 switches[n_switches].part1 = 0;
4117 infiles[n_infiles].name = 0;
4120 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4121 and place that in the environment. */
4123 static void
4124 set_collect_gcc_options (void)
4126 int i;
4127 int first_time;
4129 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4130 the compiler. */
4131 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4132 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4134 first_time = TRUE;
4135 for (i = 0; (int) i < n_switches; i++)
4137 const char *const *args;
4138 const char *p, *q;
4139 if (!first_time)
4140 obstack_grow (&collect_obstack, " ", 1);
4142 first_time = FALSE;
4144 /* Ignore elided switches. */
4145 if (switches[i].live_cond == SWITCH_IGNORE)
4146 continue;
4148 obstack_grow (&collect_obstack, "'-", 2);
4149 q = switches[i].part1;
4150 while ((p = strchr (q, '\'')))
4152 obstack_grow (&collect_obstack, q, p - q);
4153 obstack_grow (&collect_obstack, "'\\''", 4);
4154 q = ++p;
4156 obstack_grow (&collect_obstack, q, strlen (q));
4157 obstack_grow (&collect_obstack, "'", 1);
4159 for (args = switches[i].args; args && *args; args++)
4161 obstack_grow (&collect_obstack, " '", 2);
4162 q = *args;
4163 while ((p = strchr (q, '\'')))
4165 obstack_grow (&collect_obstack, q, p - q);
4166 obstack_grow (&collect_obstack, "'\\''", 4);
4167 q = ++p;
4169 obstack_grow (&collect_obstack, q, strlen (q));
4170 obstack_grow (&collect_obstack, "'", 1);
4173 obstack_grow (&collect_obstack, "\0", 1);
4174 putenv (obstack_finish (&collect_obstack));
4177 /* Process a spec string, accumulating and running commands. */
4179 /* These variables describe the input file name.
4180 input_file_number is the index on outfiles of this file,
4181 so that the output file name can be stored for later use by %o.
4182 input_basename is the start of the part of the input file
4183 sans all directory names, and basename_length is the number
4184 of characters starting there excluding the suffix .c or whatever. */
4186 static const char *input_filename;
4187 static int input_file_number;
4188 size_t input_filename_length;
4189 static int basename_length;
4190 static int suffixed_basename_length;
4191 static const char *input_basename;
4192 static const char *input_suffix;
4193 #ifndef HOST_LACKS_INODE_NUMBERS
4194 static struct stat input_stat;
4195 #endif
4196 static int input_stat_set;
4198 /* The compiler used to process the current input file. */
4199 static struct compiler *input_file_compiler;
4201 /* These are variables used within do_spec and do_spec_1. */
4203 /* Nonzero if an arg has been started and not yet terminated
4204 (with space, tab or newline). */
4205 static int arg_going;
4207 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4208 is a temporary file name. */
4209 static int delete_this_arg;
4211 /* Nonzero means %w has been seen; the next arg to be terminated
4212 is the output file name of this compilation. */
4213 static int this_is_output_file;
4215 /* Nonzero means %s has been seen; the next arg to be terminated
4216 is the name of a library file and we should try the standard
4217 search dirs for it. */
4218 static int this_is_library_file;
4220 /* Nonzero means that the input of this command is coming from a pipe. */
4221 static int input_from_pipe;
4223 /* Nonnull means substitute this for any suffix when outputting a switches
4224 arguments. */
4225 static const char *suffix_subst;
4227 /* Process the spec SPEC and run the commands specified therein.
4228 Returns 0 if the spec is successfully processed; -1 if failed. */
4231 do_spec (const char *spec)
4233 int value;
4235 value = do_spec_2 (spec);
4237 /* Force out any unfinished command.
4238 If -pipe, this forces out the last command if it ended in `|'. */
4239 if (value == 0)
4241 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4242 argbuf_index--;
4244 set_collect_gcc_options ();
4246 if (argbuf_index > 0)
4247 value = execute ();
4250 return value;
4253 static int
4254 do_spec_2 (const char *spec)
4256 const char *string;
4257 int result;
4259 clear_args ();
4260 arg_going = 0;
4261 delete_this_arg = 0;
4262 this_is_output_file = 0;
4263 this_is_library_file = 0;
4264 input_from_pipe = 0;
4265 suffix_subst = NULL;
4267 result = do_spec_1 (spec, 0, NULL);
4269 /* End any pending argument. */
4270 if (arg_going)
4272 obstack_1grow (&obstack, 0);
4273 string = obstack_finish (&obstack);
4274 if (this_is_library_file)
4275 string = find_file (string);
4276 store_arg (string, delete_this_arg, this_is_output_file);
4277 if (this_is_output_file)
4278 outfiles[input_file_number] = string;
4279 arg_going = 0;
4282 return result;
4286 /* Process the given spec string and add any new options to the end
4287 of the switches/n_switches array. */
4289 static void
4290 do_option_spec (const char *name, const char *spec)
4292 unsigned int i, value_count, value_len;
4293 const char *p, *q, *value;
4294 char *tmp_spec, *tmp_spec_p;
4296 if (configure_default_options[0].name == NULL)
4297 return;
4299 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4300 if (strcmp (configure_default_options[i].name, name) == 0)
4301 break;
4302 if (i == ARRAY_SIZE (configure_default_options))
4303 return;
4305 value = configure_default_options[i].value;
4306 value_len = strlen (value);
4308 /* Compute the size of the final spec. */
4309 value_count = 0;
4310 p = spec;
4311 while ((p = strstr (p, "%(VALUE)")) != NULL)
4313 p ++;
4314 value_count ++;
4317 /* Replace each %(VALUE) by the specified value. */
4318 tmp_spec = alloca (strlen (spec) + 1
4319 + value_count * (value_len - strlen ("%(VALUE)")));
4320 tmp_spec_p = tmp_spec;
4321 q = spec;
4322 while ((p = strstr (q, "%(VALUE)")) != NULL)
4324 memcpy (tmp_spec_p, q, p - q);
4325 tmp_spec_p = tmp_spec_p + (p - q);
4326 memcpy (tmp_spec_p, value, value_len);
4327 tmp_spec_p += value_len;
4328 q = p + strlen ("%(VALUE)");
4330 strcpy (tmp_spec_p, q);
4332 do_self_spec (tmp_spec);
4335 /* Process the given spec string and add any new options to the end
4336 of the switches/n_switches array. */
4338 static void
4339 do_self_spec (const char *spec)
4341 do_spec_2 (spec);
4342 do_spec_1 (" ", 0, NULL);
4344 if (argbuf_index > 0)
4346 int i, first;
4348 first = n_switches;
4349 n_switches += argbuf_index;
4350 switches = xrealloc (switches,
4351 sizeof (struct switchstr) * (n_switches + 1));
4353 switches[n_switches] = switches[first];
4354 for (i = 0; i < argbuf_index; i++)
4356 struct switchstr *sw;
4358 /* Each switch should start with '-'. */
4359 if (argbuf[i][0] != '-')
4360 fatal ("switch '%s' does not start with '-'", argbuf[i]);
4362 sw = &switches[i + first];
4363 sw->part1 = &argbuf[i][1];
4364 sw->args = 0;
4365 sw->live_cond = SWITCH_OK;
4366 sw->validated = 0;
4367 sw->ordering = 0;
4372 void
4373 do_spec_path (struct prefix_list *pl, const char *option,
4374 int omit_if_relative, int separate_options,
4375 int only_subdir,
4376 const char *dir_for_machine_suffix,
4377 const char *dir_for_no_suffix)
4379 static size_t bufsize = 0;
4380 static char *buffer;
4381 int idx;
4383 /* Used on systems which record the specified -L dirs
4384 and use them to search for dynamic linking. */
4385 /* Relative directories always come from -B,
4386 and it is better not to use them for searching
4387 at run time. In particular, stage1 loses. */
4388 if (omit_if_relative
4389 && !IS_ABSOLUTE_PATH (pl->prefix))
4390 return;
4392 /* Try subdirectory if there is one. */
4393 if (machine_suffix && dir_for_machine_suffix)
4395 if (strlen (pl->prefix) + strlen (machine_suffix)
4396 >= bufsize)
4397 bufsize = (strlen (pl->prefix)
4398 + strlen (machine_suffix)) * 2 + 1;
4399 buffer = xrealloc (buffer, bufsize);
4400 strcpy (buffer, pl->prefix);
4401 strcat (buffer, machine_suffix);
4402 if (is_directory (buffer, dir_for_machine_suffix, 1))
4404 do_spec_1 (option, separate_options, NULL);
4405 if (separate_options)
4406 do_spec_1 (" ", 0, NULL);
4407 do_spec_1 (buffer, 1, NULL);
4408 do_spec_1 (dir_for_machine_suffix, 1, NULL);
4409 /* Make this a separate argument. */
4410 do_spec_1 (" ", 0, NULL);
4413 if (!pl->require_machine_suffix && dir_for_no_suffix)
4415 if (is_directory (pl->prefix, dir_for_no_suffix, 1))
4417 do_spec_1 (option, separate_options, NULL);
4418 if (separate_options)
4419 do_spec_1 (" ", 0, NULL);
4420 do_spec_1 (pl->prefix, 1, NULL);
4421 do_spec_1 (dir_for_no_suffix, 1, NULL);
4422 /* Make this a separate argument. */
4423 do_spec_1 (" ", 0, NULL);
4427 if (only_subdir)
4428 return;
4430 if (machine_suffix)
4432 if (is_directory (pl->prefix, machine_suffix, 1))
4434 do_spec_1 (option, separate_options, NULL);
4435 if (separate_options)
4436 do_spec_1 (" ", 0, NULL);
4437 do_spec_1 (pl->prefix, 1, NULL);
4438 /* Remove slash from machine_suffix. */
4439 if (strlen (machine_suffix) >= bufsize)
4440 bufsize = strlen (machine_suffix) * 2 + 1;
4441 buffer = xrealloc (buffer, bufsize);
4442 strcpy (buffer, machine_suffix);
4443 idx = strlen (buffer);
4444 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4445 buffer[idx - 1] = 0;
4446 do_spec_1 (buffer, 1, NULL);
4447 /* Make this a separate argument. */
4448 do_spec_1 (" ", 0, NULL);
4451 if (!pl->require_machine_suffix)
4453 if (is_directory (pl->prefix, "", 1))
4455 do_spec_1 (option, separate_options, NULL);
4456 if (separate_options)
4457 do_spec_1 (" ", 0, NULL);
4458 /* Remove slash from pl->prefix. */
4459 if (strlen (pl->prefix) >= bufsize)
4460 bufsize = strlen (pl->prefix) * 2 + 1;
4461 buffer = xrealloc (buffer, bufsize);
4462 strcpy (buffer, pl->prefix);
4463 idx = strlen (buffer);
4464 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4465 buffer[idx - 1] = 0;
4466 do_spec_1 (buffer, 1, NULL);
4467 /* Make this a separate argument. */
4468 do_spec_1 (" ", 0, NULL);
4473 /* Process the sub-spec SPEC as a portion of a larger spec.
4474 This is like processing a whole spec except that we do
4475 not initialize at the beginning and we do not supply a
4476 newline by default at the end.
4477 INSWITCH nonzero means don't process %-sequences in SPEC;
4478 in this case, % is treated as an ordinary character.
4479 This is used while substituting switches.
4480 INSWITCH nonzero also causes SPC not to terminate an argument.
4482 Value is zero unless a line was finished
4483 and the command on that line reported an error. */
4485 static int
4486 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4488 const char *p = spec;
4489 int c;
4490 int i;
4491 const char *string;
4492 int value;
4494 while ((c = *p++))
4495 /* If substituting a switch, treat all chars like letters.
4496 Otherwise, NL, SPC, TAB and % are special. */
4497 switch (inswitch ? 'a' : c)
4499 case '\n':
4500 /* End of line: finish any pending argument,
4501 then run the pending command if one has been started. */
4502 if (arg_going)
4504 obstack_1grow (&obstack, 0);
4505 string = obstack_finish (&obstack);
4506 if (this_is_library_file)
4507 string = find_file (string);
4508 store_arg (string, delete_this_arg, this_is_output_file);
4509 if (this_is_output_file)
4510 outfiles[input_file_number] = string;
4512 arg_going = 0;
4514 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4516 /* A `|' before the newline means use a pipe here,
4517 but only if -pipe was specified.
4518 Otherwise, execute now and don't pass the `|' as an arg. */
4519 if (use_pipes)
4521 input_from_pipe = 1;
4522 break;
4524 else
4525 argbuf_index--;
4528 set_collect_gcc_options ();
4530 if (argbuf_index > 0)
4532 value = execute ();
4533 if (value)
4534 return value;
4536 /* Reinitialize for a new command, and for a new argument. */
4537 clear_args ();
4538 arg_going = 0;
4539 delete_this_arg = 0;
4540 this_is_output_file = 0;
4541 this_is_library_file = 0;
4542 input_from_pipe = 0;
4543 break;
4545 case '|':
4546 /* End any pending argument. */
4547 if (arg_going)
4549 obstack_1grow (&obstack, 0);
4550 string = obstack_finish (&obstack);
4551 if (this_is_library_file)
4552 string = find_file (string);
4553 store_arg (string, delete_this_arg, this_is_output_file);
4554 if (this_is_output_file)
4555 outfiles[input_file_number] = string;
4558 /* Use pipe */
4559 obstack_1grow (&obstack, c);
4560 arg_going = 1;
4561 break;
4563 case '\t':
4564 case ' ':
4565 /* Space or tab ends an argument if one is pending. */
4566 if (arg_going)
4568 obstack_1grow (&obstack, 0);
4569 string = obstack_finish (&obstack);
4570 if (this_is_library_file)
4571 string = find_file (string);
4572 store_arg (string, delete_this_arg, this_is_output_file);
4573 if (this_is_output_file)
4574 outfiles[input_file_number] = string;
4576 /* Reinitialize for a new argument. */
4577 arg_going = 0;
4578 delete_this_arg = 0;
4579 this_is_output_file = 0;
4580 this_is_library_file = 0;
4581 break;
4583 case '%':
4584 switch (c = *p++)
4586 case 0:
4587 fatal ("spec '%s' invalid", spec);
4589 case 'b':
4590 obstack_grow (&obstack, input_basename, basename_length);
4591 arg_going = 1;
4592 break;
4594 case 'B':
4595 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4596 arg_going = 1;
4597 break;
4599 case 'd':
4600 delete_this_arg = 2;
4601 break;
4603 /* Dump out the directories specified with LIBRARY_PATH,
4604 followed by the absolute directories
4605 that we search for startfiles. */
4606 case 'D':
4608 struct prefix_list *pl = startfile_prefixes.plist;
4610 for (; pl; pl = pl->next)
4612 const char *no_suffix_multilib_dir;
4614 no_suffix_multilib_dir = pl->os_multilib ? multilib_os_dir
4615 : multilib_dir;
4616 /* Do not separate options, include non-multilibbed variant. */
4617 do_spec_path (pl, "-L",
4618 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4620 #else
4622 #endif
4623 0, 0, multilib_dir, no_suffix_multilib_dir);
4626 break;
4628 case 'e':
4629 /* %efoo means report an error with `foo' as error message
4630 and don't execute any more commands for this file. */
4632 const char *q = p;
4633 char *buf;
4634 while (*p != 0 && *p != '\n')
4635 p++;
4636 buf = alloca (p - q + 1);
4637 strncpy (buf, q, p - q);
4638 buf[p - q] = 0;
4639 error ("%s", buf);
4640 return -1;
4642 break;
4643 case 'n':
4644 /* %nfoo means report a notice with `foo' on stderr. */
4646 const char *q = p;
4647 char *buf;
4648 while (*p != 0 && *p != '\n')
4649 p++;
4650 buf = alloca (p - q + 1);
4651 strncpy (buf, q, p - q);
4652 buf[p - q] = 0;
4653 notice ("%s\n", buf);
4654 if (*p)
4655 p++;
4657 break;
4659 case 'j':
4661 struct stat st;
4663 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4664 defined, and it is not a directory, and it is
4665 writable, use it. Otherwise, treat this like any
4666 other temporary file. */
4668 if ((!save_temps_flag)
4669 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4670 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4672 obstack_grow (&obstack, HOST_BIT_BUCKET,
4673 strlen (HOST_BIT_BUCKET));
4674 delete_this_arg = 0;
4675 arg_going = 1;
4676 break;
4679 goto create_temp_file;
4680 case '|':
4681 if (use_pipes)
4683 obstack_1grow (&obstack, '-');
4684 delete_this_arg = 0;
4685 arg_going = 1;
4687 /* consume suffix */
4688 while (*p == '.' || ISALPHA ((unsigned char) *p))
4689 p++;
4690 if (p[0] == '%' && p[1] == 'O')
4691 p += 2;
4693 break;
4695 goto create_temp_file;
4696 case 'm':
4697 if (use_pipes)
4699 /* consume suffix */
4700 while (*p == '.' || ISALPHA ((unsigned char) *p))
4701 p++;
4702 if (p[0] == '%' && p[1] == 'O')
4703 p += 2;
4705 break;
4707 goto create_temp_file;
4708 case 'g':
4709 case 'u':
4710 case 'U':
4711 create_temp_file:
4713 struct temp_name *t;
4714 int suffix_length;
4715 const char *suffix = p;
4716 char *saved_suffix = NULL;
4718 while (*p == '.' || ISALPHA ((unsigned char) *p))
4719 p++;
4720 suffix_length = p - suffix;
4721 if (p[0] == '%' && p[1] == 'O')
4723 p += 2;
4724 /* We don't support extra suffix characters after %O. */
4725 if (*p == '.' || ISALPHA ((unsigned char) *p))
4726 fatal ("spec '%s' has invalid '%%0%c'", spec, *p);
4727 if (suffix_length == 0)
4728 suffix = TARGET_OBJECT_SUFFIX;
4729 else
4731 saved_suffix
4732 = xmalloc (suffix_length
4733 + strlen (TARGET_OBJECT_SUFFIX));
4734 strncpy (saved_suffix, suffix, suffix_length);
4735 strcpy (saved_suffix + suffix_length,
4736 TARGET_OBJECT_SUFFIX);
4738 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4741 /* If the input_filename has the same suffix specified
4742 for the %g, %u, or %U, and -save-temps is specified,
4743 we could end up using that file as an intermediate
4744 thus clobbering the user's source file (.e.g.,
4745 gcc -save-temps foo.s would clobber foo.s with the
4746 output of cpp0). So check for this condition and
4747 generate a temp file as the intermediate. */
4749 if (save_temps_flag)
4751 temp_filename_length = basename_length + suffix_length;
4752 temp_filename = alloca (temp_filename_length + 1);
4753 strncpy ((char *) temp_filename, input_basename, basename_length);
4754 strncpy ((char *) temp_filename + basename_length, suffix,
4755 suffix_length);
4756 *((char *) temp_filename + temp_filename_length) = '\0';
4757 if (strcmp (temp_filename, input_filename) != 0)
4759 #ifndef HOST_LACKS_INODE_NUMBERS
4760 struct stat st_temp;
4762 /* Note, set_input() resets input_stat_set to 0. */
4763 if (input_stat_set == 0)
4765 input_stat_set = stat (input_filename, &input_stat);
4766 if (input_stat_set >= 0)
4767 input_stat_set = 1;
4770 /* If we have the stat for the input_filename
4771 and we can do the stat for the temp_filename
4772 then the they could still refer to the same
4773 file if st_dev/st_ino's are the same. */
4774 if (input_stat_set != 1
4775 || stat (temp_filename, &st_temp) < 0
4776 || input_stat.st_dev != st_temp.st_dev
4777 || input_stat.st_ino != st_temp.st_ino)
4778 #else
4779 /* Just compare canonical pathnames. */
4780 char* input_realname = lrealpath (input_filename);
4781 char* temp_realname = lrealpath (temp_filename);
4782 bool files_differ = strcmp (input_realname, temp_realname);
4783 free (input_realname);
4784 free (temp_realname);
4785 if (files_differ)
4786 #endif
4788 temp_filename = save_string (temp_filename,
4789 temp_filename_length + 1);
4790 obstack_grow (&obstack, temp_filename,
4791 temp_filename_length);
4792 arg_going = 1;
4793 delete_this_arg = 0;
4794 break;
4799 /* See if we already have an association of %g/%u/%U and
4800 suffix. */
4801 for (t = temp_names; t; t = t->next)
4802 if (t->length == suffix_length
4803 && strncmp (t->suffix, suffix, suffix_length) == 0
4804 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4805 break;
4807 /* Make a new association if needed. %u and %j
4808 require one. */
4809 if (t == 0 || c == 'u' || c == 'j')
4811 if (t == 0)
4813 t = xmalloc (sizeof (struct temp_name));
4814 t->next = temp_names;
4815 temp_names = t;
4817 t->length = suffix_length;
4818 if (saved_suffix)
4820 t->suffix = saved_suffix;
4821 saved_suffix = NULL;
4823 else
4824 t->suffix = save_string (suffix, suffix_length);
4825 t->unique = (c == 'u' || c == 'U' || c == 'j');
4826 temp_filename = make_temp_file (t->suffix);
4827 temp_filename_length = strlen (temp_filename);
4828 t->filename = temp_filename;
4829 t->filename_length = temp_filename_length;
4832 if (saved_suffix)
4833 free (saved_suffix);
4835 obstack_grow (&obstack, t->filename, t->filename_length);
4836 delete_this_arg = 1;
4838 arg_going = 1;
4839 break;
4841 case 'i':
4842 if (combine_inputs)
4844 for (i = 0; (int) i < n_infiles; i++)
4845 if ((!infiles[i].language) || (infiles[i].language[0] != '*'))
4846 if (infiles[i].incompiler == input_file_compiler)
4848 store_arg (infiles[i].name, 0, 0);
4849 infiles[i].compiled = true;
4852 else
4854 obstack_grow (&obstack, input_filename, input_filename_length);
4855 arg_going = 1;
4857 break;
4859 case 'I':
4861 struct prefix_list *pl = include_prefixes.plist;
4863 if (gcc_exec_prefix)
4865 do_spec_1 ("-iprefix", 1, NULL);
4866 /* Make this a separate argument. */
4867 do_spec_1 (" ", 0, NULL);
4868 do_spec_1 (gcc_exec_prefix, 1, NULL);
4869 do_spec_1 (" ", 0, NULL);
4872 if (target_system_root_changed ||
4873 (target_system_root && target_sysroot_hdrs_suffix))
4875 do_spec_1 ("-isysroot", 1, NULL);
4876 /* Make this a separate argument. */
4877 do_spec_1 (" ", 0, NULL);
4878 do_spec_1 (target_system_root, 1, NULL);
4879 if (target_sysroot_hdrs_suffix)
4880 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4881 do_spec_1 (" ", 0, NULL);
4884 for (; pl; pl = pl->next)
4885 /* Separate options, don't include non-suffixed variant. */
4886 do_spec_path (pl, "-isystem", 0, 1, 1, "include", "include");
4888 break;
4890 case 'o':
4892 int max = n_infiles;
4893 max += lang_specific_extra_outfiles;
4895 for (i = 0; i < max; i++)
4896 if (outfiles[i])
4897 store_arg (outfiles[i], 0, 0);
4898 break;
4901 case 'O':
4902 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4903 arg_going = 1;
4904 break;
4906 case 's':
4907 this_is_library_file = 1;
4908 break;
4910 case 'V':
4911 outfiles[input_file_number] = NULL;
4912 break;
4914 case 'w':
4915 this_is_output_file = 1;
4916 break;
4918 case 'W':
4920 int cur_index = argbuf_index;
4921 /* Handle the {...} following the %W. */
4922 if (*p != '{')
4923 fatal ("spec '%s' has invalid '%%W%c", spec, *p);
4924 p = handle_braces (p + 1);
4925 if (p == 0)
4926 return -1;
4927 /* End any pending argument. */
4928 if (arg_going)
4930 obstack_1grow (&obstack, 0);
4931 string = obstack_finish (&obstack);
4932 if (this_is_library_file)
4933 string = find_file (string);
4934 store_arg (string, delete_this_arg, this_is_output_file);
4935 if (this_is_output_file)
4936 outfiles[input_file_number] = string;
4937 arg_going = 0;
4939 /* If any args were output, mark the last one for deletion
4940 on failure. */
4941 if (argbuf_index != cur_index)
4942 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4943 break;
4946 /* %x{OPTION} records OPTION for %X to output. */
4947 case 'x':
4949 const char *p1 = p;
4950 char *string;
4952 /* Skip past the option value and make a copy. */
4953 if (*p != '{')
4954 fatal ("spec '%s' has invalid '%%x%c'", spec, *p);
4955 while (*p++ != '}')
4957 string = save_string (p1 + 1, p - p1 - 2);
4959 /* See if we already recorded this option. */
4960 for (i = 0; i < n_linker_options; i++)
4961 if (! strcmp (string, linker_options[i]))
4963 free (string);
4964 return 0;
4967 /* This option is new; add it. */
4968 add_linker_option (string, strlen (string));
4970 break;
4972 /* Dump out the options accumulated previously using %x. */
4973 case 'X':
4974 for (i = 0; i < n_linker_options; i++)
4976 do_spec_1 (linker_options[i], 1, NULL);
4977 /* Make each accumulated option a separate argument. */
4978 do_spec_1 (" ", 0, NULL);
4980 break;
4982 /* Dump out the options accumulated previously using -Wa,. */
4983 case 'Y':
4984 for (i = 0; i < n_assembler_options; i++)
4986 do_spec_1 (assembler_options[i], 1, NULL);
4987 /* Make each accumulated option a separate argument. */
4988 do_spec_1 (" ", 0, NULL);
4990 break;
4992 /* Dump out the options accumulated previously using -Wp,. */
4993 case 'Z':
4994 for (i = 0; i < n_preprocessor_options; i++)
4996 do_spec_1 (preprocessor_options[i], 1, NULL);
4997 /* Make each accumulated option a separate argument. */
4998 do_spec_1 (" ", 0, NULL);
5000 break;
5002 /* Here are digits and numbers that just process
5003 a certain constant string as a spec. */
5005 case '1':
5006 value = do_spec_1 (cc1_spec, 0, NULL);
5007 if (value != 0)
5008 return value;
5009 break;
5011 case '2':
5012 value = do_spec_1 (cc1plus_spec, 0, NULL);
5013 if (value != 0)
5014 return value;
5015 break;
5017 case 'a':
5018 value = do_spec_1 (asm_spec, 0, NULL);
5019 if (value != 0)
5020 return value;
5021 break;
5023 case 'A':
5024 value = do_spec_1 (asm_final_spec, 0, NULL);
5025 if (value != 0)
5026 return value;
5027 break;
5029 case 'C':
5031 const char *const spec
5032 = (input_file_compiler->cpp_spec
5033 ? input_file_compiler->cpp_spec
5034 : cpp_spec);
5035 value = do_spec_1 (spec, 0, NULL);
5036 if (value != 0)
5037 return value;
5039 break;
5041 case 'E':
5042 value = do_spec_1 (endfile_spec, 0, NULL);
5043 if (value != 0)
5044 return value;
5045 break;
5047 case 'l':
5048 value = do_spec_1 (link_spec, 0, NULL);
5049 if (value != 0)
5050 return value;
5051 break;
5053 case 'L':
5054 value = do_spec_1 (lib_spec, 0, NULL);
5055 if (value != 0)
5056 return value;
5057 break;
5059 case 'G':
5060 value = do_spec_1 (libgcc_spec, 0, NULL);
5061 if (value != 0)
5062 return value;
5063 break;
5065 case 'R':
5066 /* We assume there is a directory
5067 separator at the end of this string. */
5068 if (target_system_root)
5070 obstack_grow (&obstack, target_system_root,
5071 strlen (target_system_root));
5072 if (target_sysroot_suffix)
5073 obstack_grow (&obstack, target_sysroot_suffix,
5074 strlen (target_sysroot_suffix));
5076 break;
5078 case 'S':
5079 value = do_spec_1 (startfile_spec, 0, NULL);
5080 if (value != 0)
5081 return value;
5082 break;
5084 /* Here we define characters other than letters and digits. */
5086 case '{':
5087 p = handle_braces (p);
5088 if (p == 0)
5089 return -1;
5090 break;
5092 case ':':
5093 p = handle_spec_function (p);
5094 if (p == 0)
5095 return -1;
5096 break;
5098 case '%':
5099 obstack_1grow (&obstack, '%');
5100 break;
5102 case '.':
5104 unsigned len = 0;
5106 while (p[len] && p[len] != ' ' && p[len] != '%')
5107 len++;
5108 suffix_subst = save_string (p - 1, len + 1);
5109 p += len;
5111 break;
5113 /* Henceforth ignore the option(s) matching the pattern
5114 after the %<. */
5115 case '<':
5117 unsigned len = 0;
5118 int have_wildcard = 0;
5119 int i;
5121 while (p[len] && p[len] != ' ' && p[len] != '\t')
5122 len++;
5124 if (p[len-1] == '*')
5125 have_wildcard = 1;
5127 for (i = 0; i < n_switches; i++)
5128 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5129 && (have_wildcard || switches[i].part1[len] == '\0'))
5131 switches[i].live_cond = SWITCH_IGNORE;
5132 switches[i].validated = 1;
5135 p += len;
5137 break;
5139 case '*':
5140 if (soft_matched_part)
5142 do_spec_1 (soft_matched_part, 1, NULL);
5143 do_spec_1 (" ", 0, NULL);
5145 else
5146 /* Catch the case where a spec string contains something like
5147 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5148 hand side of the :. */
5149 error ("spec failure: '%%*' has not been initialized by pattern match");
5150 break;
5152 /* Process a string found as the value of a spec given by name.
5153 This feature allows individual machine descriptions
5154 to add and use their own specs.
5155 %[...] modifies -D options the way %P does;
5156 %(...) uses the spec unmodified. */
5157 case '[':
5158 error ("warning: use of obsolete %%[ operator in specs");
5159 case '(':
5161 const char *name = p;
5162 struct spec_list *sl;
5163 int len;
5165 /* The string after the S/P is the name of a spec that is to be
5166 processed. */
5167 while (*p && *p != ')' && *p != ']')
5168 p++;
5170 /* See if it's in the list. */
5171 for (len = p - name, sl = specs; sl; sl = sl->next)
5172 if (sl->name_len == len && !strncmp (sl->name, name, len))
5174 name = *(sl->ptr_spec);
5175 #ifdef DEBUG_SPECS
5176 notice ("Processing spec %c%s%c, which is '%s'\n",
5177 c, sl->name, (c == '(') ? ')' : ']', name);
5178 #endif
5179 break;
5182 if (sl)
5184 if (c == '(')
5186 value = do_spec_1 (name, 0, NULL);
5187 if (value != 0)
5188 return value;
5190 else
5192 char *x = alloca (strlen (name) * 2 + 1);
5193 char *buf = x;
5194 const char *y = name;
5195 int flag = 0;
5197 /* Copy all of NAME into BUF, but put __ after
5198 every -D and at the end of each arg. */
5199 while (1)
5201 if (! strncmp (y, "-D", 2))
5203 *x++ = '-';
5204 *x++ = 'D';
5205 *x++ = '_';
5206 *x++ = '_';
5207 y += 2;
5208 flag = 1;
5209 continue;
5211 else if (flag
5212 && (*y == ' ' || *y == '\t' || *y == '='
5213 || *y == '}' || *y == 0))
5215 *x++ = '_';
5216 *x++ = '_';
5217 flag = 0;
5219 if (*y == 0)
5220 break;
5221 else
5222 *x++ = *y++;
5224 *x = 0;
5226 value = do_spec_1 (buf, 0, NULL);
5227 if (value != 0)
5228 return value;
5232 /* Discard the closing paren or bracket. */
5233 if (*p)
5234 p++;
5236 break;
5238 default:
5239 error ("spec failure: unrecognized spec option '%c'", c);
5240 break;
5242 break;
5244 case '\\':
5245 /* Backslash: treat next character as ordinary. */
5246 c = *p++;
5248 /* Fall through. */
5249 default:
5250 /* Ordinary character: put it into the current argument. */
5251 obstack_1grow (&obstack, c);
5252 arg_going = 1;
5255 /* End of string. If we are processing a spec function, we need to
5256 end any pending argument. */
5257 if (processing_spec_function && arg_going)
5259 obstack_1grow (&obstack, 0);
5260 string = obstack_finish (&obstack);
5261 if (this_is_library_file)
5262 string = find_file (string);
5263 store_arg (string, delete_this_arg, this_is_output_file);
5264 if (this_is_output_file)
5265 outfiles[input_file_number] = string;
5266 arg_going = 0;
5269 return 0;
5272 /* Look up a spec function. */
5274 static const struct spec_function *
5275 lookup_spec_function (const char *name)
5277 static const struct spec_function * const spec_function_tables[] =
5279 static_spec_functions,
5280 lang_specific_spec_functions,
5282 const struct spec_function *sf;
5283 unsigned int i;
5285 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5287 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5288 if (strcmp (sf->name, name) == 0)
5289 return sf;
5292 return NULL;
5295 /* Evaluate a spec function. */
5297 static const char *
5298 eval_spec_function (const char *func, const char *args)
5300 const struct spec_function *sf;
5301 const char *funcval;
5303 /* Saved spec processing context. */
5304 int save_argbuf_index;
5305 int save_argbuf_length;
5306 const char **save_argbuf;
5308 int save_arg_going;
5309 int save_delete_this_arg;
5310 int save_this_is_output_file;
5311 int save_this_is_library_file;
5312 int save_input_from_pipe;
5313 const char *save_suffix_subst;
5316 sf = lookup_spec_function (func);
5317 if (sf == NULL)
5318 fatal ("unknown spec function '%s'", func);
5320 /* Push the spec processing context. */
5321 save_argbuf_index = argbuf_index;
5322 save_argbuf_length = argbuf_length;
5323 save_argbuf = argbuf;
5325 save_arg_going = arg_going;
5326 save_delete_this_arg = delete_this_arg;
5327 save_this_is_output_file = this_is_output_file;
5328 save_this_is_library_file = this_is_library_file;
5329 save_input_from_pipe = input_from_pipe;
5330 save_suffix_subst = suffix_subst;
5332 /* Create a new spec processing context, and build the function
5333 arguments. */
5335 alloc_args ();
5336 if (do_spec_2 (args) < 0)
5337 fatal ("error in args to spec function '%s'", func);
5339 /* argbuf_index is an index for the next argument to be inserted, and
5340 so contains the count of the args already inserted. */
5342 funcval = (*sf->func) (argbuf_index, argbuf);
5344 /* Pop the spec processing context. */
5345 argbuf_index = save_argbuf_index;
5346 argbuf_length = save_argbuf_length;
5347 free (argbuf);
5348 argbuf = save_argbuf;
5350 arg_going = save_arg_going;
5351 delete_this_arg = save_delete_this_arg;
5352 this_is_output_file = save_this_is_output_file;
5353 this_is_library_file = save_this_is_library_file;
5354 input_from_pipe = save_input_from_pipe;
5355 suffix_subst = save_suffix_subst;
5357 return funcval;
5360 /* Handle a spec function call of the form:
5362 %:function(args)
5364 ARGS is processed as a spec in a separate context and split into an
5365 argument vector in the normal fashion. The function returns a string
5366 containing a spec which we then process in the caller's context, or
5367 NULL if no processing is required. */
5369 static const char *
5370 handle_spec_function (const char *p)
5372 char *func, *args;
5373 const char *endp, *funcval;
5374 int count;
5376 processing_spec_function++;
5378 /* Get the function name. */
5379 for (endp = p; *endp != '\0'; endp++)
5381 if (*endp == '(') /* ) */
5382 break;
5383 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5384 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5385 fatal ("malformed spec function name");
5387 if (*endp != '(') /* ) */
5388 fatal ("no arguments for spec function");
5389 func = save_string (p, endp - p);
5390 p = ++endp;
5392 /* Get the arguments. */
5393 for (count = 0; *endp != '\0'; endp++)
5395 /* ( */
5396 if (*endp == ')')
5398 if (count == 0)
5399 break;
5400 count--;
5402 else if (*endp == '(') /* ) */
5403 count++;
5405 /* ( */
5406 if (*endp != ')')
5407 fatal ("malformed spec function arguments");
5408 args = save_string (p, endp - p);
5409 p = ++endp;
5411 /* p now points to just past the end of the spec function expression. */
5413 funcval = eval_spec_function (func, args);
5414 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5415 p = NULL;
5417 free (func);
5418 free (args);
5420 processing_spec_function--;
5422 return p;
5425 /* Inline subroutine of handle_braces. Returns true if the current
5426 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5427 static inline bool
5428 input_suffix_matches (const char *atom, const char *end_atom)
5430 /* We special case the semantics of {.s:...} and {.S:...} and their
5431 negative variants. Instead of testing the input filename suffix,
5432 we test whether the input source file is an assembler file or an
5433 assembler-with-cpp file respectively. This allows us to correctly
5434 handle the -x command line option. */
5436 if (atom + 1 == end_atom
5437 && input_file_compiler
5438 && input_file_compiler->suffix)
5440 if (*atom == 's')
5441 return !strcmp (input_file_compiler->suffix, "@assembler");
5442 if (*atom == 'S')
5443 return !strcmp (input_file_compiler->suffix, "@assembler-with-cpp");
5446 return (input_suffix
5447 && !strncmp (input_suffix, atom, end_atom - atom)
5448 && input_suffix[end_atom - atom] == '\0');
5451 /* Inline subroutine of handle_braces. Returns true if a switch
5452 matching the atom bracketed by ATOM and END_ATOM appeared on the
5453 command line. */
5454 static inline bool
5455 switch_matches (const char *atom, const char *end_atom, int starred)
5457 int i;
5458 int len = end_atom - atom;
5459 int plen = starred ? len : -1;
5461 for (i = 0; i < n_switches; i++)
5462 if (!strncmp (switches[i].part1, atom, len)
5463 && (starred || switches[i].part1[len] == '\0')
5464 && check_live_switch (i, plen))
5465 return true;
5467 return false;
5470 /* Inline subroutine of handle_braces. Mark all of the switches which
5471 match ATOM (extends to END_ATOM; STARRED indicates whether there
5472 was a star after the atom) for later processing. */
5473 static inline void
5474 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5476 int i;
5477 int len = end_atom - atom;
5478 int plen = starred ? len : -1;
5480 for (i = 0; i < n_switches; i++)
5481 if (!strncmp (switches[i].part1, atom, len)
5482 && (starred || switches[i].part1[len] == '\0')
5483 && check_live_switch (i, plen))
5484 switches[i].ordering = 1;
5487 /* Inline subroutine of handle_braces. Process all the currently
5488 marked switches through give_switch, and clear the marks. */
5489 static inline void
5490 process_marked_switches (void)
5492 int i;
5494 for (i = 0; i < n_switches; i++)
5495 if (switches[i].ordering == 1)
5497 switches[i].ordering = 0;
5498 give_switch (i, 0);
5502 /* Handle a %{ ... } construct. P points just inside the leading {.
5503 Returns a pointer one past the end of the brace block, or 0
5504 if we call do_spec_1 and that returns -1. */
5506 static const char *
5507 handle_braces (const char *p)
5509 const char *atom, *end_atom;
5510 const char *d_atom = NULL, *d_end_atom = NULL;
5511 const char *orig = p;
5513 bool a_is_suffix;
5514 bool a_is_starred;
5515 bool a_is_negated;
5516 bool a_matched;
5518 bool a_must_be_last = false;
5519 bool ordered_set = false;
5520 bool disjunct_set = false;
5521 bool disj_matched = false;
5522 bool disj_starred = true;
5523 bool n_way_choice = false;
5524 bool n_way_matched = false;
5526 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5530 if (a_must_be_last)
5531 goto invalid;
5533 /* Scan one "atom" (S in the description above of %{}, possibly
5534 with !, ., or * modifiers). */
5535 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5537 SKIP_WHITE();
5538 if (*p == '!')
5539 p++, a_is_negated = true;
5541 SKIP_WHITE();
5542 if (*p == '.')
5543 p++, a_is_suffix = true;
5545 atom = p;
5546 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5547 || *p == ',' || *p == '.' || *p == '@')
5548 p++;
5549 end_atom = p;
5551 if (*p == '*')
5552 p++, a_is_starred = 1;
5554 SKIP_WHITE();
5555 switch (*p)
5557 case '&': case '}':
5558 /* Substitute the switch(es) indicated by the current atom. */
5559 ordered_set = true;
5560 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5561 || atom == end_atom)
5562 goto invalid;
5564 mark_matching_switches (atom, end_atom, a_is_starred);
5566 if (*p == '}')
5567 process_marked_switches ();
5568 break;
5570 case '|': case ':':
5571 /* Substitute some text if the current atom appears as a switch
5572 or suffix. */
5573 disjunct_set = true;
5574 if (ordered_set)
5575 goto invalid;
5577 if (atom == end_atom)
5579 if (!n_way_choice || disj_matched || *p == '|'
5580 || a_is_negated || a_is_suffix || a_is_starred)
5581 goto invalid;
5583 /* An empty term may appear as the last choice of an
5584 N-way choice set; it means "otherwise". */
5585 a_must_be_last = true;
5586 disj_matched = !n_way_matched;
5587 disj_starred = false;
5589 else
5591 if (a_is_suffix && a_is_starred)
5592 goto invalid;
5594 if (!a_is_starred)
5595 disj_starred = false;
5597 /* Don't bother testing this atom if we already have a
5598 match. */
5599 if (!disj_matched && !n_way_matched)
5601 if (a_is_suffix)
5602 a_matched = input_suffix_matches (atom, end_atom);
5603 else
5604 a_matched = switch_matches (atom, end_atom, a_is_starred);
5606 if (a_matched != a_is_negated)
5608 disj_matched = true;
5609 d_atom = atom;
5610 d_end_atom = end_atom;
5615 if (*p == ':')
5617 /* Found the body, that is, the text to substitute if the
5618 current disjunction matches. */
5619 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5620 disj_matched && !n_way_matched);
5621 if (p == 0)
5622 return 0;
5624 /* If we have an N-way choice, reset state for the next
5625 disjunction. */
5626 if (*p == ';')
5628 n_way_choice = true;
5629 n_way_matched |= disj_matched;
5630 disj_matched = false;
5631 disj_starred = true;
5632 d_atom = d_end_atom = NULL;
5635 break;
5637 default:
5638 goto invalid;
5641 while (*p++ != '}');
5643 return p;
5645 invalid:
5646 fatal ("braced spec '%s' is invalid at '%c'", orig, *p);
5648 #undef SKIP_WHITE
5651 /* Subroutine of handle_braces. Scan and process a brace substitution body
5652 (X in the description of %{} syntax). P points one past the colon;
5653 ATOM and END_ATOM bracket the first atom which was found to be true
5654 (present) in the current disjunction; STARRED indicates whether all
5655 the atoms in the current disjunction were starred (for syntax validation);
5656 MATCHED indicates whether the disjunction matched or not, and therefore
5657 whether or not the body is to be processed through do_spec_1 or just
5658 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5659 returns -1. */
5661 static const char *
5662 process_brace_body (const char *p, const char *atom, const char *end_atom,
5663 int starred, int matched)
5665 const char *body, *end_body;
5666 unsigned int nesting_level;
5667 bool have_subst = false;
5669 /* Locate the closing } or ;, honoring nested braces.
5670 Trim trailing whitespace. */
5671 body = p;
5672 nesting_level = 1;
5673 for (;;)
5675 if (*p == '{')
5676 nesting_level++;
5677 else if (*p == '}')
5679 if (!--nesting_level)
5680 break;
5682 else if (*p == ';' && nesting_level == 1)
5683 break;
5684 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5685 have_subst = true;
5686 else if (*p == '\0')
5687 goto invalid;
5688 p++;
5691 end_body = p;
5692 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5693 end_body--;
5695 if (have_subst && !starred)
5696 goto invalid;
5698 if (matched)
5700 /* Copy the substitution body to permanent storage and execute it.
5701 If have_subst is false, this is a simple matter of running the
5702 body through do_spec_1... */
5703 char *string = save_string (body, end_body - body);
5704 if (!have_subst)
5706 if (do_spec_1 (string, 0, NULL) < 0)
5707 return 0;
5709 else
5711 /* ... but if have_subst is true, we have to process the
5712 body once for each matching switch, with %* set to the
5713 variant part of the switch. */
5714 unsigned int hard_match_len = end_atom - atom;
5715 int i;
5717 for (i = 0; i < n_switches; i++)
5718 if (!strncmp (switches[i].part1, atom, hard_match_len)
5719 && check_live_switch (i, hard_match_len))
5721 if (do_spec_1 (string, 0,
5722 &switches[i].part1[hard_match_len]) < 0)
5723 return 0;
5724 /* Pass any arguments this switch has. */
5725 give_switch (i, 1);
5726 suffix_subst = NULL;
5731 return p;
5733 invalid:
5734 fatal ("braced spec body '%s' is invalid", body);
5737 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5738 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5739 spec, or -1 if either exact match or %* is used.
5741 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5742 whose value does not begin with "no-" is obsoleted by the same value
5743 with the "no-", similarly for a switch with the "no-" prefix. */
5745 static int
5746 check_live_switch (int switchnum, int prefix_length)
5748 const char *name = switches[switchnum].part1;
5749 int i;
5751 /* In the common case of {<at-most-one-letter>*}, a negating
5752 switch would always match, so ignore that case. We will just
5753 send the conflicting switches to the compiler phase. */
5754 if (prefix_length >= 0 && prefix_length <= 1)
5755 return 1;
5757 /* If we already processed this switch and determined if it was
5758 live or not, return our past determination. */
5759 if (switches[switchnum].live_cond != 0)
5760 return switches[switchnum].live_cond > 0;
5762 /* Now search for duplicate in a manner that depends on the name. */
5763 switch (*name)
5765 case 'O':
5766 for (i = switchnum + 1; i < n_switches; i++)
5767 if (switches[i].part1[0] == 'O')
5769 switches[switchnum].validated = 1;
5770 switches[switchnum].live_cond = SWITCH_FALSE;
5771 return 0;
5773 break;
5775 case 'W': case 'f': case 'm':
5776 if (! strncmp (name + 1, "no-", 3))
5778 /* We have Xno-YYY, search for XYYY. */
5779 for (i = switchnum + 1; i < n_switches; i++)
5780 if (switches[i].part1[0] == name[0]
5781 && ! strcmp (&switches[i].part1[1], &name[4]))
5783 switches[switchnum].validated = 1;
5784 switches[switchnum].live_cond = SWITCH_FALSE;
5785 return 0;
5788 else
5790 /* We have XYYY, search for Xno-YYY. */
5791 for (i = switchnum + 1; i < n_switches; i++)
5792 if (switches[i].part1[0] == name[0]
5793 && switches[i].part1[1] == 'n'
5794 && switches[i].part1[2] == 'o'
5795 && switches[i].part1[3] == '-'
5796 && !strcmp (&switches[i].part1[4], &name[1]))
5798 switches[switchnum].validated = 1;
5799 switches[switchnum].live_cond = SWITCH_FALSE;
5800 return 0;
5803 break;
5806 /* Otherwise the switch is live. */
5807 switches[switchnum].live_cond = SWITCH_LIVE;
5808 return 1;
5811 /* Pass a switch to the current accumulating command
5812 in the same form that we received it.
5813 SWITCHNUM identifies the switch; it is an index into
5814 the vector of switches gcc received, which is `switches'.
5815 This cannot fail since it never finishes a command line.
5817 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5819 static void
5820 give_switch (int switchnum, int omit_first_word)
5822 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5823 return;
5825 if (!omit_first_word)
5827 do_spec_1 ("-", 0, NULL);
5828 do_spec_1 (switches[switchnum].part1, 1, NULL);
5831 if (switches[switchnum].args != 0)
5833 const char **p;
5834 for (p = switches[switchnum].args; *p; p++)
5836 const char *arg = *p;
5838 do_spec_1 (" ", 0, NULL);
5839 if (suffix_subst)
5841 unsigned length = strlen (arg);
5842 int dot = 0;
5844 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5845 if (arg[length] == '.')
5847 ((char *)arg)[length] = 0;
5848 dot = 1;
5849 break;
5851 do_spec_1 (arg, 1, NULL);
5852 if (dot)
5853 ((char *)arg)[length] = '.';
5854 do_spec_1 (suffix_subst, 1, NULL);
5856 else
5857 do_spec_1 (arg, 1, NULL);
5861 do_spec_1 (" ", 0, NULL);
5862 switches[switchnum].validated = 1;
5865 /* Search for a file named NAME trying various prefixes including the
5866 user's -B prefix and some standard ones.
5867 Return the absolute file name found. If nothing is found, return NAME. */
5869 static const char *
5870 find_file (const char *name)
5872 char *newname;
5874 /* Try multilib_dir if it is defined. */
5875 if (multilib_os_dir != NULL)
5877 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
5879 /* If we don't find it in the multi library dir, then fall
5880 through and look for it in the normal places. */
5881 if (newname != NULL)
5882 return newname;
5885 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
5886 return newname ? newname : name;
5889 /* Determine whether a directory exists. If LINKER, return 0 for
5890 certain fixed names not needed by the linker. If not LINKER, it is
5891 only important to return 0 if the host machine has a small ARG_MAX
5892 limit. */
5894 static int
5895 is_directory (const char *path1, const char *path2, int linker)
5897 int len1 = strlen (path1);
5898 int len2 = strlen (path2);
5899 char *path = alloca (3 + len1 + len2);
5900 char *cp;
5901 struct stat st;
5903 #ifndef SMALL_ARG_MAX
5904 if (! linker)
5905 return 1;
5906 #endif
5908 /* Construct the path from the two parts. Ensure the string ends with "/.".
5909 The resulting path will be a directory even if the given path is a
5910 symbolic link. */
5911 memcpy (path, path1, len1);
5912 memcpy (path + len1, path2, len2);
5913 cp = path + len1 + len2;
5914 if (!IS_DIR_SEPARATOR (cp[-1]))
5915 *cp++ = DIR_SEPARATOR;
5916 *cp++ = '.';
5917 *cp = '\0';
5919 /* Exclude directories that the linker is known to search. */
5920 if (linker
5921 && ((cp - path == 6
5922 && strcmp (path, concat (dir_separator_str, "lib",
5923 dir_separator_str, ".", NULL)) == 0)
5924 || (cp - path == 10
5925 && strcmp (path, concat (dir_separator_str, "usr",
5926 dir_separator_str, "lib",
5927 dir_separator_str, ".", NULL)) == 0)))
5928 return 0;
5930 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5933 /* Set up the various global variables to indicate that we're processing
5934 the input file named FILENAME. */
5936 void
5937 set_input (const char *filename)
5939 const char *p;
5941 input_filename = filename;
5942 input_filename_length = strlen (input_filename);
5944 input_basename = input_filename;
5945 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5946 /* Skip drive name so 'x:foo' is handled properly. */
5947 if (input_basename[1] == ':')
5948 input_basename += 2;
5949 #endif
5950 for (p = input_basename; *p; p++)
5951 if (IS_DIR_SEPARATOR (*p))
5952 input_basename = p + 1;
5954 /* Find a suffix starting with the last period,
5955 and set basename_length to exclude that suffix. */
5956 basename_length = strlen (input_basename);
5957 suffixed_basename_length = basename_length;
5958 p = input_basename + basename_length;
5959 while (p != input_basename && *p != '.')
5960 --p;
5961 if (*p == '.' && p != input_basename)
5963 basename_length = p - input_basename;
5964 input_suffix = p + 1;
5966 else
5967 input_suffix = "";
5969 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5970 we will need to do a stat on the input_filename. The
5971 INPUT_STAT_SET signals that the stat is needed. */
5972 input_stat_set = 0;
5975 /* On fatal signals, delete all the temporary files. */
5977 static void
5978 fatal_error (int signum)
5980 signal (signum, SIG_DFL);
5981 delete_failure_queue ();
5982 delete_temp_files ();
5983 /* Get the same signal again, this time not handled,
5984 so its normal effect occurs. */
5985 kill (getpid (), signum);
5988 extern int main (int, const char **);
5991 main (int argc, const char **argv)
5993 size_t i;
5994 int value;
5995 int linker_was_run = 0;
5996 int lang_n_infiles = 0;
5997 int num_linker_inputs = 0;
5998 char *explicit_link_files;
5999 char *specs_file;
6000 const char *p;
6001 struct user_specs *uptr;
6003 p = argv[0] + strlen (argv[0]);
6004 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6005 --p;
6006 programname = p;
6008 xmalloc_set_program_name (programname);
6010 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6011 /* Perform host dependent initialization when needed. */
6012 GCC_DRIVER_HOST_INITIALIZATION;
6013 #endif
6015 gcc_init_libintl ();
6017 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6018 signal (SIGINT, fatal_error);
6019 #ifdef SIGHUP
6020 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6021 signal (SIGHUP, fatal_error);
6022 #endif
6023 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6024 signal (SIGTERM, fatal_error);
6025 #ifdef SIGPIPE
6026 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6027 signal (SIGPIPE, fatal_error);
6028 #endif
6029 #ifdef SIGCHLD
6030 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6031 receive the signal. A different setting is inheritable */
6032 signal (SIGCHLD, SIG_DFL);
6033 #endif
6035 /* Allocate the argument vector. */
6036 alloc_args ();
6038 obstack_init (&obstack);
6040 /* Build multilib_select, et. al from the separate lines that make up each
6041 multilib selection. */
6043 const char *const *q = multilib_raw;
6044 int need_space;
6046 obstack_init (&multilib_obstack);
6047 while ((p = *q++) != (char *) 0)
6048 obstack_grow (&multilib_obstack, p, strlen (p));
6050 obstack_1grow (&multilib_obstack, 0);
6051 multilib_select = obstack_finish (&multilib_obstack);
6053 q = multilib_matches_raw;
6054 while ((p = *q++) != (char *) 0)
6055 obstack_grow (&multilib_obstack, p, strlen (p));
6057 obstack_1grow (&multilib_obstack, 0);
6058 multilib_matches = obstack_finish (&multilib_obstack);
6060 q = multilib_exclusions_raw;
6061 while ((p = *q++) != (char *) 0)
6062 obstack_grow (&multilib_obstack, p, strlen (p));
6064 obstack_1grow (&multilib_obstack, 0);
6065 multilib_exclusions = obstack_finish (&multilib_obstack);
6067 need_space = FALSE;
6068 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6070 if (need_space)
6071 obstack_1grow (&multilib_obstack, ' ');
6072 obstack_grow (&multilib_obstack,
6073 multilib_defaults_raw[i],
6074 strlen (multilib_defaults_raw[i]));
6075 need_space = TRUE;
6078 obstack_1grow (&multilib_obstack, 0);
6079 multilib_defaults = obstack_finish (&multilib_obstack);
6082 /* Set up to remember the pathname of gcc and any options
6083 needed for collect. We use argv[0] instead of programname because
6084 we need the complete pathname. */
6085 obstack_init (&collect_obstack);
6086 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6087 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6088 putenv (obstack_finish (&collect_obstack));
6090 #ifdef INIT_ENVIRONMENT
6091 /* Set up any other necessary machine specific environment variables. */
6092 putenv (INIT_ENVIRONMENT);
6093 #endif
6095 /* Make a table of what switches there are (switches, n_switches).
6096 Make a table of specified input files (infiles, n_infiles).
6097 Decode switches that are handled locally. */
6099 process_command (argc, argv);
6101 /* Initialize the vector of specs to just the default.
6102 This means one element containing 0s, as a terminator. */
6104 compilers = xmalloc (sizeof default_compilers);
6105 memcpy (compilers, default_compilers, sizeof default_compilers);
6106 n_compilers = n_default_compilers;
6108 /* Read specs from a file if there is one. */
6110 machine_suffix = concat (spec_machine, dir_separator_str,
6111 spec_version, dir_separator_str, NULL);
6112 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6114 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6115 /* Read the specs file unless it is a default one. */
6116 if (specs_file != 0 && strcmp (specs_file, "specs"))
6117 read_specs (specs_file, TRUE);
6118 else
6119 init_spec ();
6121 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6122 for any override of as, ld and libraries. */
6123 specs_file = alloca (strlen (standard_exec_prefix)
6124 + strlen (just_machine_suffix) + sizeof ("specs"));
6126 strcpy (specs_file, standard_exec_prefix);
6127 strcat (specs_file, just_machine_suffix);
6128 strcat (specs_file, "specs");
6129 if (access (specs_file, R_OK) == 0)
6130 read_specs (specs_file, TRUE);
6132 /* Process any configure-time defaults specified for the command line
6133 options, via OPTION_DEFAULT_SPECS. */
6134 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6135 do_option_spec (option_default_specs[i].name,
6136 option_default_specs[i].spec);
6138 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6139 of the command line. */
6141 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6142 do_self_spec (driver_self_specs[i]);
6144 /* If not cross-compiling, look for executables in the standard
6145 places. */
6146 if (*cross_compile == '0')
6148 if (*md_exec_prefix)
6150 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6151 PREFIX_PRIORITY_LAST, 0, 0);
6155 /* Process sysroot_suffix_spec. */
6156 if (*sysroot_suffix_spec != 0
6157 && do_spec_2 (sysroot_suffix_spec) == 0)
6159 if (argbuf_index > 1)
6160 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC.");
6161 else if (argbuf_index == 1)
6162 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6165 /* Process sysroot_hdrs_suffix_spec. */
6166 if (*sysroot_hdrs_suffix_spec != 0
6167 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6169 if (argbuf_index > 1)
6170 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC.");
6171 else if (argbuf_index == 1)
6172 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6175 /* Look for startfiles in the standard places. */
6176 if (*startfile_prefix_spec != 0
6177 && do_spec_2 (startfile_prefix_spec) == 0
6178 && do_spec_1 (" ", 0, NULL) == 0)
6180 int ndx;
6181 for (ndx = 0; ndx < argbuf_index; ndx++)
6182 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6183 PREFIX_PRIORITY_LAST, 0, 1);
6185 /* We should eventually get rid of all these and stick to
6186 startfile_prefix_spec exclusively. */
6187 else if (*cross_compile == '0' || target_system_root)
6189 if (*md_exec_prefix)
6190 add_sysrooted_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
6191 PREFIX_PRIORITY_LAST, 0, 1);
6193 if (*md_startfile_prefix)
6194 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6195 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6197 if (*md_startfile_prefix_1)
6198 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6199 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6201 /* If standard_startfile_prefix is relative, base it on
6202 standard_exec_prefix. This lets us move the installed tree
6203 as a unit. If GCC_EXEC_PREFIX is defined, base
6204 standard_startfile_prefix on that as well.
6206 If the prefix is relative, only search it for native compilers;
6207 otherwise we will search a directory containing host libraries. */
6208 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6209 add_sysrooted_prefix (&startfile_prefixes,
6210 standard_startfile_prefix, "BINUTILS",
6211 PREFIX_PRIORITY_LAST, 0, 1);
6212 else if (*cross_compile == '0')
6214 if (gcc_exec_prefix)
6215 add_prefix (&startfile_prefixes,
6216 concat (gcc_exec_prefix, machine_suffix,
6217 standard_startfile_prefix, NULL),
6218 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6219 add_prefix (&startfile_prefixes,
6220 concat (standard_exec_prefix,
6221 machine_suffix,
6222 standard_startfile_prefix, NULL),
6223 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6226 if (*standard_startfile_prefix_1)
6227 add_sysrooted_prefix (&startfile_prefixes,
6228 standard_startfile_prefix_1, "BINUTILS",
6229 PREFIX_PRIORITY_LAST, 0, 1);
6230 if (*standard_startfile_prefix_2)
6231 add_sysrooted_prefix (&startfile_prefixes,
6232 standard_startfile_prefix_2, "BINUTILS",
6233 PREFIX_PRIORITY_LAST, 0, 1);
6236 /* Process any user specified specs in the order given on the command
6237 line. */
6238 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6240 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6241 R_OK, 0);
6242 read_specs (filename ? filename : uptr->filename, FALSE);
6245 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6246 if (gcc_exec_prefix)
6247 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6248 spec_version, dir_separator_str, NULL);
6250 /* Now we have the specs.
6251 Set the `valid' bits for switches that match anything in any spec. */
6253 validate_all_switches ();
6255 /* Now that we have the switches and the specs, set
6256 the subdirectory based on the options. */
6257 set_multilib_dir ();
6259 /* Warn about any switches that no pass was interested in. */
6261 for (i = 0; (int) i < n_switches; i++)
6262 if (! switches[i].validated)
6263 error ("unrecognized option '-%s'", switches[i].part1);
6265 /* Obey some of the options. */
6267 if (print_search_dirs)
6269 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6270 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6271 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6272 return (0);
6275 if (print_file_name)
6277 printf ("%s\n", find_file (print_file_name));
6278 return (0);
6281 if (print_prog_name)
6283 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6284 printf ("%s\n", (newname ? newname : print_prog_name));
6285 return (0);
6288 if (print_multi_lib)
6290 print_multilib_info ();
6291 return (0);
6294 if (print_multi_directory)
6296 if (multilib_dir == NULL)
6297 printf (".\n");
6298 else
6299 printf ("%s\n", multilib_dir);
6300 return (0);
6303 if (print_multi_os_directory)
6305 if (multilib_os_dir == NULL)
6306 printf (".\n");
6307 else
6308 printf ("%s\n", multilib_os_dir);
6309 return (0);
6312 if (target_help_flag)
6314 /* Print if any target specific options. */
6316 /* We do not exit here. Instead we have created a fake input file
6317 called 'target-dummy' which needs to be compiled, and we pass this
6318 on to the various sub-processes, along with the --target-help
6319 switch. */
6322 if (print_help_list)
6324 display_help ();
6326 if (! verbose_flag)
6328 printf (_("\nFor bug reporting instructions, please see:\n"));
6329 printf ("%s.\n", bug_report_url);
6331 return (0);
6334 /* We do not exit here. Instead we have created a fake input file
6335 called 'help-dummy' which needs to be compiled, and we pass this
6336 on the various sub-processes, along with the --help switch. */
6339 if (verbose_flag)
6341 int n;
6342 const char *thrmod;
6344 notice ("Target: %s\n", spec_machine);
6345 notice ("Configured with: %s\n", configuration_arguments);
6347 #ifdef THREAD_MODEL_SPEC
6348 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6349 but there's no point in doing all this processing just to get
6350 thread_model back. */
6351 obstack_init (&obstack);
6352 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6353 obstack_1grow (&obstack, '\0');
6354 thrmod = obstack_finish (&obstack);
6355 #else
6356 thrmod = thread_model;
6357 #endif
6359 notice ("Thread model: %s\n", thrmod);
6361 /* compiler_version is truncated at the first space when initialized
6362 from version string, so truncate version_string at the first space
6363 before comparing. */
6364 for (n = 0; version_string[n]; n++)
6365 if (version_string[n] == ' ')
6366 break;
6368 if (! strncmp (version_string, compiler_version, n)
6369 && compiler_version[n] == 0)
6370 notice ("gcc version %s\n", version_string);
6371 else
6372 notice ("gcc driver version %s executing gcc version %s\n",
6373 version_string, compiler_version);
6375 if (n_infiles == 0)
6376 return (0);
6379 if (n_infiles == added_libraries)
6380 fatal ("no input files");
6382 /* Make a place to record the compiler output file names
6383 that correspond to the input files. */
6385 i = n_infiles;
6386 i += lang_specific_extra_outfiles;
6387 outfiles = xcalloc (i, sizeof (char *));
6389 /* Record which files were specified explicitly as link input. */
6391 explicit_link_files = xcalloc (1, n_infiles);
6393 if (combine_flag)
6394 combine_inputs = true;
6395 else
6396 combine_inputs = false;
6398 for (i = 0; (int) i < n_infiles; i++)
6400 const char *name = infiles[i].name;
6401 struct compiler *compiler = lookup_compiler (name,
6402 strlen (name),
6403 infiles[i].language);
6405 if (compiler && !(compiler->combinable))
6406 combine_inputs = false;
6408 if (lang_n_infiles > 0 && compiler != input_file_compiler
6409 && infiles[i].language && infiles[i].language[0] != '*')
6410 infiles[i].incompiler = compiler;
6411 else if (compiler)
6413 lang_n_infiles++;
6414 input_file_compiler = compiler;
6415 infiles[i].incompiler = compiler;
6417 else
6419 /* Since there is no compiler for this input file, assume it is a
6420 linker file. */
6421 explicit_link_files[i] = 1;
6422 infiles[i].incompiler = NULL;
6424 infiles[i].compiled = false;
6425 infiles[i].preprocessed = false;
6428 if (combine_flag && save_temps_flag)
6430 bool save_combine_inputs = combine_inputs;
6431 /* Must do a separate pre-processing pass for C & Objective-C files, to
6432 obtain individual .i files. */
6434 combine_inputs = false;
6435 for (i = 0; (int) i < n_infiles; i++)
6437 int this_file_error = 0;
6439 input_file_number = i;
6440 set_input (infiles[i].name);
6441 if (infiles[i].incompiler
6442 && (infiles[i].incompiler)->needs_preprocessing)
6443 input_file_compiler = infiles[i].incompiler;
6444 else
6445 continue;
6447 if (input_file_compiler)
6449 if (input_file_compiler->spec[0] == '#')
6451 error ("%s: %s compiler not installed on this system",
6452 input_filename, &input_file_compiler->spec[1]);
6453 this_file_error = 1;
6455 else
6457 value = do_spec (input_file_compiler->spec);
6458 infiles[i].preprocessed = true;
6459 if (!have_o_argbuf_index)
6460 fatal ("spec '%s' is invalid", input_file_compiler->spec);
6461 infiles[i].name = argbuf[have_o_argbuf_index];
6462 infiles[i].incompiler
6463 = lookup_compiler (infiles[i].name,
6464 strlen (infiles[i].name),
6465 infiles[i].language);
6467 if (value < 0)
6468 this_file_error = 1;
6472 if (this_file_error)
6474 delete_failure_queue ();
6475 error_count++;
6476 break;
6478 clear_failure_queue ();
6480 combine_inputs = save_combine_inputs;
6483 for (i = 0; (int) i < n_infiles; i++)
6485 int this_file_error = 0;
6487 /* Tell do_spec what to substitute for %i. */
6489 input_file_number = i;
6490 set_input (infiles[i].name);
6492 if (infiles[i].compiled)
6493 continue;
6495 /* Use the same thing in %o, unless cp->spec says otherwise. */
6497 outfiles[i] = input_filename;
6499 /* Figure out which compiler from the file's suffix. */
6501 if (! combine_inputs)
6502 input_file_compiler
6503 = lookup_compiler (infiles[i].name, input_filename_length,
6504 infiles[i].language);
6505 else
6506 input_file_compiler = infiles[i].incompiler;
6508 if (input_file_compiler)
6510 /* Ok, we found an applicable compiler. Run its spec. */
6512 if (input_file_compiler->spec[0] == '#')
6514 error ("%s: %s compiler not installed on this system",
6515 input_filename, &input_file_compiler->spec[1]);
6516 this_file_error = 1;
6518 else
6520 value = do_spec (input_file_compiler->spec);
6521 infiles[i].compiled = true;
6522 if (value < 0)
6523 this_file_error = 1;
6527 /* If this file's name does not contain a recognized suffix,
6528 record it as explicit linker input. */
6530 else
6531 explicit_link_files[i] = 1;
6533 /* Clear the delete-on-failure queue, deleting the files in it
6534 if this compilation failed. */
6536 if (this_file_error)
6538 delete_failure_queue ();
6539 error_count++;
6541 /* If this compilation succeeded, don't delete those files later. */
6542 clear_failure_queue ();
6545 /* Reset the output file name to the first input file name, for use
6546 with %b in LINK_SPEC on a target that prefers not to emit a.out
6547 by default. */
6548 if (n_infiles > 0)
6549 set_input (infiles[0].name);
6551 if (error_count == 0)
6553 /* Make sure INPUT_FILE_NUMBER points to first available open
6554 slot. */
6555 input_file_number = n_infiles;
6556 if (lang_specific_pre_link ())
6557 error_count++;
6560 /* Determine if there are any linker input files. */
6561 num_linker_inputs = 0;
6562 for (i = 0; (int) i < n_infiles; i++)
6563 if (explicit_link_files[i] || outfiles[i] != NULL)
6564 num_linker_inputs++;
6566 /* Run ld to link all the compiler output files. */
6568 if (num_linker_inputs > 0 && error_count == 0)
6570 int tmp = execution_count;
6572 /* We'll use ld if we can't find collect2. */
6573 if (! strcmp (linker_name_spec, "collect2"))
6575 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6576 if (s == NULL)
6577 linker_name_spec = "ld";
6579 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6580 for collect. */
6581 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6582 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6584 value = do_spec (link_command_spec);
6585 if (value < 0)
6586 error_count = 1;
6587 linker_was_run = (tmp != execution_count);
6590 /* If options said don't run linker,
6591 complain about input files to be given to the linker. */
6593 if (! linker_was_run && error_count == 0)
6594 for (i = 0; (int) i < n_infiles; i++)
6595 if (explicit_link_files[i])
6596 error ("%s: linker input file unused because linking not done",
6597 outfiles[i]);
6599 /* Delete some or all of the temporary files we made. */
6601 if (error_count)
6602 delete_failure_queue ();
6603 delete_temp_files ();
6605 if (print_help_list)
6607 printf (("\nFor bug reporting instructions, please see:\n"));
6608 printf ("%s\n", bug_report_url);
6611 return (signal_count != 0 ? 2
6612 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6613 : 0);
6616 /* Find the proper compilation spec for the file name NAME,
6617 whose length is LENGTH. LANGUAGE is the specified language,
6618 or 0 if this file is to be passed to the linker. */
6620 static struct compiler *
6621 lookup_compiler (const char *name, size_t length, const char *language)
6623 struct compiler *cp;
6625 /* If this was specified by the user to be a linker input, indicate that. */
6626 if (language != 0 && language[0] == '*')
6627 return 0;
6629 /* Otherwise, look for the language, if one is spec'd. */
6630 if (language != 0)
6632 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6633 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6634 return cp;
6636 error ("language %s not recognized", language);
6637 return 0;
6640 /* Look for a suffix. */
6641 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6643 if (/* The suffix `-' matches only the file name `-'. */
6644 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6645 || (strlen (cp->suffix) < length
6646 /* See if the suffix matches the end of NAME. */
6647 && !strcmp (cp->suffix,
6648 name + length - strlen (cp->suffix))
6650 break;
6653 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6654 /* Look again, but case-insensitively this time. */
6655 if (cp < compilers)
6656 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6658 if (/* The suffix `-' matches only the file name `-'. */
6659 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6660 || (strlen (cp->suffix) < length
6661 /* See if the suffix matches the end of NAME. */
6662 && ((!strcmp (cp->suffix,
6663 name + length - strlen (cp->suffix))
6664 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6665 && !strcasecmp (cp->suffix,
6666 name + length - strlen (cp->suffix)))
6668 break;
6670 #endif
6672 if (cp >= compilers)
6674 if (cp->spec[0] != '@')
6675 /* A non-alias entry: return it. */
6676 return cp;
6678 /* An alias entry maps a suffix to a language.
6679 Search for the language; pass 0 for NAME and LENGTH
6680 to avoid infinite recursion if language not found. */
6681 return lookup_compiler (NULL, 0, cp->spec + 1);
6683 return 0;
6686 static char *
6687 save_string (const char *s, int len)
6689 char *result = xmalloc (len + 1);
6691 memcpy (result, s, len);
6692 result[len] = 0;
6693 return result;
6696 void
6697 pfatal_with_name (const char *name)
6699 perror_with_name (name);
6700 delete_temp_files ();
6701 exit (1);
6704 static void
6705 perror_with_name (const char *name)
6707 error ("%s: %s", name, xstrerror (errno));
6710 static void
6711 pfatal_pexecute (const char *errmsg_fmt, const char *errmsg_arg)
6713 if (errmsg_arg)
6715 int save_errno = errno;
6717 /* Space for trailing '\0' is in %s. */
6718 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6719 sprintf (msg, errmsg_fmt, errmsg_arg);
6720 errmsg_fmt = msg;
6722 errno = save_errno;
6725 pfatal_with_name (errmsg_fmt);
6728 /* Output an error message and exit. */
6730 void
6731 fancy_abort (const char *file, int line, const char *func)
6733 fatal ("internal gcc abort in %s, at %s:%d", func, file, line);
6736 /* Output an error message and exit. */
6738 void
6739 fatal (const char *msgid, ...)
6741 va_list ap;
6743 va_start (ap, msgid);
6745 fprintf (stderr, "%s: ", programname);
6746 vfprintf (stderr, _(msgid), ap);
6747 va_end (ap);
6748 fprintf (stderr, "\n");
6749 delete_temp_files ();
6750 exit (1);
6753 void
6754 error (const char *msgid, ...)
6756 va_list ap;
6758 va_start (ap, msgid);
6759 fprintf (stderr, "%s: ", programname);
6760 vfprintf (stderr, _(msgid), ap);
6761 va_end (ap);
6763 fprintf (stderr, "\n");
6766 static void
6767 notice (const char *msgid, ...)
6769 va_list ap;
6771 va_start (ap, msgid);
6772 vfprintf (stderr, _(msgid), ap);
6773 va_end (ap);
6776 static inline void
6777 validate_switches_from_spec (const char *spec)
6779 const char *p = spec;
6780 char c;
6781 while ((c = *p++))
6782 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6783 /* We have a switch spec. */
6784 p = validate_switches (p + 1);
6787 static void
6788 validate_all_switches (void)
6790 struct compiler *comp;
6791 struct spec_list *spec;
6793 for (comp = compilers; comp->spec; comp++)
6794 validate_switches_from_spec (comp->spec);
6796 /* Look through the linked list of specs read from the specs file. */
6797 for (spec = specs; spec; spec = spec->next)
6798 validate_switches_from_spec (*spec->ptr_spec);
6800 validate_switches_from_spec (link_command_spec);
6803 /* Look at the switch-name that comes after START
6804 and mark as valid all supplied switches that match it. */
6806 static const char *
6807 validate_switches (const char *start)
6809 const char *p = start;
6810 const char *atom;
6811 size_t len;
6812 int i;
6813 bool suffix = false;
6814 bool starred = false;
6816 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6818 next_member:
6819 SKIP_WHITE ();
6821 if (*p == '!')
6822 p++;
6824 SKIP_WHITE ();
6825 if (*p == '.')
6826 suffix = true, p++;
6828 atom = p;
6829 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6830 || *p == ',' || *p == '.' || *p == '@')
6831 p++;
6832 len = p - atom;
6834 if (*p == '*')
6835 starred = true, p++;
6837 SKIP_WHITE ();
6839 if (!suffix)
6841 /* Mark all matching switches as valid. */
6842 for (i = 0; i < n_switches; i++)
6843 if (!strncmp (switches[i].part1, atom, len)
6844 && (starred || switches[i].part1[len] == 0))
6845 switches[i].validated = 1;
6848 if (*p) p++;
6849 if (*p && (p[-1] == '|' || p[-1] == '&'))
6850 goto next_member;
6852 if (*p && p[-1] == ':')
6854 while (*p && *p != ';' && *p != '}')
6856 if (*p == '%')
6858 p++;
6859 if (*p == '{' || *p == '<')
6860 p = validate_switches (p+1);
6861 else if (p[0] == 'W' && p[1] == '{')
6862 p = validate_switches (p+2);
6864 else
6865 p++;
6868 if (*p) p++;
6869 if (*p && p[-1] == ';')
6870 goto next_member;
6873 return p;
6874 #undef SKIP_WHITE
6877 struct mdswitchstr
6879 const char *str;
6880 int len;
6883 static struct mdswitchstr *mdswitches;
6884 static int n_mdswitches;
6886 /* Check whether a particular argument was used. The first time we
6887 canonicalize the switches to keep only the ones we care about. */
6889 static int
6890 used_arg (const char *p, int len)
6892 struct mswitchstr
6894 const char *str;
6895 const char *replace;
6896 int len;
6897 int rep_len;
6900 static struct mswitchstr *mswitches;
6901 static int n_mswitches;
6902 int i, j;
6904 if (!mswitches)
6906 struct mswitchstr *matches;
6907 const char *q;
6908 int cnt = 0;
6910 /* Break multilib_matches into the component strings of string
6911 and replacement string. */
6912 for (q = multilib_matches; *q != '\0'; q++)
6913 if (*q == ';')
6914 cnt++;
6916 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
6917 i = 0;
6918 q = multilib_matches;
6919 while (*q != '\0')
6921 matches[i].str = q;
6922 while (*q != ' ')
6924 if (*q == '\0')
6926 invalid_matches:
6927 fatal ("multilib spec '%s' is invalid", multilib_matches);
6929 q++;
6931 matches[i].len = q - matches[i].str;
6933 matches[i].replace = ++q;
6934 while (*q != ';' && *q != '\0')
6936 if (*q == ' ')
6937 goto invalid_matches;
6938 q++;
6940 matches[i].rep_len = q - matches[i].replace;
6941 i++;
6942 if (*q == ';')
6943 q++;
6946 /* Now build a list of the replacement string for switches that we care
6947 about. Make sure we allocate at least one entry. This prevents
6948 xmalloc from calling fatal, and prevents us from re-executing this
6949 block of code. */
6950 mswitches
6951 = xmalloc (sizeof (struct mswitchstr)
6952 * (n_mdswitches + (n_switches ? n_switches : 1)));
6953 for (i = 0; i < n_switches; i++)
6954 if (switches[i].live_cond != SWITCH_IGNORE)
6956 int xlen = strlen (switches[i].part1);
6957 for (j = 0; j < cnt; j++)
6958 if (xlen == matches[j].len
6959 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6961 mswitches[n_mswitches].str = matches[j].replace;
6962 mswitches[n_mswitches].len = matches[j].rep_len;
6963 mswitches[n_mswitches].replace = (char *) 0;
6964 mswitches[n_mswitches].rep_len = 0;
6965 n_mswitches++;
6966 break;
6970 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
6971 on the command line nor any options mutually incompatible with
6972 them. */
6973 for (i = 0; i < n_mdswitches; i++)
6975 const char *r;
6977 for (q = multilib_options; *q != '\0'; q++)
6979 while (*q == ' ')
6980 q++;
6982 r = q;
6983 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
6984 || strchr (" /", q[mdswitches[i].len]) == NULL)
6986 while (*q != ' ' && *q != '/' && *q != '\0')
6987 q++;
6988 if (*q != '/')
6989 break;
6990 q++;
6993 if (*q != ' ' && *q != '\0')
6995 while (*r != ' ' && *r != '\0')
6997 q = r;
6998 while (*q != ' ' && *q != '/' && *q != '\0')
6999 q++;
7001 if (used_arg (r, q - r))
7002 break;
7004 if (*q != '/')
7006 mswitches[n_mswitches].str = mdswitches[i].str;
7007 mswitches[n_mswitches].len = mdswitches[i].len;
7008 mswitches[n_mswitches].replace = (char *) 0;
7009 mswitches[n_mswitches].rep_len = 0;
7010 n_mswitches++;
7011 break;
7014 r = q + 1;
7016 break;
7022 for (i = 0; i < n_mswitches; i++)
7023 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7024 return 1;
7026 return 0;
7029 static int
7030 default_arg (const char *p, int len)
7032 int i;
7034 for (i = 0; i < n_mdswitches; i++)
7035 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7036 return 1;
7038 return 0;
7041 /* Work out the subdirectory to use based on the options. The format of
7042 multilib_select is a list of elements. Each element is a subdirectory
7043 name followed by a list of options followed by a semicolon. The format
7044 of multilib_exclusions is the same, but without the preceding
7045 directory. First gcc will check the exclusions, if none of the options
7046 beginning with an exclamation point are present, and all of the other
7047 options are present, then we will ignore this completely. Passing
7048 that, gcc will consider each multilib_select in turn using the same
7049 rules for matching the options. If a match is found, that subdirectory
7050 will be used. */
7052 static void
7053 set_multilib_dir (void)
7055 const char *p;
7056 unsigned int this_path_len;
7057 const char *this_path, *this_arg;
7058 const char *start, *end;
7059 int not_arg;
7060 int ok, ndfltok, first;
7062 n_mdswitches = 0;
7063 start = multilib_defaults;
7064 while (*start == ' ' || *start == '\t')
7065 start++;
7066 while (*start != '\0')
7068 n_mdswitches++;
7069 while (*start != ' ' && *start != '\t' && *start != '\0')
7070 start++;
7071 while (*start == ' ' || *start == '\t')
7072 start++;
7075 if (n_mdswitches)
7077 int i = 0;
7079 mdswitches = xmalloc (sizeof (struct mdswitchstr) * n_mdswitches);
7080 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7082 while (*start == ' ' || *start == '\t')
7083 start++;
7085 if (*start == '\0')
7086 break;
7088 for (end = start + 1;
7089 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7092 obstack_grow (&multilib_obstack, start, end - start);
7093 obstack_1grow (&multilib_obstack, 0);
7094 mdswitches[i].str = obstack_finish (&multilib_obstack);
7095 mdswitches[i++].len = end - start;
7097 if (*end == '\0')
7098 break;
7102 p = multilib_exclusions;
7103 while (*p != '\0')
7105 /* Ignore newlines. */
7106 if (*p == '\n')
7108 ++p;
7109 continue;
7112 /* Check the arguments. */
7113 ok = 1;
7114 while (*p != ';')
7116 if (*p == '\0')
7118 invalid_exclusions:
7119 fatal ("multilib exclusions '%s' is invalid",
7120 multilib_exclusions);
7123 if (! ok)
7125 ++p;
7126 continue;
7129 this_arg = p;
7130 while (*p != ' ' && *p != ';')
7132 if (*p == '\0')
7133 goto invalid_exclusions;
7134 ++p;
7137 if (*this_arg != '!')
7138 not_arg = 0;
7139 else
7141 not_arg = 1;
7142 ++this_arg;
7145 ok = used_arg (this_arg, p - this_arg);
7146 if (not_arg)
7147 ok = ! ok;
7149 if (*p == ' ')
7150 ++p;
7153 if (ok)
7154 return;
7156 ++p;
7159 first = 1;
7160 p = multilib_select;
7161 while (*p != '\0')
7163 /* Ignore newlines. */
7164 if (*p == '\n')
7166 ++p;
7167 continue;
7170 /* Get the initial path. */
7171 this_path = p;
7172 while (*p != ' ')
7174 if (*p == '\0')
7176 invalid_select:
7177 fatal ("multilib select '%s' is invalid",
7178 multilib_select);
7180 ++p;
7182 this_path_len = p - this_path;
7184 /* Check the arguments. */
7185 ok = 1;
7186 ndfltok = 1;
7187 ++p;
7188 while (*p != ';')
7190 if (*p == '\0')
7191 goto invalid_select;
7193 if (! ok)
7195 ++p;
7196 continue;
7199 this_arg = p;
7200 while (*p != ' ' && *p != ';')
7202 if (*p == '\0')
7203 goto invalid_select;
7204 ++p;
7207 if (*this_arg != '!')
7208 not_arg = 0;
7209 else
7211 not_arg = 1;
7212 ++this_arg;
7215 /* If this is a default argument, we can just ignore it.
7216 This is true even if this_arg begins with '!'. Beginning
7217 with '!' does not mean that this argument is necessarily
7218 inappropriate for this library: it merely means that
7219 there is a more specific library which uses this
7220 argument. If this argument is a default, we need not
7221 consider that more specific library. */
7222 ok = used_arg (this_arg, p - this_arg);
7223 if (not_arg)
7224 ok = ! ok;
7226 if (! ok)
7227 ndfltok = 0;
7229 if (default_arg (this_arg, p - this_arg))
7230 ok = 1;
7232 if (*p == ' ')
7233 ++p;
7236 if (ok && first)
7238 if (this_path_len != 1
7239 || this_path[0] != '.')
7241 char *new_multilib_dir = xmalloc (this_path_len + 1);
7242 char *q;
7244 strncpy (new_multilib_dir, this_path, this_path_len);
7245 new_multilib_dir[this_path_len] = '\0';
7246 q = strchr (new_multilib_dir, ':');
7247 if (q != NULL)
7248 *q = '\0';
7249 multilib_dir = new_multilib_dir;
7251 first = 0;
7254 if (ndfltok)
7256 const char *q = this_path, *end = this_path + this_path_len;
7258 while (q < end && *q != ':')
7259 q++;
7260 if (q < end)
7262 char *new_multilib_os_dir = xmalloc (end - q);
7263 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7264 new_multilib_os_dir[end - q - 1] = '\0';
7265 multilib_os_dir = new_multilib_os_dir;
7266 break;
7270 ++p;
7273 if (multilib_dir == NULL && multilib_os_dir != NULL
7274 && strcmp (multilib_os_dir, ".") == 0)
7276 free ((char *) multilib_os_dir);
7277 multilib_os_dir = NULL;
7279 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7280 multilib_os_dir = multilib_dir;
7283 /* Print out the multiple library subdirectory selection
7284 information. This prints out a series of lines. Each line looks
7285 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7286 required. Only the desired options are printed out, the negative
7287 matches. The options are print without a leading dash. There are
7288 no spaces to make it easy to use the information in the shell.
7289 Each subdirectory is printed only once. This assumes the ordering
7290 generated by the genmultilib script. Also, we leave out ones that match
7291 the exclusions. */
7293 static void
7294 print_multilib_info (void)
7296 const char *p = multilib_select;
7297 const char *last_path = 0, *this_path;
7298 int skip;
7299 unsigned int last_path_len = 0;
7301 while (*p != '\0')
7303 skip = 0;
7304 /* Ignore newlines. */
7305 if (*p == '\n')
7307 ++p;
7308 continue;
7311 /* Get the initial path. */
7312 this_path = p;
7313 while (*p != ' ')
7315 if (*p == '\0')
7317 invalid_select:
7318 fatal ("multilib select '%s' is invalid", multilib_select);
7321 ++p;
7324 /* When --disable-multilib was used but target defines
7325 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7326 to find multilib_os_dir, so skip them from output. */
7327 if (this_path[0] == '.' && this_path[1] == ':')
7328 skip = 1;
7330 /* Check for matches with the multilib_exclusions. We don't bother
7331 with the '!' in either list. If any of the exclusion rules match
7332 all of its options with the select rule, we skip it. */
7334 const char *e = multilib_exclusions;
7335 const char *this_arg;
7337 while (*e != '\0')
7339 int m = 1;
7340 /* Ignore newlines. */
7341 if (*e == '\n')
7343 ++e;
7344 continue;
7347 /* Check the arguments. */
7348 while (*e != ';')
7350 const char *q;
7351 int mp = 0;
7353 if (*e == '\0')
7355 invalid_exclusion:
7356 fatal ("multilib exclusion '%s' is invalid",
7357 multilib_exclusions);
7360 if (! m)
7362 ++e;
7363 continue;
7366 this_arg = e;
7368 while (*e != ' ' && *e != ';')
7370 if (*e == '\0')
7371 goto invalid_exclusion;
7372 ++e;
7375 q = p + 1;
7376 while (*q != ';')
7378 const char *arg;
7379 int len = e - this_arg;
7381 if (*q == '\0')
7382 goto invalid_select;
7384 arg = q;
7386 while (*q != ' ' && *q != ';')
7388 if (*q == '\0')
7389 goto invalid_select;
7390 ++q;
7393 if (! strncmp (arg, this_arg,
7394 (len < q - arg) ? q - arg : len)
7395 || default_arg (this_arg, e - this_arg))
7397 mp = 1;
7398 break;
7401 if (*q == ' ')
7402 ++q;
7405 if (! mp)
7406 m = 0;
7408 if (*e == ' ')
7409 ++e;
7412 if (m)
7414 skip = 1;
7415 break;
7418 if (*e != '\0')
7419 ++e;
7423 if (! skip)
7425 /* If this is a duplicate, skip it. */
7426 skip = (last_path != 0
7427 && (unsigned int) (p - this_path) == last_path_len
7428 && ! strncmp (last_path, this_path, last_path_len));
7430 last_path = this_path;
7431 last_path_len = p - this_path;
7434 /* If this directory requires any default arguments, we can skip
7435 it. We will already have printed a directory identical to
7436 this one which does not require that default argument. */
7437 if (! skip)
7439 const char *q;
7441 q = p + 1;
7442 while (*q != ';')
7444 const char *arg;
7446 if (*q == '\0')
7447 goto invalid_select;
7449 if (*q == '!')
7450 arg = NULL;
7451 else
7452 arg = q;
7454 while (*q != ' ' && *q != ';')
7456 if (*q == '\0')
7457 goto invalid_select;
7458 ++q;
7461 if (arg != NULL
7462 && default_arg (arg, q - arg))
7464 skip = 1;
7465 break;
7468 if (*q == ' ')
7469 ++q;
7473 if (! skip)
7475 const char *p1;
7477 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7478 putchar (*p1);
7479 putchar (';');
7482 ++p;
7483 while (*p != ';')
7485 int use_arg;
7487 if (*p == '\0')
7488 goto invalid_select;
7490 if (skip)
7492 ++p;
7493 continue;
7496 use_arg = *p != '!';
7498 if (use_arg)
7499 putchar ('@');
7501 while (*p != ' ' && *p != ';')
7503 if (*p == '\0')
7504 goto invalid_select;
7505 if (use_arg)
7506 putchar (*p);
7507 ++p;
7510 if (*p == ' ')
7511 ++p;
7514 if (! skip)
7516 /* If there are extra options, print them now. */
7517 if (multilib_extra && *multilib_extra)
7519 int print_at = TRUE;
7520 const char *q;
7522 for (q = multilib_extra; *q != '\0'; q++)
7524 if (*q == ' ')
7525 print_at = TRUE;
7526 else
7528 if (print_at)
7529 putchar ('@');
7530 putchar (*q);
7531 print_at = FALSE;
7536 putchar ('\n');
7539 ++p;
7543 /* if-exists built-in spec function.
7545 Checks to see if the file specified by the absolute pathname in
7546 ARGS exists. Returns that pathname if found.
7548 The usual use for this function is to check for a library file
7549 (whose name has been expanded with %s). */
7551 static const char *
7552 if_exists_spec_function (int argc, const char **argv)
7554 /* Must have only one argument. */
7555 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7556 return argv[0];
7558 return NULL;
7561 /* if-exists-else built-in spec function.
7563 This is like if-exists, but takes an additional argument which
7564 is returned if the first argument does not exist. */
7566 static const char *
7567 if_exists_else_spec_function (int argc, const char **argv)
7569 /* Must have exactly two arguments. */
7570 if (argc != 2)
7571 return NULL;
7573 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7574 return argv[0];
7576 return argv[1];
7579 /* replace-outfile built-in spec function.
7580 This looks for the first argument in the outfiles array's name and replaces it
7581 with the second argument. */
7583 static const char *
7584 replace_outfile_spec_function (int argc, const char **argv)
7586 int i;
7587 /* Must have exactly two arguments. */
7588 if (argc != 2)
7589 abort ();
7591 for (i = 0; i < n_infiles; i++)
7593 if (outfiles[i] && !strcmp (outfiles[i], argv[0]))
7594 outfiles[i] = xstrdup (argv[1]);
7596 return NULL;