* config/i386/i386.c (override_options): Disable x87 fancy math
[official-gcc.git] / gcc / gcc.c
blob6897bf9a336cc400c18308aba3f23962b5c92fcc
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 Free Software Foundation, Inc.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA.
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!! */
25 /* This program is the user interface to the C compiler and possibly to
26 other compilers. It is used because compilation is a complicated procedure
27 which involves running several programs and passing temporary files between
28 them, forwarding the users switches to those programs selectively,
29 and deleting the temporary files at the end.
31 CC recognizes how to compile each input file by suffixes in the file names.
32 Once it knows which kind of compilation to perform, the procedure for
33 compilation is specified by a string called a "spec". */
35 /* A Short Introduction to Adding a Command-Line Option.
37 Before adding a command-line option, consider if it is really
38 necessary. Each additional command-line option adds complexity and
39 is difficult to remove in subsequent versions.
41 In the following, consider adding the command-line argument
42 `--bar'.
44 1. Each command-line option is specified in the specs file. The
45 notation is described below in the comment entitled "The Specs
46 Language". Read it.
48 2. In this file, add an entry to "option_map" equating the long
49 `--' argument version and any shorter, single letter version. Read
50 the comments in the declaration of "struct option_map" for an
51 explanation. Do not omit the first `-'.
53 3. Look in the "specs" file to determine which program or option
54 list should be given the argument, e.g., "cc1_options". Add the
55 appropriate syntax for the shorter option version to the
56 corresponding "const char *" entry in this file. Omit the first
57 `-' from the option. For example, use `-bar', rather than `--bar'.
59 4. If the argument takes an argument, e.g., `--baz argument1',
60 modify either DEFAULT_SWITCH_TAKES_ARG or
61 DEFAULT_WORD_SWITCH_TAKES_ARG in this file. Omit the first `-'
62 from `--baz'.
64 5. Document the option in this file's display_help(). If the
65 option is passed to a subprogram, modify its corresponding
66 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
67 instead.
69 6. Compile and test. Make sure that your new specs file is being
70 read. For example, use a debugger to investigate the value of
71 "specs_file" in main(). */
73 #include "config.h"
74 #include "system.h"
75 #include "coretypes.h"
76 #include "multilib.h" /* before tm.h */
77 #include "tm.h"
78 #include <signal.h>
79 #if ! defined( SIGCHLD ) && defined( SIGCLD )
80 # define SIGCHLD SIGCLD
81 #endif
82 #include "obstack.h"
83 #include "intl.h"
84 #include "prefix.h"
85 #include "gcc.h"
86 #include "flags.h"
88 #ifdef HAVE_SYS_RESOURCE_H
89 #include <sys/resource.h>
90 #endif
91 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
92 extern int getrusage (int, struct rusage *);
93 #endif
95 /* By default there is no special suffix for target executables. */
96 /* FIXME: when autoconf is fixed, remove the host check - dj */
97 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
98 #define HAVE_TARGET_EXECUTABLE_SUFFIX
99 #endif
101 /* By default there is no special suffix for host executables. */
102 #ifdef HOST_EXECUTABLE_SUFFIX
103 #define HAVE_HOST_EXECUTABLE_SUFFIX
104 #else
105 #define HOST_EXECUTABLE_SUFFIX ""
106 #endif
108 /* By default, the suffix for target object files is ".o". */
109 #ifdef TARGET_OBJECT_SUFFIX
110 #define HAVE_TARGET_OBJECT_SUFFIX
111 #else
112 #define TARGET_OBJECT_SUFFIX ".o"
113 #endif
115 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
117 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
118 #ifndef LIBRARY_PATH_ENV
119 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
120 #endif
122 #ifndef HAVE_KILL
123 #define kill(p,s) raise(s)
124 #endif
126 /* If a stage of compilation returns an exit status >= 1,
127 compilation of that file ceases. */
129 #define MIN_FATAL_STATUS 1
131 /* Flag set by cppspec.c to 1. */
132 int is_cpp_driver;
134 /* Flag saying to pass the greatest exit code returned by a sub-process
135 to the calling program. */
136 static int pass_exit_codes;
138 /* Definition of string containing the arguments given to configure. */
139 #include "configargs.h"
141 /* Flag saying to print the directories gcc will search through looking for
142 programs, libraries, etc. */
144 static int print_search_dirs;
146 /* Flag saying to print the full filename of this file
147 as found through our usual search mechanism. */
149 static const char *print_file_name = NULL;
151 /* As print_file_name, but search for executable file. */
153 static const char *print_prog_name = NULL;
155 /* Flag saying to print the relative path we'd use to
156 find libgcc.a given the current compiler flags. */
158 static int print_multi_directory;
160 /* Flag saying to print the relative path we'd use to
161 find OS libraries given the current compiler flags. */
163 static int print_multi_os_directory;
165 /* Flag saying to print the list of subdirectories and
166 compiler flags used to select them in a standard form. */
168 static int print_multi_lib;
170 /* Flag saying to print the command line options understood by gcc and its
171 sub-processes. */
173 static int print_help_list;
175 /* Flag indicating whether we should print the command and arguments */
177 static int verbose_flag;
179 /* Flag indicating whether we should ONLY print the command and
180 arguments (like verbose_flag) without executing the command.
181 Displayed arguments are quoted so that the generated command
182 line is suitable for execution. This is intended for use in
183 shell scripts to capture the driver-generated command line. */
184 static int verbose_only_flag;
186 /* Flag indicating to print target specific command line options. */
188 static int target_help_flag;
190 /* Flag indicating whether we should report subprocess execution times
191 (if this is supported by the system - see pexecute.c). */
193 static int report_times;
195 /* Nonzero means place this string before uses of /, so that include
196 and library files can be found in an alternate location. */
198 #ifdef TARGET_SYSTEM_ROOT
199 static const char *target_system_root = TARGET_SYSTEM_ROOT;
200 #else
201 static const char *target_system_root = 0;
202 #endif
204 /* Nonzero means pass the updated target_system_root to the compiler. */
206 static int target_system_root_changed;
208 /* Nonzero means append this string to target_system_root. */
210 static const char *target_sysroot_suffix = 0;
212 /* Nonzero means append this string to target_system_root for headers. */
214 static const char *target_sysroot_hdrs_suffix = 0;
216 /* Nonzero means write "temp" files in source directory
217 and use the source file's name in them, and don't delete them. */
219 static int save_temps_flag;
221 /* Nonzero means pass multiple source files to the compiler at one time. */
223 static int combine_flag = 0;
225 /* Nonzero means use pipes to communicate between subprocesses.
226 Overridden by either of the above two flags. */
228 static int use_pipes;
230 /* The compiler version. */
232 static const char *compiler_version;
234 /* The target version specified with -V */
236 static const char *const spec_version = DEFAULT_TARGET_VERSION;
238 /* The target machine specified with -b. */
240 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
242 /* Nonzero if cross-compiling.
243 When -b is used, the value comes from the `specs' file. */
245 #ifdef CROSS_COMPILE
246 static const char *cross_compile = "1";
247 #else
248 static const char *cross_compile = "0";
249 #endif
251 #ifdef MODIFY_TARGET_NAME
253 /* Information on how to alter the target name based on a command-line
254 switch. The only case we support now is simply appending or deleting a
255 string to or from the end of the first part of the configuration name. */
257 static const struct modify_target
259 const char *const sw;
260 const enum add_del {ADD, DELETE} add_del;
261 const char *const str;
263 modify_target[] = MODIFY_TARGET_NAME;
264 #endif
266 /* The number of errors that have occurred; the link phase will not be
267 run if this is nonzero. */
268 static int error_count = 0;
270 /* Greatest exit code of sub-processes that has been encountered up to
271 now. */
272 static int greatest_status = 1;
274 /* This is the obstack which we use to allocate many strings. */
276 static struct obstack obstack;
278 /* This is the obstack to build an environment variable to pass to
279 collect2 that describes all of the relevant switches of what to
280 pass the compiler in building the list of pointers to constructors
281 and destructors. */
283 static struct obstack collect_obstack;
285 /* These structs are used to collect resource usage information for
286 subprocesses. */
287 #ifdef HAVE_GETRUSAGE
288 static struct rusage rus, prus;
289 #endif
291 /* Forward declaration for prototypes. */
292 struct path_prefix;
293 struct prefix_list;
295 static void init_spec (void);
296 static void store_arg (const char *, int, int);
297 static char *load_specs (const char *);
298 static void read_specs (const char *, int);
299 static void set_spec (const char *, const char *);
300 static struct compiler *lookup_compiler (const char *, size_t, const char *);
301 static char *build_search_list (struct path_prefix *, const char *, int);
302 static void putenv_from_prefixes (struct path_prefix *, const char *);
303 static int access_check (const char *, int);
304 static char *find_a_file (struct path_prefix *, const char *, int, int);
305 static void add_prefix (struct path_prefix *, const char *, const char *,
306 int, int, int);
307 static void add_sysrooted_prefix (struct path_prefix *, const char *,
308 const char *, int, int, int);
309 static void translate_options (int *, const char *const **);
310 static char *skip_whitespace (char *);
311 static void delete_if_ordinary (const char *);
312 static void delete_temp_files (void);
313 static void delete_failure_queue (void);
314 static void clear_failure_queue (void);
315 static int check_live_switch (int, int);
316 static const char *handle_braces (const char *);
317 static inline bool input_suffix_matches (const char *, const char *);
318 static inline bool switch_matches (const char *, const char *, int);
319 static inline void mark_matching_switches (const char *, const char *, int);
320 static inline void process_marked_switches (void);
321 static const char *process_brace_body (const char *, const char *, const char *, int, int);
322 static const struct spec_function *lookup_spec_function (const char *);
323 static const char *eval_spec_function (const char *, const char *);
324 static const char *handle_spec_function (const char *);
325 static char *save_string (const char *, int);
326 static void set_collect_gcc_options (void);
327 static void do_spec_path (struct prefix_list *, const char *, int, int, int, const char *, const char *);
328 static int do_spec_1 (const char *, int, const char *);
329 static int do_spec_2 (const char *);
330 static void do_option_spec (const char *, const char *);
331 static void do_self_spec (const char *);
332 static const char *find_file (const char *);
333 static int is_directory (const char *, const char *, int);
334 static const char *validate_switches (const char *);
335 static void validate_all_switches (void);
336 static inline void validate_switches_from_spec (const char *);
337 static void give_switch (int, int);
338 static int used_arg (const char *, int);
339 static int default_arg (const char *, int);
340 static void set_multilib_dir (void);
341 static void print_multilib_info (void);
342 static void perror_with_name (const char *);
343 static void pfatal_pexecute (const char *, const char *) ATTRIBUTE_NORETURN;
344 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
345 static void display_help (void);
346 static void add_preprocessor_option (const char *, int);
347 static void add_assembler_option (const char *, int);
348 static void add_linker_option (const char *, int);
349 static void process_command (int, const char **);
350 static int execute (void);
351 static void alloc_args (void);
352 static void clear_args (void);
353 static void fatal_error (int);
354 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
355 static void init_gcc_specs (struct obstack *, const char *, const char *,
356 const char *);
357 #endif
358 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
359 static const char *convert_filename (const char *, int, int);
360 #endif
362 static const char *if_exists_spec_function (int, const char **);
363 static const char *if_exists_else_spec_function (int, const char **);
364 static const char *replace_outfile_spec_function (int, const char **);
366 /* The Specs Language
368 Specs are strings containing lines, each of which (if not blank)
369 is made up of a program name, and arguments separated by spaces.
370 The program name must be exact and start from root, since no path
371 is searched and it is unreliable to depend on the current working directory.
372 Redirection of input or output is not supported; the subprograms must
373 accept filenames saying what files to read and write.
375 In addition, the specs can contain %-sequences to substitute variable text
376 or for conditional text. Here is a table of all defined %-sequences.
377 Note that spaces are not generated automatically around the results of
378 expanding these sequences; therefore, you can concatenate them together
379 or with constant text in a single argument.
381 %% substitute one % into the program name or argument.
382 %i substitute the name of the input file being processed.
383 %b substitute the basename of the input file being processed.
384 This is the substring up to (and not including) the last period
385 and not including the directory.
386 %B same as %b, but include the file suffix (text after the last period).
387 %gSUFFIX
388 substitute a file name that has suffix SUFFIX and is chosen
389 once per compilation, and mark the argument a la %d. To reduce
390 exposure to denial-of-service attacks, the file name is now
391 chosen in a way that is hard to predict even when previously
392 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
393 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
394 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
395 had been pre-processed. Previously, %g was simply substituted
396 with a file name chosen once per compilation, without regard
397 to any appended suffix (which was therefore treated just like
398 ordinary text), making such attacks more likely to succeed.
399 %|SUFFIX
400 like %g, but if -pipe is in effect, expands simply to "-".
401 %mSUFFIX
402 like %g, but if -pipe is in effect, expands to nothing. (We have both
403 %| and %m to accommodate differences between system assemblers; see
404 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
405 %uSUFFIX
406 like %g, but generates a new temporary file name even if %uSUFFIX
407 was already seen.
408 %USUFFIX
409 substitutes the last file name generated with %uSUFFIX, generating a
410 new one if there is no such last file name. In the absence of any
411 %uSUFFIX, this is just like %gSUFFIX, except they don't share
412 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
413 would involve the generation of two distinct file names, one
414 for each `%g.s' and another for each `%U.s'. Previously, %U was
415 simply substituted with a file name chosen for the previous %u,
416 without regard to any appended suffix.
417 %jSUFFIX
418 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
419 writable, and if save-temps is off; otherwise, substitute the name
420 of a temporary file, just like %u. This temporary file is not
421 meant for communication between processes, but rather as a junk
422 disposal mechanism.
423 %.SUFFIX
424 substitutes .SUFFIX for the suffixes of a matched switch's args when
425 it is subsequently output with %*. SUFFIX is terminated by the next
426 space or %.
427 %d marks the argument containing or following the %d as a
428 temporary file name, so that that file will be deleted if CC exits
429 successfully. Unlike %g, this contributes no text to the argument.
430 %w marks the argument containing or following the %w as the
431 "output file" of this compilation. This puts the argument
432 into the sequence of arguments that %o will substitute later.
433 %V indicates that this compilation produces no "output file".
434 %W{...}
435 like %{...} but mark last argument supplied within
436 as a file to be deleted on failure.
437 %o substitutes the names of all the output files, with spaces
438 automatically placed around them. You should write spaces
439 around the %o as well or the results are undefined.
440 %o is for use in the specs for running the linker.
441 Input files whose names have no recognized suffix are not compiled
442 at all, but they are included among the output files, so they will
443 be linked.
444 %O substitutes the suffix for object files. Note that this is
445 handled specially when it immediately follows %g, %u, or %U
446 (with or without a suffix argument) because of the need for
447 those to form complete file names. The handling is such that
448 %O is treated exactly as if it had already been substituted,
449 except that %g, %u, and %U do not currently support additional
450 SUFFIX characters following %O as they would following, for
451 example, `.o'.
452 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
453 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
454 and -B options) as necessary.
455 %s current argument is the name of a library or startup file of some sort.
456 Search for that file in a standard list of directories
457 and substitute the full name found.
458 %eSTR Print STR as an error message. STR is terminated by a newline.
459 Use this when inconsistent options are detected.
460 %nSTR Print STR as a notice. STR is terminated by a newline.
461 %x{OPTION} Accumulate an option for %X.
462 %X Output the accumulated linker options specified by compilations.
463 %Y Output the accumulated assembler options specified by compilations.
464 %Z Output the accumulated preprocessor options specified by compilations.
465 %a process ASM_SPEC as a spec.
466 This allows config.h to specify part of the spec for running as.
467 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
468 used here. This can be used to run a post-processor after the
469 assembler has done its job.
470 %D Dump out a -L option for each directory in startfile_prefixes.
471 If multilib_dir is set, extra entries are generated with it affixed.
472 %l process LINK_SPEC as a spec.
473 %L process LIB_SPEC as a spec.
474 %G process LIBGCC_SPEC as a spec.
475 %M output multilib_dir with directory separators replaced with "_";
476 if multilib_dir is not set or is ".", output "".
477 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
478 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
479 %C process CPP_SPEC as a spec.
480 %1 process CC1_SPEC as a spec.
481 %2 process CC1PLUS_SPEC as a spec.
482 %* substitute the variable part of a matched option. (See below.)
483 Note that each comma in the substituted string is replaced by
484 a single space.
485 %<S remove all occurrences of -S from the command line.
486 Note - this command is position dependent. % commands in the
487 spec string before this one will see -S, % commands in the
488 spec string after this one will not.
489 %<S* remove all occurrences of all switches beginning with -S from the
490 command line.
491 %:function(args)
492 Call the named function FUNCTION, passing it ARGS. ARGS is
493 first processed as a nested spec string, then split into an
494 argument vector in the usual fashion. The function returns
495 a string which is processed as if it had appeared literally
496 as part of the current spec.
497 %{S} substitutes the -S switch, if that switch was given to CC.
498 If that switch was not specified, this substitutes nothing.
499 Here S is a metasyntactic variable.
500 %{S*} substitutes all the switches specified to CC whose names start
501 with -S. This is used for -o, -I, etc; switches that take
502 arguments. CC considers `-o foo' as being one switch whose
503 name starts with `o'. %{o*} would substitute this text,
504 including the space; thus, two arguments would be generated.
505 %{S*&T*} likewise, but preserve order of S and T options (the order
506 of S and T in the spec is not significant). Can be any number
507 of ampersand-separated variables; for each the wild card is
508 optional. Useful for CPP as %{D*&U*&A*}.
510 %{S:X} substitutes X, if the -S switch was given to CC.
511 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
512 %{S*:X} substitutes X if one or more switches whose names start
513 with -S was given to CC. Normally X is substituted only
514 once, no matter how many such switches appeared. However,
515 if %* appears somewhere in X, then X will be substituted
516 once for each matching switch, with the %* replaced by the
517 part of that switch that matched the '*'.
518 %{.S:X} substitutes X, if processing a file with suffix S.
519 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
521 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
522 combined with !, ., and * as above binding stronger than the OR.
523 If %* appears in X, all of the alternatives must be starred, and
524 only the first matching alternative is substituted.
525 %{S:X; if S was given to CC, substitutes X;
526 T:Y; else if T was given to CC, substitutes Y;
527 :D} else substitutes D. There can be as many clauses as you need.
528 This may be combined with ., !, |, and * as above.
530 %(Spec) processes a specification defined in a specs file as *Spec:
531 %[Spec] as above, but put __ around -D arguments
533 The conditional text X in a %{S:X} or similar construct may contain
534 other nested % constructs or spaces, or even newlines. They are
535 processed as usual, as described above. Trailing white space in X is
536 ignored. White space may also appear anywhere on the left side of the
537 colon in these constructs, except between . or * and the corresponding
538 word.
540 The -O, -f, -m, and -W switches are handled specifically in these
541 constructs. If another value of -O or the negated form of a -f, -m, or
542 -W switch is found later in the command line, the earlier switch
543 value is ignored, except with {S*} where S is just one letter; this
544 passes all matching options.
546 The character | at the beginning of the predicate text is used to indicate
547 that a command should be piped to the following command, but only if -pipe
548 is specified.
550 Note that it is built into CC which switches take arguments and which
551 do not. You might think it would be useful to generalize this to
552 allow each compiler's spec to say which switches take arguments. But
553 this cannot be done in a consistent fashion. CC cannot even decide
554 which input files have been specified without knowing which switches
555 take arguments, and it must know which input files to compile in order
556 to tell which compilers to run.
558 CC also knows implicitly that arguments starting in `-l' are to be
559 treated as compiler output files, and passed to the linker in their
560 proper position among the other output files. */
562 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
564 /* config.h can define ASM_SPEC to provide extra args to the assembler
565 or extra switch-translations. */
566 #ifndef ASM_SPEC
567 #define ASM_SPEC ""
568 #endif
570 /* config.h can define ASM_FINAL_SPEC to run a post processor after
571 the assembler has run. */
572 #ifndef ASM_FINAL_SPEC
573 #define ASM_FINAL_SPEC ""
574 #endif
576 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
577 or extra switch-translations. */
578 #ifndef CPP_SPEC
579 #define CPP_SPEC ""
580 #endif
582 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
583 or extra switch-translations. */
584 #ifndef CC1_SPEC
585 #define CC1_SPEC ""
586 #endif
588 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
589 or extra switch-translations. */
590 #ifndef CC1PLUS_SPEC
591 #define CC1PLUS_SPEC ""
592 #endif
594 /* config.h can define LINK_SPEC to provide extra args to the linker
595 or extra switch-translations. */
596 #ifndef LINK_SPEC
597 #define LINK_SPEC ""
598 #endif
600 /* config.h can define LIB_SPEC to override the default libraries. */
601 #ifndef LIB_SPEC
602 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
603 #endif
605 /* mudflap specs */
606 #ifndef MFWRAP_SPEC
607 /* XXX: valid only for GNU ld */
608 /* XXX: should exactly match hooks provided by libmudflap.a */
609 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
610 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
611 --wrap=mmap --wrap=munmap --wrap=alloca\
612 } %{fmudflapth: --wrap=pthread_create --wrap=pthread_join --wrap=pthread_exit\
613 }} %{fmudflap|fmudflapth: --wrap=main}"
614 #endif
615 #ifndef MFLIB_SPEC
616 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
617 #endif
619 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
620 included. */
621 #ifndef LIBGCC_SPEC
622 #if defined(REAL_LIBGCC_SPEC)
623 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
624 #elif defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
625 /* Have gcc do the search for libgcc.a. */
626 #define LIBGCC_SPEC "libgcc.a%s"
627 #else
628 #define LIBGCC_SPEC "-lgcc"
629 #endif
630 #endif
632 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
633 #ifndef STARTFILE_SPEC
634 #define STARTFILE_SPEC \
635 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
636 #endif
638 /* config.h can define SWITCHES_NEED_SPACES to control which options
639 require spaces between the option and the argument. */
640 #ifndef SWITCHES_NEED_SPACES
641 #define SWITCHES_NEED_SPACES ""
642 #endif
644 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
645 #ifndef ENDFILE_SPEC
646 #define ENDFILE_SPEC ""
647 #endif
649 #ifndef LINKER_NAME
650 #define LINKER_NAME "collect2"
651 #endif
653 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
654 to the assembler. */
655 #ifndef ASM_DEBUG_SPEC
656 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
657 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
658 # define ASM_DEBUG_SPEC \
659 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
660 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
661 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
662 # else
663 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
664 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
665 # endif
666 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
667 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
668 # endif
669 # endif
670 #endif
671 #ifndef ASM_DEBUG_SPEC
672 # define ASM_DEBUG_SPEC ""
673 #endif
675 /* Here is the spec for running the linker, after compiling all files. */
677 /* This is overridable by the target in case they need to specify the
678 -lgcc and -lc order specially, yet not require them to override all
679 of LINK_COMMAND_SPEC. */
680 #ifndef LINK_GCC_C_SEQUENCE_SPEC
681 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
682 #endif
684 #ifndef LINK_PIE_SPEC
685 #ifdef HAVE_LD_PIE
686 #define LINK_PIE_SPEC "%{pie:-pie} "
687 #else
688 #define LINK_PIE_SPEC "%{pie:} "
689 #endif
690 #endif
692 /* -u* was put back because both BSD and SysV seem to support it. */
693 /* %{static:} simply prevents an error message if the target machine
694 doesn't handle -static. */
695 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
696 scripts which exist in user specified directories, or in standard
697 directories. */
698 #ifndef LINK_COMMAND_SPEC
699 #define LINK_COMMAND_SPEC "\
700 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
701 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
702 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
703 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o %(mflib)\
704 %{fprofile-arcs|fprofile-generate:-lgcov}\
705 %{!nostdlib:%{!nodefaultlibs:%(link_gcc_c_sequence)}}\
706 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
707 #endif
709 #ifndef LINK_LIBGCC_SPEC
710 # ifdef LINK_LIBGCC_SPECIAL
711 /* Don't generate -L options for startfile prefix list. */
712 # define LINK_LIBGCC_SPEC ""
713 # else
714 /* Do generate them. */
715 # define LINK_LIBGCC_SPEC "%D"
716 # endif
717 #endif
719 #ifndef STARTFILE_PREFIX_SPEC
720 # define STARTFILE_PREFIX_SPEC ""
721 #endif
723 #ifndef SYSROOT_SUFFIX_SPEC
724 # define SYSROOT_SUFFIX_SPEC ""
725 #endif
727 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
728 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
729 #endif
731 static const char *asm_debug;
732 static const char *cpp_spec = CPP_SPEC;
733 static const char *cc1_spec = CC1_SPEC;
734 static const char *cc1plus_spec = CC1PLUS_SPEC;
735 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
736 static const char *asm_spec = ASM_SPEC;
737 static const char *asm_final_spec = ASM_FINAL_SPEC;
738 static const char *link_spec = LINK_SPEC;
739 static const char *lib_spec = LIB_SPEC;
740 static const char *mfwrap_spec = MFWRAP_SPEC;
741 static const char *mflib_spec = MFLIB_SPEC;
742 static const char *libgcc_spec = LIBGCC_SPEC;
743 static const char *endfile_spec = ENDFILE_SPEC;
744 static const char *startfile_spec = STARTFILE_SPEC;
745 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
746 static const char *linker_name_spec = LINKER_NAME;
747 static const char *link_command_spec = LINK_COMMAND_SPEC;
748 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
749 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
750 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
751 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
753 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
754 There should be no need to override these in target dependent files,
755 but we need to copy them to the specs file so that newer versions
756 of the GCC driver can correctly drive older tool chains with the
757 appropriate -B options. */
759 /* When cpplib handles traditional preprocessing, get rid of this, and
760 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
761 that we default the front end language better. */
762 static const char *trad_capable_cpp =
763 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
765 /* We don't wrap .d files in %W{} since a missing .d file, and
766 therefore no dependency entry, confuses make into thinking a .o
767 file that happens to exist is up-to-date. */
768 static const char *cpp_unique_options =
769 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
770 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
771 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
772 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
773 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
774 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
775 %{trigraphs} %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
776 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
777 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
778 %{E|M|MM:%W{o*}}";
780 /* This contains cpp options which are common with cc1_options and are passed
781 only when preprocessing only to avoid duplication. We pass the cc1 spec
782 options to the preprocessor so that it the cc1 spec may manipulate
783 options used to set target flags. Those special target flags settings may
784 in turn cause preprocessor symbols to be defined specially. */
785 static const char *cpp_options =
786 "%(cpp_unique_options) %1 %{m*} %{std*&ansi} %{W*&pedantic*} %{w} %{f*}\
787 %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*} %{undef}\
788 %{save-temps:-fpch-preprocess}";
790 /* This contains cpp options which are not passed when the preprocessor
791 output will be used by another program. */
792 static const char *cpp_debug_options = "%{d*}";
794 /* NB: This is shared amongst all front-ends. */
795 static const char *cc1_options =
796 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
797 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
798 %{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}%{!c:%{!S:-auxbase %b}}\
799 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi}\
800 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
801 %{Qn:-fno-ident} %{--help:--help}\
802 %{--target-help:--target-help}\
803 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
804 %{fsyntax-only:-o %j} %{-param*}\
805 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}";
807 static const char *asm_options =
808 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
810 static const char *invoke_as =
811 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
812 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
813 #else
814 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
815 #endif
817 /* Some compilers have limits on line lengths, and the multilib_select
818 and/or multilib_matches strings can be very long, so we build them at
819 run time. */
820 static struct obstack multilib_obstack;
821 static const char *multilib_select;
822 static const char *multilib_matches;
823 static const char *multilib_defaults;
824 static const char *multilib_exclusions;
826 /* Check whether a particular argument is a default argument. */
828 #ifndef MULTILIB_DEFAULTS
829 #define MULTILIB_DEFAULTS { "" }
830 #endif
832 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
834 #ifndef DRIVER_SELF_SPECS
835 #define DRIVER_SELF_SPECS ""
836 #endif
838 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
840 #ifndef OPTION_DEFAULT_SPECS
841 #define OPTION_DEFAULT_SPECS { "", "" }
842 #endif
844 struct default_spec
846 const char *name;
847 const char *spec;
850 static const struct default_spec
851 option_default_specs[] = { OPTION_DEFAULT_SPECS };
853 struct user_specs
855 struct user_specs *next;
856 const char *filename;
859 static struct user_specs *user_specs_head, *user_specs_tail;
861 #ifndef SWITCH_TAKES_ARG
862 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
863 #endif
865 #ifndef WORD_SWITCH_TAKES_ARG
866 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
867 #endif
869 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
870 /* This defines which switches stop a full compilation. */
871 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
872 ((CHAR) == 'c' || (CHAR) == 'S')
874 #ifndef SWITCH_CURTAILS_COMPILATION
875 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
876 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
877 #endif
878 #endif
880 /* Record the mapping from file suffixes for compilation specs. */
882 struct compiler
884 const char *suffix; /* Use this compiler for input files
885 whose names end in this suffix. */
887 const char *spec; /* To use this compiler, run this spec. */
889 const char *cpp_spec; /* If non-NULL, substitute this spec
890 for `%C', rather than the usual
891 cpp_spec. */
892 const int combinable; /* If nonzero, compiler can deal with
893 multiple source files at once (IMA). */
894 const int needs_preprocessing; /* If nonzero, source files need to
895 be run through a preprocessor. */
898 /* Pointer to a vector of `struct compiler' that gives the spec for
899 compiling a file, based on its suffix.
900 A file that does not end in any of these suffixes will be passed
901 unchanged to the loader and nothing else will be done to it.
903 An entry containing two 0s is used to terminate the vector.
905 If multiple entries match a file, the last matching one is used. */
907 static struct compiler *compilers;
909 /* Number of entries in `compilers', not counting the null terminator. */
911 static int n_compilers;
913 /* The default list of file name suffixes and their compilation specs. */
915 static const struct compiler default_compilers[] =
917 /* Add lists of suffixes of known languages here. If those languages
918 were not present when we built the driver, we will hit these copies
919 and be given a more meaningful error than "file not used since
920 linking is not done". */
921 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
922 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
923 {".mii", "#Objective-C++", 0, 0, 0},
924 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
925 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
926 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
927 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
928 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
929 {".f", "#Fortran", 0, 0, 0}, {".for", "#Fortran", 0, 0, 0},
930 {".F", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
931 {".FPP", "#Fortran", 0, 0, 0},
932 {".f90", "#Fortran 95", 0, 0, 0}, {".f95", "#Fortran 95", 0, 0, 0},
933 {".fpp", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
934 {".FOR", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
935 {".r", "#Ratfor", 0, 0, 0},
936 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
937 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
938 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
939 /* Next come the entries for C. */
940 {".c", "@c", 0, 1, 1},
941 {"@c",
942 /* cc1 has an integrated ISO C preprocessor. We should invoke the
943 external preprocessor if -save-temps is given. */
944 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
945 %{!E:%{!M:%{!MM:\
946 %{traditional|ftraditional:\
947 %eGNU C no longer supports -traditional without -E}\
948 %{!combine:\
949 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
950 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
951 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
952 %(cc1_options)}\
953 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
954 cc1 %(cpp_unique_options) %(cc1_options)}}}\
955 %{!fsyntax-only:%(invoke_as)}} \
956 %{combine:\
957 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
958 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i}}\
959 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
960 cc1 %(cpp_unique_options) %(cc1_options)}}\
961 %{!fsyntax-only:%(invoke_as)}}}}}}", 0, 1, 1},
962 {"-",
963 "%{!E:%e-E required when input is from standard input}\
964 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
965 {".h", "@c-header", 0, 0, 0},
966 {"@c-header",
967 /* cc1 has an integrated ISO C preprocessor. We should invoke the
968 external preprocessor if -save-temps is given. */
969 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
970 %{!E:%{!M:%{!MM:\
971 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
972 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
973 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
974 %(cc1_options)\
975 -o %g.s %{!o*:--output-pch=%i.gch}\
976 %W{o*:--output-pch=%*}%V}\
977 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
978 cc1 %(cpp_unique_options) %(cc1_options)\
979 -o %g.s %{!o*:--output-pch=%i.gch}\
980 %W{o*:--output-pch=%*}%V}}}}}}", 0, 0, 0},
981 {".i", "@cpp-output", 0, 1, 0},
982 {"@cpp-output",
983 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
984 {".s", "@assembler", 0, 1, 0},
985 {"@assembler",
986 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
987 {".S", "@assembler-with-cpp", 0, 1, 0},
988 {"@assembler-with-cpp",
989 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
990 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
991 %{E|M|MM:%(cpp_debug_options)}\
992 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
993 as %(asm_debug) %(asm_options) %|.s %A }}}}"
994 #else
995 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
996 %{E|M|MM:%(cpp_debug_options)}\
997 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
998 as %(asm_debug) %(asm_options) %m.s %A }}}}"
999 #endif
1000 , 0, 1, 0},
1002 #include "specs.h"
1003 /* Mark end of table. */
1004 {0, 0, 0, 0, 0}
1007 /* Number of elements in default_compilers, not counting the terminator. */
1009 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1011 /* A vector of options to give to the linker.
1012 These options are accumulated by %x,
1013 and substituted into the linker command with %X. */
1014 static int n_linker_options;
1015 static char **linker_options;
1017 /* A vector of options to give to the assembler.
1018 These options are accumulated by -Wa,
1019 and substituted into the assembler command with %Y. */
1020 static int n_assembler_options;
1021 static char **assembler_options;
1023 /* A vector of options to give to the preprocessor.
1024 These options are accumulated by -Wp,
1025 and substituted into the preprocessor command with %Z. */
1026 static int n_preprocessor_options;
1027 static char **preprocessor_options;
1029 /* Define how to map long options into short ones. */
1031 /* This structure describes one mapping. */
1032 struct option_map
1034 /* The long option's name. */
1035 const char *const name;
1036 /* The equivalent short option. */
1037 const char *const equivalent;
1038 /* Argument info. A string of flag chars; NULL equals no options.
1039 a => argument required.
1040 o => argument optional.
1041 j => join argument to equivalent, making one word.
1042 * => require other text after NAME as an argument. */
1043 const char *const arg_info;
1046 /* This is the table of mappings. Mappings are tried sequentially
1047 for each option encountered; the first one that matches, wins. */
1049 static const struct option_map option_map[] =
1051 {"--all-warnings", "-Wall", 0},
1052 {"--ansi", "-ansi", 0},
1053 {"--assemble", "-S", 0},
1054 {"--assert", "-A", "a"},
1055 {"--classpath", "-fclasspath=", "aj"},
1056 {"--bootclasspath", "-fbootclasspath=", "aj"},
1057 {"--CLASSPATH", "-fclasspath=", "aj"},
1058 {"--combine", "-combine", 0},
1059 {"--comments", "-C", 0},
1060 {"--comments-in-macros", "-CC", 0},
1061 {"--compile", "-c", 0},
1062 {"--debug", "-g", "oj"},
1063 {"--define-macro", "-D", "aj"},
1064 {"--dependencies", "-M", 0},
1065 {"--dump", "-d", "a"},
1066 {"--dumpbase", "-dumpbase", "a"},
1067 {"--encoding", "-fencoding=", "aj"},
1068 {"--entry", "-e", 0},
1069 {"--extra-warnings", "-W", 0},
1070 {"--extdirs", "-fextdirs=", "aj"},
1071 {"--for-assembler", "-Wa", "a"},
1072 {"--for-linker", "-Xlinker", "a"},
1073 {"--force-link", "-u", "a"},
1074 {"--imacros", "-imacros", "a"},
1075 {"--include", "-include", "a"},
1076 {"--include-barrier", "-I-", 0},
1077 {"--include-directory", "-I", "aj"},
1078 {"--include-directory-after", "-idirafter", "a"},
1079 {"--include-prefix", "-iprefix", "a"},
1080 {"--include-with-prefix", "-iwithprefix", "a"},
1081 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1082 {"--include-with-prefix-after", "-iwithprefix", "a"},
1083 {"--language", "-x", "a"},
1084 {"--library-directory", "-L", "a"},
1085 {"--machine", "-m", "aj"},
1086 {"--machine-", "-m", "*j"},
1087 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1088 {"--no-line-commands", "-P", 0},
1089 {"--no-precompiled-includes", "-noprecomp", 0},
1090 {"--no-standard-includes", "-nostdinc", 0},
1091 {"--no-standard-libraries", "-nostdlib", 0},
1092 {"--no-warnings", "-w", 0},
1093 {"--optimize", "-O", "oj"},
1094 {"--output", "-o", "a"},
1095 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1096 {"--param", "--param", "a"},
1097 {"--pedantic", "-pedantic", 0},
1098 {"--pedantic-errors", "-pedantic-errors", 0},
1099 {"--pie", "-pie", 0},
1100 {"--pipe", "-pipe", 0},
1101 {"--prefix", "-B", "a"},
1102 {"--preprocess", "-E", 0},
1103 {"--print-search-dirs", "-print-search-dirs", 0},
1104 {"--print-file-name", "-print-file-name=", "aj"},
1105 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1106 {"--print-missing-file-dependencies", "-MG", 0},
1107 {"--print-multi-lib", "-print-multi-lib", 0},
1108 {"--print-multi-directory", "-print-multi-directory", 0},
1109 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1110 {"--print-prog-name", "-print-prog-name=", "aj"},
1111 {"--profile", "-p", 0},
1112 {"--profile-blocks", "-a", 0},
1113 {"--quiet", "-q", 0},
1114 {"--resource", "-fcompile-resource=", "aj"},
1115 {"--save-temps", "-save-temps", 0},
1116 {"--shared", "-shared", 0},
1117 {"--silent", "-q", 0},
1118 {"--specs", "-specs=", "aj"},
1119 {"--static", "-static", 0},
1120 {"--std", "-std=", "aj"},
1121 {"--symbolic", "-symbolic", 0},
1122 {"--time", "-time", 0},
1123 {"--trace-includes", "-H", 0},
1124 {"--traditional", "-traditional", 0},
1125 {"--traditional-cpp", "-traditional-cpp", 0},
1126 {"--trigraphs", "-trigraphs", 0},
1127 {"--undefine-macro", "-U", "aj"},
1128 {"--user-dependencies", "-MM", 0},
1129 {"--verbose", "-v", 0},
1130 {"--warn-", "-W", "*j"},
1131 {"--write-dependencies", "-MD", 0},
1132 {"--write-user-dependencies", "-MMD", 0},
1133 {"--", "-f", "*j"}
1137 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1138 static const struct {
1139 const char *const option_found;
1140 const char *const replacements;
1141 } target_option_translations[] =
1143 TARGET_OPTION_TRANSLATE_TABLE,
1144 { 0, 0 }
1146 #endif
1148 /* Translate the options described by *ARGCP and *ARGVP.
1149 Make a new vector and store it back in *ARGVP,
1150 and store its length in *ARGVC. */
1152 static void
1153 translate_options (int *argcp, const char *const **argvp)
1155 int i;
1156 int argc = *argcp;
1157 const char *const *argv = *argvp;
1158 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1159 const char **newv = xmalloc (newvsize);
1160 int newindex = 0;
1162 i = 0;
1163 newv[newindex++] = argv[i++];
1165 while (i < argc)
1167 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1168 int tott_idx;
1170 for (tott_idx = 0;
1171 target_option_translations[tott_idx].option_found;
1172 tott_idx++)
1174 if (strcmp (target_option_translations[tott_idx].option_found,
1175 argv[i]) == 0)
1177 int spaces = 1;
1178 const char *sp;
1179 char *np;
1181 for (sp = target_option_translations[tott_idx].replacements;
1182 *sp; sp++)
1184 if (*sp == ' ')
1185 spaces ++;
1188 newvsize += spaces * sizeof (const char *);
1189 newv = xrealloc (newv, newvsize);
1191 sp = target_option_translations[tott_idx].replacements;
1192 np = xstrdup (sp);
1194 while (1)
1196 while (*np == ' ')
1197 np++;
1198 if (*np == 0)
1199 break;
1200 newv[newindex++] = np;
1201 while (*np != ' ' && *np)
1202 np++;
1203 if (*np == 0)
1204 break;
1205 *np++ = 0;
1208 i ++;
1209 break;
1212 if (target_option_translations[tott_idx].option_found)
1213 continue;
1214 #endif
1216 /* Translate -- options. */
1217 if (argv[i][0] == '-' && argv[i][1] == '-')
1219 size_t j;
1220 /* Find a mapping that applies to this option. */
1221 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1223 size_t optlen = strlen (option_map[j].name);
1224 size_t arglen = strlen (argv[i]);
1225 size_t complen = arglen > optlen ? optlen : arglen;
1226 const char *arginfo = option_map[j].arg_info;
1228 if (arginfo == 0)
1229 arginfo = "";
1231 if (!strncmp (argv[i], option_map[j].name, complen))
1233 const char *arg = 0;
1235 if (arglen < optlen)
1237 size_t k;
1238 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1239 if (strlen (option_map[k].name) >= arglen
1240 && !strncmp (argv[i], option_map[k].name, arglen))
1242 error ("ambiguous abbreviation %s", argv[i]);
1243 break;
1246 if (k != ARRAY_SIZE (option_map))
1247 break;
1250 if (arglen > optlen)
1252 /* If the option has an argument, accept that. */
1253 if (argv[i][optlen] == '=')
1254 arg = argv[i] + optlen + 1;
1256 /* If this mapping requires extra text at end of name,
1257 accept that as "argument". */
1258 else if (strchr (arginfo, '*') != 0)
1259 arg = argv[i] + optlen;
1261 /* Otherwise, extra text at end means mismatch.
1262 Try other mappings. */
1263 else
1264 continue;
1267 else if (strchr (arginfo, '*') != 0)
1269 error ("incomplete '%s' option", option_map[j].name);
1270 break;
1273 /* Handle arguments. */
1274 if (strchr (arginfo, 'a') != 0)
1276 if (arg == 0)
1278 if (i + 1 == argc)
1280 error ("missing argument to '%s' option",
1281 option_map[j].name);
1282 break;
1285 arg = argv[++i];
1288 else if (strchr (arginfo, '*') != 0)
1290 else if (strchr (arginfo, 'o') == 0)
1292 if (arg != 0)
1293 error ("extraneous argument to '%s' option",
1294 option_map[j].name);
1295 arg = 0;
1298 /* Store the translation as one argv elt or as two. */
1299 if (arg != 0 && strchr (arginfo, 'j') != 0)
1300 newv[newindex++] = concat (option_map[j].equivalent, arg,
1301 NULL);
1302 else if (arg != 0)
1304 newv[newindex++] = option_map[j].equivalent;
1305 newv[newindex++] = arg;
1307 else
1308 newv[newindex++] = option_map[j].equivalent;
1310 break;
1313 i++;
1316 /* Handle old-fashioned options--just copy them through,
1317 with their arguments. */
1318 else if (argv[i][0] == '-')
1320 const char *p = argv[i] + 1;
1321 int c = *p;
1322 int nskip = 1;
1324 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1325 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1326 else if (WORD_SWITCH_TAKES_ARG (p))
1327 nskip += WORD_SWITCH_TAKES_ARG (p);
1328 else if ((c == 'B' || c == 'b' || c == 'x')
1329 && p[1] == 0)
1330 nskip += 1;
1331 else if (! strcmp (p, "Xlinker"))
1332 nskip += 1;
1333 else if (! strcmp (p, "Xpreprocessor"))
1334 nskip += 1;
1335 else if (! strcmp (p, "Xassembler"))
1336 nskip += 1;
1338 /* Watch out for an option at the end of the command line that
1339 is missing arguments, and avoid skipping past the end of the
1340 command line. */
1341 if (nskip + i > argc)
1342 nskip = argc - i;
1344 while (nskip > 0)
1346 newv[newindex++] = argv[i++];
1347 nskip--;
1350 else
1351 /* Ordinary operands, or +e options. */
1352 newv[newindex++] = argv[i++];
1355 newv[newindex] = 0;
1357 *argvp = newv;
1358 *argcp = newindex;
1361 static char *
1362 skip_whitespace (char *p)
1364 while (1)
1366 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1367 be considered whitespace. */
1368 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1369 return p + 1;
1370 else if (*p == '\n' || *p == ' ' || *p == '\t')
1371 p++;
1372 else if (*p == '#')
1374 while (*p != '\n')
1375 p++;
1376 p++;
1378 else
1379 break;
1382 return p;
1384 /* Structures to keep track of prefixes to try when looking for files. */
1386 struct prefix_list
1388 const char *prefix; /* String to prepend to the path. */
1389 struct prefix_list *next; /* Next in linked list. */
1390 int require_machine_suffix; /* Don't use without machine_suffix. */
1391 /* 2 means try both machine_suffix and just_machine_suffix. */
1392 int priority; /* Sort key - priority within list. */
1393 int os_multilib; /* 1 if OS multilib scheme should be used,
1394 0 for GCC multilib scheme. */
1397 struct path_prefix
1399 struct prefix_list *plist; /* List of prefixes to try */
1400 int max_len; /* Max length of a prefix in PLIST */
1401 const char *name; /* Name of this list (used in config stuff) */
1404 /* List of prefixes to try when looking for executables. */
1406 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1408 /* List of prefixes to try when looking for startup (crt0) files. */
1410 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1412 /* List of prefixes to try when looking for include files. */
1414 static struct path_prefix include_prefixes = { 0, 0, "include" };
1416 /* Suffix to attach to directories searched for commands.
1417 This looks like `MACHINE/VERSION/'. */
1419 static const char *machine_suffix = 0;
1421 /* Suffix to attach to directories searched for commands.
1422 This is just `MACHINE/'. */
1424 static const char *just_machine_suffix = 0;
1426 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1428 static const char *gcc_exec_prefix;
1430 /* Adjusted value of standard_libexec_prefix. */
1432 static const char *gcc_libexec_prefix;
1434 /* Default prefixes to attach to command names. */
1436 #ifndef STANDARD_STARTFILE_PREFIX_1
1437 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1438 #endif
1439 #ifndef STANDARD_STARTFILE_PREFIX_2
1440 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1441 #endif
1443 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1444 #undef MD_EXEC_PREFIX
1445 #undef MD_STARTFILE_PREFIX
1446 #undef MD_STARTFILE_PREFIX_1
1447 #endif
1449 /* If no prefixes defined, use the null string, which will disable them. */
1450 #ifndef MD_EXEC_PREFIX
1451 #define MD_EXEC_PREFIX ""
1452 #endif
1453 #ifndef MD_STARTFILE_PREFIX
1454 #define MD_STARTFILE_PREFIX ""
1455 #endif
1456 #ifndef MD_STARTFILE_PREFIX_1
1457 #define MD_STARTFILE_PREFIX_1 ""
1458 #endif
1460 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1461 static const char *const standard_exec_prefix_1 = "/usr/libexec/gcc/";
1462 static const char *const standard_exec_prefix_2 = "/usr/lib/gcc/";
1463 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1465 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1466 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1467 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1468 static const char *const standard_startfile_prefix_1
1469 = STANDARD_STARTFILE_PREFIX_1;
1470 static const char *const standard_startfile_prefix_2
1471 = STANDARD_STARTFILE_PREFIX_2;
1473 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1474 static const char *tooldir_prefix;
1476 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1478 static const char *standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1480 /* Subdirectory to use for locating libraries. Set by
1481 set_multilib_dir based on the compilation options. */
1483 static const char *multilib_dir;
1485 /* Subdirectory to use for locating libraries in OS conventions. Set by
1486 set_multilib_dir based on the compilation options. */
1488 static const char *multilib_os_dir;
1490 /* Structure to keep track of the specs that have been defined so far.
1491 These are accessed using %(specname) or %[specname] in a compiler
1492 or link spec. */
1494 struct spec_list
1496 /* The following 2 fields must be first */
1497 /* to allow EXTRA_SPECS to be initialized */
1498 const char *name; /* name of the spec. */
1499 const char *ptr; /* available ptr if no static pointer */
1501 /* The following fields are not initialized */
1502 /* by EXTRA_SPECS */
1503 const char **ptr_spec; /* pointer to the spec itself. */
1504 struct spec_list *next; /* Next spec in linked list. */
1505 int name_len; /* length of the name */
1506 int alloc_p; /* whether string was allocated */
1509 #define INIT_STATIC_SPEC(NAME,PTR) \
1510 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1512 /* List of statically defined specs. */
1513 static struct spec_list static_specs[] =
1515 INIT_STATIC_SPEC ("asm", &asm_spec),
1516 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1517 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1518 INIT_STATIC_SPEC ("asm_options", &asm_options),
1519 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1520 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1521 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1522 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1523 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1524 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1525 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1526 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1527 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1528 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1529 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1530 INIT_STATIC_SPEC ("link", &link_spec),
1531 INIT_STATIC_SPEC ("lib", &lib_spec),
1532 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1533 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1534 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1535 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1536 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1537 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1538 INIT_STATIC_SPEC ("version", &compiler_version),
1539 INIT_STATIC_SPEC ("multilib", &multilib_select),
1540 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1541 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1542 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1543 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1544 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1545 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1546 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1547 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1548 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1549 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1550 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1551 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1552 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1555 #ifdef EXTRA_SPECS /* additional specs needed */
1556 /* Structure to keep track of just the first two args of a spec_list.
1557 That is all that the EXTRA_SPECS macro gives us. */
1558 struct spec_list_1
1560 const char *const name;
1561 const char *const ptr;
1564 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1565 static struct spec_list *extra_specs = (struct spec_list *) 0;
1566 #endif
1568 /* List of dynamically allocates specs that have been defined so far. */
1570 static struct spec_list *specs = (struct spec_list *) 0;
1572 /* List of static spec functions. */
1574 static const struct spec_function static_spec_functions[] =
1576 { "if-exists", if_exists_spec_function },
1577 { "if-exists-else", if_exists_else_spec_function },
1578 { "replace-outfile", replace_outfile_spec_function },
1579 { 0, 0 }
1582 static int processing_spec_function;
1584 /* Add appropriate libgcc specs to OBSTACK, taking into account
1585 various permutations of -shared-libgcc, -shared, and such. */
1587 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1589 #ifndef USE_LD_AS_NEEDED
1590 #define USE_LD_AS_NEEDED 0
1591 #endif
1593 static void
1594 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1595 const char *static_name, const char *eh_name)
1597 char *buf;
1599 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1600 "}%{!static:%{!static-libgcc:",
1601 #if USE_LD_AS_NEEDED
1602 "%{!shared-libgcc:", static_name,
1603 " --as-needed ", shared_name, " --no-as-needed}"
1604 "%{shared-libgcc:", shared_name, "%{!shared: ", static_name,
1605 "}",
1606 #else
1607 "%{!shared:%{!shared-libgcc:", static_name, " ",
1608 eh_name, "}%{shared-libgcc:", shared_name, " ",
1609 static_name, "}}%{shared:",
1610 #ifdef LINK_EH_SPEC
1611 "%{shared-libgcc:", shared_name,
1612 "}%{!shared-libgcc:", static_name, "}",
1613 #else
1614 shared_name,
1615 #endif
1616 #endif
1617 "}}}", NULL);
1619 obstack_grow (obstack, buf, strlen (buf));
1620 free (buf);
1622 #endif /* ENABLE_SHARED_LIBGCC */
1624 /* Initialize the specs lookup routines. */
1626 static void
1627 init_spec (void)
1629 struct spec_list *next = (struct spec_list *) 0;
1630 struct spec_list *sl = (struct spec_list *) 0;
1631 int i;
1633 if (specs)
1634 return; /* Already initialized. */
1636 if (verbose_flag)
1637 notice ("Using built-in specs.\n");
1639 #ifdef EXTRA_SPECS
1640 extra_specs = xcalloc (sizeof (struct spec_list),
1641 ARRAY_SIZE (extra_specs_1));
1643 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1645 sl = &extra_specs[i];
1646 sl->name = extra_specs_1[i].name;
1647 sl->ptr = extra_specs_1[i].ptr;
1648 sl->next = next;
1649 sl->name_len = strlen (sl->name);
1650 sl->ptr_spec = &sl->ptr;
1651 next = sl;
1653 #endif
1655 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1656 on ?: in file-scope variable initializations. */
1657 asm_debug = ASM_DEBUG_SPEC;
1659 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1661 sl = &static_specs[i];
1662 sl->next = next;
1663 next = sl;
1666 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1667 /* ??? If neither -shared-libgcc nor --static-libgcc was
1668 seen, then we should be making an educated guess. Some proposed
1669 heuristics for ELF include:
1671 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1672 program will be doing dynamic loading, which will likely
1673 need the shared libgcc.
1675 (2) If "-ldl", then it's also a fair bet that we're doing
1676 dynamic loading.
1678 (3) For each ET_DYN we're linking against (either through -lfoo
1679 or /some/path/foo.so), check to see whether it or one of
1680 its dependencies depends on a shared libgcc.
1682 (4) If "-shared"
1684 If the runtime is fixed to look for program headers instead
1685 of calling __register_frame_info at all, for each object,
1686 use the shared libgcc if any EH symbol referenced.
1688 If crtstuff is fixed to not invoke __register_frame_info
1689 automatically, for each object, use the shared libgcc if
1690 any non-empty unwind section found.
1692 Doing any of this probably requires invoking an external program to
1693 do the actual object file scanning. */
1695 const char *p = libgcc_spec;
1696 int in_sep = 1;
1698 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1699 when given the proper command line arguments. */
1700 while (*p)
1702 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1704 init_gcc_specs (&obstack,
1705 #ifdef NO_SHARED_LIBGCC_MULTILIB
1706 "-lgcc_s"
1707 #else
1708 "-lgcc_s%M"
1709 #endif
1710 #ifdef USE_LIBUNWIND_EXCEPTIONS
1711 " -lunwind"
1712 #endif
1714 "-lgcc",
1715 "-lgcc_eh"
1716 #ifdef USE_LIBUNWIND_EXCEPTIONS
1717 " -lunwind"
1718 #endif
1721 p += 5;
1722 in_sep = 0;
1724 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1726 /* Ug. We don't know shared library extensions. Hope that
1727 systems that use this form don't do shared libraries. */
1728 init_gcc_specs (&obstack,
1729 #ifdef NO_SHARED_LIBGCC_MULTILIB
1730 "-lgcc_s"
1731 #else
1732 "-lgcc_s%M"
1733 #endif
1735 "libgcc.a%s",
1736 "libgcc_eh.a%s"
1737 #ifdef USE_LIBUNWIND_EXCEPTIONS
1738 " -lunwind"
1739 #endif
1741 p += 10;
1742 in_sep = 0;
1744 else
1746 obstack_1grow (&obstack, *p);
1747 in_sep = (*p == ' ');
1748 p += 1;
1752 obstack_1grow (&obstack, '\0');
1753 libgcc_spec = obstack_finish (&obstack);
1755 #endif
1756 #ifdef USE_AS_TRADITIONAL_FORMAT
1757 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1759 static const char tf[] = "--traditional-format ";
1760 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1761 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1762 asm_spec = obstack_finish (&obstack);
1764 #endif
1765 #ifdef LINK_EH_SPEC
1766 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1767 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1768 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1769 link_spec = obstack_finish (&obstack);
1770 #endif
1772 specs = sl;
1775 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1776 removed; If the spec starts with a + then SPEC is added to the end of the
1777 current spec. */
1779 static void
1780 set_spec (const char *name, const char *spec)
1782 struct spec_list *sl;
1783 const char *old_spec;
1784 int name_len = strlen (name);
1785 int i;
1787 /* If this is the first call, initialize the statically allocated specs. */
1788 if (!specs)
1790 struct spec_list *next = (struct spec_list *) 0;
1791 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1793 sl = &static_specs[i];
1794 sl->next = next;
1795 next = sl;
1797 specs = sl;
1800 /* See if the spec already exists. */
1801 for (sl = specs; sl; sl = sl->next)
1802 if (name_len == sl->name_len && !strcmp (sl->name, name))
1803 break;
1805 if (!sl)
1807 /* Not found - make it. */
1808 sl = xmalloc (sizeof (struct spec_list));
1809 sl->name = xstrdup (name);
1810 sl->name_len = name_len;
1811 sl->ptr_spec = &sl->ptr;
1812 sl->alloc_p = 0;
1813 *(sl->ptr_spec) = "";
1814 sl->next = specs;
1815 specs = sl;
1818 old_spec = *(sl->ptr_spec);
1819 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1820 ? concat (old_spec, spec + 1, NULL)
1821 : xstrdup (spec));
1823 #ifdef DEBUG_SPECS
1824 if (verbose_flag)
1825 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1826 #endif
1828 /* Free the old spec. */
1829 if (old_spec && sl->alloc_p)
1830 free ((void *) old_spec);
1832 sl->alloc_p = 1;
1835 /* Accumulate a command (program name and args), and run it. */
1837 /* Vector of pointers to arguments in the current line of specifications. */
1839 static const char **argbuf;
1841 /* Number of elements allocated in argbuf. */
1843 static int argbuf_length;
1845 /* Number of elements in argbuf currently in use (containing args). */
1847 static int argbuf_index;
1849 /* Position in the argbuf array containing the name of the output file
1850 (the value associated with the "-o" flag). */
1852 static int have_o_argbuf_index = 0;
1854 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1855 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1856 it here. */
1858 static struct temp_name {
1859 const char *suffix; /* suffix associated with the code. */
1860 int length; /* strlen (suffix). */
1861 int unique; /* Indicates whether %g or %u/%U was used. */
1862 const char *filename; /* associated filename. */
1863 int filename_length; /* strlen (filename). */
1864 struct temp_name *next;
1865 } *temp_names;
1867 /* Number of commands executed so far. */
1869 static int execution_count;
1871 /* Number of commands that exited with a signal. */
1873 static int signal_count;
1875 /* Name with which this program was invoked. */
1877 static const char *programname;
1879 /* Allocate the argument vector. */
1881 static void
1882 alloc_args (void)
1884 argbuf_length = 10;
1885 argbuf = xmalloc (argbuf_length * sizeof (const char *));
1888 /* Clear out the vector of arguments (after a command is executed). */
1890 static void
1891 clear_args (void)
1893 argbuf_index = 0;
1896 /* Add one argument to the vector at the end.
1897 This is done when a space is seen or at the end of the line.
1898 If DELETE_ALWAYS is nonzero, the arg is a filename
1899 and the file should be deleted eventually.
1900 If DELETE_FAILURE is nonzero, the arg is a filename
1901 and the file should be deleted if this compilation fails. */
1903 static void
1904 store_arg (const char *arg, int delete_always, int delete_failure)
1906 if (argbuf_index + 1 == argbuf_length)
1907 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1909 argbuf[argbuf_index++] = arg;
1910 argbuf[argbuf_index] = 0;
1912 if (strcmp (arg, "-o") == 0)
1913 have_o_argbuf_index = argbuf_index;
1914 if (delete_always || delete_failure)
1915 record_temp_file (arg, delete_always, delete_failure);
1918 /* Load specs from a file name named FILENAME, replacing occurrences of
1919 various different types of line-endings, \r\n, \n\r and just \r, with
1920 a single \n. */
1922 static char *
1923 load_specs (const char *filename)
1925 int desc;
1926 int readlen;
1927 struct stat statbuf;
1928 char *buffer;
1929 char *buffer_p;
1930 char *specs;
1931 char *specs_p;
1933 if (verbose_flag)
1934 notice ("Reading specs from %s\n", filename);
1936 /* Open and stat the file. */
1937 desc = open (filename, O_RDONLY, 0);
1938 if (desc < 0)
1939 pfatal_with_name (filename);
1940 if (stat (filename, &statbuf) < 0)
1941 pfatal_with_name (filename);
1943 /* Read contents of file into BUFFER. */
1944 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1945 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1946 if (readlen < 0)
1947 pfatal_with_name (filename);
1948 buffer[readlen] = 0;
1949 close (desc);
1951 specs = xmalloc (readlen + 1);
1952 specs_p = specs;
1953 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1955 int skip = 0;
1956 char c = *buffer_p;
1957 if (c == '\r')
1959 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1960 skip = 1;
1961 else if (*(buffer_p + 1) == '\n') /* \r\n */
1962 skip = 1;
1963 else /* \r */
1964 c = '\n';
1966 if (! skip)
1967 *specs_p++ = c;
1969 *specs_p = '\0';
1971 free (buffer);
1972 return (specs);
1975 /* Read compilation specs from a file named FILENAME,
1976 replacing the default ones.
1978 A suffix which starts with `*' is a definition for
1979 one of the machine-specific sub-specs. The "suffix" should be
1980 *asm, *cc1, *cpp, *link, *startfile, etc.
1981 The corresponding spec is stored in asm_spec, etc.,
1982 rather than in the `compilers' vector.
1984 Anything invalid in the file is a fatal error. */
1986 static void
1987 read_specs (const char *filename, int main_p)
1989 char *buffer;
1990 char *p;
1992 buffer = load_specs (filename);
1994 /* Scan BUFFER for specs, putting them in the vector. */
1995 p = buffer;
1996 while (1)
1998 char *suffix;
1999 char *spec;
2000 char *in, *out, *p1, *p2, *p3;
2002 /* Advance P in BUFFER to the next nonblank nocomment line. */
2003 p = skip_whitespace (p);
2004 if (*p == 0)
2005 break;
2007 /* Is this a special command that starts with '%'? */
2008 /* Don't allow this for the main specs file, since it would
2009 encourage people to overwrite it. */
2010 if (*p == '%' && !main_p)
2012 p1 = p;
2013 while (*p && *p != '\n')
2014 p++;
2016 /* Skip '\n'. */
2017 p++;
2019 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2020 && (p1[sizeof "%include" - 1] == ' '
2021 || p1[sizeof "%include" - 1] == '\t'))
2023 char *new_filename;
2025 p1 += sizeof ("%include");
2026 while (*p1 == ' ' || *p1 == '\t')
2027 p1++;
2029 if (*p1++ != '<' || p[-2] != '>')
2030 fatal ("specs %%include syntax malformed after %ld characters",
2031 (long) (p1 - buffer + 1));
2033 p[-2] = '\0';
2034 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2035 read_specs (new_filename ? new_filename : p1, FALSE);
2036 continue;
2038 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2039 && (p1[sizeof "%include_noerr" - 1] == ' '
2040 || p1[sizeof "%include_noerr" - 1] == '\t'))
2042 char *new_filename;
2044 p1 += sizeof "%include_noerr";
2045 while (*p1 == ' ' || *p1 == '\t')
2046 p1++;
2048 if (*p1++ != '<' || p[-2] != '>')
2049 fatal ("specs %%include syntax malformed after %ld characters",
2050 (long) (p1 - buffer + 1));
2052 p[-2] = '\0';
2053 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2054 if (new_filename)
2055 read_specs (new_filename, FALSE);
2056 else if (verbose_flag)
2057 notice ("could not find specs file %s\n", p1);
2058 continue;
2060 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2061 && (p1[sizeof "%rename" - 1] == ' '
2062 || p1[sizeof "%rename" - 1] == '\t'))
2064 int name_len;
2065 struct spec_list *sl;
2066 struct spec_list *newsl;
2068 /* Get original name. */
2069 p1 += sizeof "%rename";
2070 while (*p1 == ' ' || *p1 == '\t')
2071 p1++;
2073 if (! ISALPHA ((unsigned char) *p1))
2074 fatal ("specs %%rename syntax malformed after %ld characters",
2075 (long) (p1 - buffer));
2077 p2 = p1;
2078 while (*p2 && !ISSPACE ((unsigned char) *p2))
2079 p2++;
2081 if (*p2 != ' ' && *p2 != '\t')
2082 fatal ("specs %%rename syntax malformed after %ld characters",
2083 (long) (p2 - buffer));
2085 name_len = p2 - p1;
2086 *p2++ = '\0';
2087 while (*p2 == ' ' || *p2 == '\t')
2088 p2++;
2090 if (! ISALPHA ((unsigned char) *p2))
2091 fatal ("specs %%rename syntax malformed after %ld characters",
2092 (long) (p2 - buffer));
2094 /* Get new spec name. */
2095 p3 = p2;
2096 while (*p3 && !ISSPACE ((unsigned char) *p3))
2097 p3++;
2099 if (p3 != p - 1)
2100 fatal ("specs %%rename syntax malformed after %ld characters",
2101 (long) (p3 - buffer));
2102 *p3 = '\0';
2104 for (sl = specs; sl; sl = sl->next)
2105 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2106 break;
2108 if (!sl)
2109 fatal ("specs %s spec was not found to be renamed", p1);
2111 if (strcmp (p1, p2) == 0)
2112 continue;
2114 for (newsl = specs; newsl; newsl = newsl->next)
2115 if (strcmp (newsl->name, p2) == 0)
2116 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2117 filename, p1, p2);
2119 if (verbose_flag)
2121 notice ("rename spec %s to %s\n", p1, p2);
2122 #ifdef DEBUG_SPECS
2123 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2124 #endif
2127 set_spec (p2, *(sl->ptr_spec));
2128 if (sl->alloc_p)
2129 free ((void *) *(sl->ptr_spec));
2131 *(sl->ptr_spec) = "";
2132 sl->alloc_p = 0;
2133 continue;
2135 else
2136 fatal ("specs unknown %% command after %ld characters",
2137 (long) (p1 - buffer));
2140 /* Find the colon that should end the suffix. */
2141 p1 = p;
2142 while (*p1 && *p1 != ':' && *p1 != '\n')
2143 p1++;
2145 /* The colon shouldn't be missing. */
2146 if (*p1 != ':')
2147 fatal ("specs file malformed after %ld characters",
2148 (long) (p1 - buffer));
2150 /* Skip back over trailing whitespace. */
2151 p2 = p1;
2152 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2153 p2--;
2155 /* Copy the suffix to a string. */
2156 suffix = save_string (p, p2 - p);
2157 /* Find the next line. */
2158 p = skip_whitespace (p1 + 1);
2159 if (p[1] == 0)
2160 fatal ("specs file malformed after %ld characters",
2161 (long) (p - buffer));
2163 p1 = p;
2164 /* Find next blank line or end of string. */
2165 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2166 p1++;
2168 /* Specs end at the blank line and do not include the newline. */
2169 spec = save_string (p, p1 - p);
2170 p = p1;
2172 /* Delete backslash-newline sequences from the spec. */
2173 in = spec;
2174 out = spec;
2175 while (*in != 0)
2177 if (in[0] == '\\' && in[1] == '\n')
2178 in += 2;
2179 else if (in[0] == '#')
2180 while (*in && *in != '\n')
2181 in++;
2183 else
2184 *out++ = *in++;
2186 *out = 0;
2188 if (suffix[0] == '*')
2190 if (! strcmp (suffix, "*link_command"))
2191 link_command_spec = spec;
2192 else
2193 set_spec (suffix + 1, spec);
2195 else
2197 /* Add this pair to the vector. */
2198 compilers
2199 = xrealloc (compilers,
2200 (n_compilers + 2) * sizeof (struct compiler));
2202 compilers[n_compilers].suffix = suffix;
2203 compilers[n_compilers].spec = spec;
2204 n_compilers++;
2205 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2208 if (*suffix == 0)
2209 link_command_spec = spec;
2212 if (link_command_spec == 0)
2213 fatal ("spec file has no spec for linking");
2216 /* Record the names of temporary files we tell compilers to write,
2217 and delete them at the end of the run. */
2219 /* This is the common prefix we use to make temp file names.
2220 It is chosen once for each run of this program.
2221 It is substituted into a spec by %g or %j.
2222 Thus, all temp file names contain this prefix.
2223 In practice, all temp file names start with this prefix.
2225 This prefix comes from the envvar TMPDIR if it is defined;
2226 otherwise, from the P_tmpdir macro if that is defined;
2227 otherwise, in /usr/tmp or /tmp;
2228 or finally the current directory if all else fails. */
2230 static const char *temp_filename;
2232 /* Length of the prefix. */
2234 static int temp_filename_length;
2236 /* Define the list of temporary files to delete. */
2238 struct temp_file
2240 const char *name;
2241 struct temp_file *next;
2244 /* Queue of files to delete on success or failure of compilation. */
2245 static struct temp_file *always_delete_queue;
2246 /* Queue of files to delete on failure of compilation. */
2247 static struct temp_file *failure_delete_queue;
2249 /* Record FILENAME as a file to be deleted automatically.
2250 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2251 otherwise delete it in any case.
2252 FAIL_DELETE nonzero means delete it if a compilation step fails;
2253 otherwise delete it in any case. */
2255 void
2256 record_temp_file (const char *filename, int always_delete, int fail_delete)
2258 char *const name = xstrdup (filename);
2260 if (always_delete)
2262 struct temp_file *temp;
2263 for (temp = always_delete_queue; temp; temp = temp->next)
2264 if (! strcmp (name, temp->name))
2265 goto already1;
2267 temp = xmalloc (sizeof (struct temp_file));
2268 temp->next = always_delete_queue;
2269 temp->name = name;
2270 always_delete_queue = temp;
2272 already1:;
2275 if (fail_delete)
2277 struct temp_file *temp;
2278 for (temp = failure_delete_queue; temp; temp = temp->next)
2279 if (! strcmp (name, temp->name))
2280 goto already2;
2282 temp = xmalloc (sizeof (struct temp_file));
2283 temp->next = failure_delete_queue;
2284 temp->name = name;
2285 failure_delete_queue = temp;
2287 already2:;
2291 /* Delete all the temporary files whose names we previously recorded. */
2293 #ifndef DELETE_IF_ORDINARY
2294 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2295 do \
2297 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2298 if (unlink (NAME) < 0) \
2299 if (VERBOSE_FLAG) \
2300 perror_with_name (NAME); \
2301 } while (0)
2302 #endif
2304 static void
2305 delete_if_ordinary (const char *name)
2307 struct stat st;
2308 #ifdef DEBUG
2309 int i, c;
2311 printf ("Delete %s? (y or n) ", name);
2312 fflush (stdout);
2313 i = getchar ();
2314 if (i != '\n')
2315 while ((c = getchar ()) != '\n' && c != EOF)
2318 if (i == 'y' || i == 'Y')
2319 #endif /* DEBUG */
2320 DELETE_IF_ORDINARY (name, st, verbose_flag);
2323 static void
2324 delete_temp_files (void)
2326 struct temp_file *temp;
2328 for (temp = always_delete_queue; temp; temp = temp->next)
2329 delete_if_ordinary (temp->name);
2330 always_delete_queue = 0;
2333 /* Delete all the files to be deleted on error. */
2335 static void
2336 delete_failure_queue (void)
2338 struct temp_file *temp;
2340 for (temp = failure_delete_queue; temp; temp = temp->next)
2341 delete_if_ordinary (temp->name);
2344 static void
2345 clear_failure_queue (void)
2347 failure_delete_queue = 0;
2350 /* Build a list of search directories from PATHS.
2351 PREFIX is a string to prepend to the list.
2352 If CHECK_DIR_P is nonzero we ensure the directory exists.
2353 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2354 It is also used by the --print-search-dirs flag. */
2356 static char *
2357 build_search_list (struct path_prefix *paths, const char *prefix,
2358 int check_dir_p)
2360 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2361 int just_suffix_len
2362 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2363 int first_time = TRUE;
2364 struct prefix_list *pprefix;
2366 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2367 obstack_1grow (&collect_obstack, '=');
2369 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2371 int len = strlen (pprefix->prefix);
2373 if (machine_suffix
2374 && (! check_dir_p
2375 || is_directory (pprefix->prefix, machine_suffix, 0)))
2377 if (!first_time)
2378 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2380 first_time = FALSE;
2381 obstack_grow (&collect_obstack, pprefix->prefix, len);
2382 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2385 if (just_machine_suffix
2386 && pprefix->require_machine_suffix == 2
2387 && (! check_dir_p
2388 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2390 if (! first_time)
2391 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2393 first_time = FALSE;
2394 obstack_grow (&collect_obstack, pprefix->prefix, len);
2395 obstack_grow (&collect_obstack, just_machine_suffix,
2396 just_suffix_len);
2399 if (! pprefix->require_machine_suffix)
2401 if (! first_time)
2402 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2404 first_time = FALSE;
2405 obstack_grow (&collect_obstack, pprefix->prefix, len);
2409 obstack_1grow (&collect_obstack, '\0');
2410 return obstack_finish (&collect_obstack);
2413 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2414 for collect. */
2416 static void
2417 putenv_from_prefixes (struct path_prefix *paths, const char *env_var)
2419 putenv (build_search_list (paths, env_var, 1));
2422 /* Check whether NAME can be accessed in MODE. This is like access,
2423 except that it never considers directories to be executable. */
2425 static int
2426 access_check (const char *name, int mode)
2428 if (mode == X_OK)
2430 struct stat st;
2432 if (stat (name, &st) < 0
2433 || S_ISDIR (st.st_mode))
2434 return -1;
2437 return access (name, mode);
2440 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2441 access to check permissions.
2442 Return 0 if not found, otherwise return its name, allocated with malloc. */
2444 static char *
2445 find_a_file (struct path_prefix *pprefix, const char *name, int mode,
2446 int multilib)
2448 char *temp;
2449 const char *const file_suffix =
2450 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2451 struct prefix_list *pl;
2452 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2453 const char *multilib_name, *multilib_os_name;
2455 #ifdef DEFAULT_ASSEMBLER
2456 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2457 return xstrdup (DEFAULT_ASSEMBLER);
2458 #endif
2460 #ifdef DEFAULT_LINKER
2461 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2462 return xstrdup (DEFAULT_LINKER);
2463 #endif
2465 if (machine_suffix)
2466 len += strlen (machine_suffix);
2468 multilib_name = name;
2469 multilib_os_name = name;
2470 if (multilib && multilib_os_dir)
2472 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2473 int len2 = strlen (multilib_os_dir) + 1;
2475 len += len1 > len2 ? len1 : len2;
2476 if (multilib_dir)
2477 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2478 NULL));
2479 if (strcmp (multilib_os_dir, ".") != 0)
2480 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2481 NULL));
2484 temp = xmalloc (len);
2486 /* Determine the filename to execute (special case for absolute paths). */
2488 if (IS_ABSOLUTE_PATH (name))
2490 if (access (name, mode) == 0)
2492 strcpy (temp, name);
2493 return temp;
2496 else
2497 for (pl = pprefix->plist; pl; pl = pl->next)
2499 const char *this_name
2500 = pl->os_multilib ? multilib_os_name : multilib_name;
2502 if (machine_suffix)
2504 /* Some systems have a suffix for executable files.
2505 So try appending that first. */
2506 if (file_suffix[0] != 0)
2508 strcpy (temp, pl->prefix);
2509 strcat (temp, machine_suffix);
2510 strcat (temp, multilib_name);
2511 strcat (temp, file_suffix);
2512 if (access_check (temp, mode) == 0)
2513 return temp;
2516 /* Now try just the multilib_name. */
2517 strcpy (temp, pl->prefix);
2518 strcat (temp, machine_suffix);
2519 strcat (temp, multilib_name);
2520 if (access_check (temp, mode) == 0)
2521 return temp;
2524 /* Certain prefixes are tried with just the machine type,
2525 not the version. This is used for finding as, ld, etc. */
2526 if (just_machine_suffix && pl->require_machine_suffix == 2)
2528 /* Some systems have a suffix for executable files.
2529 So try appending that first. */
2530 if (file_suffix[0] != 0)
2532 strcpy (temp, pl->prefix);
2533 strcat (temp, just_machine_suffix);
2534 strcat (temp, multilib_name);
2535 strcat (temp, file_suffix);
2536 if (access_check (temp, mode) == 0)
2537 return temp;
2540 strcpy (temp, pl->prefix);
2541 strcat (temp, just_machine_suffix);
2542 strcat (temp, multilib_name);
2543 if (access_check (temp, mode) == 0)
2544 return temp;
2547 /* Certain prefixes can't be used without the machine suffix
2548 when the machine or version is explicitly specified. */
2549 if (! pl->require_machine_suffix)
2551 /* Some systems have a suffix for executable files.
2552 So try appending that first. */
2553 if (file_suffix[0] != 0)
2555 strcpy (temp, pl->prefix);
2556 strcat (temp, this_name);
2557 strcat (temp, file_suffix);
2558 if (access_check (temp, mode) == 0)
2559 return temp;
2562 strcpy (temp, pl->prefix);
2563 strcat (temp, this_name);
2564 if (access_check (temp, mode) == 0)
2565 return temp;
2569 free (temp);
2570 return 0;
2573 /* Ranking of prefixes in the sort list. -B prefixes are put before
2574 all others. */
2576 enum path_prefix_priority
2578 PREFIX_PRIORITY_B_OPT,
2579 PREFIX_PRIORITY_LAST
2582 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2583 order according to PRIORITY. Within each PRIORITY, new entries are
2584 appended.
2586 If WARN is nonzero, we will warn if no file is found
2587 through this prefix. WARN should point to an int
2588 which will be set to 1 if this entry is used.
2590 COMPONENT is the value to be passed to update_path.
2592 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2593 the complete value of machine_suffix.
2594 2 means try both machine_suffix and just_machine_suffix. */
2596 static void
2597 add_prefix (struct path_prefix *pprefix, const char *prefix,
2598 const char *component, /* enum prefix_priority */ int priority,
2599 int require_machine_suffix, int os_multilib)
2601 struct prefix_list *pl, **prev;
2602 int len;
2604 for (prev = &pprefix->plist;
2605 (*prev) != NULL && (*prev)->priority <= priority;
2606 prev = &(*prev)->next)
2609 /* Keep track of the longest prefix. */
2611 prefix = update_path (prefix, component);
2612 len = strlen (prefix);
2613 if (len > pprefix->max_len)
2614 pprefix->max_len = len;
2616 pl = xmalloc (sizeof (struct prefix_list));
2617 pl->prefix = prefix;
2618 pl->require_machine_suffix = require_machine_suffix;
2619 pl->priority = priority;
2620 pl->os_multilib = os_multilib;
2622 /* Insert after PREV. */
2623 pl->next = (*prev);
2624 (*prev) = pl;
2627 /* Same as add_prefix, but prepending target_system_root to prefix. */
2628 static void
2629 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2630 const char *component,
2631 /* enum prefix_priority */ int priority,
2632 int require_machine_suffix, int os_multilib)
2634 if (!IS_ABSOLUTE_PATH (prefix))
2635 fatal ("system path '%s' is not absolute", prefix);
2637 if (target_system_root)
2639 if (target_sysroot_suffix)
2640 prefix = concat (target_sysroot_suffix, prefix, NULL);
2641 prefix = concat (target_system_root, prefix, NULL);
2643 /* We have to override this because GCC's notion of sysroot
2644 moves along with GCC. */
2645 component = "GCC";
2648 add_prefix (pprefix, prefix, component, priority,
2649 require_machine_suffix, os_multilib);
2652 /* Execute the command specified by the arguments on the current line of spec.
2653 When using pipes, this includes several piped-together commands
2654 with `|' between them.
2656 Return 0 if successful, -1 if failed. */
2658 static int
2659 execute (void)
2661 int i;
2662 int n_commands; /* # of command. */
2663 char *string;
2664 struct command
2666 const char *prog; /* program name. */
2667 const char **argv; /* vector of args. */
2668 int pid; /* pid of process for this command. */
2671 struct command *commands; /* each command buffer with above info. */
2673 gcc_assert (!processing_spec_function);
2675 /* Count # of piped commands. */
2676 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2677 if (strcmp (argbuf[i], "|") == 0)
2678 n_commands++;
2680 /* Get storage for each command. */
2681 commands = alloca (n_commands * sizeof (struct command));
2683 /* Split argbuf into its separate piped processes,
2684 and record info about each one.
2685 Also search for the programs that are to be run. */
2687 commands[0].prog = argbuf[0]; /* first command. */
2688 commands[0].argv = &argbuf[0];
2689 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2691 if (string)
2692 commands[0].argv[0] = string;
2694 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2695 if (strcmp (argbuf[i], "|") == 0)
2696 { /* each command. */
2697 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2698 fatal ("-pipe not supported");
2699 #endif
2700 argbuf[i] = 0; /* termination of command args. */
2701 commands[n_commands].prog = argbuf[i + 1];
2702 commands[n_commands].argv = &argbuf[i + 1];
2703 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2704 X_OK, 0);
2705 if (string)
2706 commands[n_commands].argv[0] = string;
2707 n_commands++;
2710 argbuf[argbuf_index] = 0;
2712 /* If -v, print what we are about to do, and maybe query. */
2714 if (verbose_flag)
2716 /* For help listings, put a blank line between sub-processes. */
2717 if (print_help_list)
2718 fputc ('\n', stderr);
2720 /* Print each piped command as a separate line. */
2721 for (i = 0; i < n_commands; i++)
2723 const char *const *j;
2725 if (verbose_only_flag)
2727 for (j = commands[i].argv; *j; j++)
2729 const char *p;
2730 fprintf (stderr, " \"");
2731 for (p = *j; *p; ++p)
2733 if (*p == '"' || *p == '\\' || *p == '$')
2734 fputc ('\\', stderr);
2735 fputc (*p, stderr);
2737 fputc ('"', stderr);
2740 else
2741 for (j = commands[i].argv; *j; j++)
2742 fprintf (stderr, " %s", *j);
2744 /* Print a pipe symbol after all but the last command. */
2745 if (i + 1 != n_commands)
2746 fprintf (stderr, " |");
2747 fprintf (stderr, "\n");
2749 fflush (stderr);
2750 if (verbose_only_flag != 0)
2752 /* verbose_only_flag should act as if the spec was
2753 executed, so increment execution_count before
2754 returning. This prevents spurious warnings about
2755 unused linker input files, etc. */
2756 execution_count++;
2757 return 0;
2759 #ifdef DEBUG
2760 notice ("\nGo ahead? (y or n) ");
2761 fflush (stderr);
2762 i = getchar ();
2763 if (i != '\n')
2764 while (getchar () != '\n')
2767 if (i != 'y' && i != 'Y')
2768 return 0;
2769 #endif /* DEBUG */
2772 #ifdef ENABLE_VALGRIND_CHECKING
2773 /* Run the each command through valgrind. To simplify prepending the
2774 path to valgrind and the option "-q" (for quiet operation unless
2775 something triggers), we allocate a separate argv array. */
2777 for (i = 0; i < n_commands; i++)
2779 const char **argv;
2780 int argc;
2781 int j;
2783 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2786 argv = alloca ((argc + 3) * sizeof (char *));
2788 argv[0] = VALGRIND_PATH;
2789 argv[1] = "-q";
2790 for (j = 2; j < argc + 2; j++)
2791 argv[j] = commands[i].argv[j - 2];
2792 argv[j] = NULL;
2794 commands[i].argv = argv;
2795 commands[i].prog = argv[0];
2797 #endif
2799 /* Run each piped subprocess. */
2801 for (i = 0; i < n_commands; i++)
2803 char *errmsg_fmt, *errmsg_arg;
2804 const char *string = commands[i].argv[0];
2806 /* For some bizarre reason, the second argument of execvp() is
2807 char *const *, not const char *const *. */
2808 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2809 programname, temp_filename,
2810 &errmsg_fmt, &errmsg_arg,
2811 ((i == 0 ? PEXECUTE_FIRST : 0)
2812 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2813 | (string == commands[i].prog
2814 ? PEXECUTE_SEARCH : 0)
2815 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2817 if (commands[i].pid == -1)
2818 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2820 if (string != commands[i].prog)
2821 free ((void *) string);
2824 execution_count++;
2826 /* Wait for all the subprocesses to finish.
2827 We don't care what order they finish in;
2828 we know that N_COMMANDS waits will get them all.
2829 Ignore subprocesses that we don't know about,
2830 since they can be spawned by the process that exec'ed us. */
2833 int ret_code = 0;
2834 #ifdef HAVE_GETRUSAGE
2835 struct timeval d;
2836 double ut = 0.0, st = 0.0;
2837 #endif
2839 for (i = 0; i < n_commands;)
2841 int j;
2842 int status;
2843 int pid;
2845 pid = pwait (commands[i].pid, &status, 0);
2846 gcc_assert (pid >= 0);
2848 #ifdef HAVE_GETRUSAGE
2849 if (report_times)
2851 /* getrusage returns the total resource usage of all children
2852 up to now. Copy the previous values into prus, get the
2853 current statistics, then take the difference. */
2855 prus = rus;
2856 getrusage (RUSAGE_CHILDREN, &rus);
2857 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2858 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2859 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2861 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2862 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2863 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2865 #endif
2867 for (j = 0; j < n_commands; j++)
2868 if (commands[j].pid == pid)
2870 i++;
2871 if (WIFSIGNALED (status))
2873 #ifdef SIGPIPE
2874 /* SIGPIPE is a special case. It happens in -pipe mode
2875 when the compiler dies before the preprocessor is
2876 done, or the assembler dies before the compiler is
2877 done. There's generally been an error already, and
2878 this is just fallout. So don't generate another error
2879 unless we would otherwise have succeeded. */
2880 if (WTERMSIG (status) == SIGPIPE
2881 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2883 else
2884 #endif
2885 fatal ("\
2886 Internal error: %s (program %s)\n\
2887 Please submit a full bug report.\n\
2888 See %s for instructions.",
2889 strsignal (WTERMSIG (status)), commands[j].prog,
2890 bug_report_url);
2891 signal_count++;
2892 ret_code = -1;
2894 else if (WIFEXITED (status)
2895 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2897 if (WEXITSTATUS (status) > greatest_status)
2898 greatest_status = WEXITSTATUS (status);
2899 ret_code = -1;
2901 #ifdef HAVE_GETRUSAGE
2902 if (report_times && ut + st != 0)
2903 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2904 #endif
2905 break;
2908 return ret_code;
2912 /* Find all the switches given to us
2913 and make a vector describing them.
2914 The elements of the vector are strings, one per switch given.
2915 If a switch uses following arguments, then the `part1' field
2916 is the switch itself and the `args' field
2917 is a null-terminated vector containing the following arguments.
2918 The `live_cond' field is:
2919 0 when initialized
2920 1 if the switch is true in a conditional spec,
2921 -1 if false (overridden by a later switch)
2922 -2 if this switch should be ignored (used in %<S)
2923 The `validated' field is nonzero if any spec has looked at this switch;
2924 if it remains zero at the end of the run, it must be meaningless. */
2926 #define SWITCH_OK 0
2927 #define SWITCH_FALSE -1
2928 #define SWITCH_IGNORE -2
2929 #define SWITCH_LIVE 1
2931 struct switchstr
2933 const char *part1;
2934 const char **args;
2935 int live_cond;
2936 unsigned char validated;
2937 unsigned char ordering;
2940 static struct switchstr *switches;
2942 static int n_switches;
2944 struct infile
2946 const char *name;
2947 const char *language;
2948 struct compiler *incompiler;
2949 bool compiled;
2950 bool preprocessed;
2953 /* Also a vector of input files specified. */
2955 static struct infile *infiles;
2957 int n_infiles;
2959 /* True if multiple input files are being compiled to a single
2960 assembly file. */
2962 static bool combine_inputs;
2964 /* This counts the number of libraries added by lang_specific_driver, so that
2965 we can tell if there were any user supplied any files or libraries. */
2967 static int added_libraries;
2969 /* And a vector of corresponding output files is made up later. */
2971 const char **outfiles;
2973 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2975 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2976 is true if we should look for an executable suffix. DO_OBJ
2977 is true if we should look for an object suffix. */
2979 static const char *
2980 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2981 int do_obj ATTRIBUTE_UNUSED)
2983 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2984 int i;
2985 #endif
2986 int len;
2988 if (name == NULL)
2989 return NULL;
2991 len = strlen (name);
2993 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2994 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2995 if (do_obj && len > 2
2996 && name[len - 2] == '.'
2997 && name[len - 1] == 'o')
2999 obstack_grow (&obstack, name, len - 2);
3000 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3001 name = obstack_finish (&obstack);
3003 #endif
3005 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3006 /* If there is no filetype, make it the executable suffix (which includes
3007 the "."). But don't get confused if we have just "-o". */
3008 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3009 return name;
3011 for (i = len - 1; i >= 0; i--)
3012 if (IS_DIR_SEPARATOR (name[i]))
3013 break;
3015 for (i++; i < len; i++)
3016 if (name[i] == '.')
3017 return name;
3019 obstack_grow (&obstack, name, len);
3020 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3021 strlen (TARGET_EXECUTABLE_SUFFIX));
3022 name = obstack_finish (&obstack);
3023 #endif
3025 return name;
3027 #endif
3029 /* Display the command line switches accepted by gcc. */
3030 static void
3031 display_help (void)
3033 printf (_("Usage: %s [options] file...\n"), programname);
3034 fputs (_("Options:\n"), stdout);
3036 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3037 fputs (_(" --help Display this information\n"), stdout);
3038 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3039 if (! verbose_flag)
3040 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3041 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3042 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3043 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3044 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3045 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3046 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3047 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3048 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3049 fputs (_("\
3050 -print-multi-lib Display the mapping between command line options and\n\
3051 multiple library search directories\n"), stdout);
3052 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3053 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3054 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3055 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3056 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3057 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3058 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3059 fputs (_(" -combine Pass multiple source files to compiler at once\n"), stdout);
3060 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3061 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3062 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3063 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3064 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3065 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3066 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3067 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3068 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3069 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3070 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3071 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3072 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3073 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3074 fputs (_("\
3075 -x <language> Specify the language of the following input files\n\
3076 Permissible languages include: c c++ assembler none\n\
3077 'none' means revert to the default behavior of\n\
3078 guessing the language based on the file's extension\n\
3079 "), stdout);
3081 printf (_("\
3082 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3083 passed on to the various sub-processes invoked by %s. In order to pass\n\
3084 other options on to these processes the -W<letter> options must be used.\n\
3085 "), programname);
3087 /* The rest of the options are displayed by invocations of the various
3088 sub-processes. */
3091 static void
3092 add_preprocessor_option (const char *option, int len)
3094 n_preprocessor_options++;
3096 if (! preprocessor_options)
3097 preprocessor_options = xmalloc (n_preprocessor_options * sizeof (char *));
3098 else
3099 preprocessor_options = xrealloc (preprocessor_options,
3100 n_preprocessor_options * sizeof (char *));
3102 preprocessor_options [n_preprocessor_options - 1] =
3103 save_string (option, len);
3106 static void
3107 add_assembler_option (const char *option, int len)
3109 n_assembler_options++;
3111 if (! assembler_options)
3112 assembler_options = xmalloc (n_assembler_options * sizeof (char *));
3113 else
3114 assembler_options = xrealloc (assembler_options,
3115 n_assembler_options * sizeof (char *));
3117 assembler_options [n_assembler_options - 1] = save_string (option, len);
3120 static void
3121 add_linker_option (const char *option, int len)
3123 n_linker_options++;
3125 if (! linker_options)
3126 linker_options = xmalloc (n_linker_options * sizeof (char *));
3127 else
3128 linker_options = xrealloc (linker_options,
3129 n_linker_options * sizeof (char *));
3131 linker_options [n_linker_options - 1] = save_string (option, len);
3134 /* Create the vector `switches' and its contents.
3135 Store its length in `n_switches'. */
3137 static void
3138 process_command (int argc, const char **argv)
3140 int i;
3141 const char *temp;
3142 char *temp1;
3143 const char *spec_lang = 0;
3144 int last_language_n_infiles;
3145 int have_c = 0;
3146 int lang_n_infiles = 0;
3147 #ifdef MODIFY_TARGET_NAME
3148 int is_modify_target_name;
3149 int j;
3150 #endif
3152 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3154 n_switches = 0;
3155 n_infiles = 0;
3156 added_libraries = 0;
3158 /* Figure compiler version from version string. */
3160 compiler_version = temp1 = xstrdup (version_string);
3162 for (; *temp1; ++temp1)
3164 if (*temp1 == ' ')
3166 *temp1 = '\0';
3167 break;
3171 /* If there is a -V or -b option (or both), process it now, before
3172 trying to interpret the rest of the command line. */
3173 if (argc > 1 && argv[1][0] == '-'
3174 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3176 const char *new_version = DEFAULT_TARGET_VERSION;
3177 const char *new_machine = DEFAULT_TARGET_MACHINE;
3178 const char *progname = argv[0];
3179 char **new_argv;
3180 char *new_argv0;
3181 int baselen;
3183 while (argc > 1 && argv[1][0] == '-'
3184 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3186 char opt = argv[1][1];
3187 const char *arg;
3188 if (argv[1][2] != '\0')
3190 arg = argv[1] + 2;
3191 argc -= 1;
3192 argv += 1;
3194 else if (argc > 2)
3196 arg = argv[2];
3197 argc -= 2;
3198 argv += 2;
3200 else
3201 fatal ("'-%c' option must have argument", opt);
3202 if (opt == 'V')
3203 new_version = arg;
3204 else
3205 new_machine = arg;
3208 for (baselen = strlen (progname); baselen > 0; baselen--)
3209 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3210 break;
3211 new_argv0 = xmemdup (progname, baselen,
3212 baselen + concat_length (new_version, new_machine,
3213 "-gcc-", NULL) + 1);
3214 strcpy (new_argv0 + baselen, new_machine);
3215 strcat (new_argv0, "-gcc-");
3216 strcat (new_argv0, new_version);
3218 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3219 (argc + 1) * sizeof (argv[0]));
3220 new_argv[0] = new_argv0;
3222 execvp (new_argv0, new_argv);
3223 fatal ("couldn't run '%s': %s", new_argv0, xstrerror (errno));
3226 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3227 see if we can create it from the pathname specified in argv[0]. */
3229 gcc_libexec_prefix = standard_libexec_prefix;
3230 #ifndef VMS
3231 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3232 if (!gcc_exec_prefix)
3234 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3235 standard_exec_prefix);
3236 gcc_libexec_prefix = make_relative_prefix (argv[0],
3237 standard_bindir_prefix,
3238 standard_libexec_prefix);
3239 if (gcc_exec_prefix)
3240 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3242 else
3243 gcc_libexec_prefix = make_relative_prefix (gcc_exec_prefix,
3244 standard_exec_prefix,
3245 standard_libexec_prefix);
3246 #else
3247 #endif
3249 if (gcc_exec_prefix)
3251 int len = strlen (gcc_exec_prefix);
3253 if (len > (int) sizeof ("/lib/gcc/") - 1
3254 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3256 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3257 if (IS_DIR_SEPARATOR (*temp)
3258 && strncmp (temp + 1, "lib", 3) == 0
3259 && IS_DIR_SEPARATOR (temp[4])
3260 && strncmp (temp + 5, "gcc", 3) == 0)
3261 len -= sizeof ("/lib/gcc/") - 1;
3264 set_std_prefix (gcc_exec_prefix, len);
3265 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3266 PREFIX_PRIORITY_LAST, 0, 0);
3267 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3268 PREFIX_PRIORITY_LAST, 0, 0);
3271 /* COMPILER_PATH and LIBRARY_PATH have values
3272 that are lists of directory names with colons. */
3274 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3275 if (temp)
3277 const char *startp, *endp;
3278 char *nstore = alloca (strlen (temp) + 3);
3280 startp = endp = temp;
3281 while (1)
3283 if (*endp == PATH_SEPARATOR || *endp == 0)
3285 strncpy (nstore, startp, endp - startp);
3286 if (endp == startp)
3287 strcpy (nstore, concat (".", dir_separator_str, NULL));
3288 else if (!IS_DIR_SEPARATOR (endp[-1]))
3290 nstore[endp - startp] = DIR_SEPARATOR;
3291 nstore[endp - startp + 1] = 0;
3293 else
3294 nstore[endp - startp] = 0;
3295 add_prefix (&exec_prefixes, nstore, 0,
3296 PREFIX_PRIORITY_LAST, 0, 0);
3297 add_prefix (&include_prefixes, nstore, 0,
3298 PREFIX_PRIORITY_LAST, 0, 0);
3299 if (*endp == 0)
3300 break;
3301 endp = startp = endp + 1;
3303 else
3304 endp++;
3308 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3309 if (temp && *cross_compile == '0')
3311 const char *startp, *endp;
3312 char *nstore = alloca (strlen (temp) + 3);
3314 startp = endp = temp;
3315 while (1)
3317 if (*endp == PATH_SEPARATOR || *endp == 0)
3319 strncpy (nstore, startp, endp - startp);
3320 if (endp == startp)
3321 strcpy (nstore, concat (".", dir_separator_str, NULL));
3322 else if (!IS_DIR_SEPARATOR (endp[-1]))
3324 nstore[endp - startp] = DIR_SEPARATOR;
3325 nstore[endp - startp + 1] = 0;
3327 else
3328 nstore[endp - startp] = 0;
3329 add_prefix (&startfile_prefixes, nstore, NULL,
3330 PREFIX_PRIORITY_LAST, 0, 1);
3331 if (*endp == 0)
3332 break;
3333 endp = startp = endp + 1;
3335 else
3336 endp++;
3340 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3341 GET_ENVIRONMENT (temp, "LPATH");
3342 if (temp && *cross_compile == '0')
3344 const char *startp, *endp;
3345 char *nstore = alloca (strlen (temp) + 3);
3347 startp = endp = temp;
3348 while (1)
3350 if (*endp == PATH_SEPARATOR || *endp == 0)
3352 strncpy (nstore, startp, endp - startp);
3353 if (endp == startp)
3354 strcpy (nstore, concat (".", dir_separator_str, NULL));
3355 else if (!IS_DIR_SEPARATOR (endp[-1]))
3357 nstore[endp - startp] = DIR_SEPARATOR;
3358 nstore[endp - startp + 1] = 0;
3360 else
3361 nstore[endp - startp] = 0;
3362 add_prefix (&startfile_prefixes, nstore, NULL,
3363 PREFIX_PRIORITY_LAST, 0, 1);
3364 if (*endp == 0)
3365 break;
3366 endp = startp = endp + 1;
3368 else
3369 endp++;
3373 /* Convert new-style -- options to old-style. */
3374 translate_options (&argc, (const char *const **) &argv);
3376 /* Do language-specific adjustment/addition of flags. */
3377 lang_specific_driver (&argc, (const char *const **) &argv, &added_libraries);
3379 /* Scan argv twice. Here, the first time, just count how many switches
3380 there will be in their vector, and how many input files in theirs.
3381 Here we also parse the switches that cc itself uses (e.g. -v). */
3383 for (i = 1; i < argc; i++)
3385 if (! strcmp (argv[i], "-dumpspecs"))
3387 struct spec_list *sl;
3388 init_spec ();
3389 for (sl = specs; sl; sl = sl->next)
3390 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3391 if (link_command_spec)
3392 printf ("*link_command:\n%s\n\n", link_command_spec);
3393 exit (0);
3395 else if (! strcmp (argv[i], "-dumpversion"))
3397 printf ("%s\n", spec_version);
3398 exit (0);
3400 else if (! strcmp (argv[i], "-dumpmachine"))
3402 printf ("%s\n", spec_machine);
3403 exit (0);
3405 else if (strcmp (argv[i], "-fversion") == 0)
3407 /* translate_options () has turned --version into -fversion. */
3408 printf (_("%s (GCC) %s\n"), programname, version_string);
3409 printf ("Copyright %s 2004 Free Software Foundation, Inc.\n",
3410 _("(C)"));
3411 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3412 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3413 stdout);
3414 exit (0);
3416 else if (strcmp (argv[i], "-fhelp") == 0)
3418 /* translate_options () has turned --help into -fhelp. */
3419 print_help_list = 1;
3421 /* We will be passing a dummy file on to the sub-processes. */
3422 n_infiles++;
3423 n_switches++;
3425 /* CPP driver cannot obtain switch from cc1_options. */
3426 if (is_cpp_driver)
3427 add_preprocessor_option ("--help", 6);
3428 add_assembler_option ("--help", 6);
3429 add_linker_option ("--help", 6);
3431 else if (strcmp (argv[i], "-ftarget-help") == 0)
3433 /* translate_options() has turned --target-help into -ftarget-help. */
3434 target_help_flag = 1;
3436 /* We will be passing a dummy file on to the sub-processes. */
3437 n_infiles++;
3438 n_switches++;
3440 /* CPP driver cannot obtain switch from cc1_options. */
3441 if (is_cpp_driver)
3442 add_preprocessor_option ("--target-help", 13);
3443 add_assembler_option ("--target-help", 13);
3444 add_linker_option ("--target-help", 13);
3446 else if (! strcmp (argv[i], "-pass-exit-codes"))
3448 pass_exit_codes = 1;
3449 n_switches++;
3451 else if (! strcmp (argv[i], "-print-search-dirs"))
3452 print_search_dirs = 1;
3453 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3454 print_file_name = "libgcc.a";
3455 else if (! strncmp (argv[i], "-print-file-name=", 17))
3456 print_file_name = argv[i] + 17;
3457 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3458 print_prog_name = argv[i] + 17;
3459 else if (! strcmp (argv[i], "-print-multi-lib"))
3460 print_multi_lib = 1;
3461 else if (! strcmp (argv[i], "-print-multi-directory"))
3462 print_multi_directory = 1;
3463 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3464 print_multi_os_directory = 1;
3465 else if (! strncmp (argv[i], "-Wa,", 4))
3467 int prev, j;
3468 /* Pass the rest of this option to the assembler. */
3470 /* Split the argument at commas. */
3471 prev = 4;
3472 for (j = 4; argv[i][j]; j++)
3473 if (argv[i][j] == ',')
3475 add_assembler_option (argv[i] + prev, j - prev);
3476 prev = j + 1;
3479 /* Record the part after the last comma. */
3480 add_assembler_option (argv[i] + prev, j - prev);
3482 else if (! strncmp (argv[i], "-Wp,", 4))
3484 int prev, j;
3485 /* Pass the rest of this option to the preprocessor. */
3487 /* Split the argument at commas. */
3488 prev = 4;
3489 for (j = 4; argv[i][j]; j++)
3490 if (argv[i][j] == ',')
3492 add_preprocessor_option (argv[i] + prev, j - prev);
3493 prev = j + 1;
3496 /* Record the part after the last comma. */
3497 add_preprocessor_option (argv[i] + prev, j - prev);
3499 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3500 /* The +e options to the C++ front-end. */
3501 n_switches++;
3502 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3504 int j;
3505 /* Split the argument at commas. */
3506 for (j = 3; argv[i][j]; j++)
3507 n_infiles += (argv[i][j] == ',');
3509 else if (strcmp (argv[i], "-Xlinker") == 0)
3511 if (i + 1 == argc)
3512 fatal ("argument to '-Xlinker' is missing");
3514 n_infiles++;
3515 i++;
3517 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3519 if (i + 1 == argc)
3520 fatal ("argument to '-Xpreprocessor' is missing");
3522 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3524 else if (strcmp (argv[i], "-Xassembler") == 0)
3526 if (i + 1 == argc)
3527 fatal ("argument to '-Xassembler' is missing");
3529 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3531 else if (strcmp (argv[i], "-l") == 0)
3533 if (i + 1 == argc)
3534 fatal ("argument to '-l' is missing");
3536 n_infiles++;
3537 i++;
3539 else if (strncmp (argv[i], "-l", 2) == 0)
3540 n_infiles++;
3541 else if (strcmp (argv[i], "-save-temps") == 0)
3543 save_temps_flag = 1;
3544 n_switches++;
3546 else if (strcmp (argv[i], "-combine") == 0)
3548 combine_flag = 1;
3549 n_switches++;
3551 else if (strcmp (argv[i], "-specs") == 0)
3553 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3554 if (++i >= argc)
3555 fatal ("argument to '-specs' is missing");
3557 user->next = (struct user_specs *) 0;
3558 user->filename = argv[i];
3559 if (user_specs_tail)
3560 user_specs_tail->next = user;
3561 else
3562 user_specs_head = user;
3563 user_specs_tail = user;
3565 else if (strncmp (argv[i], "-specs=", 7) == 0)
3567 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3568 if (strlen (argv[i]) == 7)
3569 fatal ("argument to '-specs=' is missing");
3571 user->next = (struct user_specs *) 0;
3572 user->filename = argv[i] + 7;
3573 if (user_specs_tail)
3574 user_specs_tail->next = user;
3575 else
3576 user_specs_head = user;
3577 user_specs_tail = user;
3579 else if (strcmp (argv[i], "-time") == 0)
3580 report_times = 1;
3581 else if (strcmp (argv[i], "-pipe") == 0)
3583 /* -pipe has to go into the switches array as well as
3584 setting a flag. */
3585 use_pipes = 1;
3586 n_switches++;
3588 else if (strcmp (argv[i], "-###") == 0)
3590 /* This is similar to -v except that there is no execution
3591 of the commands and the echoed arguments are quoted. It
3592 is intended for use in shell scripts to capture the
3593 driver-generated command line. */
3594 verbose_only_flag++;
3595 verbose_flag++;
3597 else if (argv[i][0] == '-' && argv[i][1] != 0)
3599 const char *p = &argv[i][1];
3600 int c = *p;
3602 switch (c)
3604 case 'b':
3605 case 'V':
3606 fatal ("'-%c' must come at the start of the command line", c);
3607 break;
3609 case 'B':
3611 const char *value;
3612 int len;
3614 if (p[1] == 0 && i + 1 == argc)
3615 fatal ("argument to '-B' is missing");
3616 if (p[1] == 0)
3617 value = argv[++i];
3618 else
3619 value = p + 1;
3621 len = strlen (value);
3623 /* Catch the case where the user has forgotten to append a
3624 directory separator to the path. Note, they may be using
3625 -B to add an executable name prefix, eg "i386-elf-", in
3626 order to distinguish between multiple installations of
3627 GCC in the same directory. Hence we must check to see
3628 if appending a directory separator actually makes a
3629 valid directory name. */
3630 if (! IS_DIR_SEPARATOR (value [len - 1])
3631 && is_directory (value, "", 0))
3633 char *tmp = xmalloc (len + 2);
3634 strcpy (tmp, value);
3635 tmp[len] = DIR_SEPARATOR;
3636 tmp[++ len] = 0;
3637 value = tmp;
3640 /* As a kludge, if the arg is "[foo/]stageN/", just
3641 add "[foo/]include" to the include prefix. */
3642 if ((len == 7
3643 || (len > 7
3644 && (IS_DIR_SEPARATOR (value[len - 8]))))
3645 && strncmp (value + len - 7, "stage", 5) == 0
3646 && ISDIGIT (value[len - 2])
3647 && (IS_DIR_SEPARATOR (value[len - 1])))
3649 if (len == 7)
3650 add_prefix (&include_prefixes, "./", NULL,
3651 PREFIX_PRIORITY_B_OPT, 0, 0);
3652 else
3654 char *string = xmalloc (len - 6);
3655 memcpy (string, value, len - 7);
3656 string[len - 7] = 0;
3657 add_prefix (&include_prefixes, string, NULL,
3658 PREFIX_PRIORITY_B_OPT, 0, 0);
3662 add_prefix (&exec_prefixes, value, NULL,
3663 PREFIX_PRIORITY_B_OPT, 0, 0);
3664 add_prefix (&startfile_prefixes, value, NULL,
3665 PREFIX_PRIORITY_B_OPT, 0, 0);
3666 add_prefix (&include_prefixes, value, NULL,
3667 PREFIX_PRIORITY_B_OPT, 0, 0);
3668 n_switches++;
3670 break;
3672 case 'v': /* Print our subcommands and print versions. */
3673 n_switches++;
3674 /* If they do anything other than exactly `-v', don't set
3675 verbose_flag; rather, continue on to give the error. */
3676 if (p[1] != 0)
3677 break;
3678 verbose_flag++;
3679 if (strcmp (linker_name_spec, "collect2") == 0)
3680 add_linker_option ("-v", 2);
3681 break;
3683 case 'S':
3684 case 'c':
3685 if (p[1] == 0)
3687 have_c = 1;
3688 n_switches++;
3689 break;
3691 goto normal_switch;
3693 case 'o':
3694 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3695 if (! have_c)
3697 int skip;
3699 /* Forward scan, just in case -S or -c is specified
3700 after -o. */
3701 int j = i + 1;
3702 if (p[1] == 0)
3703 ++j;
3704 while (j < argc)
3706 if (argv[j][0] == '-')
3708 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3709 && argv[j][2] == 0)
3711 have_c = 1;
3712 break;
3714 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3715 j += skip - (argv[j][2] != 0);
3716 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3717 j += skip;
3719 j++;
3722 #endif
3723 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3724 if (p[1] == 0)
3725 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3726 else
3727 argv[i] = convert_filename (argv[i], ! have_c, 0);
3728 #endif
3729 goto normal_switch;
3731 default:
3732 normal_switch:
3734 #ifdef MODIFY_TARGET_NAME
3735 is_modify_target_name = 0;
3737 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3738 if (! strcmp (argv[i], modify_target[j].sw))
3740 char *new_name = xmalloc (strlen (modify_target[j].str)
3741 + strlen (spec_machine));
3742 const char *p, *r;
3743 char *q;
3744 int made_addition = 0;
3746 is_modify_target_name = 1;
3747 for (p = spec_machine, q = new_name; *p != 0; )
3749 if (modify_target[j].add_del == DELETE
3750 && (! strncmp (q, modify_target[j].str,
3751 strlen (modify_target[j].str))))
3752 p += strlen (modify_target[j].str);
3753 else if (modify_target[j].add_del == ADD
3754 && ! made_addition && *p == '-')
3756 for (r = modify_target[j].str; *r != 0; )
3757 *q++ = *r++;
3758 made_addition = 1;
3761 *q++ = *p++;
3764 spec_machine = new_name;
3767 if (is_modify_target_name)
3768 break;
3769 #endif
3771 n_switches++;
3773 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3774 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3775 else if (WORD_SWITCH_TAKES_ARG (p))
3776 i += WORD_SWITCH_TAKES_ARG (p);
3779 else
3781 n_infiles++;
3782 lang_n_infiles++;
3786 if ((save_temps_flag || report_times) && use_pipes)
3788 /* -save-temps overrides -pipe, so that temp files are produced */
3789 if (save_temps_flag)
3790 error ("warning: -pipe ignored because -save-temps specified");
3791 /* -time overrides -pipe because we can't get correct stats when
3792 multiple children are running at once. */
3793 else if (report_times)
3794 error ("warning: -pipe ignored because -time specified");
3796 use_pipes = 0;
3799 /* Set up the search paths before we go looking for config files. */
3801 /* These come before the md prefixes so that we will find gcc's subcommands
3802 (such as cpp) rather than those of the host system. */
3803 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3804 as well as trying the machine and the version. */
3805 #ifndef OS2
3806 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3807 PREFIX_PRIORITY_LAST, 1, 0);
3808 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3809 PREFIX_PRIORITY_LAST, 2, 0);
3810 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3811 PREFIX_PRIORITY_LAST, 2, 0);
3812 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3813 PREFIX_PRIORITY_LAST, 2, 0);
3814 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
3815 PREFIX_PRIORITY_LAST, 2, 0);
3816 #endif
3818 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3819 PREFIX_PRIORITY_LAST, 1, 0);
3820 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
3821 PREFIX_PRIORITY_LAST, 1, 0);
3823 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3824 dir_separator_str, NULL);
3826 /* If tooldir is relative, base it on exec_prefixes. A relative
3827 tooldir lets us move the installed tree as a unit.
3829 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3830 directories, so that we can search both the user specified directory
3831 and the standard place. */
3833 if (!IS_ABSOLUTE_PATH (tooldir_prefix))
3835 if (gcc_exec_prefix)
3837 char *gcc_exec_tooldir_prefix
3838 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3839 spec_version, dir_separator_str, tooldir_prefix, NULL);
3841 add_prefix (&exec_prefixes,
3842 concat (gcc_exec_tooldir_prefix, "bin",
3843 dir_separator_str, NULL),
3844 NULL, PREFIX_PRIORITY_LAST, 0, 0);
3845 add_prefix (&startfile_prefixes,
3846 concat (gcc_exec_tooldir_prefix, "lib",
3847 dir_separator_str, NULL),
3848 NULL, PREFIX_PRIORITY_LAST, 0, 1);
3851 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3852 dir_separator_str, spec_version,
3853 dir_separator_str, tooldir_prefix, NULL);
3856 add_prefix (&exec_prefixes,
3857 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3858 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3859 add_prefix (&startfile_prefixes,
3860 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3861 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3863 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3864 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3865 then consider it to relocate with the rest of the GCC installation
3866 if GCC_EXEC_PREFIX is set.
3867 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3868 if (target_system_root && gcc_exec_prefix)
3870 char *tmp_prefix = make_relative_prefix (argv[0],
3871 standard_bindir_prefix,
3872 target_system_root);
3873 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3875 target_system_root = tmp_prefix;
3876 target_system_root_changed = 1;
3879 #endif
3881 /* More prefixes are enabled in main, after we read the specs file
3882 and determine whether this is cross-compilation or not. */
3884 /* Then create the space for the vectors and scan again. */
3886 switches = xmalloc ((n_switches + 1) * sizeof (struct switchstr));
3887 infiles = xmalloc ((n_infiles + 1) * sizeof (struct infile));
3888 n_switches = 0;
3889 n_infiles = 0;
3890 last_language_n_infiles = -1;
3892 /* This, time, copy the text of each switch and store a pointer
3893 to the copy in the vector of switches.
3894 Store all the infiles in their vector. */
3896 for (i = 1; i < argc; i++)
3898 /* Just skip the switches that were handled by the preceding loop. */
3899 #ifdef MODIFY_TARGET_NAME
3900 is_modify_target_name = 0;
3902 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3903 if (! strcmp (argv[i], modify_target[j].sw))
3904 is_modify_target_name = 1;
3906 if (is_modify_target_name)
3908 else
3909 #endif
3910 if (! strncmp (argv[i], "-Wa,", 4))
3912 else if (! strncmp (argv[i], "-Wp,", 4))
3914 else if (! strcmp (argv[i], "-pass-exit-codes"))
3916 else if (! strcmp (argv[i], "-print-search-dirs"))
3918 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3920 else if (! strncmp (argv[i], "-print-file-name=", 17))
3922 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3924 else if (! strcmp (argv[i], "-print-multi-lib"))
3926 else if (! strcmp (argv[i], "-print-multi-directory"))
3928 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3930 else if (! strcmp (argv[i], "-ftarget-help"))
3932 else if (! strcmp (argv[i], "-fhelp"))
3934 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3936 /* Compensate for the +e options to the C++ front-end;
3937 they're there simply for cfront call-compatibility. We do
3938 some magic in default_compilers to pass them down properly.
3939 Note we deliberately start at the `+' here, to avoid passing
3940 -e0 or -e1 down into the linker. */
3941 switches[n_switches].part1 = &argv[i][0];
3942 switches[n_switches].args = 0;
3943 switches[n_switches].live_cond = SWITCH_OK;
3944 switches[n_switches].validated = 0;
3945 n_switches++;
3947 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3949 int prev, j;
3950 /* Split the argument at commas. */
3951 prev = 4;
3952 for (j = 4; argv[i][j]; j++)
3953 if (argv[i][j] == ',')
3955 infiles[n_infiles].language = "*";
3956 infiles[n_infiles++].name
3957 = save_string (argv[i] + prev, j - prev);
3958 prev = j + 1;
3960 /* Record the part after the last comma. */
3961 infiles[n_infiles].language = "*";
3962 infiles[n_infiles++].name = argv[i] + prev;
3964 else if (strcmp (argv[i], "-Xlinker") == 0)
3966 infiles[n_infiles].language = "*";
3967 infiles[n_infiles++].name = argv[++i];
3969 else if (strcmp (argv[i], "-Xassembler") == 0)
3971 infiles[n_infiles].language = "*";
3972 infiles[n_infiles++].name = argv[++i];
3974 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3976 infiles[n_infiles].language = "*";
3977 infiles[n_infiles++].name = argv[++i];
3979 else if (strcmp (argv[i], "-l") == 0)
3980 { /* POSIX allows separation of -l and the lib arg;
3981 canonicalize by concatenating -l with its arg */
3982 infiles[n_infiles].language = "*";
3983 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3985 else if (strncmp (argv[i], "-l", 2) == 0)
3987 infiles[n_infiles].language = "*";
3988 infiles[n_infiles++].name = argv[i];
3990 else if (strcmp (argv[i], "-specs") == 0)
3991 i++;
3992 else if (strncmp (argv[i], "-specs=", 7) == 0)
3994 else if (strcmp (argv[i], "-time") == 0)
3996 else if (strcmp (argv[i], "-###") == 0)
3998 else if (argv[i][0] == '-' && argv[i][1] != 0)
4000 const char *p = &argv[i][1];
4001 int c = *p;
4003 if (c == 'x')
4005 if (p[1] == 0 && i + 1 == argc)
4006 fatal ("argument to '-x' is missing");
4007 if (p[1] == 0)
4008 spec_lang = argv[++i];
4009 else
4010 spec_lang = p + 1;
4011 if (! strcmp (spec_lang, "none"))
4012 /* Suppress the warning if -xnone comes after the last input
4013 file, because alternate command interfaces like g++ might
4014 find it useful to place -xnone after each input file. */
4015 spec_lang = 0;
4016 else
4017 last_language_n_infiles = n_infiles;
4018 continue;
4020 switches[n_switches].part1 = p;
4021 /* Deal with option arguments in separate argv elements. */
4022 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
4023 || WORD_SWITCH_TAKES_ARG (p))
4025 int j = 0;
4026 int n_args = WORD_SWITCH_TAKES_ARG (p);
4028 if (n_args == 0)
4030 /* Count only the option arguments in separate argv elements. */
4031 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4033 if (i + n_args >= argc)
4034 fatal ("argument to '-%s' is missing", p);
4035 switches[n_switches].args
4036 = xmalloc ((n_args + 1) * sizeof(const char *));
4037 while (j < n_args)
4038 switches[n_switches].args[j++] = argv[++i];
4039 /* Null-terminate the vector. */
4040 switches[n_switches].args[j] = 0;
4042 else if (strchr (switches_need_spaces, c))
4044 /* On some systems, ld cannot handle some options without
4045 a space. So split the option from its argument. */
4046 char *part1 = xmalloc (2);
4047 part1[0] = c;
4048 part1[1] = '\0';
4050 switches[n_switches].part1 = part1;
4051 switches[n_switches].args = xmalloc (2 * sizeof (const char *));
4052 switches[n_switches].args[0] = xstrdup (p+1);
4053 switches[n_switches].args[1] = 0;
4055 else
4056 switches[n_switches].args = 0;
4058 switches[n_switches].live_cond = SWITCH_OK;
4059 switches[n_switches].validated = 0;
4060 switches[n_switches].ordering = 0;
4061 /* These are always valid, since gcc.c itself understands them. */
4062 if (!strcmp (p, "save-temps")
4063 || !strcmp (p, "static-libgcc")
4064 || !strcmp (p, "shared-libgcc")
4065 || !strcmp (p, "pipe"))
4066 switches[n_switches].validated = 1;
4067 else
4069 char ch = switches[n_switches].part1[0];
4070 if (ch == 'B')
4071 switches[n_switches].validated = 1;
4073 n_switches++;
4075 else
4077 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4078 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4079 #endif
4081 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4083 perror_with_name (argv[i]);
4084 error_count++;
4086 else
4088 infiles[n_infiles].language = spec_lang;
4089 infiles[n_infiles++].name = argv[i];
4094 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4095 error ("warning: '-x %s' after last input file has no effect", spec_lang);
4097 /* Ensure we only invoke each subprocess once. */
4098 if (target_help_flag || print_help_list)
4100 n_infiles = 1;
4102 /* Create a dummy input file, so that we can pass --target-help on to
4103 the various sub-processes. */
4104 infiles[0].language = "c";
4105 infiles[0].name = "help-dummy";
4107 if (target_help_flag)
4109 switches[n_switches].part1 = "--target-help";
4110 switches[n_switches].args = 0;
4111 switches[n_switches].live_cond = SWITCH_OK;
4112 switches[n_switches].validated = 0;
4114 n_switches++;
4117 if (print_help_list)
4119 switches[n_switches].part1 = "--help";
4120 switches[n_switches].args = 0;
4121 switches[n_switches].live_cond = SWITCH_OK;
4122 switches[n_switches].validated = 0;
4124 n_switches++;
4128 switches[n_switches].part1 = 0;
4129 infiles[n_infiles].name = 0;
4132 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4133 and place that in the environment. */
4135 static void
4136 set_collect_gcc_options (void)
4138 int i;
4139 int first_time;
4141 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4142 the compiler. */
4143 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4144 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4146 first_time = TRUE;
4147 for (i = 0; (int) i < n_switches; i++)
4149 const char *const *args;
4150 const char *p, *q;
4151 if (!first_time)
4152 obstack_grow (&collect_obstack, " ", 1);
4154 first_time = FALSE;
4156 /* Ignore elided switches. */
4157 if (switches[i].live_cond == SWITCH_IGNORE)
4158 continue;
4160 obstack_grow (&collect_obstack, "'-", 2);
4161 q = switches[i].part1;
4162 while ((p = strchr (q, '\'')))
4164 obstack_grow (&collect_obstack, q, p - q);
4165 obstack_grow (&collect_obstack, "'\\''", 4);
4166 q = ++p;
4168 obstack_grow (&collect_obstack, q, strlen (q));
4169 obstack_grow (&collect_obstack, "'", 1);
4171 for (args = switches[i].args; args && *args; args++)
4173 obstack_grow (&collect_obstack, " '", 2);
4174 q = *args;
4175 while ((p = strchr (q, '\'')))
4177 obstack_grow (&collect_obstack, q, p - q);
4178 obstack_grow (&collect_obstack, "'\\''", 4);
4179 q = ++p;
4181 obstack_grow (&collect_obstack, q, strlen (q));
4182 obstack_grow (&collect_obstack, "'", 1);
4185 obstack_grow (&collect_obstack, "\0", 1);
4186 putenv (obstack_finish (&collect_obstack));
4189 /* Process a spec string, accumulating and running commands. */
4191 /* These variables describe the input file name.
4192 input_file_number is the index on outfiles of this file,
4193 so that the output file name can be stored for later use by %o.
4194 input_basename is the start of the part of the input file
4195 sans all directory names, and basename_length is the number
4196 of characters starting there excluding the suffix .c or whatever. */
4198 static const char *input_filename;
4199 static int input_file_number;
4200 size_t input_filename_length;
4201 static int basename_length;
4202 static int suffixed_basename_length;
4203 static const char *input_basename;
4204 static const char *input_suffix;
4205 #ifndef HOST_LACKS_INODE_NUMBERS
4206 static struct stat input_stat;
4207 #endif
4208 static int input_stat_set;
4210 /* The compiler used to process the current input file. */
4211 static struct compiler *input_file_compiler;
4213 /* These are variables used within do_spec and do_spec_1. */
4215 /* Nonzero if an arg has been started and not yet terminated
4216 (with space, tab or newline). */
4217 static int arg_going;
4219 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4220 is a temporary file name. */
4221 static int delete_this_arg;
4223 /* Nonzero means %w has been seen; the next arg to be terminated
4224 is the output file name of this compilation. */
4225 static int this_is_output_file;
4227 /* Nonzero means %s has been seen; the next arg to be terminated
4228 is the name of a library file and we should try the standard
4229 search dirs for it. */
4230 static int this_is_library_file;
4232 /* Nonzero means that the input of this command is coming from a pipe. */
4233 static int input_from_pipe;
4235 /* Nonnull means substitute this for any suffix when outputting a switches
4236 arguments. */
4237 static const char *suffix_subst;
4239 /* Process the spec SPEC and run the commands specified therein.
4240 Returns 0 if the spec is successfully processed; -1 if failed. */
4243 do_spec (const char *spec)
4245 int value;
4247 value = do_spec_2 (spec);
4249 /* Force out any unfinished command.
4250 If -pipe, this forces out the last command if it ended in `|'. */
4251 if (value == 0)
4253 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4254 argbuf_index--;
4256 set_collect_gcc_options ();
4258 if (argbuf_index > 0)
4259 value = execute ();
4262 return value;
4265 static int
4266 do_spec_2 (const char *spec)
4268 const char *string;
4269 int result;
4271 clear_args ();
4272 arg_going = 0;
4273 delete_this_arg = 0;
4274 this_is_output_file = 0;
4275 this_is_library_file = 0;
4276 input_from_pipe = 0;
4277 suffix_subst = NULL;
4279 result = do_spec_1 (spec, 0, NULL);
4281 /* End any pending argument. */
4282 if (arg_going)
4284 obstack_1grow (&obstack, 0);
4285 string = obstack_finish (&obstack);
4286 if (this_is_library_file)
4287 string = find_file (string);
4288 store_arg (string, delete_this_arg, this_is_output_file);
4289 if (this_is_output_file)
4290 outfiles[input_file_number] = string;
4291 arg_going = 0;
4294 return result;
4298 /* Process the given spec string and add any new options to the end
4299 of the switches/n_switches array. */
4301 static void
4302 do_option_spec (const char *name, const char *spec)
4304 unsigned int i, value_count, value_len;
4305 const char *p, *q, *value;
4306 char *tmp_spec, *tmp_spec_p;
4308 if (configure_default_options[0].name == NULL)
4309 return;
4311 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4312 if (strcmp (configure_default_options[i].name, name) == 0)
4313 break;
4314 if (i == ARRAY_SIZE (configure_default_options))
4315 return;
4317 value = configure_default_options[i].value;
4318 value_len = strlen (value);
4320 /* Compute the size of the final spec. */
4321 value_count = 0;
4322 p = spec;
4323 while ((p = strstr (p, "%(VALUE)")) != NULL)
4325 p ++;
4326 value_count ++;
4329 /* Replace each %(VALUE) by the specified value. */
4330 tmp_spec = alloca (strlen (spec) + 1
4331 + value_count * (value_len - strlen ("%(VALUE)")));
4332 tmp_spec_p = tmp_spec;
4333 q = spec;
4334 while ((p = strstr (q, "%(VALUE)")) != NULL)
4336 memcpy (tmp_spec_p, q, p - q);
4337 tmp_spec_p = tmp_spec_p + (p - q);
4338 memcpy (tmp_spec_p, value, value_len);
4339 tmp_spec_p += value_len;
4340 q = p + strlen ("%(VALUE)");
4342 strcpy (tmp_spec_p, q);
4344 do_self_spec (tmp_spec);
4347 /* Process the given spec string and add any new options to the end
4348 of the switches/n_switches array. */
4350 static void
4351 do_self_spec (const char *spec)
4353 do_spec_2 (spec);
4354 do_spec_1 (" ", 0, NULL);
4356 if (argbuf_index > 0)
4358 int i, first;
4360 first = n_switches;
4361 n_switches += argbuf_index;
4362 switches = xrealloc (switches,
4363 sizeof (struct switchstr) * (n_switches + 1));
4365 switches[n_switches] = switches[first];
4366 for (i = 0; i < argbuf_index; i++)
4368 struct switchstr *sw;
4370 /* Each switch should start with '-'. */
4371 if (argbuf[i][0] != '-')
4372 fatal ("switch '%s' does not start with '-'", argbuf[i]);
4374 sw = &switches[i + first];
4375 sw->part1 = &argbuf[i][1];
4376 sw->args = 0;
4377 sw->live_cond = SWITCH_OK;
4378 sw->validated = 0;
4379 sw->ordering = 0;
4384 void
4385 do_spec_path (struct prefix_list *pl, const char *option,
4386 int omit_if_relative, int separate_options,
4387 int only_subdir,
4388 const char *dir_for_machine_suffix,
4389 const char *dir_for_no_suffix)
4391 static size_t bufsize = 0;
4392 static char *buffer;
4393 int idx;
4395 /* Used on systems which record the specified -L dirs
4396 and use them to search for dynamic linking. */
4397 /* Relative directories always come from -B,
4398 and it is better not to use them for searching
4399 at run time. In particular, stage1 loses. */
4400 if (omit_if_relative
4401 && !IS_ABSOLUTE_PATH (pl->prefix))
4402 return;
4404 /* Try subdirectory if there is one. */
4405 if (machine_suffix && dir_for_machine_suffix)
4407 if (strlen (pl->prefix) + strlen (machine_suffix)
4408 >= bufsize)
4409 bufsize = (strlen (pl->prefix)
4410 + strlen (machine_suffix)) * 2 + 1;
4411 buffer = xrealloc (buffer, bufsize);
4412 strcpy (buffer, pl->prefix);
4413 strcat (buffer, machine_suffix);
4414 if (is_directory (buffer, dir_for_machine_suffix, 1))
4416 do_spec_1 (option, separate_options, NULL);
4417 if (separate_options)
4418 do_spec_1 (" ", 0, NULL);
4419 do_spec_1 (buffer, 1, NULL);
4420 do_spec_1 (dir_for_machine_suffix, 1, NULL);
4421 /* Make this a separate argument. */
4422 do_spec_1 (" ", 0, NULL);
4425 if (!pl->require_machine_suffix && dir_for_no_suffix)
4427 if (is_directory (pl->prefix, dir_for_no_suffix, 1))
4429 do_spec_1 (option, separate_options, NULL);
4430 if (separate_options)
4431 do_spec_1 (" ", 0, NULL);
4432 do_spec_1 (pl->prefix, 1, NULL);
4433 do_spec_1 (dir_for_no_suffix, 1, NULL);
4434 /* Make this a separate argument. */
4435 do_spec_1 (" ", 0, NULL);
4439 if (only_subdir)
4440 return;
4442 if (machine_suffix)
4444 if (is_directory (pl->prefix, machine_suffix, 1))
4446 do_spec_1 (option, separate_options, NULL);
4447 if (separate_options)
4448 do_spec_1 (" ", 0, NULL);
4449 do_spec_1 (pl->prefix, 1, NULL);
4450 /* Remove slash from machine_suffix. */
4451 if (strlen (machine_suffix) >= bufsize)
4452 bufsize = strlen (machine_suffix) * 2 + 1;
4453 buffer = xrealloc (buffer, bufsize);
4454 strcpy (buffer, machine_suffix);
4455 idx = strlen (buffer);
4456 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4457 buffer[idx - 1] = 0;
4458 do_spec_1 (buffer, 1, NULL);
4459 /* Make this a separate argument. */
4460 do_spec_1 (" ", 0, NULL);
4463 if (!pl->require_machine_suffix)
4465 if (is_directory (pl->prefix, "", 1))
4467 do_spec_1 (option, separate_options, NULL);
4468 if (separate_options)
4469 do_spec_1 (" ", 0, NULL);
4470 /* Remove slash from pl->prefix. */
4471 if (strlen (pl->prefix) >= bufsize)
4472 bufsize = strlen (pl->prefix) * 2 + 1;
4473 buffer = xrealloc (buffer, bufsize);
4474 strcpy (buffer, pl->prefix);
4475 idx = strlen (buffer);
4476 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4477 buffer[idx - 1] = 0;
4478 do_spec_1 (buffer, 1, NULL);
4479 /* Make this a separate argument. */
4480 do_spec_1 (" ", 0, NULL);
4485 /* Process the sub-spec SPEC as a portion of a larger spec.
4486 This is like processing a whole spec except that we do
4487 not initialize at the beginning and we do not supply a
4488 newline by default at the end.
4489 INSWITCH nonzero means don't process %-sequences in SPEC;
4490 in this case, % is treated as an ordinary character.
4491 This is used while substituting switches.
4492 INSWITCH nonzero also causes SPC not to terminate an argument.
4494 Value is zero unless a line was finished
4495 and the command on that line reported an error. */
4497 static int
4498 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4500 const char *p = spec;
4501 int c;
4502 int i;
4503 const char *string;
4504 int value;
4506 while ((c = *p++))
4507 /* If substituting a switch, treat all chars like letters.
4508 Otherwise, NL, SPC, TAB and % are special. */
4509 switch (inswitch ? 'a' : c)
4511 case '\n':
4512 /* End of line: finish any pending argument,
4513 then run the pending command if one has been started. */
4514 if (arg_going)
4516 obstack_1grow (&obstack, 0);
4517 string = obstack_finish (&obstack);
4518 if (this_is_library_file)
4519 string = find_file (string);
4520 store_arg (string, delete_this_arg, this_is_output_file);
4521 if (this_is_output_file)
4522 outfiles[input_file_number] = string;
4524 arg_going = 0;
4526 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4528 /* A `|' before the newline means use a pipe here,
4529 but only if -pipe was specified.
4530 Otherwise, execute now and don't pass the `|' as an arg. */
4531 if (use_pipes)
4533 input_from_pipe = 1;
4534 break;
4536 else
4537 argbuf_index--;
4540 set_collect_gcc_options ();
4542 if (argbuf_index > 0)
4544 value = execute ();
4545 if (value)
4546 return value;
4548 /* Reinitialize for a new command, and for a new argument. */
4549 clear_args ();
4550 arg_going = 0;
4551 delete_this_arg = 0;
4552 this_is_output_file = 0;
4553 this_is_library_file = 0;
4554 input_from_pipe = 0;
4555 break;
4557 case '|':
4558 /* End any pending argument. */
4559 if (arg_going)
4561 obstack_1grow (&obstack, 0);
4562 string = obstack_finish (&obstack);
4563 if (this_is_library_file)
4564 string = find_file (string);
4565 store_arg (string, delete_this_arg, this_is_output_file);
4566 if (this_is_output_file)
4567 outfiles[input_file_number] = string;
4570 /* Use pipe */
4571 obstack_1grow (&obstack, c);
4572 arg_going = 1;
4573 break;
4575 case '\t':
4576 case ' ':
4577 /* Space or tab ends an argument if one is pending. */
4578 if (arg_going)
4580 obstack_1grow (&obstack, 0);
4581 string = obstack_finish (&obstack);
4582 if (this_is_library_file)
4583 string = find_file (string);
4584 store_arg (string, delete_this_arg, this_is_output_file);
4585 if (this_is_output_file)
4586 outfiles[input_file_number] = string;
4588 /* Reinitialize for a new argument. */
4589 arg_going = 0;
4590 delete_this_arg = 0;
4591 this_is_output_file = 0;
4592 this_is_library_file = 0;
4593 break;
4595 case '%':
4596 switch (c = *p++)
4598 case 0:
4599 fatal ("spec '%s' invalid", spec);
4601 case 'b':
4602 obstack_grow (&obstack, input_basename, basename_length);
4603 arg_going = 1;
4604 break;
4606 case 'B':
4607 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4608 arg_going = 1;
4609 break;
4611 case 'd':
4612 delete_this_arg = 2;
4613 break;
4615 /* Dump out the directories specified with LIBRARY_PATH,
4616 followed by the absolute directories
4617 that we search for startfiles. */
4618 case 'D':
4620 struct prefix_list *pl = startfile_prefixes.plist;
4622 for (; pl; pl = pl->next)
4624 const char *no_suffix_multilib_dir;
4626 no_suffix_multilib_dir = pl->os_multilib ? multilib_os_dir
4627 : multilib_dir;
4628 /* Do not separate options, include non-multilibbed variant. */
4629 do_spec_path (pl, "-L",
4630 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4632 #else
4634 #endif
4635 0, 0, multilib_dir, no_suffix_multilib_dir);
4638 break;
4640 case 'e':
4641 /* %efoo means report an error with `foo' as error message
4642 and don't execute any more commands for this file. */
4644 const char *q = p;
4645 char *buf;
4646 while (*p != 0 && *p != '\n')
4647 p++;
4648 buf = alloca (p - q + 1);
4649 strncpy (buf, q, p - q);
4650 buf[p - q] = 0;
4651 error ("%s", buf);
4652 return -1;
4654 break;
4655 case 'n':
4656 /* %nfoo means report a notice with `foo' on stderr. */
4658 const char *q = p;
4659 char *buf;
4660 while (*p != 0 && *p != '\n')
4661 p++;
4662 buf = alloca (p - q + 1);
4663 strncpy (buf, q, p - q);
4664 buf[p - q] = 0;
4665 notice ("%s\n", buf);
4666 if (*p)
4667 p++;
4669 break;
4671 case 'j':
4673 struct stat st;
4675 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4676 defined, and it is not a directory, and it is
4677 writable, use it. Otherwise, treat this like any
4678 other temporary file. */
4680 if ((!save_temps_flag)
4681 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4682 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4684 obstack_grow (&obstack, HOST_BIT_BUCKET,
4685 strlen (HOST_BIT_BUCKET));
4686 delete_this_arg = 0;
4687 arg_going = 1;
4688 break;
4691 goto create_temp_file;
4692 case '|':
4693 if (use_pipes)
4695 obstack_1grow (&obstack, '-');
4696 delete_this_arg = 0;
4697 arg_going = 1;
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 'm':
4709 if (use_pipes)
4711 /* consume suffix */
4712 while (*p == '.' || ISALPHA ((unsigned char) *p))
4713 p++;
4714 if (p[0] == '%' && p[1] == 'O')
4715 p += 2;
4717 break;
4719 goto create_temp_file;
4720 case 'g':
4721 case 'u':
4722 case 'U':
4723 create_temp_file:
4725 struct temp_name *t;
4726 int suffix_length;
4727 const char *suffix = p;
4728 char *saved_suffix = NULL;
4730 while (*p == '.' || ISALPHA ((unsigned char) *p))
4731 p++;
4732 suffix_length = p - suffix;
4733 if (p[0] == '%' && p[1] == 'O')
4735 p += 2;
4736 /* We don't support extra suffix characters after %O. */
4737 if (*p == '.' || ISALPHA ((unsigned char) *p))
4738 fatal ("spec '%s' has invalid '%%0%c'", spec, *p);
4739 if (suffix_length == 0)
4740 suffix = TARGET_OBJECT_SUFFIX;
4741 else
4743 saved_suffix
4744 = xmalloc (suffix_length
4745 + strlen (TARGET_OBJECT_SUFFIX));
4746 strncpy (saved_suffix, suffix, suffix_length);
4747 strcpy (saved_suffix + suffix_length,
4748 TARGET_OBJECT_SUFFIX);
4750 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4753 /* If the input_filename has the same suffix specified
4754 for the %g, %u, or %U, and -save-temps is specified,
4755 we could end up using that file as an intermediate
4756 thus clobbering the user's source file (.e.g.,
4757 gcc -save-temps foo.s would clobber foo.s with the
4758 output of cpp0). So check for this condition and
4759 generate a temp file as the intermediate. */
4761 if (save_temps_flag)
4763 temp_filename_length = basename_length + suffix_length;
4764 temp_filename = alloca (temp_filename_length + 1);
4765 strncpy ((char *) temp_filename, input_basename, basename_length);
4766 strncpy ((char *) temp_filename + basename_length, suffix,
4767 suffix_length);
4768 *((char *) temp_filename + temp_filename_length) = '\0';
4769 if (strcmp (temp_filename, input_filename) != 0)
4771 #ifndef HOST_LACKS_INODE_NUMBERS
4772 struct stat st_temp;
4774 /* Note, set_input() resets input_stat_set to 0. */
4775 if (input_stat_set == 0)
4777 input_stat_set = stat (input_filename, &input_stat);
4778 if (input_stat_set >= 0)
4779 input_stat_set = 1;
4782 /* If we have the stat for the input_filename
4783 and we can do the stat for the temp_filename
4784 then the they could still refer to the same
4785 file if st_dev/st_ino's are the same. */
4786 if (input_stat_set != 1
4787 || stat (temp_filename, &st_temp) < 0
4788 || input_stat.st_dev != st_temp.st_dev
4789 || input_stat.st_ino != st_temp.st_ino)
4790 #else
4791 /* Just compare canonical pathnames. */
4792 char* input_realname = lrealpath (input_filename);
4793 char* temp_realname = lrealpath (temp_filename);
4794 bool files_differ = strcmp (input_realname, temp_realname);
4795 free (input_realname);
4796 free (temp_realname);
4797 if (files_differ)
4798 #endif
4800 temp_filename = save_string (temp_filename,
4801 temp_filename_length + 1);
4802 obstack_grow (&obstack, temp_filename,
4803 temp_filename_length);
4804 arg_going = 1;
4805 delete_this_arg = 0;
4806 break;
4811 /* See if we already have an association of %g/%u/%U and
4812 suffix. */
4813 for (t = temp_names; t; t = t->next)
4814 if (t->length == suffix_length
4815 && strncmp (t->suffix, suffix, suffix_length) == 0
4816 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4817 break;
4819 /* Make a new association if needed. %u and %j
4820 require one. */
4821 if (t == 0 || c == 'u' || c == 'j')
4823 if (t == 0)
4825 t = xmalloc (sizeof (struct temp_name));
4826 t->next = temp_names;
4827 temp_names = t;
4829 t->length = suffix_length;
4830 if (saved_suffix)
4832 t->suffix = saved_suffix;
4833 saved_suffix = NULL;
4835 else
4836 t->suffix = save_string (suffix, suffix_length);
4837 t->unique = (c == 'u' || c == 'U' || c == 'j');
4838 temp_filename = make_temp_file (t->suffix);
4839 temp_filename_length = strlen (temp_filename);
4840 t->filename = temp_filename;
4841 t->filename_length = temp_filename_length;
4844 if (saved_suffix)
4845 free (saved_suffix);
4847 obstack_grow (&obstack, t->filename, t->filename_length);
4848 delete_this_arg = 1;
4850 arg_going = 1;
4851 break;
4853 case 'i':
4854 if (combine_inputs)
4856 for (i = 0; (int) i < n_infiles; i++)
4857 if ((!infiles[i].language) || (infiles[i].language[0] != '*'))
4858 if (infiles[i].incompiler == input_file_compiler)
4860 store_arg (infiles[i].name, 0, 0);
4861 infiles[i].compiled = true;
4864 else
4866 obstack_grow (&obstack, input_filename, input_filename_length);
4867 arg_going = 1;
4869 break;
4871 case 'I':
4873 struct prefix_list *pl = include_prefixes.plist;
4875 if (gcc_exec_prefix)
4877 do_spec_1 ("-iprefix", 1, NULL);
4878 /* Make this a separate argument. */
4879 do_spec_1 (" ", 0, NULL);
4880 do_spec_1 (gcc_exec_prefix, 1, NULL);
4881 do_spec_1 (" ", 0, NULL);
4884 if (target_system_root_changed ||
4885 (target_system_root && target_sysroot_hdrs_suffix))
4887 do_spec_1 ("-isysroot", 1, NULL);
4888 /* Make this a separate argument. */
4889 do_spec_1 (" ", 0, NULL);
4890 do_spec_1 (target_system_root, 1, NULL);
4891 if (target_sysroot_hdrs_suffix)
4892 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4893 do_spec_1 (" ", 0, NULL);
4896 for (; pl; pl = pl->next)
4897 /* Separate options, don't include non-suffixed variant. */
4898 do_spec_path (pl, "-isystem", 0, 1, 1, "include", "include");
4900 break;
4902 case 'o':
4904 int max = n_infiles;
4905 max += lang_specific_extra_outfiles;
4907 for (i = 0; i < max; i++)
4908 if (outfiles[i])
4909 store_arg (outfiles[i], 0, 0);
4910 break;
4913 case 'O':
4914 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4915 arg_going = 1;
4916 break;
4918 case 's':
4919 this_is_library_file = 1;
4920 break;
4922 case 'V':
4923 outfiles[input_file_number] = NULL;
4924 break;
4926 case 'w':
4927 this_is_output_file = 1;
4928 break;
4930 case 'W':
4932 int cur_index = argbuf_index;
4933 /* Handle the {...} following the %W. */
4934 if (*p != '{')
4935 fatal ("spec '%s' has invalid '%%W%c", spec, *p);
4936 p = handle_braces (p + 1);
4937 if (p == 0)
4938 return -1;
4939 /* End any pending argument. */
4940 if (arg_going)
4942 obstack_1grow (&obstack, 0);
4943 string = obstack_finish (&obstack);
4944 if (this_is_library_file)
4945 string = find_file (string);
4946 store_arg (string, delete_this_arg, this_is_output_file);
4947 if (this_is_output_file)
4948 outfiles[input_file_number] = string;
4949 arg_going = 0;
4951 /* If any args were output, mark the last one for deletion
4952 on failure. */
4953 if (argbuf_index != cur_index)
4954 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4955 break;
4958 /* %x{OPTION} records OPTION for %X to output. */
4959 case 'x':
4961 const char *p1 = p;
4962 char *string;
4964 /* Skip past the option value and make a copy. */
4965 if (*p != '{')
4966 fatal ("spec '%s' has invalid '%%x%c'", spec, *p);
4967 while (*p++ != '}')
4969 string = save_string (p1 + 1, p - p1 - 2);
4971 /* See if we already recorded this option. */
4972 for (i = 0; i < n_linker_options; i++)
4973 if (! strcmp (string, linker_options[i]))
4975 free (string);
4976 return 0;
4979 /* This option is new; add it. */
4980 add_linker_option (string, strlen (string));
4982 break;
4984 /* Dump out the options accumulated previously using %x. */
4985 case 'X':
4986 for (i = 0; i < n_linker_options; i++)
4988 do_spec_1 (linker_options[i], 1, NULL);
4989 /* Make each accumulated option a separate argument. */
4990 do_spec_1 (" ", 0, NULL);
4992 break;
4994 /* Dump out the options accumulated previously using -Wa,. */
4995 case 'Y':
4996 for (i = 0; i < n_assembler_options; i++)
4998 do_spec_1 (assembler_options[i], 1, NULL);
4999 /* Make each accumulated option a separate argument. */
5000 do_spec_1 (" ", 0, NULL);
5002 break;
5004 /* Dump out the options accumulated previously using -Wp,. */
5005 case 'Z':
5006 for (i = 0; i < n_preprocessor_options; i++)
5008 do_spec_1 (preprocessor_options[i], 1, NULL);
5009 /* Make each accumulated option a separate argument. */
5010 do_spec_1 (" ", 0, NULL);
5012 break;
5014 /* Here are digits and numbers that just process
5015 a certain constant string as a spec. */
5017 case '1':
5018 value = do_spec_1 (cc1_spec, 0, NULL);
5019 if (value != 0)
5020 return value;
5021 break;
5023 case '2':
5024 value = do_spec_1 (cc1plus_spec, 0, NULL);
5025 if (value != 0)
5026 return value;
5027 break;
5029 case 'a':
5030 value = do_spec_1 (asm_spec, 0, NULL);
5031 if (value != 0)
5032 return value;
5033 break;
5035 case 'A':
5036 value = do_spec_1 (asm_final_spec, 0, NULL);
5037 if (value != 0)
5038 return value;
5039 break;
5041 case 'C':
5043 const char *const spec
5044 = (input_file_compiler->cpp_spec
5045 ? input_file_compiler->cpp_spec
5046 : cpp_spec);
5047 value = do_spec_1 (spec, 0, NULL);
5048 if (value != 0)
5049 return value;
5051 break;
5053 case 'E':
5054 value = do_spec_1 (endfile_spec, 0, NULL);
5055 if (value != 0)
5056 return value;
5057 break;
5059 case 'l':
5060 value = do_spec_1 (link_spec, 0, NULL);
5061 if (value != 0)
5062 return value;
5063 break;
5065 case 'L':
5066 value = do_spec_1 (lib_spec, 0, NULL);
5067 if (value != 0)
5068 return value;
5069 break;
5071 case 'G':
5072 value = do_spec_1 (libgcc_spec, 0, NULL);
5073 if (value != 0)
5074 return value;
5075 break;
5077 case 'M':
5078 if (multilib_dir && strcmp (multilib_dir, ".") != 0)
5080 char *p;
5081 const char *q;
5082 size_t len;
5084 len = strlen (multilib_dir);
5085 obstack_blank (&obstack, len + 1);
5086 p = obstack_next_free (&obstack) - (len + 1);
5088 *p++ = '_';
5089 for (q = multilib_dir; *q ; ++q, ++p)
5090 *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
5092 break;
5094 case 'R':
5095 /* We assume there is a directory
5096 separator at the end of this string. */
5097 if (target_system_root)
5099 obstack_grow (&obstack, target_system_root,
5100 strlen (target_system_root));
5101 if (target_sysroot_suffix)
5102 obstack_grow (&obstack, target_sysroot_suffix,
5103 strlen (target_sysroot_suffix));
5105 break;
5107 case 'S':
5108 value = do_spec_1 (startfile_spec, 0, NULL);
5109 if (value != 0)
5110 return value;
5111 break;
5113 /* Here we define characters other than letters and digits. */
5115 case '{':
5116 p = handle_braces (p);
5117 if (p == 0)
5118 return -1;
5119 break;
5121 case ':':
5122 p = handle_spec_function (p);
5123 if (p == 0)
5124 return -1;
5125 break;
5127 case '%':
5128 obstack_1grow (&obstack, '%');
5129 break;
5131 case '.':
5133 unsigned len = 0;
5135 while (p[len] && p[len] != ' ' && p[len] != '%')
5136 len++;
5137 suffix_subst = save_string (p - 1, len + 1);
5138 p += len;
5140 break;
5142 /* Henceforth ignore the option(s) matching the pattern
5143 after the %<. */
5144 case '<':
5146 unsigned len = 0;
5147 int have_wildcard = 0;
5148 int i;
5150 while (p[len] && p[len] != ' ' && p[len] != '\t')
5151 len++;
5153 if (p[len-1] == '*')
5154 have_wildcard = 1;
5156 for (i = 0; i < n_switches; i++)
5157 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5158 && (have_wildcard || switches[i].part1[len] == '\0'))
5160 switches[i].live_cond = SWITCH_IGNORE;
5161 switches[i].validated = 1;
5164 p += len;
5166 break;
5168 case '*':
5169 if (soft_matched_part)
5171 do_spec_1 (soft_matched_part, 1, NULL);
5172 do_spec_1 (" ", 0, NULL);
5174 else
5175 /* Catch the case where a spec string contains something like
5176 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5177 hand side of the :. */
5178 error ("spec failure: '%%*' has not been initialized by pattern match");
5179 break;
5181 /* Process a string found as the value of a spec given by name.
5182 This feature allows individual machine descriptions
5183 to add and use their own specs.
5184 %[...] modifies -D options the way %P does;
5185 %(...) uses the spec unmodified. */
5186 case '[':
5187 error ("warning: use of obsolete %%[ operator in specs");
5188 case '(':
5190 const char *name = p;
5191 struct spec_list *sl;
5192 int len;
5194 /* The string after the S/P is the name of a spec that is to be
5195 processed. */
5196 while (*p && *p != ')' && *p != ']')
5197 p++;
5199 /* See if it's in the list. */
5200 for (len = p - name, sl = specs; sl; sl = sl->next)
5201 if (sl->name_len == len && !strncmp (sl->name, name, len))
5203 name = *(sl->ptr_spec);
5204 #ifdef DEBUG_SPECS
5205 notice ("Processing spec %c%s%c, which is '%s'\n",
5206 c, sl->name, (c == '(') ? ')' : ']', name);
5207 #endif
5208 break;
5211 if (sl)
5213 if (c == '(')
5215 value = do_spec_1 (name, 0, NULL);
5216 if (value != 0)
5217 return value;
5219 else
5221 char *x = alloca (strlen (name) * 2 + 1);
5222 char *buf = x;
5223 const char *y = name;
5224 int flag = 0;
5226 /* Copy all of NAME into BUF, but put __ after
5227 every -D and at the end of each arg. */
5228 while (1)
5230 if (! strncmp (y, "-D", 2))
5232 *x++ = '-';
5233 *x++ = 'D';
5234 *x++ = '_';
5235 *x++ = '_';
5236 y += 2;
5237 flag = 1;
5238 continue;
5240 else if (flag
5241 && (*y == ' ' || *y == '\t' || *y == '='
5242 || *y == '}' || *y == 0))
5244 *x++ = '_';
5245 *x++ = '_';
5246 flag = 0;
5248 if (*y == 0)
5249 break;
5250 else
5251 *x++ = *y++;
5253 *x = 0;
5255 value = do_spec_1 (buf, 0, NULL);
5256 if (value != 0)
5257 return value;
5261 /* Discard the closing paren or bracket. */
5262 if (*p)
5263 p++;
5265 break;
5267 default:
5268 error ("spec failure: unrecognized spec option '%c'", c);
5269 break;
5271 break;
5273 case '\\':
5274 /* Backslash: treat next character as ordinary. */
5275 c = *p++;
5277 /* Fall through. */
5278 default:
5279 /* Ordinary character: put it into the current argument. */
5280 obstack_1grow (&obstack, c);
5281 arg_going = 1;
5284 /* End of string. If we are processing a spec function, we need to
5285 end any pending argument. */
5286 if (processing_spec_function && arg_going)
5288 obstack_1grow (&obstack, 0);
5289 string = obstack_finish (&obstack);
5290 if (this_is_library_file)
5291 string = find_file (string);
5292 store_arg (string, delete_this_arg, this_is_output_file);
5293 if (this_is_output_file)
5294 outfiles[input_file_number] = string;
5295 arg_going = 0;
5298 return 0;
5301 /* Look up a spec function. */
5303 static const struct spec_function *
5304 lookup_spec_function (const char *name)
5306 static const struct spec_function * const spec_function_tables[] =
5308 static_spec_functions,
5309 lang_specific_spec_functions,
5311 const struct spec_function *sf;
5312 unsigned int i;
5314 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5316 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5317 if (strcmp (sf->name, name) == 0)
5318 return sf;
5321 return NULL;
5324 /* Evaluate a spec function. */
5326 static const char *
5327 eval_spec_function (const char *func, const char *args)
5329 const struct spec_function *sf;
5330 const char *funcval;
5332 /* Saved spec processing context. */
5333 int save_argbuf_index;
5334 int save_argbuf_length;
5335 const char **save_argbuf;
5337 int save_arg_going;
5338 int save_delete_this_arg;
5339 int save_this_is_output_file;
5340 int save_this_is_library_file;
5341 int save_input_from_pipe;
5342 const char *save_suffix_subst;
5345 sf = lookup_spec_function (func);
5346 if (sf == NULL)
5347 fatal ("unknown spec function '%s'", func);
5349 /* Push the spec processing context. */
5350 save_argbuf_index = argbuf_index;
5351 save_argbuf_length = argbuf_length;
5352 save_argbuf = argbuf;
5354 save_arg_going = arg_going;
5355 save_delete_this_arg = delete_this_arg;
5356 save_this_is_output_file = this_is_output_file;
5357 save_this_is_library_file = this_is_library_file;
5358 save_input_from_pipe = input_from_pipe;
5359 save_suffix_subst = suffix_subst;
5361 /* Create a new spec processing context, and build the function
5362 arguments. */
5364 alloc_args ();
5365 if (do_spec_2 (args) < 0)
5366 fatal ("error in args to spec function '%s'", func);
5368 /* argbuf_index is an index for the next argument to be inserted, and
5369 so contains the count of the args already inserted. */
5371 funcval = (*sf->func) (argbuf_index, argbuf);
5373 /* Pop the spec processing context. */
5374 argbuf_index = save_argbuf_index;
5375 argbuf_length = save_argbuf_length;
5376 free (argbuf);
5377 argbuf = save_argbuf;
5379 arg_going = save_arg_going;
5380 delete_this_arg = save_delete_this_arg;
5381 this_is_output_file = save_this_is_output_file;
5382 this_is_library_file = save_this_is_library_file;
5383 input_from_pipe = save_input_from_pipe;
5384 suffix_subst = save_suffix_subst;
5386 return funcval;
5389 /* Handle a spec function call of the form:
5391 %:function(args)
5393 ARGS is processed as a spec in a separate context and split into an
5394 argument vector in the normal fashion. The function returns a string
5395 containing a spec which we then process in the caller's context, or
5396 NULL if no processing is required. */
5398 static const char *
5399 handle_spec_function (const char *p)
5401 char *func, *args;
5402 const char *endp, *funcval;
5403 int count;
5405 processing_spec_function++;
5407 /* Get the function name. */
5408 for (endp = p; *endp != '\0'; endp++)
5410 if (*endp == '(') /* ) */
5411 break;
5412 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5413 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5414 fatal ("malformed spec function name");
5416 if (*endp != '(') /* ) */
5417 fatal ("no arguments for spec function");
5418 func = save_string (p, endp - p);
5419 p = ++endp;
5421 /* Get the arguments. */
5422 for (count = 0; *endp != '\0'; endp++)
5424 /* ( */
5425 if (*endp == ')')
5427 if (count == 0)
5428 break;
5429 count--;
5431 else if (*endp == '(') /* ) */
5432 count++;
5434 /* ( */
5435 if (*endp != ')')
5436 fatal ("malformed spec function arguments");
5437 args = save_string (p, endp - p);
5438 p = ++endp;
5440 /* p now points to just past the end of the spec function expression. */
5442 funcval = eval_spec_function (func, args);
5443 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5444 p = NULL;
5446 free (func);
5447 free (args);
5449 processing_spec_function--;
5451 return p;
5454 /* Inline subroutine of handle_braces. Returns true if the current
5455 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5456 static inline bool
5457 input_suffix_matches (const char *atom, const char *end_atom)
5459 return (input_suffix
5460 && !strncmp (input_suffix, atom, end_atom - atom)
5461 && input_suffix[end_atom - atom] == '\0');
5464 /* Inline subroutine of handle_braces. Returns true if a switch
5465 matching the atom bracketed by ATOM and END_ATOM appeared on the
5466 command line. */
5467 static inline bool
5468 switch_matches (const char *atom, const char *end_atom, int starred)
5470 int i;
5471 int len = end_atom - atom;
5472 int plen = starred ? len : -1;
5474 for (i = 0; i < n_switches; i++)
5475 if (!strncmp (switches[i].part1, atom, len)
5476 && (starred || switches[i].part1[len] == '\0')
5477 && check_live_switch (i, plen))
5478 return true;
5480 return false;
5483 /* Inline subroutine of handle_braces. Mark all of the switches which
5484 match ATOM (extends to END_ATOM; STARRED indicates whether there
5485 was a star after the atom) for later processing. */
5486 static inline void
5487 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5489 int i;
5490 int len = end_atom - atom;
5491 int plen = starred ? len : -1;
5493 for (i = 0; i < n_switches; i++)
5494 if (!strncmp (switches[i].part1, atom, len)
5495 && (starred || switches[i].part1[len] == '\0')
5496 && check_live_switch (i, plen))
5497 switches[i].ordering = 1;
5500 /* Inline subroutine of handle_braces. Process all the currently
5501 marked switches through give_switch, and clear the marks. */
5502 static inline void
5503 process_marked_switches (void)
5505 int i;
5507 for (i = 0; i < n_switches; i++)
5508 if (switches[i].ordering == 1)
5510 switches[i].ordering = 0;
5511 give_switch (i, 0);
5515 /* Handle a %{ ... } construct. P points just inside the leading {.
5516 Returns a pointer one past the end of the brace block, or 0
5517 if we call do_spec_1 and that returns -1. */
5519 static const char *
5520 handle_braces (const char *p)
5522 const char *atom, *end_atom;
5523 const char *d_atom = NULL, *d_end_atom = NULL;
5524 const char *orig = p;
5526 bool a_is_suffix;
5527 bool a_is_starred;
5528 bool a_is_negated;
5529 bool a_matched;
5531 bool a_must_be_last = false;
5532 bool ordered_set = false;
5533 bool disjunct_set = false;
5534 bool disj_matched = false;
5535 bool disj_starred = true;
5536 bool n_way_choice = false;
5537 bool n_way_matched = false;
5539 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5543 if (a_must_be_last)
5544 goto invalid;
5546 /* Scan one "atom" (S in the description above of %{}, possibly
5547 with !, ., or * modifiers). */
5548 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5550 SKIP_WHITE();
5551 if (*p == '!')
5552 p++, a_is_negated = true;
5554 SKIP_WHITE();
5555 if (*p == '.')
5556 p++, a_is_suffix = true;
5558 atom = p;
5559 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5560 || *p == ',' || *p == '.' || *p == '@')
5561 p++;
5562 end_atom = p;
5564 if (*p == '*')
5565 p++, a_is_starred = 1;
5567 SKIP_WHITE();
5568 switch (*p)
5570 case '&': case '}':
5571 /* Substitute the switch(es) indicated by the current atom. */
5572 ordered_set = true;
5573 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5574 || atom == end_atom)
5575 goto invalid;
5577 mark_matching_switches (atom, end_atom, a_is_starred);
5579 if (*p == '}')
5580 process_marked_switches ();
5581 break;
5583 case '|': case ':':
5584 /* Substitute some text if the current atom appears as a switch
5585 or suffix. */
5586 disjunct_set = true;
5587 if (ordered_set)
5588 goto invalid;
5590 if (atom == end_atom)
5592 if (!n_way_choice || disj_matched || *p == '|'
5593 || a_is_negated || a_is_suffix || a_is_starred)
5594 goto invalid;
5596 /* An empty term may appear as the last choice of an
5597 N-way choice set; it means "otherwise". */
5598 a_must_be_last = true;
5599 disj_matched = !n_way_matched;
5600 disj_starred = false;
5602 else
5604 if (a_is_suffix && a_is_starred)
5605 goto invalid;
5607 if (!a_is_starred)
5608 disj_starred = false;
5610 /* Don't bother testing this atom if we already have a
5611 match. */
5612 if (!disj_matched && !n_way_matched)
5614 if (a_is_suffix)
5615 a_matched = input_suffix_matches (atom, end_atom);
5616 else
5617 a_matched = switch_matches (atom, end_atom, a_is_starred);
5619 if (a_matched != a_is_negated)
5621 disj_matched = true;
5622 d_atom = atom;
5623 d_end_atom = end_atom;
5628 if (*p == ':')
5630 /* Found the body, that is, the text to substitute if the
5631 current disjunction matches. */
5632 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5633 disj_matched && !n_way_matched);
5634 if (p == 0)
5635 return 0;
5637 /* If we have an N-way choice, reset state for the next
5638 disjunction. */
5639 if (*p == ';')
5641 n_way_choice = true;
5642 n_way_matched |= disj_matched;
5643 disj_matched = false;
5644 disj_starred = true;
5645 d_atom = d_end_atom = NULL;
5648 break;
5650 default:
5651 goto invalid;
5654 while (*p++ != '}');
5656 return p;
5658 invalid:
5659 fatal ("braced spec '%s' is invalid at '%c'", orig, *p);
5661 #undef SKIP_WHITE
5664 /* Subroutine of handle_braces. Scan and process a brace substitution body
5665 (X in the description of %{} syntax). P points one past the colon;
5666 ATOM and END_ATOM bracket the first atom which was found to be true
5667 (present) in the current disjunction; STARRED indicates whether all
5668 the atoms in the current disjunction were starred (for syntax validation);
5669 MATCHED indicates whether the disjunction matched or not, and therefore
5670 whether or not the body is to be processed through do_spec_1 or just
5671 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5672 returns -1. */
5674 static const char *
5675 process_brace_body (const char *p, const char *atom, const char *end_atom,
5676 int starred, int matched)
5678 const char *body, *end_body;
5679 unsigned int nesting_level;
5680 bool have_subst = false;
5682 /* Locate the closing } or ;, honoring nested braces.
5683 Trim trailing whitespace. */
5684 body = p;
5685 nesting_level = 1;
5686 for (;;)
5688 if (*p == '{')
5689 nesting_level++;
5690 else if (*p == '}')
5692 if (!--nesting_level)
5693 break;
5695 else if (*p == ';' && nesting_level == 1)
5696 break;
5697 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5698 have_subst = true;
5699 else if (*p == '\0')
5700 goto invalid;
5701 p++;
5704 end_body = p;
5705 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5706 end_body--;
5708 if (have_subst && !starred)
5709 goto invalid;
5711 if (matched)
5713 /* Copy the substitution body to permanent storage and execute it.
5714 If have_subst is false, this is a simple matter of running the
5715 body through do_spec_1... */
5716 char *string = save_string (body, end_body - body);
5717 if (!have_subst)
5719 if (do_spec_1 (string, 0, NULL) < 0)
5720 return 0;
5722 else
5724 /* ... but if have_subst is true, we have to process the
5725 body once for each matching switch, with %* set to the
5726 variant part of the switch. */
5727 unsigned int hard_match_len = end_atom - atom;
5728 int i;
5730 for (i = 0; i < n_switches; i++)
5731 if (!strncmp (switches[i].part1, atom, hard_match_len)
5732 && check_live_switch (i, hard_match_len))
5734 if (do_spec_1 (string, 0,
5735 &switches[i].part1[hard_match_len]) < 0)
5736 return 0;
5737 /* Pass any arguments this switch has. */
5738 give_switch (i, 1);
5739 suffix_subst = NULL;
5744 return p;
5746 invalid:
5747 fatal ("braced spec body '%s' is invalid", body);
5750 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5751 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5752 spec, or -1 if either exact match or %* is used.
5754 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5755 whose value does not begin with "no-" is obsoleted by the same value
5756 with the "no-", similarly for a switch with the "no-" prefix. */
5758 static int
5759 check_live_switch (int switchnum, int prefix_length)
5761 const char *name = switches[switchnum].part1;
5762 int i;
5764 /* In the common case of {<at-most-one-letter>*}, a negating
5765 switch would always match, so ignore that case. We will just
5766 send the conflicting switches to the compiler phase. */
5767 if (prefix_length >= 0 && prefix_length <= 1)
5768 return 1;
5770 /* If we already processed this switch and determined if it was
5771 live or not, return our past determination. */
5772 if (switches[switchnum].live_cond != 0)
5773 return switches[switchnum].live_cond > 0;
5775 /* Now search for duplicate in a manner that depends on the name. */
5776 switch (*name)
5778 case 'O':
5779 for (i = switchnum + 1; i < n_switches; i++)
5780 if (switches[i].part1[0] == 'O')
5782 switches[switchnum].validated = 1;
5783 switches[switchnum].live_cond = SWITCH_FALSE;
5784 return 0;
5786 break;
5788 case 'W': case 'f': case 'm':
5789 if (! strncmp (name + 1, "no-", 3))
5791 /* We have Xno-YYY, search for XYYY. */
5792 for (i = switchnum + 1; i < n_switches; i++)
5793 if (switches[i].part1[0] == name[0]
5794 && ! strcmp (&switches[i].part1[1], &name[4]))
5796 switches[switchnum].validated = 1;
5797 switches[switchnum].live_cond = SWITCH_FALSE;
5798 return 0;
5801 else
5803 /* We have XYYY, search for Xno-YYY. */
5804 for (i = switchnum + 1; i < n_switches; i++)
5805 if (switches[i].part1[0] == name[0]
5806 && switches[i].part1[1] == 'n'
5807 && switches[i].part1[2] == 'o'
5808 && switches[i].part1[3] == '-'
5809 && !strcmp (&switches[i].part1[4], &name[1]))
5811 switches[switchnum].validated = 1;
5812 switches[switchnum].live_cond = SWITCH_FALSE;
5813 return 0;
5816 break;
5819 /* Otherwise the switch is live. */
5820 switches[switchnum].live_cond = SWITCH_LIVE;
5821 return 1;
5824 /* Pass a switch to the current accumulating command
5825 in the same form that we received it.
5826 SWITCHNUM identifies the switch; it is an index into
5827 the vector of switches gcc received, which is `switches'.
5828 This cannot fail since it never finishes a command line.
5830 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5832 static void
5833 give_switch (int switchnum, int omit_first_word)
5835 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5836 return;
5838 if (!omit_first_word)
5840 do_spec_1 ("-", 0, NULL);
5841 do_spec_1 (switches[switchnum].part1, 1, NULL);
5844 if (switches[switchnum].args != 0)
5846 const char **p;
5847 for (p = switches[switchnum].args; *p; p++)
5849 const char *arg = *p;
5851 do_spec_1 (" ", 0, NULL);
5852 if (suffix_subst)
5854 unsigned length = strlen (arg);
5855 int dot = 0;
5857 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5858 if (arg[length] == '.')
5860 ((char *)arg)[length] = 0;
5861 dot = 1;
5862 break;
5864 do_spec_1 (arg, 1, NULL);
5865 if (dot)
5866 ((char *)arg)[length] = '.';
5867 do_spec_1 (suffix_subst, 1, NULL);
5869 else
5870 do_spec_1 (arg, 1, NULL);
5874 do_spec_1 (" ", 0, NULL);
5875 switches[switchnum].validated = 1;
5878 /* Search for a file named NAME trying various prefixes including the
5879 user's -B prefix and some standard ones.
5880 Return the absolute file name found. If nothing is found, return NAME. */
5882 static const char *
5883 find_file (const char *name)
5885 char *newname;
5887 /* Try multilib_dir if it is defined. */
5888 if (multilib_os_dir != NULL)
5890 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
5892 /* If we don't find it in the multi library dir, then fall
5893 through and look for it in the normal places. */
5894 if (newname != NULL)
5895 return newname;
5898 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
5899 return newname ? newname : name;
5902 /* Determine whether a directory exists. If LINKER, return 0 for
5903 certain fixed names not needed by the linker. If not LINKER, it is
5904 only important to return 0 if the host machine has a small ARG_MAX
5905 limit. */
5907 static int
5908 is_directory (const char *path1, const char *path2, int linker)
5910 int len1 = strlen (path1);
5911 int len2 = strlen (path2);
5912 char *path = alloca (3 + len1 + len2);
5913 char *cp;
5914 struct stat st;
5916 #ifndef SMALL_ARG_MAX
5917 if (! linker)
5918 return 1;
5919 #endif
5921 /* Construct the path from the two parts. Ensure the string ends with "/.".
5922 The resulting path will be a directory even if the given path is a
5923 symbolic link. */
5924 memcpy (path, path1, len1);
5925 memcpy (path + len1, path2, len2);
5926 cp = path + len1 + len2;
5927 if (!IS_DIR_SEPARATOR (cp[-1]))
5928 *cp++ = DIR_SEPARATOR;
5929 *cp++ = '.';
5930 *cp = '\0';
5932 /* Exclude directories that the linker is known to search. */
5933 if (linker
5934 && ((cp - path == 6
5935 && strcmp (path, concat (dir_separator_str, "lib",
5936 dir_separator_str, ".", NULL)) == 0)
5937 || (cp - path == 10
5938 && strcmp (path, concat (dir_separator_str, "usr",
5939 dir_separator_str, "lib",
5940 dir_separator_str, ".", NULL)) == 0)))
5941 return 0;
5943 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5946 /* Set up the various global variables to indicate that we're processing
5947 the input file named FILENAME. */
5949 void
5950 set_input (const char *filename)
5952 const char *p;
5954 input_filename = filename;
5955 input_filename_length = strlen (input_filename);
5957 input_basename = input_filename;
5958 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5959 /* Skip drive name so 'x:foo' is handled properly. */
5960 if (input_basename[1] == ':')
5961 input_basename += 2;
5962 #endif
5963 for (p = input_basename; *p; p++)
5964 if (IS_DIR_SEPARATOR (*p))
5965 input_basename = p + 1;
5967 /* Find a suffix starting with the last period,
5968 and set basename_length to exclude that suffix. */
5969 basename_length = strlen (input_basename);
5970 suffixed_basename_length = basename_length;
5971 p = input_basename + basename_length;
5972 while (p != input_basename && *p != '.')
5973 --p;
5974 if (*p == '.' && p != input_basename)
5976 basename_length = p - input_basename;
5977 input_suffix = p + 1;
5979 else
5980 input_suffix = "";
5982 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5983 we will need to do a stat on the input_filename. The
5984 INPUT_STAT_SET signals that the stat is needed. */
5985 input_stat_set = 0;
5988 /* On fatal signals, delete all the temporary files. */
5990 static void
5991 fatal_error (int signum)
5993 signal (signum, SIG_DFL);
5994 delete_failure_queue ();
5995 delete_temp_files ();
5996 /* Get the same signal again, this time not handled,
5997 so its normal effect occurs. */
5998 kill (getpid (), signum);
6001 extern int main (int, const char **);
6004 main (int argc, const char **argv)
6006 size_t i;
6007 int value;
6008 int linker_was_run = 0;
6009 int lang_n_infiles = 0;
6010 int num_linker_inputs = 0;
6011 char *explicit_link_files;
6012 char *specs_file;
6013 const char *p;
6014 struct user_specs *uptr;
6016 p = argv[0] + strlen (argv[0]);
6017 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6018 --p;
6019 programname = p;
6021 xmalloc_set_program_name (programname);
6023 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6024 /* Perform host dependent initialization when needed. */
6025 GCC_DRIVER_HOST_INITIALIZATION;
6026 #endif
6028 gcc_init_libintl ();
6030 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6031 signal (SIGINT, fatal_error);
6032 #ifdef SIGHUP
6033 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6034 signal (SIGHUP, fatal_error);
6035 #endif
6036 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6037 signal (SIGTERM, fatal_error);
6038 #ifdef SIGPIPE
6039 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6040 signal (SIGPIPE, fatal_error);
6041 #endif
6042 #ifdef SIGCHLD
6043 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6044 receive the signal. A different setting is inheritable */
6045 signal (SIGCHLD, SIG_DFL);
6046 #endif
6048 /* Allocate the argument vector. */
6049 alloc_args ();
6051 obstack_init (&obstack);
6053 /* Build multilib_select, et. al from the separate lines that make up each
6054 multilib selection. */
6056 const char *const *q = multilib_raw;
6057 int need_space;
6059 obstack_init (&multilib_obstack);
6060 while ((p = *q++) != (char *) 0)
6061 obstack_grow (&multilib_obstack, p, strlen (p));
6063 obstack_1grow (&multilib_obstack, 0);
6064 multilib_select = obstack_finish (&multilib_obstack);
6066 q = multilib_matches_raw;
6067 while ((p = *q++) != (char *) 0)
6068 obstack_grow (&multilib_obstack, p, strlen (p));
6070 obstack_1grow (&multilib_obstack, 0);
6071 multilib_matches = obstack_finish (&multilib_obstack);
6073 q = multilib_exclusions_raw;
6074 while ((p = *q++) != (char *) 0)
6075 obstack_grow (&multilib_obstack, p, strlen (p));
6077 obstack_1grow (&multilib_obstack, 0);
6078 multilib_exclusions = obstack_finish (&multilib_obstack);
6080 need_space = FALSE;
6081 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6083 if (need_space)
6084 obstack_1grow (&multilib_obstack, ' ');
6085 obstack_grow (&multilib_obstack,
6086 multilib_defaults_raw[i],
6087 strlen (multilib_defaults_raw[i]));
6088 need_space = TRUE;
6091 obstack_1grow (&multilib_obstack, 0);
6092 multilib_defaults = obstack_finish (&multilib_obstack);
6095 /* Set up to remember the pathname of gcc and any options
6096 needed for collect. We use argv[0] instead of programname because
6097 we need the complete pathname. */
6098 obstack_init (&collect_obstack);
6099 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6100 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6101 putenv (obstack_finish (&collect_obstack));
6103 #ifdef INIT_ENVIRONMENT
6104 /* Set up any other necessary machine specific environment variables. */
6105 putenv (INIT_ENVIRONMENT);
6106 #endif
6108 /* Make a table of what switches there are (switches, n_switches).
6109 Make a table of specified input files (infiles, n_infiles).
6110 Decode switches that are handled locally. */
6112 process_command (argc, argv);
6114 /* Initialize the vector of specs to just the default.
6115 This means one element containing 0s, as a terminator. */
6117 compilers = xmalloc (sizeof default_compilers);
6118 memcpy (compilers, default_compilers, sizeof default_compilers);
6119 n_compilers = n_default_compilers;
6121 /* Read specs from a file if there is one. */
6123 machine_suffix = concat (spec_machine, dir_separator_str,
6124 spec_version, dir_separator_str, NULL);
6125 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6127 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6128 /* Read the specs file unless it is a default one. */
6129 if (specs_file != 0 && strcmp (specs_file, "specs"))
6130 read_specs (specs_file, TRUE);
6131 else
6132 init_spec ();
6134 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6135 for any override of as, ld and libraries. */
6136 specs_file = alloca (strlen (standard_exec_prefix)
6137 + strlen (just_machine_suffix) + sizeof ("specs"));
6139 strcpy (specs_file, standard_exec_prefix);
6140 strcat (specs_file, just_machine_suffix);
6141 strcat (specs_file, "specs");
6142 if (access (specs_file, R_OK) == 0)
6143 read_specs (specs_file, TRUE);
6145 /* Process any configure-time defaults specified for the command line
6146 options, via OPTION_DEFAULT_SPECS. */
6147 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6148 do_option_spec (option_default_specs[i].name,
6149 option_default_specs[i].spec);
6151 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6152 of the command line. */
6154 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6155 do_self_spec (driver_self_specs[i]);
6157 /* If not cross-compiling, look for executables in the standard
6158 places. */
6159 if (*cross_compile == '0')
6161 if (*md_exec_prefix)
6163 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6164 PREFIX_PRIORITY_LAST, 0, 0);
6168 /* Process sysroot_suffix_spec. */
6169 if (*sysroot_suffix_spec != 0
6170 && do_spec_2 (sysroot_suffix_spec) == 0)
6172 if (argbuf_index > 1)
6173 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC.");
6174 else if (argbuf_index == 1)
6175 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6178 /* Process sysroot_hdrs_suffix_spec. */
6179 if (*sysroot_hdrs_suffix_spec != 0
6180 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6182 if (argbuf_index > 1)
6183 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC.");
6184 else if (argbuf_index == 1)
6185 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6188 /* Look for startfiles in the standard places. */
6189 if (*startfile_prefix_spec != 0
6190 && do_spec_2 (startfile_prefix_spec) == 0
6191 && do_spec_1 (" ", 0, NULL) == 0)
6193 int ndx;
6194 for (ndx = 0; ndx < argbuf_index; ndx++)
6195 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6196 PREFIX_PRIORITY_LAST, 0, 1);
6198 /* We should eventually get rid of all these and stick to
6199 startfile_prefix_spec exclusively. */
6200 else if (*cross_compile == '0' || target_system_root)
6202 if (*md_exec_prefix)
6203 add_sysrooted_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
6204 PREFIX_PRIORITY_LAST, 0, 1);
6206 if (*md_startfile_prefix)
6207 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6208 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6210 if (*md_startfile_prefix_1)
6211 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6212 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6214 /* If standard_startfile_prefix is relative, base it on
6215 standard_exec_prefix. This lets us move the installed tree
6216 as a unit. If GCC_EXEC_PREFIX is defined, base
6217 standard_startfile_prefix on that as well.
6219 If the prefix is relative, only search it for native compilers;
6220 otherwise we will search a directory containing host libraries. */
6221 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6222 add_sysrooted_prefix (&startfile_prefixes,
6223 standard_startfile_prefix, "BINUTILS",
6224 PREFIX_PRIORITY_LAST, 0, 1);
6225 else if (*cross_compile == '0')
6227 if (gcc_exec_prefix)
6228 add_prefix (&startfile_prefixes,
6229 concat (gcc_exec_prefix, machine_suffix,
6230 standard_startfile_prefix, NULL),
6231 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6232 add_prefix (&startfile_prefixes,
6233 concat (standard_exec_prefix,
6234 machine_suffix,
6235 standard_startfile_prefix, NULL),
6236 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6239 if (*standard_startfile_prefix_1)
6240 add_sysrooted_prefix (&startfile_prefixes,
6241 standard_startfile_prefix_1, "BINUTILS",
6242 PREFIX_PRIORITY_LAST, 0, 1);
6243 if (*standard_startfile_prefix_2)
6244 add_sysrooted_prefix (&startfile_prefixes,
6245 standard_startfile_prefix_2, "BINUTILS",
6246 PREFIX_PRIORITY_LAST, 0, 1);
6249 /* Process any user specified specs in the order given on the command
6250 line. */
6251 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6253 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6254 R_OK, 0);
6255 read_specs (filename ? filename : uptr->filename, FALSE);
6258 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6259 if (gcc_exec_prefix)
6260 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6261 spec_version, dir_separator_str, NULL);
6263 /* Now we have the specs.
6264 Set the `valid' bits for switches that match anything in any spec. */
6266 validate_all_switches ();
6268 /* Now that we have the switches and the specs, set
6269 the subdirectory based on the options. */
6270 set_multilib_dir ();
6272 /* Warn about any switches that no pass was interested in. */
6274 for (i = 0; (int) i < n_switches; i++)
6275 if (! switches[i].validated)
6276 error ("unrecognized option '-%s'", switches[i].part1);
6278 /* Obey some of the options. */
6280 if (print_search_dirs)
6282 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6283 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6284 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6285 return (0);
6288 if (print_file_name)
6290 printf ("%s\n", find_file (print_file_name));
6291 return (0);
6294 if (print_prog_name)
6296 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6297 printf ("%s\n", (newname ? newname : print_prog_name));
6298 return (0);
6301 if (print_multi_lib)
6303 print_multilib_info ();
6304 return (0);
6307 if (print_multi_directory)
6309 if (multilib_dir == NULL)
6310 printf (".\n");
6311 else
6312 printf ("%s\n", multilib_dir);
6313 return (0);
6316 if (print_multi_os_directory)
6318 if (multilib_os_dir == NULL)
6319 printf (".\n");
6320 else
6321 printf ("%s\n", multilib_os_dir);
6322 return (0);
6325 if (target_help_flag)
6327 /* Print if any target specific options. */
6329 /* We do not exit here. Instead we have created a fake input file
6330 called 'target-dummy' which needs to be compiled, and we pass this
6331 on to the various sub-processes, along with the --target-help
6332 switch. */
6335 if (print_help_list)
6337 display_help ();
6339 if (! verbose_flag)
6341 printf (_("\nFor bug reporting instructions, please see:\n"));
6342 printf ("%s.\n", bug_report_url);
6344 return (0);
6347 /* We do not exit here. Instead we have created a fake input file
6348 called 'help-dummy' which needs to be compiled, and we pass this
6349 on the various sub-processes, along with the --help switch. */
6352 if (verbose_flag)
6354 int n;
6355 const char *thrmod;
6357 notice ("Configured with: %s\n", configuration_arguments);
6359 #ifdef THREAD_MODEL_SPEC
6360 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6361 but there's no point in doing all this processing just to get
6362 thread_model back. */
6363 obstack_init (&obstack);
6364 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6365 obstack_1grow (&obstack, '\0');
6366 thrmod = obstack_finish (&obstack);
6367 #else
6368 thrmod = thread_model;
6369 #endif
6371 notice ("Thread model: %s\n", thrmod);
6373 /* compiler_version is truncated at the first space when initialized
6374 from version string, so truncate version_string at the first space
6375 before comparing. */
6376 for (n = 0; version_string[n]; n++)
6377 if (version_string[n] == ' ')
6378 break;
6380 if (! strncmp (version_string, compiler_version, n)
6381 && compiler_version[n] == 0)
6382 notice ("gcc version %s\n", version_string);
6383 else
6384 notice ("gcc driver version %s executing gcc version %s\n",
6385 version_string, compiler_version);
6387 if (n_infiles == 0)
6388 return (0);
6391 if (n_infiles == added_libraries)
6392 fatal ("no input files");
6394 /* Make a place to record the compiler output file names
6395 that correspond to the input files. */
6397 i = n_infiles;
6398 i += lang_specific_extra_outfiles;
6399 outfiles = xcalloc (i, sizeof (char *));
6401 /* Record which files were specified explicitly as link input. */
6403 explicit_link_files = xcalloc (1, n_infiles);
6405 if (combine_flag)
6406 combine_inputs = true;
6407 else
6408 combine_inputs = false;
6410 for (i = 0; (int) i < n_infiles; i++)
6412 const char *name = infiles[i].name;
6413 struct compiler *compiler = lookup_compiler (name,
6414 strlen (name),
6415 infiles[i].language);
6417 if (compiler && !(compiler->combinable))
6418 combine_inputs = false;
6420 if (lang_n_infiles > 0 && compiler != input_file_compiler
6421 && infiles[i].language && infiles[i].language[0] != '*')
6422 infiles[i].incompiler = compiler;
6423 else if (compiler)
6425 lang_n_infiles++;
6426 input_file_compiler = compiler;
6427 infiles[i].incompiler = compiler;
6429 else
6431 /* Since there is no compiler for this input file, assume it is a
6432 linker file. */
6433 explicit_link_files[i] = 1;
6434 infiles[i].incompiler = NULL;
6436 infiles[i].compiled = false;
6437 infiles[i].preprocessed = false;
6440 if (combine_flag && save_temps_flag)
6442 bool save_combine_inputs = combine_inputs;
6443 /* Must do a separate pre-processing pass for C & Objective-C files, to
6444 obtain individual .i files. */
6446 combine_inputs = false;
6447 for (i = 0; (int) i < n_infiles; i++)
6449 int this_file_error = 0;
6451 input_file_number = i;
6452 set_input (infiles[i].name);
6453 if (infiles[i].incompiler
6454 && (infiles[i].incompiler)->needs_preprocessing)
6455 input_file_compiler = infiles[i].incompiler;
6456 else
6457 continue;
6459 if (input_file_compiler)
6461 if (input_file_compiler->spec[0] == '#')
6463 error ("%s: %s compiler not installed on this system",
6464 input_filename, &input_file_compiler->spec[1]);
6465 this_file_error = 1;
6467 else
6469 value = do_spec (input_file_compiler->spec);
6470 infiles[i].preprocessed = true;
6471 if (!have_o_argbuf_index)
6472 fatal ("spec '%s' is invalid", input_file_compiler->spec);
6473 infiles[i].name = argbuf[have_o_argbuf_index];
6474 infiles[i].incompiler
6475 = lookup_compiler (infiles[i].name,
6476 strlen (infiles[i].name),
6477 infiles[i].language);
6479 if (value < 0)
6480 this_file_error = 1;
6484 if (this_file_error)
6486 delete_failure_queue ();
6487 error_count++;
6488 break;
6490 clear_failure_queue ();
6492 combine_inputs = save_combine_inputs;
6495 for (i = 0; (int) i < n_infiles; i++)
6497 int this_file_error = 0;
6499 /* Tell do_spec what to substitute for %i. */
6501 input_file_number = i;
6502 set_input (infiles[i].name);
6504 if (infiles[i].compiled)
6505 continue;
6507 /* Use the same thing in %o, unless cp->spec says otherwise. */
6509 outfiles[i] = input_filename;
6511 /* Figure out which compiler from the file's suffix. */
6513 if (! combine_inputs)
6514 input_file_compiler
6515 = lookup_compiler (infiles[i].name, input_filename_length,
6516 infiles[i].language);
6517 else
6518 input_file_compiler = infiles[i].incompiler;
6520 if (input_file_compiler)
6522 /* Ok, we found an applicable compiler. Run its spec. */
6524 if (input_file_compiler->spec[0] == '#')
6526 error ("%s: %s compiler not installed on this system",
6527 input_filename, &input_file_compiler->spec[1]);
6528 this_file_error = 1;
6530 else
6532 value = do_spec (input_file_compiler->spec);
6533 infiles[i].compiled = true;
6534 if (value < 0)
6535 this_file_error = 1;
6539 /* If this file's name does not contain a recognized suffix,
6540 record it as explicit linker input. */
6542 else
6543 explicit_link_files[i] = 1;
6545 /* Clear the delete-on-failure queue, deleting the files in it
6546 if this compilation failed. */
6548 if (this_file_error)
6550 delete_failure_queue ();
6551 error_count++;
6552 break;
6554 /* If this compilation succeeded, don't delete those files later. */
6555 clear_failure_queue ();
6558 /* Reset the output file name to the first input file name, for use
6559 with %b in LINK_SPEC on a target that prefers not to emit a.out
6560 by default. */
6561 if (n_infiles > 0)
6562 set_input (infiles[0].name);
6564 if (error_count == 0)
6566 /* Make sure INPUT_FILE_NUMBER points to first available open
6567 slot. */
6568 input_file_number = n_infiles;
6569 if (lang_specific_pre_link ())
6570 error_count++;
6573 /* Determine if there are any linker input files. */
6574 num_linker_inputs = 0;
6575 for (i = 0; (int) i < n_infiles; i++)
6576 if (explicit_link_files[i] || outfiles[i] != NULL)
6577 num_linker_inputs++;
6579 /* Run ld to link all the compiler output files. */
6581 if (num_linker_inputs > 0 && error_count == 0)
6583 int tmp = execution_count;
6585 /* We'll use ld if we can't find collect2. */
6586 if (! strcmp (linker_name_spec, "collect2"))
6588 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6589 if (s == NULL)
6590 linker_name_spec = "ld";
6592 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6593 for collect. */
6594 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6595 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6597 value = do_spec (link_command_spec);
6598 if (value < 0)
6599 error_count = 1;
6600 linker_was_run = (tmp != execution_count);
6603 /* If options said don't run linker,
6604 complain about input files to be given to the linker. */
6606 if (! linker_was_run && error_count == 0)
6607 for (i = 0; (int) i < n_infiles; i++)
6608 if (explicit_link_files[i])
6609 error ("%s: linker input file unused because linking not done",
6610 outfiles[i]);
6612 /* Delete some or all of the temporary files we made. */
6614 if (error_count)
6615 delete_failure_queue ();
6616 delete_temp_files ();
6618 if (print_help_list)
6620 printf (("\nFor bug reporting instructions, please see:\n"));
6621 printf ("%s\n", bug_report_url);
6624 return (signal_count != 0 ? 2
6625 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6626 : 0);
6629 /* Find the proper compilation spec for the file name NAME,
6630 whose length is LENGTH. LANGUAGE is the specified language,
6631 or 0 if this file is to be passed to the linker. */
6633 static struct compiler *
6634 lookup_compiler (const char *name, size_t length, const char *language)
6636 struct compiler *cp;
6638 /* If this was specified by the user to be a linker input, indicate that. */
6639 if (language != 0 && language[0] == '*')
6640 return 0;
6642 /* Otherwise, look for the language, if one is spec'd. */
6643 if (language != 0)
6645 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6646 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6647 return cp;
6649 error ("language %s not recognized", language);
6650 return 0;
6653 /* Look for a suffix. */
6654 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6656 if (/* The suffix `-' matches only the file name `-'. */
6657 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6658 || (strlen (cp->suffix) < length
6659 /* See if the suffix matches the end of NAME. */
6660 && !strcmp (cp->suffix,
6661 name + length - strlen (cp->suffix))
6663 break;
6666 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6667 /* Look again, but case-insensitively this time. */
6668 if (cp < compilers)
6669 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6671 if (/* The suffix `-' matches only the file name `-'. */
6672 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6673 || (strlen (cp->suffix) < length
6674 /* See if the suffix matches the end of NAME. */
6675 && ((!strcmp (cp->suffix,
6676 name + length - strlen (cp->suffix))
6677 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6678 && !strcasecmp (cp->suffix,
6679 name + length - strlen (cp->suffix)))
6681 break;
6683 #endif
6685 if (cp >= compilers)
6687 if (cp->spec[0] != '@')
6688 /* A non-alias entry: return it. */
6689 return cp;
6691 /* An alias entry maps a suffix to a language.
6692 Search for the language; pass 0 for NAME and LENGTH
6693 to avoid infinite recursion if language not found. */
6694 return lookup_compiler (NULL, 0, cp->spec + 1);
6696 return 0;
6699 static char *
6700 save_string (const char *s, int len)
6702 char *result = xmalloc (len + 1);
6704 memcpy (result, s, len);
6705 result[len] = 0;
6706 return result;
6709 void
6710 pfatal_with_name (const char *name)
6712 perror_with_name (name);
6713 delete_temp_files ();
6714 exit (1);
6717 static void
6718 perror_with_name (const char *name)
6720 error ("%s: %s", name, xstrerror (errno));
6723 static void
6724 pfatal_pexecute (const char *errmsg_fmt, const char *errmsg_arg)
6726 if (errmsg_arg)
6728 int save_errno = errno;
6730 /* Space for trailing '\0' is in %s. */
6731 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6732 sprintf (msg, errmsg_fmt, errmsg_arg);
6733 errmsg_fmt = msg;
6735 errno = save_errno;
6738 pfatal_with_name (errmsg_fmt);
6741 /* Output an error message and exit. */
6743 void
6744 fancy_abort (const char *file, int line, const char *func)
6746 fatal ("internal gcc abort in %s, at %s:%d", func, file, line);
6749 /* Output an error message and exit. */
6751 void
6752 fatal (const char *msgid, ...)
6754 va_list ap;
6756 va_start (ap, msgid);
6758 fprintf (stderr, "%s: ", programname);
6759 vfprintf (stderr, _(msgid), ap);
6760 va_end (ap);
6761 fprintf (stderr, "\n");
6762 delete_temp_files ();
6763 exit (1);
6766 void
6767 error (const char *msgid, ...)
6769 va_list ap;
6771 va_start (ap, msgid);
6772 fprintf (stderr, "%s: ", programname);
6773 vfprintf (stderr, _(msgid), ap);
6774 va_end (ap);
6776 fprintf (stderr, "\n");
6779 static void
6780 notice (const char *msgid, ...)
6782 va_list ap;
6784 va_start (ap, msgid);
6785 vfprintf (stderr, _(msgid), ap);
6786 va_end (ap);
6789 static inline void
6790 validate_switches_from_spec (const char *spec)
6792 const char *p = spec;
6793 char c;
6794 while ((c = *p++))
6795 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6796 /* We have a switch spec. */
6797 p = validate_switches (p + 1);
6800 static void
6801 validate_all_switches (void)
6803 struct compiler *comp;
6804 struct spec_list *spec;
6806 for (comp = compilers; comp->spec; comp++)
6807 validate_switches_from_spec (comp->spec);
6809 /* Look through the linked list of specs read from the specs file. */
6810 for (spec = specs; spec; spec = spec->next)
6811 validate_switches_from_spec (*spec->ptr_spec);
6813 validate_switches_from_spec (link_command_spec);
6816 /* Look at the switch-name that comes after START
6817 and mark as valid all supplied switches that match it. */
6819 static const char *
6820 validate_switches (const char *start)
6822 const char *p = start;
6823 const char *atom;
6824 size_t len;
6825 int i;
6826 bool suffix = false;
6827 bool starred = false;
6829 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6831 next_member:
6832 SKIP_WHITE ();
6834 if (*p == '!')
6835 p++;
6837 SKIP_WHITE ();
6838 if (*p == '.')
6839 suffix = true, p++;
6841 atom = p;
6842 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6843 || *p == ',' || *p == '.' || *p == '@')
6844 p++;
6845 len = p - atom;
6847 if (*p == '*')
6848 starred = true, p++;
6850 SKIP_WHITE ();
6852 if (!suffix)
6854 /* Mark all matching switches as valid. */
6855 for (i = 0; i < n_switches; i++)
6856 if (!strncmp (switches[i].part1, atom, len)
6857 && (starred || switches[i].part1[len] == 0))
6858 switches[i].validated = 1;
6861 if (*p) p++;
6862 if (*p && (p[-1] == '|' || p[-1] == '&'))
6863 goto next_member;
6865 if (*p && p[-1] == ':')
6867 while (*p && *p != ';' && *p != '}')
6869 if (*p == '%')
6871 p++;
6872 if (*p == '{' || *p == '<')
6873 p = validate_switches (p+1);
6874 else if (p[0] == 'W' && p[1] == '{')
6875 p = validate_switches (p+2);
6877 else
6878 p++;
6881 if (*p) p++;
6882 if (*p && p[-1] == ';')
6883 goto next_member;
6886 return p;
6887 #undef SKIP_WHITE
6890 struct mdswitchstr
6892 const char *str;
6893 int len;
6896 static struct mdswitchstr *mdswitches;
6897 static int n_mdswitches;
6899 /* Check whether a particular argument was used. The first time we
6900 canonicalize the switches to keep only the ones we care about. */
6902 static int
6903 used_arg (const char *p, int len)
6905 struct mswitchstr
6907 const char *str;
6908 const char *replace;
6909 int len;
6910 int rep_len;
6913 static struct mswitchstr *mswitches;
6914 static int n_mswitches;
6915 int i, j;
6917 if (!mswitches)
6919 struct mswitchstr *matches;
6920 const char *q;
6921 int cnt = 0;
6923 /* Break multilib_matches into the component strings of string
6924 and replacement string. */
6925 for (q = multilib_matches; *q != '\0'; q++)
6926 if (*q == ';')
6927 cnt++;
6929 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
6930 i = 0;
6931 q = multilib_matches;
6932 while (*q != '\0')
6934 matches[i].str = q;
6935 while (*q != ' ')
6937 if (*q == '\0')
6939 invalid_matches:
6940 fatal ("multilib spec '%s' is invalid", multilib_matches);
6942 q++;
6944 matches[i].len = q - matches[i].str;
6946 matches[i].replace = ++q;
6947 while (*q != ';' && *q != '\0')
6949 if (*q == ' ')
6950 goto invalid_matches;
6951 q++;
6953 matches[i].rep_len = q - matches[i].replace;
6954 i++;
6955 if (*q == ';')
6956 q++;
6959 /* Now build a list of the replacement string for switches that we care
6960 about. Make sure we allocate at least one entry. This prevents
6961 xmalloc from calling fatal, and prevents us from re-executing this
6962 block of code. */
6963 mswitches
6964 = xmalloc (sizeof (struct mswitchstr)
6965 * (n_mdswitches + (n_switches ? n_switches : 1)));
6966 for (i = 0; i < n_switches; i++)
6967 if (switches[i].live_cond != SWITCH_IGNORE)
6969 int xlen = strlen (switches[i].part1);
6970 for (j = 0; j < cnt; j++)
6971 if (xlen == matches[j].len
6972 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6974 mswitches[n_mswitches].str = matches[j].replace;
6975 mswitches[n_mswitches].len = matches[j].rep_len;
6976 mswitches[n_mswitches].replace = (char *) 0;
6977 mswitches[n_mswitches].rep_len = 0;
6978 n_mswitches++;
6979 break;
6983 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
6984 on the command line nor any options mutually incompatible with
6985 them. */
6986 for (i = 0; i < n_mdswitches; i++)
6988 const char *r;
6990 for (q = multilib_options; *q != '\0'; q++)
6992 while (*q == ' ')
6993 q++;
6995 r = q;
6996 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
6997 || strchr (" /", q[mdswitches[i].len]) == NULL)
6999 while (*q != ' ' && *q != '/' && *q != '\0')
7000 q++;
7001 if (*q != '/')
7002 break;
7003 q++;
7006 if (*q != ' ' && *q != '\0')
7008 while (*r != ' ' && *r != '\0')
7010 q = r;
7011 while (*q != ' ' && *q != '/' && *q != '\0')
7012 q++;
7014 if (used_arg (r, q - r))
7015 break;
7017 if (*q != '/')
7019 mswitches[n_mswitches].str = mdswitches[i].str;
7020 mswitches[n_mswitches].len = mdswitches[i].len;
7021 mswitches[n_mswitches].replace = (char *) 0;
7022 mswitches[n_mswitches].rep_len = 0;
7023 n_mswitches++;
7024 break;
7027 r = q + 1;
7029 break;
7035 for (i = 0; i < n_mswitches; i++)
7036 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7037 return 1;
7039 return 0;
7042 static int
7043 default_arg (const char *p, int len)
7045 int i;
7047 for (i = 0; i < n_mdswitches; i++)
7048 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7049 return 1;
7051 return 0;
7054 /* Work out the subdirectory to use based on the options. The format of
7055 multilib_select is a list of elements. Each element is a subdirectory
7056 name followed by a list of options followed by a semicolon. The format
7057 of multilib_exclusions is the same, but without the preceding
7058 directory. First gcc will check the exclusions, if none of the options
7059 beginning with an exclamation point are present, and all of the other
7060 options are present, then we will ignore this completely. Passing
7061 that, gcc will consider each multilib_select in turn using the same
7062 rules for matching the options. If a match is found, that subdirectory
7063 will be used. */
7065 static void
7066 set_multilib_dir (void)
7068 const char *p;
7069 unsigned int this_path_len;
7070 const char *this_path, *this_arg;
7071 const char *start, *end;
7072 int not_arg;
7073 int ok, ndfltok, first;
7075 n_mdswitches = 0;
7076 start = multilib_defaults;
7077 while (*start == ' ' || *start == '\t')
7078 start++;
7079 while (*start != '\0')
7081 n_mdswitches++;
7082 while (*start != ' ' && *start != '\t' && *start != '\0')
7083 start++;
7084 while (*start == ' ' || *start == '\t')
7085 start++;
7088 if (n_mdswitches)
7090 int i = 0;
7092 mdswitches = xmalloc (sizeof (struct mdswitchstr) * n_mdswitches);
7093 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7095 while (*start == ' ' || *start == '\t')
7096 start++;
7098 if (*start == '\0')
7099 break;
7101 for (end = start + 1;
7102 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7105 obstack_grow (&multilib_obstack, start, end - start);
7106 obstack_1grow (&multilib_obstack, 0);
7107 mdswitches[i].str = obstack_finish (&multilib_obstack);
7108 mdswitches[i++].len = end - start;
7110 if (*end == '\0')
7111 break;
7115 p = multilib_exclusions;
7116 while (*p != '\0')
7118 /* Ignore newlines. */
7119 if (*p == '\n')
7121 ++p;
7122 continue;
7125 /* Check the arguments. */
7126 ok = 1;
7127 while (*p != ';')
7129 if (*p == '\0')
7131 invalid_exclusions:
7132 fatal ("multilib exclusions '%s' is invalid",
7133 multilib_exclusions);
7136 if (! ok)
7138 ++p;
7139 continue;
7142 this_arg = p;
7143 while (*p != ' ' && *p != ';')
7145 if (*p == '\0')
7146 goto invalid_exclusions;
7147 ++p;
7150 if (*this_arg != '!')
7151 not_arg = 0;
7152 else
7154 not_arg = 1;
7155 ++this_arg;
7158 ok = used_arg (this_arg, p - this_arg);
7159 if (not_arg)
7160 ok = ! ok;
7162 if (*p == ' ')
7163 ++p;
7166 if (ok)
7167 return;
7169 ++p;
7172 first = 1;
7173 p = multilib_select;
7174 while (*p != '\0')
7176 /* Ignore newlines. */
7177 if (*p == '\n')
7179 ++p;
7180 continue;
7183 /* Get the initial path. */
7184 this_path = p;
7185 while (*p != ' ')
7187 if (*p == '\0')
7189 invalid_select:
7190 fatal ("multilib select '%s' is invalid",
7191 multilib_select);
7193 ++p;
7195 this_path_len = p - this_path;
7197 /* Check the arguments. */
7198 ok = 1;
7199 ndfltok = 1;
7200 ++p;
7201 while (*p != ';')
7203 if (*p == '\0')
7204 goto invalid_select;
7206 if (! ok)
7208 ++p;
7209 continue;
7212 this_arg = p;
7213 while (*p != ' ' && *p != ';')
7215 if (*p == '\0')
7216 goto invalid_select;
7217 ++p;
7220 if (*this_arg != '!')
7221 not_arg = 0;
7222 else
7224 not_arg = 1;
7225 ++this_arg;
7228 /* If this is a default argument, we can just ignore it.
7229 This is true even if this_arg begins with '!'. Beginning
7230 with '!' does not mean that this argument is necessarily
7231 inappropriate for this library: it merely means that
7232 there is a more specific library which uses this
7233 argument. If this argument is a default, we need not
7234 consider that more specific library. */
7235 ok = used_arg (this_arg, p - this_arg);
7236 if (not_arg)
7237 ok = ! ok;
7239 if (! ok)
7240 ndfltok = 0;
7242 if (default_arg (this_arg, p - this_arg))
7243 ok = 1;
7245 if (*p == ' ')
7246 ++p;
7249 if (ok && first)
7251 if (this_path_len != 1
7252 || this_path[0] != '.')
7254 char *new_multilib_dir = xmalloc (this_path_len + 1);
7255 char *q;
7257 strncpy (new_multilib_dir, this_path, this_path_len);
7258 new_multilib_dir[this_path_len] = '\0';
7259 q = strchr (new_multilib_dir, ':');
7260 if (q != NULL)
7261 *q = '\0';
7262 multilib_dir = new_multilib_dir;
7264 first = 0;
7267 if (ndfltok)
7269 const char *q = this_path, *end = this_path + this_path_len;
7271 while (q < end && *q != ':')
7272 q++;
7273 if (q < end)
7275 char *new_multilib_os_dir = xmalloc (end - q);
7276 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7277 new_multilib_os_dir[end - q - 1] = '\0';
7278 multilib_os_dir = new_multilib_os_dir;
7279 break;
7283 ++p;
7286 if (multilib_dir == NULL && multilib_os_dir != NULL
7287 && strcmp (multilib_os_dir, ".") == 0)
7289 free ((char *) multilib_os_dir);
7290 multilib_os_dir = NULL;
7292 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7293 multilib_os_dir = multilib_dir;
7296 /* Print out the multiple library subdirectory selection
7297 information. This prints out a series of lines. Each line looks
7298 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7299 required. Only the desired options are printed out, the negative
7300 matches. The options are print without a leading dash. There are
7301 no spaces to make it easy to use the information in the shell.
7302 Each subdirectory is printed only once. This assumes the ordering
7303 generated by the genmultilib script. Also, we leave out ones that match
7304 the exclusions. */
7306 static void
7307 print_multilib_info (void)
7309 const char *p = multilib_select;
7310 const char *last_path = 0, *this_path;
7311 int skip;
7312 unsigned int last_path_len = 0;
7314 while (*p != '\0')
7316 skip = 0;
7317 /* Ignore newlines. */
7318 if (*p == '\n')
7320 ++p;
7321 continue;
7324 /* Get the initial path. */
7325 this_path = p;
7326 while (*p != ' ')
7328 if (*p == '\0')
7330 invalid_select:
7331 fatal ("multilib select '%s' is invalid", multilib_select);
7334 ++p;
7337 /* When --disable-multilib was used but target defines
7338 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7339 to find multilib_os_dir, so skip them from output. */
7340 if (this_path[0] == '.' && this_path[1] == ':')
7341 skip = 1;
7343 /* Check for matches with the multilib_exclusions. We don't bother
7344 with the '!' in either list. If any of the exclusion rules match
7345 all of its options with the select rule, we skip it. */
7347 const char *e = multilib_exclusions;
7348 const char *this_arg;
7350 while (*e != '\0')
7352 int m = 1;
7353 /* Ignore newlines. */
7354 if (*e == '\n')
7356 ++e;
7357 continue;
7360 /* Check the arguments. */
7361 while (*e != ';')
7363 const char *q;
7364 int mp = 0;
7366 if (*e == '\0')
7368 invalid_exclusion:
7369 fatal ("multilib exclusion '%s' is invalid",
7370 multilib_exclusions);
7373 if (! m)
7375 ++e;
7376 continue;
7379 this_arg = e;
7381 while (*e != ' ' && *e != ';')
7383 if (*e == '\0')
7384 goto invalid_exclusion;
7385 ++e;
7388 q = p + 1;
7389 while (*q != ';')
7391 const char *arg;
7392 int len = e - this_arg;
7394 if (*q == '\0')
7395 goto invalid_select;
7397 arg = q;
7399 while (*q != ' ' && *q != ';')
7401 if (*q == '\0')
7402 goto invalid_select;
7403 ++q;
7406 if (! strncmp (arg, this_arg,
7407 (len < q - arg) ? q - arg : len)
7408 || default_arg (this_arg, e - this_arg))
7410 mp = 1;
7411 break;
7414 if (*q == ' ')
7415 ++q;
7418 if (! mp)
7419 m = 0;
7421 if (*e == ' ')
7422 ++e;
7425 if (m)
7427 skip = 1;
7428 break;
7431 if (*e != '\0')
7432 ++e;
7436 if (! skip)
7438 /* If this is a duplicate, skip it. */
7439 skip = (last_path != 0
7440 && (unsigned int) (p - this_path) == last_path_len
7441 && ! strncmp (last_path, this_path, last_path_len));
7443 last_path = this_path;
7444 last_path_len = p - this_path;
7447 /* If this directory requires any default arguments, we can skip
7448 it. We will already have printed a directory identical to
7449 this one which does not require that default argument. */
7450 if (! skip)
7452 const char *q;
7454 q = p + 1;
7455 while (*q != ';')
7457 const char *arg;
7459 if (*q == '\0')
7460 goto invalid_select;
7462 if (*q == '!')
7463 arg = NULL;
7464 else
7465 arg = q;
7467 while (*q != ' ' && *q != ';')
7469 if (*q == '\0')
7470 goto invalid_select;
7471 ++q;
7474 if (arg != NULL
7475 && default_arg (arg, q - arg))
7477 skip = 1;
7478 break;
7481 if (*q == ' ')
7482 ++q;
7486 if (! skip)
7488 const char *p1;
7490 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7491 putchar (*p1);
7492 putchar (';');
7495 ++p;
7496 while (*p != ';')
7498 int use_arg;
7500 if (*p == '\0')
7501 goto invalid_select;
7503 if (skip)
7505 ++p;
7506 continue;
7509 use_arg = *p != '!';
7511 if (use_arg)
7512 putchar ('@');
7514 while (*p != ' ' && *p != ';')
7516 if (*p == '\0')
7517 goto invalid_select;
7518 if (use_arg)
7519 putchar (*p);
7520 ++p;
7523 if (*p == ' ')
7524 ++p;
7527 if (! skip)
7529 /* If there are extra options, print them now. */
7530 if (multilib_extra && *multilib_extra)
7532 int print_at = TRUE;
7533 const char *q;
7535 for (q = multilib_extra; *q != '\0'; q++)
7537 if (*q == ' ')
7538 print_at = TRUE;
7539 else
7541 if (print_at)
7542 putchar ('@');
7543 putchar (*q);
7544 print_at = FALSE;
7549 putchar ('\n');
7552 ++p;
7556 /* if-exists built-in spec function.
7558 Checks to see if the file specified by the absolute pathname in
7559 ARGS exists. Returns that pathname if found.
7561 The usual use for this function is to check for a library file
7562 (whose name has been expanded with %s). */
7564 static const char *
7565 if_exists_spec_function (int argc, const char **argv)
7567 /* Must have only one argument. */
7568 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7569 return argv[0];
7571 return NULL;
7574 /* if-exists-else built-in spec function.
7576 This is like if-exists, but takes an additional argument which
7577 is returned if the first argument does not exist. */
7579 static const char *
7580 if_exists_else_spec_function (int argc, const char **argv)
7582 /* Must have exactly two arguments. */
7583 if (argc != 2)
7584 return NULL;
7586 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7587 return argv[0];
7589 return argv[1];
7592 /* replace-outfile built-in spec function.
7593 This looks for the first argument in the outfiles array's name and replaces it
7594 with the second argument. */
7596 static const char *
7597 replace_outfile_spec_function (int argc, const char **argv)
7599 int i;
7600 /* Must have exactly two arguments. */
7601 if (argc != 2)
7602 abort ();
7604 for (i = 0; i < n_infiles; i++)
7606 if (outfiles[i] && !strcmp (outfiles[i], argv[0]))
7607 outfiles[i] = xstrdup (argv[1]);
7609 return NULL;