* loop.c (scan_loop): Do not consider insns setting the frame
[official-gcc.git] / gcc / gcc.c
blob076d224bebd5d0f0a49b801d6bce02878fddcf2c
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation,
4 Inc.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2, or (at your option) any later
11 version.
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING. If not, write to the Free
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
21 02111-1307, USA.
23 This paragraph is here to try to keep Sun CC from dying.
24 The number of chars here seems crucial!!!! */
26 /* This program is the user interface to the C compiler and possibly to
27 other compilers. It is used because compilation is a complicated procedure
28 which involves running several programs and passing temporary files between
29 them, forwarding the users switches to those programs selectively,
30 and deleting the temporary files at the end.
32 CC recognizes how to compile each input file by suffixes in the file names.
33 Once it knows which kind of compilation to perform, the procedure for
34 compilation is specified by a string called a "spec". */
36 /* A Short Introduction to Adding a Command-Line Option.
38 Before adding a command-line option, consider if it is really
39 necessary. Each additional command-line option adds complexity and
40 is difficult to remove in subsequent versions.
42 In the following, consider adding the command-line argument
43 `--bar'.
45 1. Each command-line option is specified in the specs file. The
46 notation is described below in the comment entitled "The Specs
47 Language". Read it.
49 2. In this file, add an entry to "option_map" equating the long
50 `--' argument version and any shorter, single letter version. Read
51 the comments in the declaration of "struct option_map" for an
52 explanation. Do not omit the first `-'.
54 3. Look in the "specs" file to determine which program or option
55 list should be given the argument, e.g., "cc1_options". Add the
56 appropriate syntax for the shorter option version to the
57 corresponding "const char *" entry in this file. Omit the first
58 `-' from the option. For example, use `-bar', rather than `--bar'.
60 4. If the argument takes an argument, e.g., `--baz argument1',
61 modify either DEFAULT_SWITCH_TAKES_ARG or
62 DEFAULT_WORD_SWITCH_TAKES_ARG in gcc.h. Omit the first `-'
63 from `--baz'.
65 5. Document the option in this file's display_help(). If the
66 option is passed to a subprogram, modify its corresponding
67 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
68 instead.
70 6. Compile and test. Make sure that your new specs file is being
71 read. For example, use a debugger to investigate the value of
72 "specs_file" in main(). */
74 #include "config.h"
75 #include "system.h"
76 #include "coretypes.h"
77 #include "multilib.h" /* before tm.h */
78 #include "tm.h"
79 #include <signal.h>
80 #if ! defined( SIGCHLD ) && defined( SIGCLD )
81 # define SIGCHLD SIGCLD
82 #endif
83 #include "obstack.h"
84 #include "intl.h"
85 #include "prefix.h"
86 #include "gcc.h"
87 #include "flags.h"
89 /* By default there is no special suffix for target executables. */
90 /* FIXME: when autoconf is fixed, remove the host check - dj */
91 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
92 #define HAVE_TARGET_EXECUTABLE_SUFFIX
93 #endif
95 /* By default there is no special suffix for host executables. */
96 #ifdef HOST_EXECUTABLE_SUFFIX
97 #define HAVE_HOST_EXECUTABLE_SUFFIX
98 #else
99 #define HOST_EXECUTABLE_SUFFIX ""
100 #endif
102 /* By default, the suffix for target object files is ".o". */
103 #ifdef TARGET_OBJECT_SUFFIX
104 #define HAVE_TARGET_OBJECT_SUFFIX
105 #else
106 #define TARGET_OBJECT_SUFFIX ".o"
107 #endif
109 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
111 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
112 #ifndef LIBRARY_PATH_ENV
113 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
114 #endif
116 #ifndef HAVE_KILL
117 #define kill(p,s) raise(s)
118 #endif
120 /* If a stage of compilation returns an exit status >= 1,
121 compilation of that file ceases. */
123 #define MIN_FATAL_STATUS 1
125 /* Flag set by cppspec.c to 1. */
126 int is_cpp_driver;
128 /* Flag saying to pass the greatest exit code returned by a sub-process
129 to the calling program. */
130 static int pass_exit_codes;
132 /* Definition of string containing the arguments given to configure. */
133 #include "configargs.h"
135 /* Flag saying to print the directories gcc will search through looking for
136 programs, libraries, etc. */
138 static int print_search_dirs;
140 /* Flag saying to print the full filename of this file
141 as found through our usual search mechanism. */
143 static const char *print_file_name = NULL;
145 /* As print_file_name, but search for executable file. */
147 static const char *print_prog_name = NULL;
149 /* Flag saying to print the relative path we'd use to
150 find libgcc.a given the current compiler flags. */
152 static int print_multi_directory;
154 /* Flag saying to print the relative path we'd use to
155 find OS libraries given the current compiler flags. */
157 static int print_multi_os_directory;
159 /* Flag saying to print the list of subdirectories and
160 compiler flags used to select them in a standard form. */
162 static int print_multi_lib;
164 /* Flag saying to print the command line options understood by gcc and its
165 sub-processes. */
167 static int print_help_list;
169 /* Flag indicating whether we should print the command and arguments */
171 static int verbose_flag;
173 /* Flag indicating whether we should ONLY print the command and
174 arguments (like verbose_flag) without executing the command.
175 Displayed arguments are quoted so that the generated command
176 line is suitable for execution. This is intended for use in
177 shell scripts to capture the driver-generated command line. */
178 static int verbose_only_flag;
180 /* Flag indicating to print target specific command line options. */
182 static int target_help_flag;
184 /* Flag indicating whether we should report subprocess execution times
185 (if this is supported by the system - see pexecute.c). */
187 static int report_times;
189 /* Nonzero means place this string before uses of /, so that include
190 and library files can be found in an alternate location. */
192 #ifdef TARGET_SYSTEM_ROOT
193 static const char *target_system_root = TARGET_SYSTEM_ROOT;
194 #else
195 static const char *target_system_root = 0;
196 #endif
198 /* Nonzero means pass the updated target_system_root to the compiler. */
200 static int target_system_root_changed;
202 /* Nonzero means append this string to target_system_root. */
204 static const char *target_sysroot_suffix = 0;
206 /* Nonzero means append this string to target_system_root for headers. */
208 static const char *target_sysroot_hdrs_suffix = 0;
210 /* Nonzero means write "temp" files in source directory
211 and use the source file's name in them, and don't delete them. */
213 static int save_temps_flag;
215 /* Nonzero means pass multiple source files to the compiler at one time. */
217 static int combine_flag = 0;
219 /* Nonzero means use pipes to communicate between subprocesses.
220 Overridden by either of the above two flags. */
222 static int use_pipes;
224 /* The compiler version. */
226 static const char *compiler_version;
228 /* The target version specified with -V */
230 static const char *const spec_version = DEFAULT_TARGET_VERSION;
232 /* The target machine specified with -b. */
234 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
236 /* Nonzero if cross-compiling.
237 When -b is used, the value comes from the `specs' file. */
239 #ifdef CROSS_COMPILE
240 static const char *cross_compile = "1";
241 #else
242 static const char *cross_compile = "0";
243 #endif
245 #ifdef MODIFY_TARGET_NAME
247 /* Information on how to alter the target name based on a command-line
248 switch. The only case we support now is simply appending or deleting a
249 string to or from the end of the first part of the configuration name. */
251 static const struct modify_target
253 const char *const sw;
254 const enum add_del {ADD, DELETE} add_del;
255 const char *const str;
257 modify_target[] = MODIFY_TARGET_NAME;
258 #endif
260 /* The number of errors that have occurred; the link phase will not be
261 run if this is nonzero. */
262 static int error_count = 0;
264 /* Greatest exit code of sub-processes that has been encountered up to
265 now. */
266 static int greatest_status = 1;
268 /* This is the obstack which we use to allocate many strings. */
270 static struct obstack obstack;
272 /* This is the obstack to build an environment variable to pass to
273 collect2 that describes all of the relevant switches of what to
274 pass the compiler in building the list of pointers to constructors
275 and destructors. */
277 static struct obstack collect_obstack;
279 /* Forward declaration for prototypes. */
280 struct path_prefix;
281 struct prefix_list;
283 static void init_spec (void);
284 static void store_arg (const char *, int, int);
285 static char *load_specs (const char *);
286 static void read_specs (const char *, int);
287 static void set_spec (const char *, const char *);
288 static struct compiler *lookup_compiler (const char *, size_t, const char *);
289 static char *build_search_list (struct path_prefix *, const char *, int);
290 static void putenv_from_prefixes (struct path_prefix *, const char *);
291 static int access_check (const char *, int);
292 static char *find_a_file (struct path_prefix *, const char *, int, int);
293 static void add_prefix (struct path_prefix *, const char *, const char *,
294 int, int, int);
295 static void add_sysrooted_prefix (struct path_prefix *, const char *,
296 const char *, int, int, int);
297 static void translate_options (int *, const char *const **);
298 static char *skip_whitespace (char *);
299 static void delete_if_ordinary (const char *);
300 static void delete_temp_files (void);
301 static void delete_failure_queue (void);
302 static void clear_failure_queue (void);
303 static int check_live_switch (int, int);
304 static const char *handle_braces (const char *);
305 static inline bool input_suffix_matches (const char *, const char *);
306 static inline bool switch_matches (const char *, const char *, int);
307 static inline void mark_matching_switches (const char *, const char *, int);
308 static inline void process_marked_switches (void);
309 static const char *process_brace_body (const char *, const char *, const char *, int, int);
310 static const struct spec_function *lookup_spec_function (const char *);
311 static const char *eval_spec_function (const char *, const char *);
312 static const char *handle_spec_function (const char *);
313 static char *save_string (const char *, int);
314 static void set_collect_gcc_options (void);
315 static void do_spec_path (struct prefix_list *, const char *, int, int, int, const char *, const char *);
316 static int do_spec_1 (const char *, int, const char *);
317 static int do_spec_2 (const char *);
318 static void do_option_spec (const char *, const char *);
319 static void do_self_spec (const char *);
320 static const char *find_file (const char *);
321 static int is_directory (const char *, const char *, int);
322 static const char *validate_switches (const char *);
323 static void validate_all_switches (void);
324 static inline void validate_switches_from_spec (const char *);
325 static void give_switch (int, int);
326 static int used_arg (const char *, int);
327 static int default_arg (const char *, int);
328 static void set_multilib_dir (void);
329 static void print_multilib_info (void);
330 static void perror_with_name (const char *);
331 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
332 static void display_help (void);
333 static void add_preprocessor_option (const char *, int);
334 static void add_assembler_option (const char *, int);
335 static void add_linker_option (const char *, int);
336 static void process_command (int, const char **);
337 static int execute (void);
338 static void alloc_args (void);
339 static void clear_args (void);
340 static void fatal_error (int);
341 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
342 static void init_gcc_specs (struct obstack *, const char *, const char *,
343 const char *);
344 #endif
345 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
346 static const char *convert_filename (const char *, int, int);
347 #endif
349 static const char *if_exists_spec_function (int, const char **);
350 static const char *if_exists_else_spec_function (int, const char **);
351 static const char *replace_outfile_spec_function (int, const char **);
353 /* The Specs Language
355 Specs are strings containing lines, each of which (if not blank)
356 is made up of a program name, and arguments separated by spaces.
357 The program name must be exact and start from root, since no path
358 is searched and it is unreliable to depend on the current working directory.
359 Redirection of input or output is not supported; the subprograms must
360 accept filenames saying what files to read and write.
362 In addition, the specs can contain %-sequences to substitute variable text
363 or for conditional text. Here is a table of all defined %-sequences.
364 Note that spaces are not generated automatically around the results of
365 expanding these sequences; therefore, you can concatenate them together
366 or with constant text in a single argument.
368 %% substitute one % into the program name or argument.
369 %i substitute the name of the input file being processed.
370 %b substitute the basename of the input file being processed.
371 This is the substring up to (and not including) the last period
372 and not including the directory.
373 %B same as %b, but include the file suffix (text after the last period).
374 %gSUFFIX
375 substitute a file name that has suffix SUFFIX and is chosen
376 once per compilation, and mark the argument a la %d. To reduce
377 exposure to denial-of-service attacks, the file name is now
378 chosen in a way that is hard to predict even when previously
379 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
380 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
381 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
382 had been pre-processed. Previously, %g was simply substituted
383 with a file name chosen once per compilation, without regard
384 to any appended suffix (which was therefore treated just like
385 ordinary text), making such attacks more likely to succeed.
386 %|SUFFIX
387 like %g, but if -pipe is in effect, expands simply to "-".
388 %mSUFFIX
389 like %g, but if -pipe is in effect, expands to nothing. (We have both
390 %| and %m to accommodate differences between system assemblers; see
391 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
392 %uSUFFIX
393 like %g, but generates a new temporary file name even if %uSUFFIX
394 was already seen.
395 %USUFFIX
396 substitutes the last file name generated with %uSUFFIX, generating a
397 new one if there is no such last file name. In the absence of any
398 %uSUFFIX, this is just like %gSUFFIX, except they don't share
399 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
400 would involve the generation of two distinct file names, one
401 for each `%g.s' and another for each `%U.s'. Previously, %U was
402 simply substituted with a file name chosen for the previous %u,
403 without regard to any appended suffix.
404 %jSUFFIX
405 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
406 writable, and if save-temps is off; otherwise, substitute the name
407 of a temporary file, just like %u. This temporary file is not
408 meant for communication between processes, but rather as a junk
409 disposal mechanism.
410 %.SUFFIX
411 substitutes .SUFFIX for the suffixes of a matched switch's args when
412 it is subsequently output with %*. SUFFIX is terminated by the next
413 space or %.
414 %d marks the argument containing or following the %d as a
415 temporary file name, so that that file will be deleted if CC exits
416 successfully. Unlike %g, this contributes no text to the argument.
417 %w marks the argument containing or following the %w as the
418 "output file" of this compilation. This puts the argument
419 into the sequence of arguments that %o will substitute later.
420 %V indicates that this compilation produces no "output file".
421 %W{...}
422 like %{...} but mark last argument supplied within
423 as a file to be deleted on failure.
424 %o substitutes the names of all the output files, with spaces
425 automatically placed around them. You should write spaces
426 around the %o as well or the results are undefined.
427 %o is for use in the specs for running the linker.
428 Input files whose names have no recognized suffix are not compiled
429 at all, but they are included among the output files, so they will
430 be linked.
431 %O substitutes the suffix for object files. Note that this is
432 handled specially when it immediately follows %g, %u, or %U
433 (with or without a suffix argument) because of the need for
434 those to form complete file names. The handling is such that
435 %O is treated exactly as if it had already been substituted,
436 except that %g, %u, and %U do not currently support additional
437 SUFFIX characters following %O as they would following, for
438 example, `.o'.
439 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
440 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
441 and -B options) as necessary.
442 %s current argument is the name of a library or startup file of some sort.
443 Search for that file in a standard list of directories
444 and substitute the full name found.
445 %eSTR Print STR as an error message. STR is terminated by a newline.
446 Use this when inconsistent options are detected.
447 %nSTR Print STR as a notice. STR is terminated by a newline.
448 %x{OPTION} Accumulate an option for %X.
449 %X Output the accumulated linker options specified by compilations.
450 %Y Output the accumulated assembler options specified by compilations.
451 %Z Output the accumulated preprocessor options specified by compilations.
452 %a process ASM_SPEC as a spec.
453 This allows config.h to specify part of the spec for running as.
454 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
455 used here. This can be used to run a post-processor after the
456 assembler has done its job.
457 %D Dump out a -L option for each directory in startfile_prefixes.
458 If multilib_dir is set, extra entries are generated with it affixed.
459 %l process LINK_SPEC as a spec.
460 %L process LIB_SPEC as a spec.
461 %G process LIBGCC_SPEC as a spec.
462 %R Output the concatenation of target_system_root and
463 target_sysroot_suffix.
464 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
465 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
466 %C process CPP_SPEC as a spec.
467 %1 process CC1_SPEC as a spec.
468 %2 process CC1PLUS_SPEC as a spec.
469 %* substitute the variable part of a matched option. (See below.)
470 Note that each comma in the substituted string is replaced by
471 a single space.
472 %<S remove all occurrences of -S from the command line.
473 Note - this command is position dependent. % commands in the
474 spec string before this one will see -S, % commands in the
475 spec string after this one will not.
476 %<S* remove all occurrences of all switches beginning with -S from the
477 command line.
478 %:function(args)
479 Call the named function FUNCTION, passing it ARGS. ARGS is
480 first processed as a nested spec string, then split into an
481 argument vector in the usual fashion. The function returns
482 a string which is processed as if it had appeared literally
483 as part of the current spec.
484 %{S} substitutes the -S switch, if that switch was given to CC.
485 If that switch was not specified, this substitutes nothing.
486 Here S is a metasyntactic variable.
487 %{S*} substitutes all the switches specified to CC whose names start
488 with -S. This is used for -o, -I, etc; switches that take
489 arguments. CC considers `-o foo' as being one switch whose
490 name starts with `o'. %{o*} would substitute this text,
491 including the space; thus, two arguments would be generated.
492 %{S*&T*} likewise, but preserve order of S and T options (the order
493 of S and T in the spec is not significant). Can be any number
494 of ampersand-separated variables; for each the wild card is
495 optional. Useful for CPP as %{D*&U*&A*}.
497 %{S:X} substitutes X, if the -S switch was given to CC.
498 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
499 %{S*:X} substitutes X if one or more switches whose names start
500 with -S was given to CC. Normally X is substituted only
501 once, no matter how many such switches appeared. However,
502 if %* appears somewhere in X, then X will be substituted
503 once for each matching switch, with the %* replaced by the
504 part of that switch that matched the '*'.
505 %{.S:X} substitutes X, if processing a file with suffix S.
506 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
508 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
509 combined with !, ., and * as above binding stronger than the OR.
510 If %* appears in X, all of the alternatives must be starred, and
511 only the first matching alternative is substituted.
512 %{S:X; if S was given to CC, substitutes X;
513 T:Y; else if T was given to CC, substitutes Y;
514 :D} else substitutes D. There can be as many clauses as you need.
515 This may be combined with ., !, |, and * as above.
517 %(Spec) processes a specification defined in a specs file as *Spec:
518 %[Spec] as above, but put __ around -D arguments
520 The conditional text X in a %{S:X} or similar construct may contain
521 other nested % constructs or spaces, or even newlines. They are
522 processed as usual, as described above. Trailing white space in X is
523 ignored. White space may also appear anywhere on the left side of the
524 colon in these constructs, except between . or * and the corresponding
525 word.
527 The -O, -f, -m, and -W switches are handled specifically in these
528 constructs. If another value of -O or the negated form of a -f, -m, or
529 -W switch is found later in the command line, the earlier switch
530 value is ignored, except with {S*} where S is just one letter; this
531 passes all matching options.
533 The character | at the beginning of the predicate text is used to indicate
534 that a command should be piped to the following command, but only if -pipe
535 is specified.
537 Note that it is built into CC which switches take arguments and which
538 do not. You might think it would be useful to generalize this to
539 allow each compiler's spec to say which switches take arguments. But
540 this cannot be done in a consistent fashion. CC cannot even decide
541 which input files have been specified without knowing which switches
542 take arguments, and it must know which input files to compile in order
543 to tell which compilers to run.
545 CC also knows implicitly that arguments starting in `-l' are to be
546 treated as compiler output files, and passed to the linker in their
547 proper position among the other output files. */
549 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
551 /* config.h can define ASM_SPEC to provide extra args to the assembler
552 or extra switch-translations. */
553 #ifndef ASM_SPEC
554 #define ASM_SPEC ""
555 #endif
557 /* config.h can define ASM_FINAL_SPEC to run a post processor after
558 the assembler has run. */
559 #ifndef ASM_FINAL_SPEC
560 #define ASM_FINAL_SPEC ""
561 #endif
563 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
564 or extra switch-translations. */
565 #ifndef CPP_SPEC
566 #define CPP_SPEC ""
567 #endif
569 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
570 or extra switch-translations. */
571 #ifndef CC1_SPEC
572 #define CC1_SPEC ""
573 #endif
575 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
576 or extra switch-translations. */
577 #ifndef CC1PLUS_SPEC
578 #define CC1PLUS_SPEC ""
579 #endif
581 /* config.h can define LINK_SPEC to provide extra args to the linker
582 or extra switch-translations. */
583 #ifndef LINK_SPEC
584 #define LINK_SPEC ""
585 #endif
587 /* config.h can define LIB_SPEC to override the default libraries. */
588 #ifndef LIB_SPEC
589 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
590 #endif
592 /* mudflap specs */
593 #ifndef MFWRAP_SPEC
594 /* XXX: valid only for GNU ld */
595 /* XXX: should exactly match hooks provided by libmudflap.a */
596 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
597 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
598 --wrap=mmap --wrap=munmap --wrap=alloca\
599 } %{fmudflapth: --wrap=pthread_create --wrap=pthread_join --wrap=pthread_exit\
600 }} %{fmudflap|fmudflapth: --wrap=main}"
601 #endif
602 #ifndef MFLIB_SPEC
603 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
604 #endif
606 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
607 included. */
608 #ifndef LIBGCC_SPEC
609 #if defined(REAL_LIBGCC_SPEC)
610 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
611 #elif defined(LINK_LIBGCC_SPECIAL_1)
612 /* Have gcc do the search for libgcc.a. */
613 #define LIBGCC_SPEC "libgcc.a%s"
614 #else
615 #define LIBGCC_SPEC "-lgcc"
616 #endif
617 #endif
619 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
620 #ifndef STARTFILE_SPEC
621 #define STARTFILE_SPEC \
622 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
623 #endif
625 /* config.h can define SWITCHES_NEED_SPACES to control which options
626 require spaces between the option and the argument. */
627 #ifndef SWITCHES_NEED_SPACES
628 #define SWITCHES_NEED_SPACES ""
629 #endif
631 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
632 #ifndef ENDFILE_SPEC
633 #define ENDFILE_SPEC ""
634 #endif
636 #ifndef LINKER_NAME
637 #define LINKER_NAME "collect2"
638 #endif
640 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
641 to the assembler. */
642 #ifndef ASM_DEBUG_SPEC
643 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
644 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
645 # define ASM_DEBUG_SPEC \
646 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
647 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
648 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
649 # else
650 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
651 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
652 # endif
653 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
654 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
655 # endif
656 # endif
657 #endif
658 #ifndef ASM_DEBUG_SPEC
659 # define ASM_DEBUG_SPEC ""
660 #endif
662 /* Here is the spec for running the linker, after compiling all files. */
664 /* This is overridable by the target in case they need to specify the
665 -lgcc and -lc order specially, yet not require them to override all
666 of LINK_COMMAND_SPEC. */
667 #ifndef LINK_GCC_C_SEQUENCE_SPEC
668 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
669 #endif
671 #ifndef LINK_PIE_SPEC
672 #ifdef HAVE_LD_PIE
673 #define LINK_PIE_SPEC "%{pie:-pie} "
674 #else
675 #define LINK_PIE_SPEC "%{pie:} "
676 #endif
677 #endif
679 /* -u* was put back because both BSD and SysV seem to support it. */
680 /* %{static:} simply prevents an error message if the target machine
681 doesn't handle -static. */
682 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
683 scripts which exist in user specified directories, or in standard
684 directories. */
685 #ifndef LINK_COMMAND_SPEC
686 #define LINK_COMMAND_SPEC "\
687 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
688 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
689 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
690 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o %(mflib)\
691 %{fprofile-arcs|fprofile-generate|coverage:-lgcov}\
692 %{!nostdlib:%{!nodefaultlibs:%(link_gcc_c_sequence)}}\
693 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
694 #endif
696 #ifndef LINK_LIBGCC_SPEC
697 /* Generate -L options for startfile prefix list. */
698 # define LINK_LIBGCC_SPEC "%D"
699 #endif
701 #ifndef STARTFILE_PREFIX_SPEC
702 # define STARTFILE_PREFIX_SPEC ""
703 #endif
705 #ifndef SYSROOT_SPEC
706 # define SYSROOT_SPEC "--sysroot=%R"
707 #endif
709 #ifndef SYSROOT_SUFFIX_SPEC
710 # define SYSROOT_SUFFIX_SPEC ""
711 #endif
713 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
714 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
715 #endif
717 static const char *asm_debug;
718 static const char *cpp_spec = CPP_SPEC;
719 static const char *cc1_spec = CC1_SPEC;
720 static const char *cc1plus_spec = CC1PLUS_SPEC;
721 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
722 static const char *asm_spec = ASM_SPEC;
723 static const char *asm_final_spec = ASM_FINAL_SPEC;
724 static const char *link_spec = LINK_SPEC;
725 static const char *lib_spec = LIB_SPEC;
726 static const char *mfwrap_spec = MFWRAP_SPEC;
727 static const char *mflib_spec = MFLIB_SPEC;
728 static const char *libgcc_spec = LIBGCC_SPEC;
729 static const char *endfile_spec = ENDFILE_SPEC;
730 static const char *startfile_spec = STARTFILE_SPEC;
731 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
732 static const char *linker_name_spec = LINKER_NAME;
733 static const char *link_command_spec = LINK_COMMAND_SPEC;
734 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
735 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
736 static const char *sysroot_spec = SYSROOT_SPEC;
737 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
738 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
740 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
741 There should be no need to override these in target dependent files,
742 but we need to copy them to the specs file so that newer versions
743 of the GCC driver can correctly drive older tool chains with the
744 appropriate -B options. */
746 /* When cpplib handles traditional preprocessing, get rid of this, and
747 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
748 that we default the front end language better. */
749 static const char *trad_capable_cpp =
750 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
752 /* We don't wrap .d files in %W{} since a missing .d file, and
753 therefore no dependency entry, confuses make into thinking a .o
754 file that happens to exist is up-to-date. */
755 static const char *cpp_unique_options =
756 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
757 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
758 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
759 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
760 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
761 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
762 %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
763 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
764 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
765 %{E|M|MM:%W{o*}}";
767 /* This contains cpp options which are common with cc1_options and are passed
768 only when preprocessing only to avoid duplication. We pass the cc1 spec
769 options to the preprocessor so that it the cc1 spec may manipulate
770 options used to set target flags. Those special target flags settings may
771 in turn cause preprocessor symbols to be defined specially. */
772 static const char *cpp_options =
773 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
774 %{f*} %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*}\
775 %{undef} %{save-temps:-fpch-preprocess}";
777 /* This contains cpp options which are not passed when the preprocessor
778 output will be used by another program. */
779 static const char *cpp_debug_options = "%{d*}";
781 /* NB: This is shared amongst all front-ends. */
782 static const char *cc1_options =
783 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
784 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
785 %{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}%{!c:%{!S:-auxbase %b}}\
786 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
787 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
788 %{Qn:-fno-ident} %{--help:--help}\
789 %{--target-help:--target-help}\
790 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
791 %{fsyntax-only:-o %j} %{-param*}\
792 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
793 %{coverage:-fprofile-arcs -ftest-coverage}";
795 static const char *asm_options =
796 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
798 static const char *invoke_as =
799 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
800 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
801 #else
802 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
803 #endif
805 /* Some compilers have limits on line lengths, and the multilib_select
806 and/or multilib_matches strings can be very long, so we build them at
807 run time. */
808 static struct obstack multilib_obstack;
809 static const char *multilib_select;
810 static const char *multilib_matches;
811 static const char *multilib_defaults;
812 static const char *multilib_exclusions;
814 /* Check whether a particular argument is a default argument. */
816 #ifndef MULTILIB_DEFAULTS
817 #define MULTILIB_DEFAULTS { "" }
818 #endif
820 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
822 #ifndef DRIVER_SELF_SPECS
823 #define DRIVER_SELF_SPECS ""
824 #endif
826 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
828 #ifndef OPTION_DEFAULT_SPECS
829 #define OPTION_DEFAULT_SPECS { "", "" }
830 #endif
832 struct default_spec
834 const char *name;
835 const char *spec;
838 static const struct default_spec
839 option_default_specs[] = { OPTION_DEFAULT_SPECS };
841 struct user_specs
843 struct user_specs *next;
844 const char *filename;
847 static struct user_specs *user_specs_head, *user_specs_tail;
849 #ifndef SWITCH_TAKES_ARG
850 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
851 #endif
853 #ifndef WORD_SWITCH_TAKES_ARG
854 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
855 #endif
857 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
858 /* This defines which switches stop a full compilation. */
859 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
860 ((CHAR) == 'c' || (CHAR) == 'S')
862 #ifndef SWITCH_CURTAILS_COMPILATION
863 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
864 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
865 #endif
866 #endif
868 /* Record the mapping from file suffixes for compilation specs. */
870 struct compiler
872 const char *suffix; /* Use this compiler for input files
873 whose names end in this suffix. */
875 const char *spec; /* To use this compiler, run this spec. */
877 const char *cpp_spec; /* If non-NULL, substitute this spec
878 for `%C', rather than the usual
879 cpp_spec. */
880 const int combinable; /* If nonzero, compiler can deal with
881 multiple source files at once (IMA). */
882 const int needs_preprocessing; /* If nonzero, source files need to
883 be run through a preprocessor. */
886 /* Pointer to a vector of `struct compiler' that gives the spec for
887 compiling a file, based on its suffix.
888 A file that does not end in any of these suffixes will be passed
889 unchanged to the loader and nothing else will be done to it.
891 An entry containing two 0s is used to terminate the vector.
893 If multiple entries match a file, the last matching one is used. */
895 static struct compiler *compilers;
897 /* Number of entries in `compilers', not counting the null terminator. */
899 static int n_compilers;
901 /* The default list of file name suffixes and their compilation specs. */
903 static const struct compiler default_compilers[] =
905 /* Add lists of suffixes of known languages here. If those languages
906 were not present when we built the driver, we will hit these copies
907 and be given a more meaningful error than "file not used since
908 linking is not done". */
909 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
910 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
911 {".mii", "#Objective-C++", 0, 0, 0},
912 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
913 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
914 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
915 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
916 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
917 {".f", "#Fortran", 0, 0, 0}, {".for", "#Fortran", 0, 0, 0},
918 {".F", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
919 {".FPP", "#Fortran", 0, 0, 0},
920 {".f90", "#Fortran 95", 0, 0, 0}, {".f95", "#Fortran 95", 0, 0, 0},
921 {".fpp", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
922 {".FOR", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
923 {".r", "#Ratfor", 0, 0, 0},
924 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
925 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
926 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
927 /* Next come the entries for C. */
928 {".c", "@c", 0, 1, 1},
929 {"@c",
930 /* cc1 has an integrated ISO C preprocessor. We should invoke the
931 external preprocessor if -save-temps is given. */
932 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
933 %{!E:%{!M:%{!MM:\
934 %{traditional|ftraditional:\
935 %eGNU C no longer supports -traditional without -E}\
936 %{!combine:\
937 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
938 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
939 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
940 %(cc1_options)}\
941 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
942 cc1 %(cpp_unique_options) %(cc1_options)}}}\
943 %{!fsyntax-only:%(invoke_as)}} \
944 %{combine:\
945 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
946 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i}}\
947 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
948 cc1 %(cpp_unique_options) %(cc1_options)}}\
949 %{!fsyntax-only:%(invoke_as)}}}}}}", 0, 1, 1},
950 {"-",
951 "%{!E:%e-E or -x required when input is from standard input}\
952 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
953 {".h", "@c-header", 0, 0, 0},
954 {"@c-header",
955 /* cc1 has an integrated ISO C preprocessor. We should invoke the
956 external preprocessor if -save-temps is given. */
957 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
958 %{!E:%{!M:%{!MM:\
959 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
960 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
961 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
962 %(cc1_options)\
963 -o %g.s %{!o*:--output-pch=%i.gch}\
964 %W{o*:--output-pch=%*}%V}\
965 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
966 cc1 %(cpp_unique_options) %(cc1_options)\
967 -o %g.s %{!o*:--output-pch=%i.gch}\
968 %W{o*:--output-pch=%*}%V}}}}}}", 0, 0, 0},
969 {".i", "@cpp-output", 0, 1, 0},
970 {"@cpp-output",
971 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
972 {".s", "@assembler", 0, 1, 0},
973 {"@assembler",
974 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
975 {".S", "@assembler-with-cpp", 0, 1, 0},
976 {"@assembler-with-cpp",
977 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
978 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
979 %{E|M|MM:%(cpp_debug_options)}\
980 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
981 as %(asm_debug) %(asm_options) %|.s %A }}}}"
982 #else
983 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
984 %{E|M|MM:%(cpp_debug_options)}\
985 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
986 as %(asm_debug) %(asm_options) %m.s %A }}}}"
987 #endif
988 , 0, 1, 0},
990 #include "specs.h"
991 /* Mark end of table. */
992 {0, 0, 0, 0, 0}
995 /* Number of elements in default_compilers, not counting the terminator. */
997 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
999 /* A vector of options to give to the linker.
1000 These options are accumulated by %x,
1001 and substituted into the linker command with %X. */
1002 static int n_linker_options;
1003 static char **linker_options;
1005 /* A vector of options to give to the assembler.
1006 These options are accumulated by -Wa,
1007 and substituted into the assembler command with %Y. */
1008 static int n_assembler_options;
1009 static char **assembler_options;
1011 /* A vector of options to give to the preprocessor.
1012 These options are accumulated by -Wp,
1013 and substituted into the preprocessor command with %Z. */
1014 static int n_preprocessor_options;
1015 static char **preprocessor_options;
1017 /* Define how to map long options into short ones. */
1019 /* This structure describes one mapping. */
1020 struct option_map
1022 /* The long option's name. */
1023 const char *const name;
1024 /* The equivalent short option. */
1025 const char *const equivalent;
1026 /* Argument info. A string of flag chars; NULL equals no options.
1027 a => argument required.
1028 o => argument optional.
1029 j => join argument to equivalent, making one word.
1030 * => require other text after NAME as an argument. */
1031 const char *const arg_info;
1034 /* This is the table of mappings. Mappings are tried sequentially
1035 for each option encountered; the first one that matches, wins. */
1037 static const struct option_map option_map[] =
1039 {"--all-warnings", "-Wall", 0},
1040 {"--ansi", "-ansi", 0},
1041 {"--assemble", "-S", 0},
1042 {"--assert", "-A", "a"},
1043 {"--classpath", "-fclasspath=", "aj"},
1044 {"--bootclasspath", "-fbootclasspath=", "aj"},
1045 {"--CLASSPATH", "-fclasspath=", "aj"},
1046 {"--combine", "-combine", 0},
1047 {"--comments", "-C", 0},
1048 {"--comments-in-macros", "-CC", 0},
1049 {"--compile", "-c", 0},
1050 {"--debug", "-g", "oj"},
1051 {"--define-macro", "-D", "aj"},
1052 {"--dependencies", "-M", 0},
1053 {"--dump", "-d", "a"},
1054 {"--dumpbase", "-dumpbase", "a"},
1055 {"--encoding", "-fencoding=", "aj"},
1056 {"--entry", "-e", 0},
1057 {"--extra-warnings", "-W", 0},
1058 {"--extdirs", "-fextdirs=", "aj"},
1059 {"--for-assembler", "-Wa", "a"},
1060 {"--for-linker", "-Xlinker", "a"},
1061 {"--force-link", "-u", "a"},
1062 {"--coverage", "-coverage", 0},
1063 {"--imacros", "-imacros", "a"},
1064 {"--include", "-include", "a"},
1065 {"--include-barrier", "-I-", 0},
1066 {"--include-directory", "-I", "aj"},
1067 {"--include-directory-after", "-idirafter", "a"},
1068 {"--include-prefix", "-iprefix", "a"},
1069 {"--include-with-prefix", "-iwithprefix", "a"},
1070 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1071 {"--include-with-prefix-after", "-iwithprefix", "a"},
1072 {"--language", "-x", "a"},
1073 {"--library-directory", "-L", "a"},
1074 {"--machine", "-m", "aj"},
1075 {"--machine-", "-m", "*j"},
1076 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1077 {"--no-line-commands", "-P", 0},
1078 {"--no-precompiled-includes", "-noprecomp", 0},
1079 {"--no-standard-includes", "-nostdinc", 0},
1080 {"--no-standard-libraries", "-nostdlib", 0},
1081 {"--no-warnings", "-w", 0},
1082 {"--optimize", "-O", "oj"},
1083 {"--output", "-o", "a"},
1084 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1085 {"--param", "--param", "a"},
1086 {"--pass-exit-codes", "-pass-exit-codes", 0},
1087 {"--pedantic", "-pedantic", 0},
1088 {"--pedantic-errors", "-pedantic-errors", 0},
1089 {"--pie", "-pie", 0},
1090 {"--pipe", "-pipe", 0},
1091 {"--prefix", "-B", "a"},
1092 {"--preprocess", "-E", 0},
1093 {"--print-search-dirs", "-print-search-dirs", 0},
1094 {"--print-file-name", "-print-file-name=", "aj"},
1095 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1096 {"--print-missing-file-dependencies", "-MG", 0},
1097 {"--print-multi-lib", "-print-multi-lib", 0},
1098 {"--print-multi-directory", "-print-multi-directory", 0},
1099 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1100 {"--print-prog-name", "-print-prog-name=", "aj"},
1101 {"--profile", "-p", 0},
1102 {"--profile-blocks", "-a", 0},
1103 {"--quiet", "-q", 0},
1104 {"--resource", "-fcompile-resource=", "aj"},
1105 {"--save-temps", "-save-temps", 0},
1106 {"--shared", "-shared", 0},
1107 {"--silent", "-q", 0},
1108 {"--specs", "-specs=", "aj"},
1109 {"--static", "-static", 0},
1110 {"--std", "-std=", "aj"},
1111 {"--symbolic", "-symbolic", 0},
1112 {"--time", "-time", 0},
1113 {"--trace-includes", "-H", 0},
1114 {"--traditional", "-traditional", 0},
1115 {"--traditional-cpp", "-traditional-cpp", 0},
1116 {"--trigraphs", "-trigraphs", 0},
1117 {"--undefine-macro", "-U", "aj"},
1118 {"--user-dependencies", "-MM", 0},
1119 {"--verbose", "-v", 0},
1120 {"--warn-", "-W", "*j"},
1121 {"--write-dependencies", "-MD", 0},
1122 {"--write-user-dependencies", "-MMD", 0},
1123 {"--", "-f", "*j"}
1127 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1128 static const struct {
1129 const char *const option_found;
1130 const char *const replacements;
1131 } target_option_translations[] =
1133 TARGET_OPTION_TRANSLATE_TABLE,
1134 { 0, 0 }
1136 #endif
1138 /* Translate the options described by *ARGCP and *ARGVP.
1139 Make a new vector and store it back in *ARGVP,
1140 and store its length in *ARGVC. */
1142 static void
1143 translate_options (int *argcp, const char *const **argvp)
1145 int i;
1146 int argc = *argcp;
1147 const char *const *argv = *argvp;
1148 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1149 const char **newv = xmalloc (newvsize);
1150 int newindex = 0;
1152 i = 0;
1153 newv[newindex++] = argv[i++];
1155 while (i < argc)
1157 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1158 int tott_idx;
1160 for (tott_idx = 0;
1161 target_option_translations[tott_idx].option_found;
1162 tott_idx++)
1164 if (strcmp (target_option_translations[tott_idx].option_found,
1165 argv[i]) == 0)
1167 int spaces = 1;
1168 const char *sp;
1169 char *np;
1171 for (sp = target_option_translations[tott_idx].replacements;
1172 *sp; sp++)
1174 if (*sp == ' ')
1175 spaces ++;
1178 newvsize += spaces * sizeof (const char *);
1179 newv = xrealloc (newv, newvsize);
1181 sp = target_option_translations[tott_idx].replacements;
1182 np = xstrdup (sp);
1184 while (1)
1186 while (*np == ' ')
1187 np++;
1188 if (*np == 0)
1189 break;
1190 newv[newindex++] = np;
1191 while (*np != ' ' && *np)
1192 np++;
1193 if (*np == 0)
1194 break;
1195 *np++ = 0;
1198 i ++;
1199 break;
1202 if (target_option_translations[tott_idx].option_found)
1203 continue;
1204 #endif
1206 /* Translate -- options. */
1207 if (argv[i][0] == '-' && argv[i][1] == '-')
1209 size_t j;
1210 /* Find a mapping that applies to this option. */
1211 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1213 size_t optlen = strlen (option_map[j].name);
1214 size_t arglen = strlen (argv[i]);
1215 size_t complen = arglen > optlen ? optlen : arglen;
1216 const char *arginfo = option_map[j].arg_info;
1218 if (arginfo == 0)
1219 arginfo = "";
1221 if (!strncmp (argv[i], option_map[j].name, complen))
1223 const char *arg = 0;
1225 if (arglen < optlen)
1227 size_t k;
1228 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1229 if (strlen (option_map[k].name) >= arglen
1230 && !strncmp (argv[i], option_map[k].name, arglen))
1232 error ("ambiguous abbreviation %s", argv[i]);
1233 break;
1236 if (k != ARRAY_SIZE (option_map))
1237 break;
1240 if (arglen > optlen)
1242 /* If the option has an argument, accept that. */
1243 if (argv[i][optlen] == '=')
1244 arg = argv[i] + optlen + 1;
1246 /* If this mapping requires extra text at end of name,
1247 accept that as "argument". */
1248 else if (strchr (arginfo, '*') != 0)
1249 arg = argv[i] + optlen;
1251 /* Otherwise, extra text at end means mismatch.
1252 Try other mappings. */
1253 else
1254 continue;
1257 else if (strchr (arginfo, '*') != 0)
1259 error ("incomplete '%s' option", option_map[j].name);
1260 break;
1263 /* Handle arguments. */
1264 if (strchr (arginfo, 'a') != 0)
1266 if (arg == 0)
1268 if (i + 1 == argc)
1270 error ("missing argument to '%s' option",
1271 option_map[j].name);
1272 break;
1275 arg = argv[++i];
1278 else if (strchr (arginfo, '*') != 0)
1280 else if (strchr (arginfo, 'o') == 0)
1282 if (arg != 0)
1283 error ("extraneous argument to '%s' option",
1284 option_map[j].name);
1285 arg = 0;
1288 /* Store the translation as one argv elt or as two. */
1289 if (arg != 0 && strchr (arginfo, 'j') != 0)
1290 newv[newindex++] = concat (option_map[j].equivalent, arg,
1291 NULL);
1292 else if (arg != 0)
1294 newv[newindex++] = option_map[j].equivalent;
1295 newv[newindex++] = arg;
1297 else
1298 newv[newindex++] = option_map[j].equivalent;
1300 break;
1303 i++;
1306 /* Handle old-fashioned options--just copy them through,
1307 with their arguments. */
1308 else if (argv[i][0] == '-')
1310 const char *p = argv[i] + 1;
1311 int c = *p;
1312 int nskip = 1;
1314 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1315 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1316 else if (WORD_SWITCH_TAKES_ARG (p))
1317 nskip += WORD_SWITCH_TAKES_ARG (p);
1318 else if ((c == 'B' || c == 'b' || c == 'x')
1319 && p[1] == 0)
1320 nskip += 1;
1321 else if (! strcmp (p, "Xlinker"))
1322 nskip += 1;
1323 else if (! strcmp (p, "Xpreprocessor"))
1324 nskip += 1;
1325 else if (! strcmp (p, "Xassembler"))
1326 nskip += 1;
1328 /* Watch out for an option at the end of the command line that
1329 is missing arguments, and avoid skipping past the end of the
1330 command line. */
1331 if (nskip + i > argc)
1332 nskip = argc - i;
1334 while (nskip > 0)
1336 newv[newindex++] = argv[i++];
1337 nskip--;
1340 else
1341 /* Ordinary operands, or +e options. */
1342 newv[newindex++] = argv[i++];
1345 newv[newindex] = 0;
1347 *argvp = newv;
1348 *argcp = newindex;
1351 static char *
1352 skip_whitespace (char *p)
1354 while (1)
1356 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1357 be considered whitespace. */
1358 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1359 return p + 1;
1360 else if (*p == '\n' || *p == ' ' || *p == '\t')
1361 p++;
1362 else if (*p == '#')
1364 while (*p != '\n')
1365 p++;
1366 p++;
1368 else
1369 break;
1372 return p;
1374 /* Structures to keep track of prefixes to try when looking for files. */
1376 struct prefix_list
1378 const char *prefix; /* String to prepend to the path. */
1379 struct prefix_list *next; /* Next in linked list. */
1380 int require_machine_suffix; /* Don't use without machine_suffix. */
1381 /* 2 means try both machine_suffix and just_machine_suffix. */
1382 int priority; /* Sort key - priority within list. */
1383 int os_multilib; /* 1 if OS multilib scheme should be used,
1384 0 for GCC multilib scheme. */
1387 struct path_prefix
1389 struct prefix_list *plist; /* List of prefixes to try */
1390 int max_len; /* Max length of a prefix in PLIST */
1391 const char *name; /* Name of this list (used in config stuff) */
1394 /* List of prefixes to try when looking for executables. */
1396 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1398 /* List of prefixes to try when looking for startup (crt0) files. */
1400 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1402 /* List of prefixes to try when looking for include files. */
1404 static struct path_prefix include_prefixes = { 0, 0, "include" };
1406 /* Suffix to attach to directories searched for commands.
1407 This looks like `MACHINE/VERSION/'. */
1409 static const char *machine_suffix = 0;
1411 /* Suffix to attach to directories searched for commands.
1412 This is just `MACHINE/'. */
1414 static const char *just_machine_suffix = 0;
1416 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1418 static const char *gcc_exec_prefix;
1420 /* Adjusted value of standard_libexec_prefix. */
1422 static const char *gcc_libexec_prefix;
1424 /* Default prefixes to attach to command names. */
1426 #ifndef STANDARD_STARTFILE_PREFIX_1
1427 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1428 #endif
1429 #ifndef STANDARD_STARTFILE_PREFIX_2
1430 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1431 #endif
1433 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1434 #undef MD_EXEC_PREFIX
1435 #undef MD_STARTFILE_PREFIX
1436 #undef MD_STARTFILE_PREFIX_1
1437 #endif
1439 /* If no prefixes defined, use the null string, which will disable them. */
1440 #ifndef MD_EXEC_PREFIX
1441 #define MD_EXEC_PREFIX ""
1442 #endif
1443 #ifndef MD_STARTFILE_PREFIX
1444 #define MD_STARTFILE_PREFIX ""
1445 #endif
1446 #ifndef MD_STARTFILE_PREFIX_1
1447 #define MD_STARTFILE_PREFIX_1 ""
1448 #endif
1450 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1451 static const char *const standard_exec_prefix_1 = "/usr/libexec/gcc/";
1452 static const char *const standard_exec_prefix_2 = "/usr/lib/gcc/";
1453 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1455 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1456 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1457 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1458 static const char *const standard_startfile_prefix_1
1459 = STANDARD_STARTFILE_PREFIX_1;
1460 static const char *const standard_startfile_prefix_2
1461 = STANDARD_STARTFILE_PREFIX_2;
1463 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1464 static const char *tooldir_prefix;
1466 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1468 static const char *standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1470 /* Subdirectory to use for locating libraries. Set by
1471 set_multilib_dir based on the compilation options. */
1473 static const char *multilib_dir;
1475 /* Subdirectory to use for locating libraries in OS conventions. Set by
1476 set_multilib_dir based on the compilation options. */
1478 static const char *multilib_os_dir;
1480 /* Structure to keep track of the specs that have been defined so far.
1481 These are accessed using %(specname) or %[specname] in a compiler
1482 or link spec. */
1484 struct spec_list
1486 /* The following 2 fields must be first */
1487 /* to allow EXTRA_SPECS to be initialized */
1488 const char *name; /* name of the spec. */
1489 const char *ptr; /* available ptr if no static pointer */
1491 /* The following fields are not initialized */
1492 /* by EXTRA_SPECS */
1493 const char **ptr_spec; /* pointer to the spec itself. */
1494 struct spec_list *next; /* Next spec in linked list. */
1495 int name_len; /* length of the name */
1496 int alloc_p; /* whether string was allocated */
1499 #define INIT_STATIC_SPEC(NAME,PTR) \
1500 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1502 /* List of statically defined specs. */
1503 static struct spec_list static_specs[] =
1505 INIT_STATIC_SPEC ("asm", &asm_spec),
1506 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1507 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1508 INIT_STATIC_SPEC ("asm_options", &asm_options),
1509 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1510 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1511 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1512 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1513 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1514 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1515 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1516 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1517 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1518 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1519 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1520 INIT_STATIC_SPEC ("link", &link_spec),
1521 INIT_STATIC_SPEC ("lib", &lib_spec),
1522 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1523 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1524 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1525 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1526 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1527 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1528 INIT_STATIC_SPEC ("version", &compiler_version),
1529 INIT_STATIC_SPEC ("multilib", &multilib_select),
1530 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1531 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1532 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1533 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1534 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1535 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1536 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1537 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1538 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1539 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1540 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1541 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1542 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1543 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1546 #ifdef EXTRA_SPECS /* additional specs needed */
1547 /* Structure to keep track of just the first two args of a spec_list.
1548 That is all that the EXTRA_SPECS macro gives us. */
1549 struct spec_list_1
1551 const char *const name;
1552 const char *const ptr;
1555 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1556 static struct spec_list *extra_specs = (struct spec_list *) 0;
1557 #endif
1559 /* List of dynamically allocates specs that have been defined so far. */
1561 static struct spec_list *specs = (struct spec_list *) 0;
1563 /* List of static spec functions. */
1565 static const struct spec_function static_spec_functions[] =
1567 { "if-exists", if_exists_spec_function },
1568 { "if-exists-else", if_exists_else_spec_function },
1569 { "replace-outfile", replace_outfile_spec_function },
1570 { 0, 0 }
1573 static int processing_spec_function;
1575 /* Add appropriate libgcc specs to OBSTACK, taking into account
1576 various permutations of -shared-libgcc, -shared, and such. */
1578 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1580 #ifndef USE_LD_AS_NEEDED
1581 #define USE_LD_AS_NEEDED 0
1582 #endif
1584 static void
1585 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1586 const char *static_name, const char *eh_name)
1588 char *buf;
1590 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1591 "}%{!static:%{!static-libgcc:",
1592 #if USE_LD_AS_NEEDED
1593 "%{!shared-libgcc:", static_name,
1594 " --as-needed ", shared_name, " --no-as-needed}"
1595 "%{shared-libgcc:", shared_name, "%{!shared: ", static_name,
1596 "}",
1597 #else
1598 "%{!shared:%{!shared-libgcc:", static_name, " ",
1599 eh_name, "}%{shared-libgcc:", shared_name, " ",
1600 static_name, "}}%{shared:",
1601 #ifdef LINK_EH_SPEC
1602 "%{shared-libgcc:", shared_name,
1603 "}%{!shared-libgcc:", static_name, "}",
1604 #else
1605 shared_name,
1606 #endif
1607 #endif
1608 "}}}", NULL);
1610 obstack_grow (obstack, buf, strlen (buf));
1611 free (buf);
1613 #endif /* ENABLE_SHARED_LIBGCC */
1615 /* Initialize the specs lookup routines. */
1617 static void
1618 init_spec (void)
1620 struct spec_list *next = (struct spec_list *) 0;
1621 struct spec_list *sl = (struct spec_list *) 0;
1622 int i;
1624 if (specs)
1625 return; /* Already initialized. */
1627 if (verbose_flag)
1628 notice ("Using built-in specs.\n");
1630 #ifdef EXTRA_SPECS
1631 extra_specs = xcalloc (sizeof (struct spec_list),
1632 ARRAY_SIZE (extra_specs_1));
1634 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1636 sl = &extra_specs[i];
1637 sl->name = extra_specs_1[i].name;
1638 sl->ptr = extra_specs_1[i].ptr;
1639 sl->next = next;
1640 sl->name_len = strlen (sl->name);
1641 sl->ptr_spec = &sl->ptr;
1642 next = sl;
1644 #endif
1646 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1647 on ?: in file-scope variable initializations. */
1648 asm_debug = ASM_DEBUG_SPEC;
1650 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1652 sl = &static_specs[i];
1653 sl->next = next;
1654 next = sl;
1657 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1658 /* ??? If neither -shared-libgcc nor --static-libgcc was
1659 seen, then we should be making an educated guess. Some proposed
1660 heuristics for ELF include:
1662 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1663 program will be doing dynamic loading, which will likely
1664 need the shared libgcc.
1666 (2) If "-ldl", then it's also a fair bet that we're doing
1667 dynamic loading.
1669 (3) For each ET_DYN we're linking against (either through -lfoo
1670 or /some/path/foo.so), check to see whether it or one of
1671 its dependencies depends on a shared libgcc.
1673 (4) If "-shared"
1675 If the runtime is fixed to look for program headers instead
1676 of calling __register_frame_info at all, for each object,
1677 use the shared libgcc if any EH symbol referenced.
1679 If crtstuff is fixed to not invoke __register_frame_info
1680 automatically, for each object, use the shared libgcc if
1681 any non-empty unwind section found.
1683 Doing any of this probably requires invoking an external program to
1684 do the actual object file scanning. */
1686 const char *p = libgcc_spec;
1687 int in_sep = 1;
1689 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1690 when given the proper command line arguments. */
1691 while (*p)
1693 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1695 init_gcc_specs (&obstack,
1696 "-lgcc_s"
1697 #ifdef USE_LIBUNWIND_EXCEPTIONS
1698 " -lunwind"
1699 #endif
1701 "-lgcc",
1702 "-lgcc_eh"
1703 #ifdef USE_LIBUNWIND_EXCEPTIONS
1704 # ifdef HAVE_LD_STATIC_DYNAMIC
1705 " %{!static:-Bstatic} -lunwind %{!static:-Bdynamic}"
1706 # else
1707 " -lunwind"
1708 # endif
1709 #endif
1712 p += 5;
1713 in_sep = 0;
1715 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1717 /* Ug. We don't know shared library extensions. Hope that
1718 systems that use this form don't do shared libraries. */
1719 init_gcc_specs (&obstack,
1720 "-lgcc_s",
1721 "libgcc.a%s",
1722 "libgcc_eh.a%s"
1723 #ifdef USE_LIBUNWIND_EXCEPTIONS
1724 " -lunwind"
1725 #endif
1727 p += 10;
1728 in_sep = 0;
1730 else
1732 obstack_1grow (&obstack, *p);
1733 in_sep = (*p == ' ');
1734 p += 1;
1738 obstack_1grow (&obstack, '\0');
1739 libgcc_spec = XOBFINISH (&obstack, const char *);
1741 #endif
1742 #ifdef USE_AS_TRADITIONAL_FORMAT
1743 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1745 static const char tf[] = "--traditional-format ";
1746 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1747 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1748 asm_spec = XOBFINISH (&obstack, const char *);
1750 #endif
1751 #ifdef LINK_EH_SPEC
1752 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1753 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1754 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1755 link_spec = XOBFINISH (&obstack, const char *);
1756 #endif
1758 specs = sl;
1761 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1762 removed; If the spec starts with a + then SPEC is added to the end of the
1763 current spec. */
1765 static void
1766 set_spec (const char *name, const char *spec)
1768 struct spec_list *sl;
1769 const char *old_spec;
1770 int name_len = strlen (name);
1771 int i;
1773 /* If this is the first call, initialize the statically allocated specs. */
1774 if (!specs)
1776 struct spec_list *next = (struct spec_list *) 0;
1777 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1779 sl = &static_specs[i];
1780 sl->next = next;
1781 next = sl;
1783 specs = sl;
1786 /* See if the spec already exists. */
1787 for (sl = specs; sl; sl = sl->next)
1788 if (name_len == sl->name_len && !strcmp (sl->name, name))
1789 break;
1791 if (!sl)
1793 /* Not found - make it. */
1794 sl = xmalloc (sizeof (struct spec_list));
1795 sl->name = xstrdup (name);
1796 sl->name_len = name_len;
1797 sl->ptr_spec = &sl->ptr;
1798 sl->alloc_p = 0;
1799 *(sl->ptr_spec) = "";
1800 sl->next = specs;
1801 specs = sl;
1804 old_spec = *(sl->ptr_spec);
1805 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1806 ? concat (old_spec, spec + 1, NULL)
1807 : xstrdup (spec));
1809 #ifdef DEBUG_SPECS
1810 if (verbose_flag)
1811 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1812 #endif
1814 /* Free the old spec. */
1815 if (old_spec && sl->alloc_p)
1816 free ((void *) old_spec);
1818 sl->alloc_p = 1;
1821 /* Accumulate a command (program name and args), and run it. */
1823 /* Vector of pointers to arguments in the current line of specifications. */
1825 static const char **argbuf;
1827 /* Number of elements allocated in argbuf. */
1829 static int argbuf_length;
1831 /* Number of elements in argbuf currently in use (containing args). */
1833 static int argbuf_index;
1835 /* Position in the argbuf array containing the name of the output file
1836 (the value associated with the "-o" flag). */
1838 static int have_o_argbuf_index = 0;
1840 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1841 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1842 it here. */
1844 static struct temp_name {
1845 const char *suffix; /* suffix associated with the code. */
1846 int length; /* strlen (suffix). */
1847 int unique; /* Indicates whether %g or %u/%U was used. */
1848 const char *filename; /* associated filename. */
1849 int filename_length; /* strlen (filename). */
1850 struct temp_name *next;
1851 } *temp_names;
1853 /* Number of commands executed so far. */
1855 static int execution_count;
1857 /* Number of commands that exited with a signal. */
1859 static int signal_count;
1861 /* Name with which this program was invoked. */
1863 static const char *programname;
1865 /* Allocate the argument vector. */
1867 static void
1868 alloc_args (void)
1870 argbuf_length = 10;
1871 argbuf = xmalloc (argbuf_length * sizeof (const char *));
1874 /* Clear out the vector of arguments (after a command is executed). */
1876 static void
1877 clear_args (void)
1879 argbuf_index = 0;
1882 /* Add one argument to the vector at the end.
1883 This is done when a space is seen or at the end of the line.
1884 If DELETE_ALWAYS is nonzero, the arg is a filename
1885 and the file should be deleted eventually.
1886 If DELETE_FAILURE is nonzero, the arg is a filename
1887 and the file should be deleted if this compilation fails. */
1889 static void
1890 store_arg (const char *arg, int delete_always, int delete_failure)
1892 if (argbuf_index + 1 == argbuf_length)
1893 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1895 argbuf[argbuf_index++] = arg;
1896 argbuf[argbuf_index] = 0;
1898 if (strcmp (arg, "-o") == 0)
1899 have_o_argbuf_index = argbuf_index;
1900 if (delete_always || delete_failure)
1901 record_temp_file (arg, delete_always, delete_failure);
1904 /* Load specs from a file name named FILENAME, replacing occurrences of
1905 various different types of line-endings, \r\n, \n\r and just \r, with
1906 a single \n. */
1908 static char *
1909 load_specs (const char *filename)
1911 int desc;
1912 int readlen;
1913 struct stat statbuf;
1914 char *buffer;
1915 char *buffer_p;
1916 char *specs;
1917 char *specs_p;
1919 if (verbose_flag)
1920 notice ("Reading specs from %s\n", filename);
1922 /* Open and stat the file. */
1923 desc = open (filename, O_RDONLY, 0);
1924 if (desc < 0)
1925 pfatal_with_name (filename);
1926 if (stat (filename, &statbuf) < 0)
1927 pfatal_with_name (filename);
1929 /* Read contents of file into BUFFER. */
1930 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1931 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1932 if (readlen < 0)
1933 pfatal_with_name (filename);
1934 buffer[readlen] = 0;
1935 close (desc);
1937 specs = xmalloc (readlen + 1);
1938 specs_p = specs;
1939 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1941 int skip = 0;
1942 char c = *buffer_p;
1943 if (c == '\r')
1945 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1946 skip = 1;
1947 else if (*(buffer_p + 1) == '\n') /* \r\n */
1948 skip = 1;
1949 else /* \r */
1950 c = '\n';
1952 if (! skip)
1953 *specs_p++ = c;
1955 *specs_p = '\0';
1957 free (buffer);
1958 return (specs);
1961 /* Read compilation specs from a file named FILENAME,
1962 replacing the default ones.
1964 A suffix which starts with `*' is a definition for
1965 one of the machine-specific sub-specs. The "suffix" should be
1966 *asm, *cc1, *cpp, *link, *startfile, etc.
1967 The corresponding spec is stored in asm_spec, etc.,
1968 rather than in the `compilers' vector.
1970 Anything invalid in the file is a fatal error. */
1972 static void
1973 read_specs (const char *filename, int main_p)
1975 char *buffer;
1976 char *p;
1978 buffer = load_specs (filename);
1980 /* Scan BUFFER for specs, putting them in the vector. */
1981 p = buffer;
1982 while (1)
1984 char *suffix;
1985 char *spec;
1986 char *in, *out, *p1, *p2, *p3;
1988 /* Advance P in BUFFER to the next nonblank nocomment line. */
1989 p = skip_whitespace (p);
1990 if (*p == 0)
1991 break;
1993 /* Is this a special command that starts with '%'? */
1994 /* Don't allow this for the main specs file, since it would
1995 encourage people to overwrite it. */
1996 if (*p == '%' && !main_p)
1998 p1 = p;
1999 while (*p && *p != '\n')
2000 p++;
2002 /* Skip '\n'. */
2003 p++;
2005 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2006 && (p1[sizeof "%include" - 1] == ' '
2007 || p1[sizeof "%include" - 1] == '\t'))
2009 char *new_filename;
2011 p1 += sizeof ("%include");
2012 while (*p1 == ' ' || *p1 == '\t')
2013 p1++;
2015 if (*p1++ != '<' || p[-2] != '>')
2016 fatal ("specs %%include syntax malformed after %ld characters",
2017 (long) (p1 - buffer + 1));
2019 p[-2] = '\0';
2020 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2021 read_specs (new_filename ? new_filename : p1, FALSE);
2022 continue;
2024 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2025 && (p1[sizeof "%include_noerr" - 1] == ' '
2026 || p1[sizeof "%include_noerr" - 1] == '\t'))
2028 char *new_filename;
2030 p1 += sizeof "%include_noerr";
2031 while (*p1 == ' ' || *p1 == '\t')
2032 p1++;
2034 if (*p1++ != '<' || p[-2] != '>')
2035 fatal ("specs %%include syntax malformed after %ld characters",
2036 (long) (p1 - buffer + 1));
2038 p[-2] = '\0';
2039 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2040 if (new_filename)
2041 read_specs (new_filename, FALSE);
2042 else if (verbose_flag)
2043 notice ("could not find specs file %s\n", p1);
2044 continue;
2046 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2047 && (p1[sizeof "%rename" - 1] == ' '
2048 || p1[sizeof "%rename" - 1] == '\t'))
2050 int name_len;
2051 struct spec_list *sl;
2052 struct spec_list *newsl;
2054 /* Get original name. */
2055 p1 += sizeof "%rename";
2056 while (*p1 == ' ' || *p1 == '\t')
2057 p1++;
2059 if (! ISALPHA ((unsigned char) *p1))
2060 fatal ("specs %%rename syntax malformed after %ld characters",
2061 (long) (p1 - buffer));
2063 p2 = p1;
2064 while (*p2 && !ISSPACE ((unsigned char) *p2))
2065 p2++;
2067 if (*p2 != ' ' && *p2 != '\t')
2068 fatal ("specs %%rename syntax malformed after %ld characters",
2069 (long) (p2 - buffer));
2071 name_len = p2 - p1;
2072 *p2++ = '\0';
2073 while (*p2 == ' ' || *p2 == '\t')
2074 p2++;
2076 if (! ISALPHA ((unsigned char) *p2))
2077 fatal ("specs %%rename syntax malformed after %ld characters",
2078 (long) (p2 - buffer));
2080 /* Get new spec name. */
2081 p3 = p2;
2082 while (*p3 && !ISSPACE ((unsigned char) *p3))
2083 p3++;
2085 if (p3 != p - 1)
2086 fatal ("specs %%rename syntax malformed after %ld characters",
2087 (long) (p3 - buffer));
2088 *p3 = '\0';
2090 for (sl = specs; sl; sl = sl->next)
2091 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2092 break;
2094 if (!sl)
2095 fatal ("specs %s spec was not found to be renamed", p1);
2097 if (strcmp (p1, p2) == 0)
2098 continue;
2100 for (newsl = specs; newsl; newsl = newsl->next)
2101 if (strcmp (newsl->name, p2) == 0)
2102 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2103 filename, p1, p2);
2105 if (verbose_flag)
2107 notice ("rename spec %s to %s\n", p1, p2);
2108 #ifdef DEBUG_SPECS
2109 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2110 #endif
2113 set_spec (p2, *(sl->ptr_spec));
2114 if (sl->alloc_p)
2115 free ((void *) *(sl->ptr_spec));
2117 *(sl->ptr_spec) = "";
2118 sl->alloc_p = 0;
2119 continue;
2121 else
2122 fatal ("specs unknown %% command after %ld characters",
2123 (long) (p1 - buffer));
2126 /* Find the colon that should end the suffix. */
2127 p1 = p;
2128 while (*p1 && *p1 != ':' && *p1 != '\n')
2129 p1++;
2131 /* The colon shouldn't be missing. */
2132 if (*p1 != ':')
2133 fatal ("specs file malformed after %ld characters",
2134 (long) (p1 - buffer));
2136 /* Skip back over trailing whitespace. */
2137 p2 = p1;
2138 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2139 p2--;
2141 /* Copy the suffix to a string. */
2142 suffix = save_string (p, p2 - p);
2143 /* Find the next line. */
2144 p = skip_whitespace (p1 + 1);
2145 if (p[1] == 0)
2146 fatal ("specs file malformed after %ld characters",
2147 (long) (p - buffer));
2149 p1 = p;
2150 /* Find next blank line or end of string. */
2151 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2152 p1++;
2154 /* Specs end at the blank line and do not include the newline. */
2155 spec = save_string (p, p1 - p);
2156 p = p1;
2158 /* Delete backslash-newline sequences from the spec. */
2159 in = spec;
2160 out = spec;
2161 while (*in != 0)
2163 if (in[0] == '\\' && in[1] == '\n')
2164 in += 2;
2165 else if (in[0] == '#')
2166 while (*in && *in != '\n')
2167 in++;
2169 else
2170 *out++ = *in++;
2172 *out = 0;
2174 if (suffix[0] == '*')
2176 if (! strcmp (suffix, "*link_command"))
2177 link_command_spec = spec;
2178 else
2179 set_spec (suffix + 1, spec);
2181 else
2183 /* Add this pair to the vector. */
2184 compilers
2185 = xrealloc (compilers,
2186 (n_compilers + 2) * sizeof (struct compiler));
2188 compilers[n_compilers].suffix = suffix;
2189 compilers[n_compilers].spec = spec;
2190 n_compilers++;
2191 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2194 if (*suffix == 0)
2195 link_command_spec = spec;
2198 if (link_command_spec == 0)
2199 fatal ("spec file has no spec for linking");
2202 /* Record the names of temporary files we tell compilers to write,
2203 and delete them at the end of the run. */
2205 /* This is the common prefix we use to make temp file names.
2206 It is chosen once for each run of this program.
2207 It is substituted into a spec by %g or %j.
2208 Thus, all temp file names contain this prefix.
2209 In practice, all temp file names start with this prefix.
2211 This prefix comes from the envvar TMPDIR if it is defined;
2212 otherwise, from the P_tmpdir macro if that is defined;
2213 otherwise, in /usr/tmp or /tmp;
2214 or finally the current directory if all else fails. */
2216 static const char *temp_filename;
2218 /* Length of the prefix. */
2220 static int temp_filename_length;
2222 /* Define the list of temporary files to delete. */
2224 struct temp_file
2226 const char *name;
2227 struct temp_file *next;
2230 /* Queue of files to delete on success or failure of compilation. */
2231 static struct temp_file *always_delete_queue;
2232 /* Queue of files to delete on failure of compilation. */
2233 static struct temp_file *failure_delete_queue;
2235 /* Record FILENAME as a file to be deleted automatically.
2236 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2237 otherwise delete it in any case.
2238 FAIL_DELETE nonzero means delete it if a compilation step fails;
2239 otherwise delete it in any case. */
2241 void
2242 record_temp_file (const char *filename, int always_delete, int fail_delete)
2244 char *const name = xstrdup (filename);
2246 if (always_delete)
2248 struct temp_file *temp;
2249 for (temp = always_delete_queue; temp; temp = temp->next)
2250 if (! strcmp (name, temp->name))
2251 goto already1;
2253 temp = xmalloc (sizeof (struct temp_file));
2254 temp->next = always_delete_queue;
2255 temp->name = name;
2256 always_delete_queue = temp;
2258 already1:;
2261 if (fail_delete)
2263 struct temp_file *temp;
2264 for (temp = failure_delete_queue; temp; temp = temp->next)
2265 if (! strcmp (name, temp->name))
2266 goto already2;
2268 temp = xmalloc (sizeof (struct temp_file));
2269 temp->next = failure_delete_queue;
2270 temp->name = name;
2271 failure_delete_queue = temp;
2273 already2:;
2277 /* Delete all the temporary files whose names we previously recorded. */
2279 #ifndef DELETE_IF_ORDINARY
2280 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2281 do \
2283 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2284 if (unlink (NAME) < 0) \
2285 if (VERBOSE_FLAG) \
2286 perror_with_name (NAME); \
2287 } while (0)
2288 #endif
2290 static void
2291 delete_if_ordinary (const char *name)
2293 struct stat st;
2294 #ifdef DEBUG
2295 int i, c;
2297 printf ("Delete %s? (y or n) ", name);
2298 fflush (stdout);
2299 i = getchar ();
2300 if (i != '\n')
2301 while ((c = getchar ()) != '\n' && c != EOF)
2304 if (i == 'y' || i == 'Y')
2305 #endif /* DEBUG */
2306 DELETE_IF_ORDINARY (name, st, verbose_flag);
2309 static void
2310 delete_temp_files (void)
2312 struct temp_file *temp;
2314 for (temp = always_delete_queue; temp; temp = temp->next)
2315 delete_if_ordinary (temp->name);
2316 always_delete_queue = 0;
2319 /* Delete all the files to be deleted on error. */
2321 static void
2322 delete_failure_queue (void)
2324 struct temp_file *temp;
2326 for (temp = failure_delete_queue; temp; temp = temp->next)
2327 delete_if_ordinary (temp->name);
2330 static void
2331 clear_failure_queue (void)
2333 failure_delete_queue = 0;
2336 /* Build a list of search directories from PATHS.
2337 PREFIX is a string to prepend to the list.
2338 If CHECK_DIR_P is nonzero we ensure the directory exists.
2339 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2340 It is also used by the --print-search-dirs flag. */
2342 static char *
2343 build_search_list (struct path_prefix *paths, const char *prefix,
2344 int check_dir_p)
2346 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2347 int just_suffix_len
2348 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2349 int first_time = TRUE;
2350 struct prefix_list *pprefix;
2352 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2353 obstack_1grow (&collect_obstack, '=');
2355 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2357 int len = strlen (pprefix->prefix);
2359 if (machine_suffix
2360 && (! check_dir_p
2361 || is_directory (pprefix->prefix, machine_suffix, 0)))
2363 if (!first_time)
2364 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2366 first_time = FALSE;
2367 obstack_grow (&collect_obstack, pprefix->prefix, len);
2368 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2371 if (just_machine_suffix
2372 && pprefix->require_machine_suffix == 2
2373 && (! check_dir_p
2374 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2376 if (! first_time)
2377 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2379 first_time = FALSE;
2380 obstack_grow (&collect_obstack, pprefix->prefix, len);
2381 obstack_grow (&collect_obstack, just_machine_suffix,
2382 just_suffix_len);
2385 if (! pprefix->require_machine_suffix)
2387 if (! first_time)
2388 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2390 first_time = FALSE;
2391 obstack_grow (&collect_obstack, pprefix->prefix, len);
2395 obstack_1grow (&collect_obstack, '\0');
2396 return XOBFINISH (&collect_obstack, char *);
2399 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2400 for collect. */
2402 static void
2403 putenv_from_prefixes (struct path_prefix *paths, const char *env_var)
2405 putenv (build_search_list (paths, env_var, 1));
2408 /* Check whether NAME can be accessed in MODE. This is like access,
2409 except that it never considers directories to be executable. */
2411 static int
2412 access_check (const char *name, int mode)
2414 if (mode == X_OK)
2416 struct stat st;
2418 if (stat (name, &st) < 0
2419 || S_ISDIR (st.st_mode))
2420 return -1;
2423 return access (name, mode);
2426 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2427 access to check permissions.
2428 Return 0 if not found, otherwise return its name, allocated with malloc. */
2430 static char *
2431 find_a_file (struct path_prefix *pprefix, const char *name, int mode,
2432 int multilib)
2434 char *temp;
2435 const char *const file_suffix =
2436 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2437 struct prefix_list *pl;
2438 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2439 const char *multilib_name, *multilib_os_name;
2441 #ifdef DEFAULT_ASSEMBLER
2442 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2443 return xstrdup (DEFAULT_ASSEMBLER);
2444 #endif
2446 #ifdef DEFAULT_LINKER
2447 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2448 return xstrdup (DEFAULT_LINKER);
2449 #endif
2451 if (machine_suffix)
2452 len += strlen (machine_suffix);
2454 multilib_name = name;
2455 multilib_os_name = name;
2456 if (multilib && multilib_os_dir)
2458 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2459 int len2 = strlen (multilib_os_dir) + 1;
2461 len += len1 > len2 ? len1 : len2;
2462 if (multilib_dir)
2463 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2464 NULL));
2465 if (strcmp (multilib_os_dir, ".") != 0)
2466 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2467 NULL));
2470 temp = xmalloc (len);
2472 /* Determine the filename to execute (special case for absolute paths). */
2474 if (IS_ABSOLUTE_PATH (name))
2476 if (access (name, mode) == 0)
2478 strcpy (temp, name);
2479 return temp;
2482 else
2483 for (pl = pprefix->plist; pl; pl = pl->next)
2485 const char *this_name
2486 = pl->os_multilib ? multilib_os_name : multilib_name;
2488 if (machine_suffix)
2490 /* Some systems have a suffix for executable files.
2491 So try appending that first. */
2492 if (file_suffix[0] != 0)
2494 strcpy (temp, pl->prefix);
2495 strcat (temp, machine_suffix);
2496 strcat (temp, multilib_name);
2497 strcat (temp, file_suffix);
2498 if (access_check (temp, mode) == 0)
2499 return temp;
2502 /* Now try just the multilib_name. */
2503 strcpy (temp, pl->prefix);
2504 strcat (temp, machine_suffix);
2505 strcat (temp, multilib_name);
2506 if (access_check (temp, mode) == 0)
2507 return temp;
2510 /* Certain prefixes are tried with just the machine type,
2511 not the version. This is used for finding as, ld, etc. */
2512 if (just_machine_suffix && pl->require_machine_suffix == 2)
2514 /* Some systems have a suffix for executable files.
2515 So try appending that first. */
2516 if (file_suffix[0] != 0)
2518 strcpy (temp, pl->prefix);
2519 strcat (temp, just_machine_suffix);
2520 strcat (temp, multilib_name);
2521 strcat (temp, file_suffix);
2522 if (access_check (temp, mode) == 0)
2523 return temp;
2526 strcpy (temp, pl->prefix);
2527 strcat (temp, just_machine_suffix);
2528 strcat (temp, multilib_name);
2529 if (access_check (temp, mode) == 0)
2530 return temp;
2533 /* Certain prefixes can't be used without the machine suffix
2534 when the machine or version is explicitly specified. */
2535 if (! pl->require_machine_suffix)
2537 /* Some systems have a suffix for executable files.
2538 So try appending that first. */
2539 if (file_suffix[0] != 0)
2541 strcpy (temp, pl->prefix);
2542 strcat (temp, this_name);
2543 strcat (temp, file_suffix);
2544 if (access_check (temp, mode) == 0)
2545 return temp;
2548 strcpy (temp, pl->prefix);
2549 strcat (temp, this_name);
2550 if (access_check (temp, mode) == 0)
2551 return temp;
2555 free (temp);
2556 return 0;
2559 /* Ranking of prefixes in the sort list. -B prefixes are put before
2560 all others. */
2562 enum path_prefix_priority
2564 PREFIX_PRIORITY_B_OPT,
2565 PREFIX_PRIORITY_LAST
2568 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2569 order according to PRIORITY. Within each PRIORITY, new entries are
2570 appended.
2572 If WARN is nonzero, we will warn if no file is found
2573 through this prefix. WARN should point to an int
2574 which will be set to 1 if this entry is used.
2576 COMPONENT is the value to be passed to update_path.
2578 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2579 the complete value of machine_suffix.
2580 2 means try both machine_suffix and just_machine_suffix. */
2582 static void
2583 add_prefix (struct path_prefix *pprefix, const char *prefix,
2584 const char *component, /* enum prefix_priority */ int priority,
2585 int require_machine_suffix, int os_multilib)
2587 struct prefix_list *pl, **prev;
2588 int len;
2590 for (prev = &pprefix->plist;
2591 (*prev) != NULL && (*prev)->priority <= priority;
2592 prev = &(*prev)->next)
2595 /* Keep track of the longest prefix. */
2597 prefix = update_path (prefix, component);
2598 len = strlen (prefix);
2599 if (len > pprefix->max_len)
2600 pprefix->max_len = len;
2602 pl = xmalloc (sizeof (struct prefix_list));
2603 pl->prefix = prefix;
2604 pl->require_machine_suffix = require_machine_suffix;
2605 pl->priority = priority;
2606 pl->os_multilib = os_multilib;
2608 /* Insert after PREV. */
2609 pl->next = (*prev);
2610 (*prev) = pl;
2613 /* Same as add_prefix, but prepending target_system_root to prefix. */
2614 static void
2615 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2616 const char *component,
2617 /* enum prefix_priority */ int priority,
2618 int require_machine_suffix, int os_multilib)
2620 if (!IS_ABSOLUTE_PATH (prefix))
2621 fatal ("system path '%s' is not absolute", prefix);
2623 if (target_system_root)
2625 if (target_sysroot_suffix)
2626 prefix = concat (target_sysroot_suffix, prefix, NULL);
2627 prefix = concat (target_system_root, prefix, NULL);
2629 /* We have to override this because GCC's notion of sysroot
2630 moves along with GCC. */
2631 component = "GCC";
2634 add_prefix (pprefix, prefix, component, priority,
2635 require_machine_suffix, os_multilib);
2638 /* Execute the command specified by the arguments on the current line of spec.
2639 When using pipes, this includes several piped-together commands
2640 with `|' between them.
2642 Return 0 if successful, -1 if failed. */
2644 static int
2645 execute (void)
2647 int i;
2648 int n_commands; /* # of command. */
2649 char *string;
2650 struct pex_obj *pex;
2651 struct command
2653 const char *prog; /* program name. */
2654 const char **argv; /* vector of args. */
2657 struct command *commands; /* each command buffer with above info. */
2659 gcc_assert (!processing_spec_function);
2661 /* Count # of piped commands. */
2662 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2663 if (strcmp (argbuf[i], "|") == 0)
2664 n_commands++;
2666 /* Get storage for each command. */
2667 commands = alloca (n_commands * sizeof (struct command));
2669 /* Split argbuf into its separate piped processes,
2670 and record info about each one.
2671 Also search for the programs that are to be run. */
2673 commands[0].prog = argbuf[0]; /* first command. */
2674 commands[0].argv = &argbuf[0];
2675 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2677 if (string)
2678 commands[0].argv[0] = string;
2680 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2681 if (strcmp (argbuf[i], "|") == 0)
2682 { /* each command. */
2683 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2684 fatal ("-pipe not supported");
2685 #endif
2686 argbuf[i] = 0; /* termination of command args. */
2687 commands[n_commands].prog = argbuf[i + 1];
2688 commands[n_commands].argv = &argbuf[i + 1];
2689 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2690 X_OK, 0);
2691 if (string)
2692 commands[n_commands].argv[0] = string;
2693 n_commands++;
2696 argbuf[argbuf_index] = 0;
2698 /* If -v, print what we are about to do, and maybe query. */
2700 if (verbose_flag)
2702 /* For help listings, put a blank line between sub-processes. */
2703 if (print_help_list)
2704 fputc ('\n', stderr);
2706 /* Print each piped command as a separate line. */
2707 for (i = 0; i < n_commands; i++)
2709 const char *const *j;
2711 if (verbose_only_flag)
2713 for (j = commands[i].argv; *j; j++)
2715 const char *p;
2716 fprintf (stderr, " \"");
2717 for (p = *j; *p; ++p)
2719 if (*p == '"' || *p == '\\' || *p == '$')
2720 fputc ('\\', stderr);
2721 fputc (*p, stderr);
2723 fputc ('"', stderr);
2726 else
2727 for (j = commands[i].argv; *j; j++)
2728 fprintf (stderr, " %s", *j);
2730 /* Print a pipe symbol after all but the last command. */
2731 if (i + 1 != n_commands)
2732 fprintf (stderr, " |");
2733 fprintf (stderr, "\n");
2735 fflush (stderr);
2736 if (verbose_only_flag != 0)
2738 /* verbose_only_flag should act as if the spec was
2739 executed, so increment execution_count before
2740 returning. This prevents spurious warnings about
2741 unused linker input files, etc. */
2742 execution_count++;
2743 return 0;
2745 #ifdef DEBUG
2746 notice ("\nGo ahead? (y or n) ");
2747 fflush (stderr);
2748 i = getchar ();
2749 if (i != '\n')
2750 while (getchar () != '\n')
2753 if (i != 'y' && i != 'Y')
2754 return 0;
2755 #endif /* DEBUG */
2758 #ifdef ENABLE_VALGRIND_CHECKING
2759 /* Run the each command through valgrind. To simplify prepending the
2760 path to valgrind and the option "-q" (for quiet operation unless
2761 something triggers), we allocate a separate argv array. */
2763 for (i = 0; i < n_commands; i++)
2765 const char **argv;
2766 int argc;
2767 int j;
2769 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2772 argv = alloca ((argc + 3) * sizeof (char *));
2774 argv[0] = VALGRIND_PATH;
2775 argv[1] = "-q";
2776 for (j = 2; j < argc + 2; j++)
2777 argv[j] = commands[i].argv[j - 2];
2778 argv[j] = NULL;
2780 commands[i].argv = argv;
2781 commands[i].prog = argv[0];
2783 #endif
2785 /* Run each piped subprocess. */
2787 pex = pex_init (PEX_USE_PIPES | (report_times ? PEX_RECORD_TIMES : 0),
2788 programname, temp_filename);
2789 if (pex == NULL)
2790 pfatal_with_name (_("pex_init failed"));
2792 for (i = 0; i < n_commands; i++)
2794 const char *errmsg;
2795 int err;
2796 const char *string = commands[i].argv[0];
2798 errmsg = pex_run (pex,
2799 ((i + 1 == n_commands ? PEX_LAST : 0)
2800 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2801 string, (char * const *) commands[i].argv,
2802 NULL, NULL, &err);
2803 if (errmsg != NULL)
2805 if (err == 0)
2806 fatal (errmsg);
2807 else
2809 errno = err;
2810 pfatal_with_name (errmsg);
2814 if (string != commands[i].prog)
2815 free ((void *) string);
2818 execution_count++;
2820 /* Wait for all the subprocesses to finish. */
2823 int *statuses;
2824 struct pex_time *times = NULL;
2825 int ret_code = 0;
2827 statuses = alloca (n_commands * sizeof (int));
2828 if (!pex_get_status (pex, n_commands, statuses))
2829 pfatal_with_name (_("failed to get exit status"));
2831 if (report_times)
2833 times = alloca (n_commands * sizeof (struct pex_time));
2834 if (!pex_get_times (pex, n_commands, times))
2835 pfatal_with_name (_("failed to get process times"));
2838 pex_free (pex);
2840 for (i = 0; i < n_commands; ++i)
2842 int status = statuses[i];
2844 if (WIFSIGNALED (status))
2846 #ifdef SIGPIPE
2847 /* SIGPIPE is a special case. It happens in -pipe mode
2848 when the compiler dies before the preprocessor is done,
2849 or the assembler dies before the compiler is done.
2850 There's generally been an error already, and this is
2851 just fallout. So don't generate another error unless
2852 we would otherwise have succeeded. */
2853 if (WTERMSIG (status) == SIGPIPE
2854 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2856 else
2857 #endif
2858 fatal ("\
2859 Internal error: %s (program %s)\n\
2860 Please submit a full bug report.\n\
2861 See %s for instructions.",
2862 strsignal (WTERMSIG (status)), commands[i].prog,
2863 bug_report_url);
2864 signal_count++;
2865 ret_code = -1;
2867 else if (WIFEXITED (status)
2868 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2870 if (WEXITSTATUS (status) > greatest_status)
2871 greatest_status = WEXITSTATUS (status);
2872 ret_code = -1;
2875 if (report_times)
2877 struct pex_time *pt = &times[i];
2878 double ut, st;
2880 ut = ((double) pt->user_seconds
2881 + (double) pt->user_microseconds / 1.0e6);
2882 st = ((double) pt->system_seconds
2883 + (double) pt->system_microseconds / 1.0e6);
2885 if (ut + st != 0)
2886 notice ("# %s %.2f %.2f\n", commands[i].prog, ut, st);
2890 return ret_code;
2894 /* Find all the switches given to us
2895 and make a vector describing them.
2896 The elements of the vector are strings, one per switch given.
2897 If a switch uses following arguments, then the `part1' field
2898 is the switch itself and the `args' field
2899 is a null-terminated vector containing the following arguments.
2900 The `live_cond' field is:
2901 0 when initialized
2902 1 if the switch is true in a conditional spec,
2903 -1 if false (overridden by a later switch)
2904 -2 if this switch should be ignored (used in %<S)
2905 The `validated' field is nonzero if any spec has looked at this switch;
2906 if it remains zero at the end of the run, it must be meaningless. */
2908 #define SWITCH_OK 0
2909 #define SWITCH_FALSE -1
2910 #define SWITCH_IGNORE -2
2911 #define SWITCH_LIVE 1
2913 struct switchstr
2915 const char *part1;
2916 const char **args;
2917 int live_cond;
2918 unsigned char validated;
2919 unsigned char ordering;
2922 static struct switchstr *switches;
2924 static int n_switches;
2926 struct infile
2928 const char *name;
2929 const char *language;
2930 struct compiler *incompiler;
2931 bool compiled;
2932 bool preprocessed;
2935 /* Also a vector of input files specified. */
2937 static struct infile *infiles;
2939 int n_infiles;
2941 /* True if multiple input files are being compiled to a single
2942 assembly file. */
2944 static bool combine_inputs;
2946 /* This counts the number of libraries added by lang_specific_driver, so that
2947 we can tell if there were any user supplied any files or libraries. */
2949 static int added_libraries;
2951 /* And a vector of corresponding output files is made up later. */
2953 const char **outfiles;
2955 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2957 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2958 is true if we should look for an executable suffix. DO_OBJ
2959 is true if we should look for an object suffix. */
2961 static const char *
2962 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2963 int do_obj ATTRIBUTE_UNUSED)
2965 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2966 int i;
2967 #endif
2968 int len;
2970 if (name == NULL)
2971 return NULL;
2973 len = strlen (name);
2975 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2976 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2977 if (do_obj && len > 2
2978 && name[len - 2] == '.'
2979 && name[len - 1] == 'o')
2981 obstack_grow (&obstack, name, len - 2);
2982 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2983 name = XOBFINISH (&obstack, const char *);
2985 #endif
2987 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2988 /* If there is no filetype, make it the executable suffix (which includes
2989 the "."). But don't get confused if we have just "-o". */
2990 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2991 return name;
2993 for (i = len - 1; i >= 0; i--)
2994 if (IS_DIR_SEPARATOR (name[i]))
2995 break;
2997 for (i++; i < len; i++)
2998 if (name[i] == '.')
2999 return name;
3001 obstack_grow (&obstack, name, len);
3002 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3003 strlen (TARGET_EXECUTABLE_SUFFIX));
3004 name = XOBFINISH (&obstack, const char *);
3005 #endif
3007 return name;
3009 #endif
3011 /* Display the command line switches accepted by gcc. */
3012 static void
3013 display_help (void)
3015 printf (_("Usage: %s [options] file...\n"), programname);
3016 fputs (_("Options:\n"), stdout);
3018 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3019 fputs (_(" --help Display this information\n"), stdout);
3020 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3021 if (! verbose_flag)
3022 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3023 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3024 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3025 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3026 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3027 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3028 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3029 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3030 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3031 fputs (_("\
3032 -print-multi-lib Display the mapping between command line options and\n\
3033 multiple library search directories\n"), stdout);
3034 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3035 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3036 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3037 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3038 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3039 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3040 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3041 fputs (_(" -combine Pass multiple source files to compiler at once\n"), stdout);
3042 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3043 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3044 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3045 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3046 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3047 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3048 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3049 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3050 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3051 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3052 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3053 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3054 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3055 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3056 fputs (_("\
3057 -x <language> Specify the language of the following input files\n\
3058 Permissible languages include: c c++ assembler none\n\
3059 'none' means revert to the default behavior of\n\
3060 guessing the language based on the file's extension\n\
3061 "), stdout);
3063 printf (_("\
3064 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3065 passed on to the various sub-processes invoked by %s. In order to pass\n\
3066 other options on to these processes the -W<letter> options must be used.\n\
3067 "), programname);
3069 /* The rest of the options are displayed by invocations of the various
3070 sub-processes. */
3073 static void
3074 add_preprocessor_option (const char *option, int len)
3076 n_preprocessor_options++;
3078 if (! preprocessor_options)
3079 preprocessor_options = xmalloc (n_preprocessor_options * sizeof (char *));
3080 else
3081 preprocessor_options = xrealloc (preprocessor_options,
3082 n_preprocessor_options * sizeof (char *));
3084 preprocessor_options [n_preprocessor_options - 1] =
3085 save_string (option, len);
3088 static void
3089 add_assembler_option (const char *option, int len)
3091 n_assembler_options++;
3093 if (! assembler_options)
3094 assembler_options = xmalloc (n_assembler_options * sizeof (char *));
3095 else
3096 assembler_options = xrealloc (assembler_options,
3097 n_assembler_options * sizeof (char *));
3099 assembler_options [n_assembler_options - 1] = save_string (option, len);
3102 static void
3103 add_linker_option (const char *option, int len)
3105 n_linker_options++;
3107 if (! linker_options)
3108 linker_options = xmalloc (n_linker_options * sizeof (char *));
3109 else
3110 linker_options = xrealloc (linker_options,
3111 n_linker_options * sizeof (char *));
3113 linker_options [n_linker_options - 1] = save_string (option, len);
3116 /* Create the vector `switches' and its contents.
3117 Store its length in `n_switches'. */
3119 static void
3120 process_command (int argc, const char **argv)
3122 int i;
3123 const char *temp;
3124 char *temp1;
3125 const char *spec_lang = 0;
3126 int last_language_n_infiles;
3127 int have_c = 0;
3128 int lang_n_infiles = 0;
3129 #ifdef MODIFY_TARGET_NAME
3130 int is_modify_target_name;
3131 int j;
3132 #endif
3134 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3136 n_switches = 0;
3137 n_infiles = 0;
3138 added_libraries = 0;
3140 /* Figure compiler version from version string. */
3142 compiler_version = temp1 = xstrdup (version_string);
3144 for (; *temp1; ++temp1)
3146 if (*temp1 == ' ')
3148 *temp1 = '\0';
3149 break;
3153 /* If there is a -V or -b option (or both), process it now, before
3154 trying to interpret the rest of the command line. */
3155 if (argc > 1 && argv[1][0] == '-'
3156 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3158 const char *new_version = DEFAULT_TARGET_VERSION;
3159 const char *new_machine = DEFAULT_TARGET_MACHINE;
3160 const char *progname = argv[0];
3161 char **new_argv;
3162 char *new_argv0;
3163 int baselen;
3165 while (argc > 1 && argv[1][0] == '-'
3166 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3168 char opt = argv[1][1];
3169 const char *arg;
3170 if (argv[1][2] != '\0')
3172 arg = argv[1] + 2;
3173 argc -= 1;
3174 argv += 1;
3176 else if (argc > 2)
3178 arg = argv[2];
3179 argc -= 2;
3180 argv += 2;
3182 else
3183 fatal ("'-%c' option must have argument", opt);
3184 if (opt == 'V')
3185 new_version = arg;
3186 else
3187 new_machine = arg;
3190 for (baselen = strlen (progname); baselen > 0; baselen--)
3191 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3192 break;
3193 new_argv0 = xmemdup (progname, baselen,
3194 baselen + concat_length (new_version, new_machine,
3195 "-gcc-", NULL) + 1);
3196 strcpy (new_argv0 + baselen, new_machine);
3197 strcat (new_argv0, "-gcc-");
3198 strcat (new_argv0, new_version);
3200 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3201 (argc + 1) * sizeof (argv[0]));
3202 new_argv[0] = new_argv0;
3204 execvp (new_argv0, new_argv);
3205 fatal ("couldn't run '%s': %s", new_argv0, xstrerror (errno));
3208 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3209 see if we can create it from the pathname specified in argv[0]. */
3211 gcc_libexec_prefix = standard_libexec_prefix;
3212 #ifndef VMS
3213 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3214 if (!gcc_exec_prefix)
3216 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3217 standard_exec_prefix);
3218 gcc_libexec_prefix = make_relative_prefix (argv[0],
3219 standard_bindir_prefix,
3220 standard_libexec_prefix);
3221 if (gcc_exec_prefix)
3222 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3224 else
3225 gcc_libexec_prefix = make_relative_prefix (gcc_exec_prefix,
3226 standard_exec_prefix,
3227 standard_libexec_prefix);
3228 #else
3229 #endif
3231 if (gcc_exec_prefix)
3233 int len = strlen (gcc_exec_prefix);
3235 if (len > (int) sizeof ("/lib/gcc/") - 1
3236 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3238 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3239 if (IS_DIR_SEPARATOR (*temp)
3240 && strncmp (temp + 1, "lib", 3) == 0
3241 && IS_DIR_SEPARATOR (temp[4])
3242 && strncmp (temp + 5, "gcc", 3) == 0)
3243 len -= sizeof ("/lib/gcc/") - 1;
3246 set_std_prefix (gcc_exec_prefix, len);
3247 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3248 PREFIX_PRIORITY_LAST, 0, 0);
3249 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3250 PREFIX_PRIORITY_LAST, 0, 0);
3253 /* COMPILER_PATH and LIBRARY_PATH have values
3254 that are lists of directory names with colons. */
3256 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3257 if (temp)
3259 const char *startp, *endp;
3260 char *nstore = alloca (strlen (temp) + 3);
3262 startp = endp = temp;
3263 while (1)
3265 if (*endp == PATH_SEPARATOR || *endp == 0)
3267 strncpy (nstore, startp, endp - startp);
3268 if (endp == startp)
3269 strcpy (nstore, concat (".", dir_separator_str, NULL));
3270 else if (!IS_DIR_SEPARATOR (endp[-1]))
3272 nstore[endp - startp] = DIR_SEPARATOR;
3273 nstore[endp - startp + 1] = 0;
3275 else
3276 nstore[endp - startp] = 0;
3277 add_prefix (&exec_prefixes, nstore, 0,
3278 PREFIX_PRIORITY_LAST, 0, 0);
3279 add_prefix (&include_prefixes, nstore, 0,
3280 PREFIX_PRIORITY_LAST, 0, 0);
3281 if (*endp == 0)
3282 break;
3283 endp = startp = endp + 1;
3285 else
3286 endp++;
3290 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3291 if (temp && *cross_compile == '0')
3293 const char *startp, *endp;
3294 char *nstore = alloca (strlen (temp) + 3);
3296 startp = endp = temp;
3297 while (1)
3299 if (*endp == PATH_SEPARATOR || *endp == 0)
3301 strncpy (nstore, startp, endp - startp);
3302 if (endp == startp)
3303 strcpy (nstore, concat (".", dir_separator_str, NULL));
3304 else if (!IS_DIR_SEPARATOR (endp[-1]))
3306 nstore[endp - startp] = DIR_SEPARATOR;
3307 nstore[endp - startp + 1] = 0;
3309 else
3310 nstore[endp - startp] = 0;
3311 add_prefix (&startfile_prefixes, nstore, NULL,
3312 PREFIX_PRIORITY_LAST, 0, 1);
3313 if (*endp == 0)
3314 break;
3315 endp = startp = endp + 1;
3317 else
3318 endp++;
3322 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3323 GET_ENVIRONMENT (temp, "LPATH");
3324 if (temp && *cross_compile == '0')
3326 const char *startp, *endp;
3327 char *nstore = alloca (strlen (temp) + 3);
3329 startp = endp = temp;
3330 while (1)
3332 if (*endp == PATH_SEPARATOR || *endp == 0)
3334 strncpy (nstore, startp, endp - startp);
3335 if (endp == startp)
3336 strcpy (nstore, concat (".", dir_separator_str, NULL));
3337 else if (!IS_DIR_SEPARATOR (endp[-1]))
3339 nstore[endp - startp] = DIR_SEPARATOR;
3340 nstore[endp - startp + 1] = 0;
3342 else
3343 nstore[endp - startp] = 0;
3344 add_prefix (&startfile_prefixes, nstore, NULL,
3345 PREFIX_PRIORITY_LAST, 0, 1);
3346 if (*endp == 0)
3347 break;
3348 endp = startp = endp + 1;
3350 else
3351 endp++;
3355 /* Convert new-style -- options to old-style. */
3356 translate_options (&argc, (const char *const **) &argv);
3358 /* Do language-specific adjustment/addition of flags. */
3359 lang_specific_driver (&argc, (const char *const **) &argv, &added_libraries);
3361 /* Scan argv twice. Here, the first time, just count how many switches
3362 there will be in their vector, and how many input files in theirs.
3363 Here we also parse the switches that cc itself uses (e.g. -v). */
3365 for (i = 1; i < argc; i++)
3367 if (! strcmp (argv[i], "-dumpspecs"))
3369 struct spec_list *sl;
3370 init_spec ();
3371 for (sl = specs; sl; sl = sl->next)
3372 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3373 if (link_command_spec)
3374 printf ("*link_command:\n%s\n\n", link_command_spec);
3375 exit (0);
3377 else if (! strcmp (argv[i], "-dumpversion"))
3379 printf ("%s\n", spec_version);
3380 exit (0);
3382 else if (! strcmp (argv[i], "-dumpmachine"))
3384 printf ("%s\n", spec_machine);
3385 exit (0);
3387 else if (strcmp (argv[i], "-fversion") == 0)
3389 /* translate_options () has turned --version into -fversion. */
3390 printf (_("%s (GCC) %s\n"), programname, version_string);
3391 printf ("Copyright %s 2005 Free Software Foundation, Inc.\n",
3392 _("(C)"));
3393 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3394 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3395 stdout);
3396 exit (0);
3398 else if (strcmp (argv[i], "-fhelp") == 0)
3400 /* translate_options () has turned --help into -fhelp. */
3401 print_help_list = 1;
3403 /* We will be passing a dummy file on to the sub-processes. */
3404 n_infiles++;
3405 n_switches++;
3407 /* CPP driver cannot obtain switch from cc1_options. */
3408 if (is_cpp_driver)
3409 add_preprocessor_option ("--help", 6);
3410 add_assembler_option ("--help", 6);
3411 add_linker_option ("--help", 6);
3413 else if (strcmp (argv[i], "-ftarget-help") == 0)
3415 /* translate_options() has turned --target-help into -ftarget-help. */
3416 target_help_flag = 1;
3418 /* We will be passing a dummy file on to the sub-processes. */
3419 n_infiles++;
3420 n_switches++;
3422 /* CPP driver cannot obtain switch from cc1_options. */
3423 if (is_cpp_driver)
3424 add_preprocessor_option ("--target-help", 13);
3425 add_assembler_option ("--target-help", 13);
3426 add_linker_option ("--target-help", 13);
3428 else if (! strcmp (argv[i], "-pass-exit-codes"))
3430 pass_exit_codes = 1;
3431 n_switches++;
3433 else if (! strcmp (argv[i], "-print-search-dirs"))
3434 print_search_dirs = 1;
3435 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3436 print_file_name = "libgcc.a";
3437 else if (! strncmp (argv[i], "-print-file-name=", 17))
3438 print_file_name = argv[i] + 17;
3439 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3440 print_prog_name = argv[i] + 17;
3441 else if (! strcmp (argv[i], "-print-multi-lib"))
3442 print_multi_lib = 1;
3443 else if (! strcmp (argv[i], "-print-multi-directory"))
3444 print_multi_directory = 1;
3445 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3446 print_multi_os_directory = 1;
3447 else if (! strncmp (argv[i], "-Wa,", 4))
3449 int prev, j;
3450 /* Pass the rest of this option to the assembler. */
3452 /* Split the argument at commas. */
3453 prev = 4;
3454 for (j = 4; argv[i][j]; j++)
3455 if (argv[i][j] == ',')
3457 add_assembler_option (argv[i] + prev, j - prev);
3458 prev = j + 1;
3461 /* Record the part after the last comma. */
3462 add_assembler_option (argv[i] + prev, j - prev);
3464 else if (! strncmp (argv[i], "-Wp,", 4))
3466 int prev, j;
3467 /* Pass the rest of this option to the preprocessor. */
3469 /* Split the argument at commas. */
3470 prev = 4;
3471 for (j = 4; argv[i][j]; j++)
3472 if (argv[i][j] == ',')
3474 add_preprocessor_option (argv[i] + prev, j - prev);
3475 prev = j + 1;
3478 /* Record the part after the last comma. */
3479 add_preprocessor_option (argv[i] + prev, j - prev);
3481 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3482 /* The +e options to the C++ front-end. */
3483 n_switches++;
3484 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3486 int j;
3487 /* Split the argument at commas. */
3488 for (j = 3; argv[i][j]; j++)
3489 n_infiles += (argv[i][j] == ',');
3491 else if (strcmp (argv[i], "-Xlinker") == 0)
3493 if (i + 1 == argc)
3494 fatal ("argument to '-Xlinker' is missing");
3496 n_infiles++;
3497 i++;
3499 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3501 if (i + 1 == argc)
3502 fatal ("argument to '-Xpreprocessor' is missing");
3504 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3506 else if (strcmp (argv[i], "-Xassembler") == 0)
3508 if (i + 1 == argc)
3509 fatal ("argument to '-Xassembler' is missing");
3511 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3513 else if (strcmp (argv[i], "-l") == 0)
3515 if (i + 1 == argc)
3516 fatal ("argument to '-l' is missing");
3518 n_infiles++;
3519 i++;
3521 else if (strncmp (argv[i], "-l", 2) == 0)
3522 n_infiles++;
3523 else if (strcmp (argv[i], "-save-temps") == 0)
3525 save_temps_flag = 1;
3526 n_switches++;
3528 else if (strcmp (argv[i], "-combine") == 0)
3530 combine_flag = 1;
3531 n_switches++;
3533 else if (strcmp (argv[i], "-specs") == 0)
3535 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3536 if (++i >= argc)
3537 fatal ("argument to '-specs' is missing");
3539 user->next = (struct user_specs *) 0;
3540 user->filename = argv[i];
3541 if (user_specs_tail)
3542 user_specs_tail->next = user;
3543 else
3544 user_specs_head = user;
3545 user_specs_tail = user;
3547 else if (strncmp (argv[i], "-specs=", 7) == 0)
3549 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3550 if (strlen (argv[i]) == 7)
3551 fatal ("argument to '-specs=' is missing");
3553 user->next = (struct user_specs *) 0;
3554 user->filename = argv[i] + 7;
3555 if (user_specs_tail)
3556 user_specs_tail->next = user;
3557 else
3558 user_specs_head = user;
3559 user_specs_tail = user;
3561 else if (strcmp (argv[i], "-time") == 0)
3562 report_times = 1;
3563 else if (strcmp (argv[i], "-pipe") == 0)
3565 /* -pipe has to go into the switches array as well as
3566 setting a flag. */
3567 use_pipes = 1;
3568 n_switches++;
3570 else if (strcmp (argv[i], "-###") == 0)
3572 /* This is similar to -v except that there is no execution
3573 of the commands and the echoed arguments are quoted. It
3574 is intended for use in shell scripts to capture the
3575 driver-generated command line. */
3576 verbose_only_flag++;
3577 verbose_flag++;
3579 else if (argv[i][0] == '-' && argv[i][1] != 0)
3581 const char *p = &argv[i][1];
3582 int c = *p;
3584 switch (c)
3586 case 'b':
3587 case 'V':
3588 fatal ("'-%c' must come at the start of the command line", c);
3589 break;
3591 case 'B':
3593 const char *value;
3594 int len;
3596 if (p[1] == 0 && i + 1 == argc)
3597 fatal ("argument to '-B' is missing");
3598 if (p[1] == 0)
3599 value = argv[++i];
3600 else
3601 value = p + 1;
3603 len = strlen (value);
3605 /* Catch the case where the user has forgotten to append a
3606 directory separator to the path. Note, they may be using
3607 -B to add an executable name prefix, eg "i386-elf-", in
3608 order to distinguish between multiple installations of
3609 GCC in the same directory. Hence we must check to see
3610 if appending a directory separator actually makes a
3611 valid directory name. */
3612 if (! IS_DIR_SEPARATOR (value [len - 1])
3613 && is_directory (value, "", 0))
3615 char *tmp = xmalloc (len + 2);
3616 strcpy (tmp, value);
3617 tmp[len] = DIR_SEPARATOR;
3618 tmp[++ len] = 0;
3619 value = tmp;
3622 /* As a kludge, if the arg is "[foo/]stageN/", just
3623 add "[foo/]include" to the include prefix. */
3624 if ((len == 7
3625 || (len > 7
3626 && (IS_DIR_SEPARATOR (value[len - 8]))))
3627 && strncmp (value + len - 7, "stage", 5) == 0
3628 && ISDIGIT (value[len - 2])
3629 && (IS_DIR_SEPARATOR (value[len - 1])))
3631 if (len == 7)
3632 add_prefix (&include_prefixes, "./", NULL,
3633 PREFIX_PRIORITY_B_OPT, 0, 0);
3634 else
3636 char *string = xmalloc (len - 6);
3637 memcpy (string, value, len - 7);
3638 string[len - 7] = 0;
3639 add_prefix (&include_prefixes, string, NULL,
3640 PREFIX_PRIORITY_B_OPT, 0, 0);
3644 add_prefix (&exec_prefixes, value, NULL,
3645 PREFIX_PRIORITY_B_OPT, 0, 0);
3646 add_prefix (&startfile_prefixes, value, NULL,
3647 PREFIX_PRIORITY_B_OPT, 0, 0);
3648 add_prefix (&include_prefixes, value, NULL,
3649 PREFIX_PRIORITY_B_OPT, 0, 0);
3650 n_switches++;
3652 break;
3654 case 'v': /* Print our subcommands and print versions. */
3655 n_switches++;
3656 /* If they do anything other than exactly `-v', don't set
3657 verbose_flag; rather, continue on to give the error. */
3658 if (p[1] != 0)
3659 break;
3660 verbose_flag++;
3661 break;
3663 case 'S':
3664 case 'c':
3665 if (p[1] == 0)
3667 have_c = 1;
3668 n_switches++;
3669 break;
3671 goto normal_switch;
3673 case 'o':
3674 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3675 if (! have_c)
3677 int skip;
3679 /* Forward scan, just in case -S or -c is specified
3680 after -o. */
3681 int j = i + 1;
3682 if (p[1] == 0)
3683 ++j;
3684 while (j < argc)
3686 if (argv[j][0] == '-')
3688 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3689 && argv[j][2] == 0)
3691 have_c = 1;
3692 break;
3694 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3695 j += skip - (argv[j][2] != 0);
3696 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3697 j += skip;
3699 j++;
3702 #endif
3703 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3704 if (p[1] == 0)
3705 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3706 else
3707 argv[i] = convert_filename (argv[i], ! have_c, 0);
3708 #endif
3709 goto normal_switch;
3711 default:
3712 normal_switch:
3714 #ifdef MODIFY_TARGET_NAME
3715 is_modify_target_name = 0;
3717 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3718 if (! strcmp (argv[i], modify_target[j].sw))
3720 char *new_name = xmalloc (strlen (modify_target[j].str)
3721 + strlen (spec_machine));
3722 const char *p, *r;
3723 char *q;
3724 int made_addition = 0;
3726 is_modify_target_name = 1;
3727 for (p = spec_machine, q = new_name; *p != 0; )
3729 if (modify_target[j].add_del == DELETE
3730 && (! strncmp (q, modify_target[j].str,
3731 strlen (modify_target[j].str))))
3732 p += strlen (modify_target[j].str);
3733 else if (modify_target[j].add_del == ADD
3734 && ! made_addition && *p == '-')
3736 for (r = modify_target[j].str; *r != 0; )
3737 *q++ = *r++;
3738 made_addition = 1;
3741 *q++ = *p++;
3744 spec_machine = new_name;
3747 if (is_modify_target_name)
3748 break;
3749 #endif
3751 n_switches++;
3753 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3754 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3755 else if (WORD_SWITCH_TAKES_ARG (p))
3756 i += WORD_SWITCH_TAKES_ARG (p);
3759 else
3761 n_infiles++;
3762 lang_n_infiles++;
3766 if (save_temps_flag && use_pipes)
3768 /* -save-temps overrides -pipe, so that temp files are produced */
3769 if (save_temps_flag)
3770 error ("warning: -pipe ignored because -save-temps specified");
3771 use_pipes = 0;
3774 /* Set up the search paths before we go looking for config files. */
3776 /* These come before the md prefixes so that we will find gcc's subcommands
3777 (such as cpp) rather than those of the host system. */
3778 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3779 as well as trying the machine and the version. */
3780 #ifndef OS2
3781 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3782 PREFIX_PRIORITY_LAST, 1, 0);
3783 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3784 PREFIX_PRIORITY_LAST, 2, 0);
3785 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3786 PREFIX_PRIORITY_LAST, 2, 0);
3787 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3788 PREFIX_PRIORITY_LAST, 2, 0);
3789 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
3790 PREFIX_PRIORITY_LAST, 2, 0);
3791 #endif
3793 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3794 PREFIX_PRIORITY_LAST, 1, 0);
3795 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
3796 PREFIX_PRIORITY_LAST, 1, 0);
3798 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3799 dir_separator_str, NULL);
3801 /* If tooldir is relative, base it on exec_prefixes. A relative
3802 tooldir lets us move the installed tree as a unit.
3804 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3805 directories, so that we can search both the user specified directory
3806 and the standard place. */
3808 if (!IS_ABSOLUTE_PATH (tooldir_prefix))
3810 if (gcc_exec_prefix)
3812 char *gcc_exec_tooldir_prefix
3813 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3814 spec_version, dir_separator_str, tooldir_prefix, NULL);
3816 add_prefix (&exec_prefixes,
3817 concat (gcc_exec_tooldir_prefix, "bin",
3818 dir_separator_str, NULL),
3819 NULL, PREFIX_PRIORITY_LAST, 0, 0);
3820 add_prefix (&startfile_prefixes,
3821 concat (gcc_exec_tooldir_prefix, "lib",
3822 dir_separator_str, NULL),
3823 NULL, PREFIX_PRIORITY_LAST, 0, 1);
3826 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3827 dir_separator_str, spec_version,
3828 dir_separator_str, tooldir_prefix, NULL);
3831 add_prefix (&exec_prefixes,
3832 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3833 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3834 add_prefix (&startfile_prefixes,
3835 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3836 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3838 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3839 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3840 then consider it to relocate with the rest of the GCC installation
3841 if GCC_EXEC_PREFIX is set.
3842 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3843 if (target_system_root && gcc_exec_prefix)
3845 char *tmp_prefix = make_relative_prefix (argv[0],
3846 standard_bindir_prefix,
3847 target_system_root);
3848 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3850 target_system_root = tmp_prefix;
3851 target_system_root_changed = 1;
3854 #endif
3856 /* More prefixes are enabled in main, after we read the specs file
3857 and determine whether this is cross-compilation or not. */
3859 /* Then create the space for the vectors and scan again. */
3861 switches = xmalloc ((n_switches + 1) * sizeof (struct switchstr));
3862 infiles = xmalloc ((n_infiles + 1) * sizeof (struct infile));
3863 n_switches = 0;
3864 n_infiles = 0;
3865 last_language_n_infiles = -1;
3867 /* This, time, copy the text of each switch and store a pointer
3868 to the copy in the vector of switches.
3869 Store all the infiles in their vector. */
3871 for (i = 1; i < argc; i++)
3873 /* Just skip the switches that were handled by the preceding loop. */
3874 #ifdef MODIFY_TARGET_NAME
3875 is_modify_target_name = 0;
3877 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3878 if (! strcmp (argv[i], modify_target[j].sw))
3879 is_modify_target_name = 1;
3881 if (is_modify_target_name)
3883 else
3884 #endif
3885 if (! strncmp (argv[i], "-Wa,", 4))
3887 else if (! strncmp (argv[i], "-Wp,", 4))
3889 else if (! strcmp (argv[i], "-pass-exit-codes"))
3891 else if (! strcmp (argv[i], "-print-search-dirs"))
3893 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3895 else if (! strncmp (argv[i], "-print-file-name=", 17))
3897 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3899 else if (! strcmp (argv[i], "-print-multi-lib"))
3901 else if (! strcmp (argv[i], "-print-multi-directory"))
3903 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3905 else if (! strcmp (argv[i], "-ftarget-help"))
3907 else if (! strcmp (argv[i], "-fhelp"))
3909 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3911 /* Compensate for the +e options to the C++ front-end;
3912 they're there simply for cfront call-compatibility. We do
3913 some magic in default_compilers to pass them down properly.
3914 Note we deliberately start at the `+' here, to avoid passing
3915 -e0 or -e1 down into the linker. */
3916 switches[n_switches].part1 = &argv[i][0];
3917 switches[n_switches].args = 0;
3918 switches[n_switches].live_cond = SWITCH_OK;
3919 switches[n_switches].validated = 0;
3920 n_switches++;
3922 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3924 int prev, j;
3925 /* Split the argument at commas. */
3926 prev = 4;
3927 for (j = 4; argv[i][j]; j++)
3928 if (argv[i][j] == ',')
3930 infiles[n_infiles].language = "*";
3931 infiles[n_infiles++].name
3932 = save_string (argv[i] + prev, j - prev);
3933 prev = j + 1;
3935 /* Record the part after the last comma. */
3936 infiles[n_infiles].language = "*";
3937 infiles[n_infiles++].name = argv[i] + prev;
3939 else if (strcmp (argv[i], "-Xlinker") == 0)
3941 infiles[n_infiles].language = "*";
3942 infiles[n_infiles++].name = argv[++i];
3944 /* Xassembler and Xpreprocessor were already handled in the first argv
3945 scan, so all we need to do here is ignore them and their argument. */
3946 else if (strcmp (argv[i], "-Xassembler") == 0)
3947 i++;
3948 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3949 i++;
3950 else if (strcmp (argv[i], "-l") == 0)
3951 { /* POSIX allows separation of -l and the lib arg;
3952 canonicalize by concatenating -l with its arg */
3953 infiles[n_infiles].language = "*";
3954 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3956 else if (strncmp (argv[i], "-l", 2) == 0)
3958 infiles[n_infiles].language = "*";
3959 infiles[n_infiles++].name = argv[i];
3961 else if (strcmp (argv[i], "-specs") == 0)
3962 i++;
3963 else if (strncmp (argv[i], "-specs=", 7) == 0)
3965 else if (strcmp (argv[i], "-time") == 0)
3967 else if (strcmp (argv[i], "-###") == 0)
3969 else if (argv[i][0] == '-' && argv[i][1] != 0)
3971 const char *p = &argv[i][1];
3972 int c = *p;
3974 if (c == 'x')
3976 if (p[1] == 0 && i + 1 == argc)
3977 fatal ("argument to '-x' is missing");
3978 if (p[1] == 0)
3979 spec_lang = argv[++i];
3980 else
3981 spec_lang = p + 1;
3982 if (! strcmp (spec_lang, "none"))
3983 /* Suppress the warning if -xnone comes after the last input
3984 file, because alternate command interfaces like g++ might
3985 find it useful to place -xnone after each input file. */
3986 spec_lang = 0;
3987 else
3988 last_language_n_infiles = n_infiles;
3989 continue;
3991 switches[n_switches].part1 = p;
3992 /* Deal with option arguments in separate argv elements. */
3993 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
3994 || WORD_SWITCH_TAKES_ARG (p))
3996 int j = 0;
3997 int n_args = WORD_SWITCH_TAKES_ARG (p);
3999 if (n_args == 0)
4001 /* Count only the option arguments in separate argv elements. */
4002 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4004 if (i + n_args >= argc)
4005 fatal ("argument to '-%s' is missing", p);
4006 switches[n_switches].args
4007 = xmalloc ((n_args + 1) * sizeof(const char *));
4008 while (j < n_args)
4009 switches[n_switches].args[j++] = argv[++i];
4010 /* Null-terminate the vector. */
4011 switches[n_switches].args[j] = 0;
4013 else if (strchr (switches_need_spaces, c))
4015 /* On some systems, ld cannot handle some options without
4016 a space. So split the option from its argument. */
4017 char *part1 = xmalloc (2);
4018 part1[0] = c;
4019 part1[1] = '\0';
4021 switches[n_switches].part1 = part1;
4022 switches[n_switches].args = xmalloc (2 * sizeof (const char *));
4023 switches[n_switches].args[0] = xstrdup (p+1);
4024 switches[n_switches].args[1] = 0;
4026 else
4027 switches[n_switches].args = 0;
4029 switches[n_switches].live_cond = SWITCH_OK;
4030 switches[n_switches].validated = 0;
4031 switches[n_switches].ordering = 0;
4032 /* These are always valid, since gcc.c itself understands them. */
4033 if (!strcmp (p, "save-temps")
4034 || !strcmp (p, "static-libgcc")
4035 || !strcmp (p, "shared-libgcc")
4036 || !strcmp (p, "pipe"))
4037 switches[n_switches].validated = 1;
4038 else
4040 char ch = switches[n_switches].part1[0];
4041 if (ch == 'B')
4042 switches[n_switches].validated = 1;
4044 n_switches++;
4046 else
4048 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4049 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4050 #endif
4052 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4054 perror_with_name (argv[i]);
4055 error_count++;
4057 else
4059 infiles[n_infiles].language = spec_lang;
4060 infiles[n_infiles++].name = argv[i];
4065 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4066 error ("warning: '-x %s' after last input file has no effect", spec_lang);
4068 /* Ensure we only invoke each subprocess once. */
4069 if (target_help_flag || print_help_list)
4071 n_infiles = 1;
4073 /* Create a dummy input file, so that we can pass --target-help on to
4074 the various sub-processes. */
4075 infiles[0].language = "c";
4076 infiles[0].name = "help-dummy";
4078 if (target_help_flag)
4080 switches[n_switches].part1 = "--target-help";
4081 switches[n_switches].args = 0;
4082 switches[n_switches].live_cond = SWITCH_OK;
4083 switches[n_switches].validated = 0;
4085 n_switches++;
4088 if (print_help_list)
4090 switches[n_switches].part1 = "--help";
4091 switches[n_switches].args = 0;
4092 switches[n_switches].live_cond = SWITCH_OK;
4093 switches[n_switches].validated = 0;
4095 n_switches++;
4099 switches[n_switches].part1 = 0;
4100 infiles[n_infiles].name = 0;
4103 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4104 and place that in the environment. */
4106 static void
4107 set_collect_gcc_options (void)
4109 int i;
4110 int first_time;
4112 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4113 the compiler. */
4114 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4115 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4117 first_time = TRUE;
4118 for (i = 0; (int) i < n_switches; i++)
4120 const char *const *args;
4121 const char *p, *q;
4122 if (!first_time)
4123 obstack_grow (&collect_obstack, " ", 1);
4125 first_time = FALSE;
4127 /* Ignore elided switches. */
4128 if (switches[i].live_cond == SWITCH_IGNORE)
4129 continue;
4131 obstack_grow (&collect_obstack, "'-", 2);
4132 q = switches[i].part1;
4133 while ((p = strchr (q, '\'')))
4135 obstack_grow (&collect_obstack, q, p - q);
4136 obstack_grow (&collect_obstack, "'\\''", 4);
4137 q = ++p;
4139 obstack_grow (&collect_obstack, q, strlen (q));
4140 obstack_grow (&collect_obstack, "'", 1);
4142 for (args = switches[i].args; args && *args; args++)
4144 obstack_grow (&collect_obstack, " '", 2);
4145 q = *args;
4146 while ((p = strchr (q, '\'')))
4148 obstack_grow (&collect_obstack, q, p - q);
4149 obstack_grow (&collect_obstack, "'\\''", 4);
4150 q = ++p;
4152 obstack_grow (&collect_obstack, q, strlen (q));
4153 obstack_grow (&collect_obstack, "'", 1);
4156 obstack_grow (&collect_obstack, "\0", 1);
4157 putenv (XOBFINISH (&collect_obstack, char *));
4160 /* Process a spec string, accumulating and running commands. */
4162 /* These variables describe the input file name.
4163 input_file_number is the index on outfiles of this file,
4164 so that the output file name can be stored for later use by %o.
4165 input_basename is the start of the part of the input file
4166 sans all directory names, and basename_length is the number
4167 of characters starting there excluding the suffix .c or whatever. */
4169 static const char *input_filename;
4170 static int input_file_number;
4171 size_t input_filename_length;
4172 static int basename_length;
4173 static int suffixed_basename_length;
4174 static const char *input_basename;
4175 static const char *input_suffix;
4176 #ifndef HOST_LACKS_INODE_NUMBERS
4177 static struct stat input_stat;
4178 #endif
4179 static int input_stat_set;
4181 /* The compiler used to process the current input file. */
4182 static struct compiler *input_file_compiler;
4184 /* These are variables used within do_spec and do_spec_1. */
4186 /* Nonzero if an arg has been started and not yet terminated
4187 (with space, tab or newline). */
4188 static int arg_going;
4190 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4191 is a temporary file name. */
4192 static int delete_this_arg;
4194 /* Nonzero means %w has been seen; the next arg to be terminated
4195 is the output file name of this compilation. */
4196 static int this_is_output_file;
4198 /* Nonzero means %s has been seen; the next arg to be terminated
4199 is the name of a library file and we should try the standard
4200 search dirs for it. */
4201 static int this_is_library_file;
4203 /* Nonzero means that the input of this command is coming from a pipe. */
4204 static int input_from_pipe;
4206 /* Nonnull means substitute this for any suffix when outputting a switches
4207 arguments. */
4208 static const char *suffix_subst;
4210 /* Process the spec SPEC and run the commands specified therein.
4211 Returns 0 if the spec is successfully processed; -1 if failed. */
4214 do_spec (const char *spec)
4216 int value;
4218 value = do_spec_2 (spec);
4220 /* Force out any unfinished command.
4221 If -pipe, this forces out the last command if it ended in `|'. */
4222 if (value == 0)
4224 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4225 argbuf_index--;
4227 set_collect_gcc_options ();
4229 if (argbuf_index > 0)
4230 value = execute ();
4233 return value;
4236 static int
4237 do_spec_2 (const char *spec)
4239 const char *string;
4240 int result;
4242 clear_args ();
4243 arg_going = 0;
4244 delete_this_arg = 0;
4245 this_is_output_file = 0;
4246 this_is_library_file = 0;
4247 input_from_pipe = 0;
4248 suffix_subst = NULL;
4250 result = do_spec_1 (spec, 0, NULL);
4252 /* End any pending argument. */
4253 if (arg_going)
4255 obstack_1grow (&obstack, 0);
4256 string = XOBFINISH (&obstack, const char *);
4257 if (this_is_library_file)
4258 string = find_file (string);
4259 store_arg (string, delete_this_arg, this_is_output_file);
4260 if (this_is_output_file)
4261 outfiles[input_file_number] = string;
4262 arg_going = 0;
4265 return result;
4269 /* Process the given spec string and add any new options to the end
4270 of the switches/n_switches array. */
4272 static void
4273 do_option_spec (const char *name, const char *spec)
4275 unsigned int i, value_count, value_len;
4276 const char *p, *q, *value;
4277 char *tmp_spec, *tmp_spec_p;
4279 if (configure_default_options[0].name == NULL)
4280 return;
4282 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4283 if (strcmp (configure_default_options[i].name, name) == 0)
4284 break;
4285 if (i == ARRAY_SIZE (configure_default_options))
4286 return;
4288 value = configure_default_options[i].value;
4289 value_len = strlen (value);
4291 /* Compute the size of the final spec. */
4292 value_count = 0;
4293 p = spec;
4294 while ((p = strstr (p, "%(VALUE)")) != NULL)
4296 p ++;
4297 value_count ++;
4300 /* Replace each %(VALUE) by the specified value. */
4301 tmp_spec = alloca (strlen (spec) + 1
4302 + value_count * (value_len - strlen ("%(VALUE)")));
4303 tmp_spec_p = tmp_spec;
4304 q = spec;
4305 while ((p = strstr (q, "%(VALUE)")) != NULL)
4307 memcpy (tmp_spec_p, q, p - q);
4308 tmp_spec_p = tmp_spec_p + (p - q);
4309 memcpy (tmp_spec_p, value, value_len);
4310 tmp_spec_p += value_len;
4311 q = p + strlen ("%(VALUE)");
4313 strcpy (tmp_spec_p, q);
4315 do_self_spec (tmp_spec);
4318 /* Process the given spec string and add any new options to the end
4319 of the switches/n_switches array. */
4321 static void
4322 do_self_spec (const char *spec)
4324 do_spec_2 (spec);
4325 do_spec_1 (" ", 0, NULL);
4327 if (argbuf_index > 0)
4329 int i, first;
4331 first = n_switches;
4332 n_switches += argbuf_index;
4333 switches = xrealloc (switches,
4334 sizeof (struct switchstr) * (n_switches + 1));
4336 switches[n_switches] = switches[first];
4337 for (i = 0; i < argbuf_index; i++)
4339 struct switchstr *sw;
4341 /* Each switch should start with '-'. */
4342 if (argbuf[i][0] != '-')
4343 fatal ("switch '%s' does not start with '-'", argbuf[i]);
4345 sw = &switches[i + first];
4346 sw->part1 = &argbuf[i][1];
4347 sw->args = 0;
4348 sw->live_cond = SWITCH_OK;
4349 sw->validated = 0;
4350 sw->ordering = 0;
4355 void
4356 do_spec_path (struct prefix_list *pl, const char *option,
4357 int omit_if_relative, int separate_options,
4358 int only_subdir,
4359 const char *dir_for_machine_suffix,
4360 const char *dir_for_no_suffix)
4362 static size_t bufsize = 0;
4363 static char *buffer;
4364 int idx;
4365 bool multilib_p = false;
4367 /* Used on systems which record the specified -L dirs
4368 and use them to search for dynamic linking. */
4369 /* Relative directories always come from -B,
4370 and it is better not to use them for searching
4371 at run time. In particular, stage1 loses. */
4372 if (omit_if_relative
4373 && !IS_ABSOLUTE_PATH (pl->prefix))
4374 return;
4376 /* Try subdirectory if there is one. */
4377 if (machine_suffix && dir_for_machine_suffix)
4379 if (strlen (pl->prefix) + strlen (machine_suffix)
4380 >= bufsize)
4381 bufsize = (strlen (pl->prefix)
4382 + strlen (machine_suffix)) * 2 + 1;
4383 buffer = xrealloc (buffer, bufsize);
4384 strcpy (buffer, pl->prefix);
4385 strcat (buffer, machine_suffix);
4386 if (is_directory (buffer, dir_for_machine_suffix, 1))
4388 multilib_p = true;
4389 do_spec_1 (option, separate_options, NULL);
4390 if (separate_options)
4391 do_spec_1 (" ", 0, NULL);
4392 do_spec_1 (buffer, 1, NULL);
4393 do_spec_1 (dir_for_machine_suffix, 1, NULL);
4394 /* Make this a separate argument. */
4395 do_spec_1 (" ", 0, NULL);
4398 if (!pl->require_machine_suffix && dir_for_no_suffix)
4400 if (is_directory (pl->prefix, dir_for_no_suffix, 1))
4402 multilib_p = true;
4403 do_spec_1 (option, separate_options, NULL);
4404 if (separate_options)
4405 do_spec_1 (" ", 0, NULL);
4406 do_spec_1 (pl->prefix, 1, NULL);
4407 do_spec_1 (dir_for_no_suffix, 1, NULL);
4408 /* Make this a separate argument. */
4409 do_spec_1 (" ", 0, NULL);
4413 if (only_subdir || multilib_p)
4414 return;
4416 if (machine_suffix)
4418 if (is_directory (pl->prefix, machine_suffix, 1))
4420 do_spec_1 (option, separate_options, NULL);
4421 if (separate_options)
4422 do_spec_1 (" ", 0, NULL);
4423 do_spec_1 (pl->prefix, 1, NULL);
4424 /* Remove slash from machine_suffix. */
4425 if (strlen (machine_suffix) >= bufsize)
4426 bufsize = strlen (machine_suffix) * 2 + 1;
4427 buffer = xrealloc (buffer, bufsize);
4428 strcpy (buffer, machine_suffix);
4429 idx = strlen (buffer);
4430 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4431 buffer[idx - 1] = 0;
4432 do_spec_1 (buffer, 1, NULL);
4433 /* Make this a separate argument. */
4434 do_spec_1 (" ", 0, NULL);
4437 if (!pl->require_machine_suffix)
4439 if (is_directory (pl->prefix, "", 1))
4441 do_spec_1 (option, separate_options, NULL);
4442 if (separate_options)
4443 do_spec_1 (" ", 0, NULL);
4444 /* Remove slash from pl->prefix. */
4445 if (strlen (pl->prefix) >= bufsize)
4446 bufsize = strlen (pl->prefix) * 2 + 1;
4447 buffer = xrealloc (buffer, bufsize);
4448 strcpy (buffer, pl->prefix);
4449 idx = strlen (buffer);
4450 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4451 buffer[idx - 1] = 0;
4452 do_spec_1 (buffer, 1, NULL);
4453 /* Make this a separate argument. */
4454 do_spec_1 (" ", 0, NULL);
4459 /* Process the sub-spec SPEC as a portion of a larger spec.
4460 This is like processing a whole spec except that we do
4461 not initialize at the beginning and we do not supply a
4462 newline by default at the end.
4463 INSWITCH nonzero means don't process %-sequences in SPEC;
4464 in this case, % is treated as an ordinary character.
4465 This is used while substituting switches.
4466 INSWITCH nonzero also causes SPC not to terminate an argument.
4468 Value is zero unless a line was finished
4469 and the command on that line reported an error. */
4471 static int
4472 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4474 const char *p = spec;
4475 int c;
4476 int i;
4477 const char *string;
4478 int value;
4480 while ((c = *p++))
4481 /* If substituting a switch, treat all chars like letters.
4482 Otherwise, NL, SPC, TAB and % are special. */
4483 switch (inswitch ? 'a' : c)
4485 case '\n':
4486 /* End of line: finish any pending argument,
4487 then run the pending command if one has been started. */
4488 if (arg_going)
4490 obstack_1grow (&obstack, 0);
4491 string = XOBFINISH (&obstack, const char *);
4492 if (this_is_library_file)
4493 string = find_file (string);
4494 store_arg (string, delete_this_arg, this_is_output_file);
4495 if (this_is_output_file)
4496 outfiles[input_file_number] = string;
4498 arg_going = 0;
4500 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4502 /* A `|' before the newline means use a pipe here,
4503 but only if -pipe was specified.
4504 Otherwise, execute now and don't pass the `|' as an arg. */
4505 if (use_pipes)
4507 input_from_pipe = 1;
4508 break;
4510 else
4511 argbuf_index--;
4514 set_collect_gcc_options ();
4516 if (argbuf_index > 0)
4518 value = execute ();
4519 if (value)
4520 return value;
4522 /* Reinitialize for a new command, and for a new argument. */
4523 clear_args ();
4524 arg_going = 0;
4525 delete_this_arg = 0;
4526 this_is_output_file = 0;
4527 this_is_library_file = 0;
4528 input_from_pipe = 0;
4529 break;
4531 case '|':
4532 /* End any pending argument. */
4533 if (arg_going)
4535 obstack_1grow (&obstack, 0);
4536 string = XOBFINISH (&obstack, const char *);
4537 if (this_is_library_file)
4538 string = find_file (string);
4539 store_arg (string, delete_this_arg, this_is_output_file);
4540 if (this_is_output_file)
4541 outfiles[input_file_number] = string;
4544 /* Use pipe */
4545 obstack_1grow (&obstack, c);
4546 arg_going = 1;
4547 break;
4549 case '\t':
4550 case ' ':
4551 /* Space or tab ends an argument if one is pending. */
4552 if (arg_going)
4554 obstack_1grow (&obstack, 0);
4555 string = XOBFINISH (&obstack, const char *);
4556 if (this_is_library_file)
4557 string = find_file (string);
4558 store_arg (string, delete_this_arg, this_is_output_file);
4559 if (this_is_output_file)
4560 outfiles[input_file_number] = string;
4562 /* Reinitialize for a new argument. */
4563 arg_going = 0;
4564 delete_this_arg = 0;
4565 this_is_output_file = 0;
4566 this_is_library_file = 0;
4567 break;
4569 case '%':
4570 switch (c = *p++)
4572 case 0:
4573 fatal ("spec '%s' invalid", spec);
4575 case 'b':
4576 obstack_grow (&obstack, input_basename, basename_length);
4577 arg_going = 1;
4578 break;
4580 case 'B':
4581 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4582 arg_going = 1;
4583 break;
4585 case 'd':
4586 delete_this_arg = 2;
4587 break;
4589 /* Dump out the directories specified with LIBRARY_PATH,
4590 followed by the absolute directories
4591 that we search for startfiles. */
4592 case 'D':
4594 struct prefix_list *pl = startfile_prefixes.plist;
4596 for (; pl; pl = pl->next)
4598 const char *no_suffix_multilib_dir;
4600 no_suffix_multilib_dir = pl->os_multilib ? multilib_os_dir
4601 : multilib_dir;
4602 /* Do not separate options, include non-multilibbed variant. */
4603 do_spec_path (pl, "-L",
4604 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4606 #else
4608 #endif
4609 0, 0, multilib_dir, no_suffix_multilib_dir);
4612 break;
4614 case 'e':
4615 /* %efoo means report an error with `foo' as error message
4616 and don't execute any more commands for this file. */
4618 const char *q = p;
4619 char *buf;
4620 while (*p != 0 && *p != '\n')
4621 p++;
4622 buf = alloca (p - q + 1);
4623 strncpy (buf, q, p - q);
4624 buf[p - q] = 0;
4625 error ("%s", buf);
4626 return -1;
4628 break;
4629 case 'n':
4630 /* %nfoo means report a notice with `foo' on stderr. */
4632 const char *q = p;
4633 char *buf;
4634 while (*p != 0 && *p != '\n')
4635 p++;
4636 buf = alloca (p - q + 1);
4637 strncpy (buf, q, p - q);
4638 buf[p - q] = 0;
4639 notice ("%s\n", buf);
4640 if (*p)
4641 p++;
4643 break;
4645 case 'j':
4647 struct stat st;
4649 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4650 defined, and it is not a directory, and it is
4651 writable, use it. Otherwise, treat this like any
4652 other temporary file. */
4654 if ((!save_temps_flag)
4655 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4656 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4658 obstack_grow (&obstack, HOST_BIT_BUCKET,
4659 strlen (HOST_BIT_BUCKET));
4660 delete_this_arg = 0;
4661 arg_going = 1;
4662 break;
4665 goto create_temp_file;
4666 case '|':
4667 if (use_pipes)
4669 obstack_1grow (&obstack, '-');
4670 delete_this_arg = 0;
4671 arg_going = 1;
4673 /* consume suffix */
4674 while (*p == '.' || ISALPHA ((unsigned char) *p))
4675 p++;
4676 if (p[0] == '%' && p[1] == 'O')
4677 p += 2;
4679 break;
4681 goto create_temp_file;
4682 case 'm':
4683 if (use_pipes)
4685 /* consume suffix */
4686 while (*p == '.' || ISALPHA ((unsigned char) *p))
4687 p++;
4688 if (p[0] == '%' && p[1] == 'O')
4689 p += 2;
4691 break;
4693 goto create_temp_file;
4694 case 'g':
4695 case 'u':
4696 case 'U':
4697 create_temp_file:
4699 struct temp_name *t;
4700 int suffix_length;
4701 const char *suffix = p;
4702 char *saved_suffix = NULL;
4704 while (*p == '.' || ISALPHA ((unsigned char) *p))
4705 p++;
4706 suffix_length = p - suffix;
4707 if (p[0] == '%' && p[1] == 'O')
4709 p += 2;
4710 /* We don't support extra suffix characters after %O. */
4711 if (*p == '.' || ISALPHA ((unsigned char) *p))
4712 fatal ("spec '%s' has invalid '%%0%c'", spec, *p);
4713 if (suffix_length == 0)
4714 suffix = TARGET_OBJECT_SUFFIX;
4715 else
4717 saved_suffix
4718 = xmalloc (suffix_length
4719 + strlen (TARGET_OBJECT_SUFFIX));
4720 strncpy (saved_suffix, suffix, suffix_length);
4721 strcpy (saved_suffix + suffix_length,
4722 TARGET_OBJECT_SUFFIX);
4724 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4727 /* If the input_filename has the same suffix specified
4728 for the %g, %u, or %U, and -save-temps is specified,
4729 we could end up using that file as an intermediate
4730 thus clobbering the user's source file (.e.g.,
4731 gcc -save-temps foo.s would clobber foo.s with the
4732 output of cpp0). So check for this condition and
4733 generate a temp file as the intermediate. */
4735 if (save_temps_flag)
4737 temp_filename_length = basename_length + suffix_length;
4738 temp_filename = alloca (temp_filename_length + 1);
4739 strncpy ((char *) temp_filename, input_basename, basename_length);
4740 strncpy ((char *) temp_filename + basename_length, suffix,
4741 suffix_length);
4742 *((char *) temp_filename + temp_filename_length) = '\0';
4743 if (strcmp (temp_filename, input_filename) != 0)
4745 #ifndef HOST_LACKS_INODE_NUMBERS
4746 struct stat st_temp;
4748 /* Note, set_input() resets input_stat_set to 0. */
4749 if (input_stat_set == 0)
4751 input_stat_set = stat (input_filename, &input_stat);
4752 if (input_stat_set >= 0)
4753 input_stat_set = 1;
4756 /* If we have the stat for the input_filename
4757 and we can do the stat for the temp_filename
4758 then the they could still refer to the same
4759 file if st_dev/st_ino's are the same. */
4760 if (input_stat_set != 1
4761 || stat (temp_filename, &st_temp) < 0
4762 || input_stat.st_dev != st_temp.st_dev
4763 || input_stat.st_ino != st_temp.st_ino)
4764 #else
4765 /* Just compare canonical pathnames. */
4766 char* input_realname = lrealpath (input_filename);
4767 char* temp_realname = lrealpath (temp_filename);
4768 bool files_differ = strcmp (input_realname, temp_realname);
4769 free (input_realname);
4770 free (temp_realname);
4771 if (files_differ)
4772 #endif
4774 temp_filename = save_string (temp_filename,
4775 temp_filename_length + 1);
4776 obstack_grow (&obstack, temp_filename,
4777 temp_filename_length);
4778 arg_going = 1;
4779 delete_this_arg = 0;
4780 break;
4785 /* See if we already have an association of %g/%u/%U and
4786 suffix. */
4787 for (t = temp_names; t; t = t->next)
4788 if (t->length == suffix_length
4789 && strncmp (t->suffix, suffix, suffix_length) == 0
4790 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4791 break;
4793 /* Make a new association if needed. %u and %j
4794 require one. */
4795 if (t == 0 || c == 'u' || c == 'j')
4797 if (t == 0)
4799 t = xmalloc (sizeof (struct temp_name));
4800 t->next = temp_names;
4801 temp_names = t;
4803 t->length = suffix_length;
4804 if (saved_suffix)
4806 t->suffix = saved_suffix;
4807 saved_suffix = NULL;
4809 else
4810 t->suffix = save_string (suffix, suffix_length);
4811 t->unique = (c == 'u' || c == 'U' || c == 'j');
4812 temp_filename = make_temp_file (t->suffix);
4813 temp_filename_length = strlen (temp_filename);
4814 t->filename = temp_filename;
4815 t->filename_length = temp_filename_length;
4818 if (saved_suffix)
4819 free (saved_suffix);
4821 obstack_grow (&obstack, t->filename, t->filename_length);
4822 delete_this_arg = 1;
4824 arg_going = 1;
4825 break;
4827 case 'i':
4828 if (combine_inputs)
4830 for (i = 0; (int) i < n_infiles; i++)
4831 if ((!infiles[i].language) || (infiles[i].language[0] != '*'))
4832 if (infiles[i].incompiler == input_file_compiler)
4834 store_arg (infiles[i].name, 0, 0);
4835 infiles[i].compiled = true;
4838 else
4840 obstack_grow (&obstack, input_filename, input_filename_length);
4841 arg_going = 1;
4843 break;
4845 case 'I':
4847 struct prefix_list *pl = include_prefixes.plist;
4849 if (gcc_exec_prefix)
4851 do_spec_1 ("-iprefix", 1, NULL);
4852 /* Make this a separate argument. */
4853 do_spec_1 (" ", 0, NULL);
4854 do_spec_1 (gcc_exec_prefix, 1, NULL);
4855 do_spec_1 (" ", 0, NULL);
4858 if (target_system_root_changed ||
4859 (target_system_root && target_sysroot_hdrs_suffix))
4861 do_spec_1 ("-isysroot", 1, NULL);
4862 /* Make this a separate argument. */
4863 do_spec_1 (" ", 0, NULL);
4864 do_spec_1 (target_system_root, 1, NULL);
4865 if (target_sysroot_hdrs_suffix)
4866 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4867 do_spec_1 (" ", 0, NULL);
4870 for (; pl; pl = pl->next)
4871 /* Separate options, don't include non-suffixed variant. */
4872 do_spec_path (pl, "-isystem", 0, 1, 1, "include", "include");
4874 break;
4876 case 'o':
4878 int max = n_infiles;
4879 max += lang_specific_extra_outfiles;
4881 for (i = 0; i < max; i++)
4882 if (outfiles[i])
4883 store_arg (outfiles[i], 0, 0);
4884 break;
4887 case 'O':
4888 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4889 arg_going = 1;
4890 break;
4892 case 's':
4893 this_is_library_file = 1;
4894 break;
4896 case 'V':
4897 outfiles[input_file_number] = NULL;
4898 break;
4900 case 'w':
4901 this_is_output_file = 1;
4902 break;
4904 case 'W':
4906 int cur_index = argbuf_index;
4907 /* Handle the {...} following the %W. */
4908 if (*p != '{')
4909 fatal ("spec '%s' has invalid '%%W%c", spec, *p);
4910 p = handle_braces (p + 1);
4911 if (p == 0)
4912 return -1;
4913 /* End any pending argument. */
4914 if (arg_going)
4916 obstack_1grow (&obstack, 0);
4917 string = XOBFINISH (&obstack, const char *);
4918 if (this_is_library_file)
4919 string = find_file (string);
4920 store_arg (string, delete_this_arg, this_is_output_file);
4921 if (this_is_output_file)
4922 outfiles[input_file_number] = string;
4923 arg_going = 0;
4925 /* If any args were output, mark the last one for deletion
4926 on failure. */
4927 if (argbuf_index != cur_index)
4928 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4929 break;
4932 /* %x{OPTION} records OPTION for %X to output. */
4933 case 'x':
4935 const char *p1 = p;
4936 char *string;
4938 /* Skip past the option value and make a copy. */
4939 if (*p != '{')
4940 fatal ("spec '%s' has invalid '%%x%c'", spec, *p);
4941 while (*p++ != '}')
4943 string = save_string (p1 + 1, p - p1 - 2);
4945 /* See if we already recorded this option. */
4946 for (i = 0; i < n_linker_options; i++)
4947 if (! strcmp (string, linker_options[i]))
4949 free (string);
4950 return 0;
4953 /* This option is new; add it. */
4954 add_linker_option (string, strlen (string));
4956 break;
4958 /* Dump out the options accumulated previously using %x. */
4959 case 'X':
4960 for (i = 0; i < n_linker_options; i++)
4962 do_spec_1 (linker_options[i], 1, NULL);
4963 /* Make each accumulated option a separate argument. */
4964 do_spec_1 (" ", 0, NULL);
4966 break;
4968 /* Dump out the options accumulated previously using -Wa,. */
4969 case 'Y':
4970 for (i = 0; i < n_assembler_options; i++)
4972 do_spec_1 (assembler_options[i], 1, NULL);
4973 /* Make each accumulated option a separate argument. */
4974 do_spec_1 (" ", 0, NULL);
4976 break;
4978 /* Dump out the options accumulated previously using -Wp,. */
4979 case 'Z':
4980 for (i = 0; i < n_preprocessor_options; i++)
4982 do_spec_1 (preprocessor_options[i], 1, NULL);
4983 /* Make each accumulated option a separate argument. */
4984 do_spec_1 (" ", 0, NULL);
4986 break;
4988 /* Here are digits and numbers that just process
4989 a certain constant string as a spec. */
4991 case '1':
4992 value = do_spec_1 (cc1_spec, 0, NULL);
4993 if (value != 0)
4994 return value;
4995 break;
4997 case '2':
4998 value = do_spec_1 (cc1plus_spec, 0, NULL);
4999 if (value != 0)
5000 return value;
5001 break;
5003 case 'a':
5004 value = do_spec_1 (asm_spec, 0, NULL);
5005 if (value != 0)
5006 return value;
5007 break;
5009 case 'A':
5010 value = do_spec_1 (asm_final_spec, 0, NULL);
5011 if (value != 0)
5012 return value;
5013 break;
5015 case 'C':
5017 const char *const spec
5018 = (input_file_compiler->cpp_spec
5019 ? input_file_compiler->cpp_spec
5020 : cpp_spec);
5021 value = do_spec_1 (spec, 0, NULL);
5022 if (value != 0)
5023 return value;
5025 break;
5027 case 'E':
5028 value = do_spec_1 (endfile_spec, 0, NULL);
5029 if (value != 0)
5030 return value;
5031 break;
5033 case 'l':
5034 value = do_spec_1 (link_spec, 0, NULL);
5035 if (value != 0)
5036 return value;
5037 break;
5039 case 'L':
5040 value = do_spec_1 (lib_spec, 0, NULL);
5041 if (value != 0)
5042 return value;
5043 break;
5045 case 'G':
5046 value = do_spec_1 (libgcc_spec, 0, NULL);
5047 if (value != 0)
5048 return value;
5049 break;
5051 case 'R':
5052 /* We assume there is a directory
5053 separator at the end of this string. */
5054 if (target_system_root)
5056 obstack_grow (&obstack, target_system_root,
5057 strlen (target_system_root));
5058 if (target_sysroot_suffix)
5059 obstack_grow (&obstack, target_sysroot_suffix,
5060 strlen (target_sysroot_suffix));
5062 break;
5064 case 'S':
5065 value = do_spec_1 (startfile_spec, 0, NULL);
5066 if (value != 0)
5067 return value;
5068 break;
5070 /* Here we define characters other than letters and digits. */
5072 case '{':
5073 p = handle_braces (p);
5074 if (p == 0)
5075 return -1;
5076 break;
5078 case ':':
5079 p = handle_spec_function (p);
5080 if (p == 0)
5081 return -1;
5082 break;
5084 case '%':
5085 obstack_1grow (&obstack, '%');
5086 break;
5088 case '.':
5090 unsigned len = 0;
5092 while (p[len] && p[len] != ' ' && p[len] != '%')
5093 len++;
5094 suffix_subst = save_string (p - 1, len + 1);
5095 p += len;
5097 break;
5099 /* Henceforth ignore the option(s) matching the pattern
5100 after the %<. */
5101 case '<':
5103 unsigned len = 0;
5104 int have_wildcard = 0;
5105 int i;
5107 while (p[len] && p[len] != ' ' && p[len] != '\t')
5108 len++;
5110 if (p[len-1] == '*')
5111 have_wildcard = 1;
5113 for (i = 0; i < n_switches; i++)
5114 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5115 && (have_wildcard || switches[i].part1[len] == '\0'))
5117 switches[i].live_cond = SWITCH_IGNORE;
5118 switches[i].validated = 1;
5121 p += len;
5123 break;
5125 case '*':
5126 if (soft_matched_part)
5128 do_spec_1 (soft_matched_part, 1, NULL);
5129 do_spec_1 (" ", 0, NULL);
5131 else
5132 /* Catch the case where a spec string contains something like
5133 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5134 hand side of the :. */
5135 error ("spec failure: '%%*' has not been initialized by pattern match");
5136 break;
5138 /* Process a string found as the value of a spec given by name.
5139 This feature allows individual machine descriptions
5140 to add and use their own specs.
5141 %[...] modifies -D options the way %P does;
5142 %(...) uses the spec unmodified. */
5143 case '[':
5144 error ("warning: use of obsolete %%[ operator in specs");
5145 case '(':
5147 const char *name = p;
5148 struct spec_list *sl;
5149 int len;
5151 /* The string after the S/P is the name of a spec that is to be
5152 processed. */
5153 while (*p && *p != ')' && *p != ']')
5154 p++;
5156 /* See if it's in the list. */
5157 for (len = p - name, sl = specs; sl; sl = sl->next)
5158 if (sl->name_len == len && !strncmp (sl->name, name, len))
5160 name = *(sl->ptr_spec);
5161 #ifdef DEBUG_SPECS
5162 notice ("Processing spec %c%s%c, which is '%s'\n",
5163 c, sl->name, (c == '(') ? ')' : ']', name);
5164 #endif
5165 break;
5168 if (sl)
5170 if (c == '(')
5172 value = do_spec_1 (name, 0, NULL);
5173 if (value != 0)
5174 return value;
5176 else
5178 char *x = alloca (strlen (name) * 2 + 1);
5179 char *buf = x;
5180 const char *y = name;
5181 int flag = 0;
5183 /* Copy all of NAME into BUF, but put __ after
5184 every -D and at the end of each arg. */
5185 while (1)
5187 if (! strncmp (y, "-D", 2))
5189 *x++ = '-';
5190 *x++ = 'D';
5191 *x++ = '_';
5192 *x++ = '_';
5193 y += 2;
5194 flag = 1;
5195 continue;
5197 else if (flag
5198 && (*y == ' ' || *y == '\t' || *y == '='
5199 || *y == '}' || *y == 0))
5201 *x++ = '_';
5202 *x++ = '_';
5203 flag = 0;
5205 if (*y == 0)
5206 break;
5207 else
5208 *x++ = *y++;
5210 *x = 0;
5212 value = do_spec_1 (buf, 0, NULL);
5213 if (value != 0)
5214 return value;
5218 /* Discard the closing paren or bracket. */
5219 if (*p)
5220 p++;
5222 break;
5224 default:
5225 error ("spec failure: unrecognized spec option '%c'", c);
5226 break;
5228 break;
5230 case '\\':
5231 /* Backslash: treat next character as ordinary. */
5232 c = *p++;
5234 /* Fall through. */
5235 default:
5236 /* Ordinary character: put it into the current argument. */
5237 obstack_1grow (&obstack, c);
5238 arg_going = 1;
5241 /* End of string. If we are processing a spec function, we need to
5242 end any pending argument. */
5243 if (processing_spec_function && arg_going)
5245 obstack_1grow (&obstack, 0);
5246 string = XOBFINISH (&obstack, const char *);
5247 if (this_is_library_file)
5248 string = find_file (string);
5249 store_arg (string, delete_this_arg, this_is_output_file);
5250 if (this_is_output_file)
5251 outfiles[input_file_number] = string;
5252 arg_going = 0;
5255 return 0;
5258 /* Look up a spec function. */
5260 static const struct spec_function *
5261 lookup_spec_function (const char *name)
5263 static const struct spec_function * const spec_function_tables[] =
5265 static_spec_functions,
5266 lang_specific_spec_functions,
5268 const struct spec_function *sf;
5269 unsigned int i;
5271 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5273 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5274 if (strcmp (sf->name, name) == 0)
5275 return sf;
5278 return NULL;
5281 /* Evaluate a spec function. */
5283 static const char *
5284 eval_spec_function (const char *func, const char *args)
5286 const struct spec_function *sf;
5287 const char *funcval;
5289 /* Saved spec processing context. */
5290 int save_argbuf_index;
5291 int save_argbuf_length;
5292 const char **save_argbuf;
5294 int save_arg_going;
5295 int save_delete_this_arg;
5296 int save_this_is_output_file;
5297 int save_this_is_library_file;
5298 int save_input_from_pipe;
5299 const char *save_suffix_subst;
5302 sf = lookup_spec_function (func);
5303 if (sf == NULL)
5304 fatal ("unknown spec function '%s'", func);
5306 /* Push the spec processing context. */
5307 save_argbuf_index = argbuf_index;
5308 save_argbuf_length = argbuf_length;
5309 save_argbuf = argbuf;
5311 save_arg_going = arg_going;
5312 save_delete_this_arg = delete_this_arg;
5313 save_this_is_output_file = this_is_output_file;
5314 save_this_is_library_file = this_is_library_file;
5315 save_input_from_pipe = input_from_pipe;
5316 save_suffix_subst = suffix_subst;
5318 /* Create a new spec processing context, and build the function
5319 arguments. */
5321 alloc_args ();
5322 if (do_spec_2 (args) < 0)
5323 fatal ("error in args to spec function '%s'", func);
5325 /* argbuf_index is an index for the next argument to be inserted, and
5326 so contains the count of the args already inserted. */
5328 funcval = (*sf->func) (argbuf_index, argbuf);
5330 /* Pop the spec processing context. */
5331 argbuf_index = save_argbuf_index;
5332 argbuf_length = save_argbuf_length;
5333 free (argbuf);
5334 argbuf = save_argbuf;
5336 arg_going = save_arg_going;
5337 delete_this_arg = save_delete_this_arg;
5338 this_is_output_file = save_this_is_output_file;
5339 this_is_library_file = save_this_is_library_file;
5340 input_from_pipe = save_input_from_pipe;
5341 suffix_subst = save_suffix_subst;
5343 return funcval;
5346 /* Handle a spec function call of the form:
5348 %:function(args)
5350 ARGS is processed as a spec in a separate context and split into an
5351 argument vector in the normal fashion. The function returns a string
5352 containing a spec which we then process in the caller's context, or
5353 NULL if no processing is required. */
5355 static const char *
5356 handle_spec_function (const char *p)
5358 char *func, *args;
5359 const char *endp, *funcval;
5360 int count;
5362 processing_spec_function++;
5364 /* Get the function name. */
5365 for (endp = p; *endp != '\0'; endp++)
5367 if (*endp == '(') /* ) */
5368 break;
5369 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5370 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5371 fatal ("malformed spec function name");
5373 if (*endp != '(') /* ) */
5374 fatal ("no arguments for spec function");
5375 func = save_string (p, endp - p);
5376 p = ++endp;
5378 /* Get the arguments. */
5379 for (count = 0; *endp != '\0'; endp++)
5381 /* ( */
5382 if (*endp == ')')
5384 if (count == 0)
5385 break;
5386 count--;
5388 else if (*endp == '(') /* ) */
5389 count++;
5391 /* ( */
5392 if (*endp != ')')
5393 fatal ("malformed spec function arguments");
5394 args = save_string (p, endp - p);
5395 p = ++endp;
5397 /* p now points to just past the end of the spec function expression. */
5399 funcval = eval_spec_function (func, args);
5400 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5401 p = NULL;
5403 free (func);
5404 free (args);
5406 processing_spec_function--;
5408 return p;
5411 /* Inline subroutine of handle_braces. Returns true if the current
5412 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5413 static inline bool
5414 input_suffix_matches (const char *atom, const char *end_atom)
5416 /* We special case the semantics of {.s:...} and {.S:...} and their
5417 negative variants. Instead of testing the input filename suffix,
5418 we test whether the input source file is an assembler file or an
5419 assembler-with-cpp file respectively. This allows us to correctly
5420 handle the -x command line option. */
5422 if (atom + 1 == end_atom
5423 && input_file_compiler
5424 && input_file_compiler->suffix)
5426 if (*atom == 's')
5427 return !strcmp (input_file_compiler->suffix, "@assembler");
5428 if (*atom == 'S')
5429 return !strcmp (input_file_compiler->suffix, "@assembler-with-cpp");
5432 return (input_suffix
5433 && !strncmp (input_suffix, atom, end_atom - atom)
5434 && input_suffix[end_atom - atom] == '\0');
5437 /* Inline subroutine of handle_braces. Returns true if a switch
5438 matching the atom bracketed by ATOM and END_ATOM appeared on the
5439 command line. */
5440 static inline bool
5441 switch_matches (const char *atom, const char *end_atom, int starred)
5443 int i;
5444 int len = end_atom - atom;
5445 int plen = starred ? len : -1;
5447 for (i = 0; i < n_switches; i++)
5448 if (!strncmp (switches[i].part1, atom, len)
5449 && (starred || switches[i].part1[len] == '\0')
5450 && check_live_switch (i, plen))
5451 return true;
5453 return false;
5456 /* Inline subroutine of handle_braces. Mark all of the switches which
5457 match ATOM (extends to END_ATOM; STARRED indicates whether there
5458 was a star after the atom) for later processing. */
5459 static inline void
5460 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5462 int i;
5463 int len = end_atom - atom;
5464 int plen = starred ? len : -1;
5466 for (i = 0; i < n_switches; i++)
5467 if (!strncmp (switches[i].part1, atom, len)
5468 && (starred || switches[i].part1[len] == '\0')
5469 && check_live_switch (i, plen))
5470 switches[i].ordering = 1;
5473 /* Inline subroutine of handle_braces. Process all the currently
5474 marked switches through give_switch, and clear the marks. */
5475 static inline void
5476 process_marked_switches (void)
5478 int i;
5480 for (i = 0; i < n_switches; i++)
5481 if (switches[i].ordering == 1)
5483 switches[i].ordering = 0;
5484 give_switch (i, 0);
5488 /* Handle a %{ ... } construct. P points just inside the leading {.
5489 Returns a pointer one past the end of the brace block, or 0
5490 if we call do_spec_1 and that returns -1. */
5492 static const char *
5493 handle_braces (const char *p)
5495 const char *atom, *end_atom;
5496 const char *d_atom = NULL, *d_end_atom = NULL;
5497 const char *orig = p;
5499 bool a_is_suffix;
5500 bool a_is_starred;
5501 bool a_is_negated;
5502 bool a_matched;
5504 bool a_must_be_last = false;
5505 bool ordered_set = false;
5506 bool disjunct_set = false;
5507 bool disj_matched = false;
5508 bool disj_starred = true;
5509 bool n_way_choice = false;
5510 bool n_way_matched = false;
5512 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5516 if (a_must_be_last)
5517 goto invalid;
5519 /* Scan one "atom" (S in the description above of %{}, possibly
5520 with !, ., or * modifiers). */
5521 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5523 SKIP_WHITE();
5524 if (*p == '!')
5525 p++, a_is_negated = true;
5527 SKIP_WHITE();
5528 if (*p == '.')
5529 p++, a_is_suffix = true;
5531 atom = p;
5532 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5533 || *p == ',' || *p == '.' || *p == '@')
5534 p++;
5535 end_atom = p;
5537 if (*p == '*')
5538 p++, a_is_starred = 1;
5540 SKIP_WHITE();
5541 switch (*p)
5543 case '&': case '}':
5544 /* Substitute the switch(es) indicated by the current atom. */
5545 ordered_set = true;
5546 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5547 || atom == end_atom)
5548 goto invalid;
5550 mark_matching_switches (atom, end_atom, a_is_starred);
5552 if (*p == '}')
5553 process_marked_switches ();
5554 break;
5556 case '|': case ':':
5557 /* Substitute some text if the current atom appears as a switch
5558 or suffix. */
5559 disjunct_set = true;
5560 if (ordered_set)
5561 goto invalid;
5563 if (atom == end_atom)
5565 if (!n_way_choice || disj_matched || *p == '|'
5566 || a_is_negated || a_is_suffix || a_is_starred)
5567 goto invalid;
5569 /* An empty term may appear as the last choice of an
5570 N-way choice set; it means "otherwise". */
5571 a_must_be_last = true;
5572 disj_matched = !n_way_matched;
5573 disj_starred = false;
5575 else
5577 if (a_is_suffix && a_is_starred)
5578 goto invalid;
5580 if (!a_is_starred)
5581 disj_starred = false;
5583 /* Don't bother testing this atom if we already have a
5584 match. */
5585 if (!disj_matched && !n_way_matched)
5587 if (a_is_suffix)
5588 a_matched = input_suffix_matches (atom, end_atom);
5589 else
5590 a_matched = switch_matches (atom, end_atom, a_is_starred);
5592 if (a_matched != a_is_negated)
5594 disj_matched = true;
5595 d_atom = atom;
5596 d_end_atom = end_atom;
5601 if (*p == ':')
5603 /* Found the body, that is, the text to substitute if the
5604 current disjunction matches. */
5605 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5606 disj_matched && !n_way_matched);
5607 if (p == 0)
5608 return 0;
5610 /* If we have an N-way choice, reset state for the next
5611 disjunction. */
5612 if (*p == ';')
5614 n_way_choice = true;
5615 n_way_matched |= disj_matched;
5616 disj_matched = false;
5617 disj_starred = true;
5618 d_atom = d_end_atom = NULL;
5621 break;
5623 default:
5624 goto invalid;
5627 while (*p++ != '}');
5629 return p;
5631 invalid:
5632 fatal ("braced spec '%s' is invalid at '%c'", orig, *p);
5634 #undef SKIP_WHITE
5637 /* Subroutine of handle_braces. Scan and process a brace substitution body
5638 (X in the description of %{} syntax). P points one past the colon;
5639 ATOM and END_ATOM bracket the first atom which was found to be true
5640 (present) in the current disjunction; STARRED indicates whether all
5641 the atoms in the current disjunction were starred (for syntax validation);
5642 MATCHED indicates whether the disjunction matched or not, and therefore
5643 whether or not the body is to be processed through do_spec_1 or just
5644 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5645 returns -1. */
5647 static const char *
5648 process_brace_body (const char *p, const char *atom, const char *end_atom,
5649 int starred, int matched)
5651 const char *body, *end_body;
5652 unsigned int nesting_level;
5653 bool have_subst = false;
5655 /* Locate the closing } or ;, honoring nested braces.
5656 Trim trailing whitespace. */
5657 body = p;
5658 nesting_level = 1;
5659 for (;;)
5661 if (*p == '{')
5662 nesting_level++;
5663 else if (*p == '}')
5665 if (!--nesting_level)
5666 break;
5668 else if (*p == ';' && nesting_level == 1)
5669 break;
5670 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5671 have_subst = true;
5672 else if (*p == '\0')
5673 goto invalid;
5674 p++;
5677 end_body = p;
5678 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5679 end_body--;
5681 if (have_subst && !starred)
5682 goto invalid;
5684 if (matched)
5686 /* Copy the substitution body to permanent storage and execute it.
5687 If have_subst is false, this is a simple matter of running the
5688 body through do_spec_1... */
5689 char *string = save_string (body, end_body - body);
5690 if (!have_subst)
5692 if (do_spec_1 (string, 0, NULL) < 0)
5693 return 0;
5695 else
5697 /* ... but if have_subst is true, we have to process the
5698 body once for each matching switch, with %* set to the
5699 variant part of the switch. */
5700 unsigned int hard_match_len = end_atom - atom;
5701 int i;
5703 for (i = 0; i < n_switches; i++)
5704 if (!strncmp (switches[i].part1, atom, hard_match_len)
5705 && check_live_switch (i, hard_match_len))
5707 if (do_spec_1 (string, 0,
5708 &switches[i].part1[hard_match_len]) < 0)
5709 return 0;
5710 /* Pass any arguments this switch has. */
5711 give_switch (i, 1);
5712 suffix_subst = NULL;
5717 return p;
5719 invalid:
5720 fatal ("braced spec body '%s' is invalid", body);
5723 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5724 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5725 spec, or -1 if either exact match or %* is used.
5727 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5728 whose value does not begin with "no-" is obsoleted by the same value
5729 with the "no-", similarly for a switch with the "no-" prefix. */
5731 static int
5732 check_live_switch (int switchnum, int prefix_length)
5734 const char *name = switches[switchnum].part1;
5735 int i;
5737 /* In the common case of {<at-most-one-letter>*}, a negating
5738 switch would always match, so ignore that case. We will just
5739 send the conflicting switches to the compiler phase. */
5740 if (prefix_length >= 0 && prefix_length <= 1)
5741 return 1;
5743 /* If we already processed this switch and determined if it was
5744 live or not, return our past determination. */
5745 if (switches[switchnum].live_cond != 0)
5746 return switches[switchnum].live_cond > 0;
5748 /* Now search for duplicate in a manner that depends on the name. */
5749 switch (*name)
5751 case 'O':
5752 for (i = switchnum + 1; i < n_switches; i++)
5753 if (switches[i].part1[0] == 'O')
5755 switches[switchnum].validated = 1;
5756 switches[switchnum].live_cond = SWITCH_FALSE;
5757 return 0;
5759 break;
5761 case 'W': case 'f': case 'm':
5762 if (! strncmp (name + 1, "no-", 3))
5764 /* We have Xno-YYY, search for XYYY. */
5765 for (i = switchnum + 1; i < n_switches; i++)
5766 if (switches[i].part1[0] == name[0]
5767 && ! strcmp (&switches[i].part1[1], &name[4]))
5769 switches[switchnum].validated = 1;
5770 switches[switchnum].live_cond = SWITCH_FALSE;
5771 return 0;
5774 else
5776 /* We have XYYY, search for Xno-YYY. */
5777 for (i = switchnum + 1; i < n_switches; i++)
5778 if (switches[i].part1[0] == name[0]
5779 && switches[i].part1[1] == 'n'
5780 && switches[i].part1[2] == 'o'
5781 && switches[i].part1[3] == '-'
5782 && !strcmp (&switches[i].part1[4], &name[1]))
5784 switches[switchnum].validated = 1;
5785 switches[switchnum].live_cond = SWITCH_FALSE;
5786 return 0;
5789 break;
5792 /* Otherwise the switch is live. */
5793 switches[switchnum].live_cond = SWITCH_LIVE;
5794 return 1;
5797 /* Pass a switch to the current accumulating command
5798 in the same form that we received it.
5799 SWITCHNUM identifies the switch; it is an index into
5800 the vector of switches gcc received, which is `switches'.
5801 This cannot fail since it never finishes a command line.
5803 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5805 static void
5806 give_switch (int switchnum, int omit_first_word)
5808 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5809 return;
5811 if (!omit_first_word)
5813 do_spec_1 ("-", 0, NULL);
5814 do_spec_1 (switches[switchnum].part1, 1, NULL);
5817 if (switches[switchnum].args != 0)
5819 const char **p;
5820 for (p = switches[switchnum].args; *p; p++)
5822 const char *arg = *p;
5824 do_spec_1 (" ", 0, NULL);
5825 if (suffix_subst)
5827 unsigned length = strlen (arg);
5828 int dot = 0;
5830 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5831 if (arg[length] == '.')
5833 ((char *)arg)[length] = 0;
5834 dot = 1;
5835 break;
5837 do_spec_1 (arg, 1, NULL);
5838 if (dot)
5839 ((char *)arg)[length] = '.';
5840 do_spec_1 (suffix_subst, 1, NULL);
5842 else
5843 do_spec_1 (arg, 1, NULL);
5847 do_spec_1 (" ", 0, NULL);
5848 switches[switchnum].validated = 1;
5851 /* Search for a file named NAME trying various prefixes including the
5852 user's -B prefix and some standard ones.
5853 Return the absolute file name found. If nothing is found, return NAME. */
5855 static const char *
5856 find_file (const char *name)
5858 char *newname;
5860 /* Try multilib_dir if it is defined. */
5861 if (multilib_os_dir != NULL)
5863 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
5865 /* If we don't find it in the multi library dir, then fall
5866 through and look for it in the normal places. */
5867 if (newname != NULL)
5868 return newname;
5871 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
5872 return newname ? newname : name;
5875 /* Determine whether a directory exists. If LINKER, return 0 for
5876 certain fixed names not needed by the linker. If not LINKER, it is
5877 only important to return 0 if the host machine has a small ARG_MAX
5878 limit. */
5880 static int
5881 is_directory (const char *path1, const char *path2, int linker)
5883 int len1 = strlen (path1);
5884 int len2 = strlen (path2);
5885 char *path = alloca (3 + len1 + len2);
5886 char *cp;
5887 struct stat st;
5889 #ifndef SMALL_ARG_MAX
5890 if (! linker)
5891 return 1;
5892 #endif
5894 /* Construct the path from the two parts. Ensure the string ends with "/.".
5895 The resulting path will be a directory even if the given path is a
5896 symbolic link. */
5897 memcpy (path, path1, len1);
5898 memcpy (path + len1, path2, len2);
5899 cp = path + len1 + len2;
5900 if (!IS_DIR_SEPARATOR (cp[-1]))
5901 *cp++ = DIR_SEPARATOR;
5902 *cp++ = '.';
5903 *cp = '\0';
5905 /* Exclude directories that the linker is known to search. */
5906 if (linker
5907 && ((cp - path == 6
5908 && strcmp (path, concat (dir_separator_str, "lib",
5909 dir_separator_str, ".", NULL)) == 0)
5910 || (cp - path == 10
5911 && strcmp (path, concat (dir_separator_str, "usr",
5912 dir_separator_str, "lib",
5913 dir_separator_str, ".", NULL)) == 0)))
5914 return 0;
5916 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5919 /* Set up the various global variables to indicate that we're processing
5920 the input file named FILENAME. */
5922 void
5923 set_input (const char *filename)
5925 const char *p;
5927 input_filename = filename;
5928 input_filename_length = strlen (input_filename);
5930 input_basename = input_filename;
5931 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5932 /* Skip drive name so 'x:foo' is handled properly. */
5933 if (input_basename[1] == ':')
5934 input_basename += 2;
5935 #endif
5936 for (p = input_basename; *p; p++)
5937 if (IS_DIR_SEPARATOR (*p))
5938 input_basename = p + 1;
5940 /* Find a suffix starting with the last period,
5941 and set basename_length to exclude that suffix. */
5942 basename_length = strlen (input_basename);
5943 suffixed_basename_length = basename_length;
5944 p = input_basename + basename_length;
5945 while (p != input_basename && *p != '.')
5946 --p;
5947 if (*p == '.' && p != input_basename)
5949 basename_length = p - input_basename;
5950 input_suffix = p + 1;
5952 else
5953 input_suffix = "";
5955 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5956 we will need to do a stat on the input_filename. The
5957 INPUT_STAT_SET signals that the stat is needed. */
5958 input_stat_set = 0;
5961 /* On fatal signals, delete all the temporary files. */
5963 static void
5964 fatal_error (int signum)
5966 signal (signum, SIG_DFL);
5967 delete_failure_queue ();
5968 delete_temp_files ();
5969 /* Get the same signal again, this time not handled,
5970 so its normal effect occurs. */
5971 kill (getpid (), signum);
5974 extern int main (int, const char **);
5977 main (int argc, const char **argv)
5979 size_t i;
5980 int value;
5981 int linker_was_run = 0;
5982 int lang_n_infiles = 0;
5983 int num_linker_inputs = 0;
5984 char *explicit_link_files;
5985 char *specs_file;
5986 const char *p;
5987 struct user_specs *uptr;
5989 p = argv[0] + strlen (argv[0]);
5990 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
5991 --p;
5992 programname = p;
5994 xmalloc_set_program_name (programname);
5996 #ifdef GCC_DRIVER_HOST_INITIALIZATION
5997 /* Perform host dependent initialization when needed. */
5998 GCC_DRIVER_HOST_INITIALIZATION;
5999 #endif
6001 /* Unlock the stdio streams. */
6002 unlock_std_streams ();
6004 gcc_init_libintl ();
6006 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6007 signal (SIGINT, fatal_error);
6008 #ifdef SIGHUP
6009 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6010 signal (SIGHUP, fatal_error);
6011 #endif
6012 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6013 signal (SIGTERM, fatal_error);
6014 #ifdef SIGPIPE
6015 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6016 signal (SIGPIPE, fatal_error);
6017 #endif
6018 #ifdef SIGCHLD
6019 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6020 receive the signal. A different setting is inheritable */
6021 signal (SIGCHLD, SIG_DFL);
6022 #endif
6024 /* Allocate the argument vector. */
6025 alloc_args ();
6027 obstack_init (&obstack);
6029 /* Build multilib_select, et. al from the separate lines that make up each
6030 multilib selection. */
6032 const char *const *q = multilib_raw;
6033 int need_space;
6035 obstack_init (&multilib_obstack);
6036 while ((p = *q++) != (char *) 0)
6037 obstack_grow (&multilib_obstack, p, strlen (p));
6039 obstack_1grow (&multilib_obstack, 0);
6040 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6042 q = multilib_matches_raw;
6043 while ((p = *q++) != (char *) 0)
6044 obstack_grow (&multilib_obstack, p, strlen (p));
6046 obstack_1grow (&multilib_obstack, 0);
6047 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6049 q = multilib_exclusions_raw;
6050 while ((p = *q++) != (char *) 0)
6051 obstack_grow (&multilib_obstack, p, strlen (p));
6053 obstack_1grow (&multilib_obstack, 0);
6054 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6056 need_space = FALSE;
6057 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6059 if (need_space)
6060 obstack_1grow (&multilib_obstack, ' ');
6061 obstack_grow (&multilib_obstack,
6062 multilib_defaults_raw[i],
6063 strlen (multilib_defaults_raw[i]));
6064 need_space = TRUE;
6067 obstack_1grow (&multilib_obstack, 0);
6068 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6071 /* Set up to remember the pathname of gcc and any options
6072 needed for collect. We use argv[0] instead of programname because
6073 we need the complete pathname. */
6074 obstack_init (&collect_obstack);
6075 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6076 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6077 putenv (XOBFINISH (&collect_obstack, char *));
6079 #ifdef INIT_ENVIRONMENT
6080 /* Set up any other necessary machine specific environment variables. */
6081 putenv (INIT_ENVIRONMENT);
6082 #endif
6084 /* Make a table of what switches there are (switches, n_switches).
6085 Make a table of specified input files (infiles, n_infiles).
6086 Decode switches that are handled locally. */
6088 process_command (argc, argv);
6090 /* Initialize the vector of specs to just the default.
6091 This means one element containing 0s, as a terminator. */
6093 compilers = xmalloc (sizeof default_compilers);
6094 memcpy (compilers, default_compilers, sizeof default_compilers);
6095 n_compilers = n_default_compilers;
6097 /* Read specs from a file if there is one. */
6099 machine_suffix = concat (spec_machine, dir_separator_str,
6100 spec_version, dir_separator_str, NULL);
6101 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6103 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6104 /* Read the specs file unless it is a default one. */
6105 if (specs_file != 0 && strcmp (specs_file, "specs"))
6106 read_specs (specs_file, TRUE);
6107 else
6108 init_spec ();
6110 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6111 for any override of as, ld and libraries. */
6112 specs_file = alloca (strlen (standard_exec_prefix)
6113 + strlen (just_machine_suffix) + sizeof ("specs"));
6115 strcpy (specs_file, standard_exec_prefix);
6116 strcat (specs_file, just_machine_suffix);
6117 strcat (specs_file, "specs");
6118 if (access (specs_file, R_OK) == 0)
6119 read_specs (specs_file, TRUE);
6121 /* Process any configure-time defaults specified for the command line
6122 options, via OPTION_DEFAULT_SPECS. */
6123 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6124 do_option_spec (option_default_specs[i].name,
6125 option_default_specs[i].spec);
6127 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6128 of the command line. */
6130 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6131 do_self_spec (driver_self_specs[i]);
6133 /* If not cross-compiling, look for executables in the standard
6134 places. */
6135 if (*cross_compile == '0')
6137 if (*md_exec_prefix)
6139 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6140 PREFIX_PRIORITY_LAST, 0, 0);
6144 /* Process sysroot_suffix_spec. */
6145 if (*sysroot_suffix_spec != 0
6146 && do_spec_2 (sysroot_suffix_spec) == 0)
6148 if (argbuf_index > 1)
6149 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC.");
6150 else if (argbuf_index == 1)
6151 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6154 #ifdef HAVE_LD_SYSROOT
6155 /* Pass the --sysroot option to the linker, if it supports that. If
6156 there is a sysroot_suffix_spec, it has already been processed by
6157 this point, so target_system_root really is the system root we
6158 should be using. */
6159 if (target_system_root)
6161 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6162 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6163 set_spec ("link", XOBFINISH (&obstack, const char *));
6165 #endif
6167 /* Process sysroot_hdrs_suffix_spec. */
6168 if (*sysroot_hdrs_suffix_spec != 0
6169 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6171 if (argbuf_index > 1)
6172 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC.");
6173 else if (argbuf_index == 1)
6174 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6177 /* Look for startfiles in the standard places. */
6178 if (*startfile_prefix_spec != 0
6179 && do_spec_2 (startfile_prefix_spec) == 0
6180 && do_spec_1 (" ", 0, NULL) == 0)
6182 int ndx;
6183 for (ndx = 0; ndx < argbuf_index; ndx++)
6184 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6185 PREFIX_PRIORITY_LAST, 0, 1);
6187 /* We should eventually get rid of all these and stick to
6188 startfile_prefix_spec exclusively. */
6189 else if (*cross_compile == '0' || target_system_root)
6191 if (*md_startfile_prefix)
6192 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6193 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6195 if (*md_startfile_prefix_1)
6196 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6197 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6199 /* If standard_startfile_prefix is relative, base it on
6200 standard_exec_prefix. This lets us move the installed tree
6201 as a unit. If GCC_EXEC_PREFIX is defined, base
6202 standard_startfile_prefix on that as well.
6204 If the prefix is relative, only search it for native compilers;
6205 otherwise we will search a directory containing host libraries. */
6206 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6207 add_sysrooted_prefix (&startfile_prefixes,
6208 standard_startfile_prefix, "BINUTILS",
6209 PREFIX_PRIORITY_LAST, 0, 1);
6210 else if (*cross_compile == '0')
6212 if (gcc_exec_prefix)
6213 add_prefix (&startfile_prefixes,
6214 concat (gcc_exec_prefix, machine_suffix,
6215 standard_startfile_prefix, NULL),
6216 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6217 add_prefix (&startfile_prefixes,
6218 concat (standard_exec_prefix,
6219 machine_suffix,
6220 standard_startfile_prefix, NULL),
6221 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6224 if (*standard_startfile_prefix_1)
6225 add_sysrooted_prefix (&startfile_prefixes,
6226 standard_startfile_prefix_1, "BINUTILS",
6227 PREFIX_PRIORITY_LAST, 0, 1);
6228 if (*standard_startfile_prefix_2)
6229 add_sysrooted_prefix (&startfile_prefixes,
6230 standard_startfile_prefix_2, "BINUTILS",
6231 PREFIX_PRIORITY_LAST, 0, 1);
6234 /* Process any user specified specs in the order given on the command
6235 line. */
6236 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6238 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6239 R_OK, 0);
6240 read_specs (filename ? filename : uptr->filename, FALSE);
6243 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6244 if (gcc_exec_prefix)
6245 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6246 spec_version, dir_separator_str, NULL);
6248 /* Now we have the specs.
6249 Set the `valid' bits for switches that match anything in any spec. */
6251 validate_all_switches ();
6253 /* Now that we have the switches and the specs, set
6254 the subdirectory based on the options. */
6255 set_multilib_dir ();
6257 /* Warn about any switches that no pass was interested in. */
6259 for (i = 0; (int) i < n_switches; i++)
6260 if (! switches[i].validated)
6261 error ("unrecognized option '-%s'", switches[i].part1);
6263 /* Obey some of the options. */
6265 if (print_search_dirs)
6267 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6268 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6269 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6270 return (0);
6273 if (print_file_name)
6275 printf ("%s\n", find_file (print_file_name));
6276 return (0);
6279 if (print_prog_name)
6281 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6282 printf ("%s\n", (newname ? newname : print_prog_name));
6283 return (0);
6286 if (print_multi_lib)
6288 print_multilib_info ();
6289 return (0);
6292 if (print_multi_directory)
6294 if (multilib_dir == NULL)
6295 printf (".\n");
6296 else
6297 printf ("%s\n", multilib_dir);
6298 return (0);
6301 if (print_multi_os_directory)
6303 if (multilib_os_dir == NULL)
6304 printf (".\n");
6305 else
6306 printf ("%s\n", multilib_os_dir);
6307 return (0);
6310 if (target_help_flag)
6312 /* Print if any target specific options. */
6314 /* We do not exit here. Instead we have created a fake input file
6315 called 'target-dummy' which needs to be compiled, and we pass this
6316 on to the various sub-processes, along with the --target-help
6317 switch. */
6320 if (print_help_list)
6322 display_help ();
6324 if (! verbose_flag)
6326 printf (_("\nFor bug reporting instructions, please see:\n"));
6327 printf ("%s.\n", bug_report_url);
6329 return (0);
6332 /* We do not exit here. Instead we have created a fake input file
6333 called 'help-dummy' which needs to be compiled, and we pass this
6334 on the various sub-processes, along with the --help switch. */
6337 if (verbose_flag)
6339 int n;
6340 const char *thrmod;
6342 notice ("Target: %s\n", spec_machine);
6343 notice ("Configured with: %s\n", configuration_arguments);
6345 #ifdef THREAD_MODEL_SPEC
6346 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6347 but there's no point in doing all this processing just to get
6348 thread_model back. */
6349 obstack_init (&obstack);
6350 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6351 obstack_1grow (&obstack, '\0');
6352 thrmod = XOBFINISH (&obstack, const char *);
6353 #else
6354 thrmod = thread_model;
6355 #endif
6357 notice ("Thread model: %s\n", thrmod);
6359 /* compiler_version is truncated at the first space when initialized
6360 from version string, so truncate version_string at the first space
6361 before comparing. */
6362 for (n = 0; version_string[n]; n++)
6363 if (version_string[n] == ' ')
6364 break;
6366 if (! strncmp (version_string, compiler_version, n)
6367 && compiler_version[n] == 0)
6368 notice ("gcc version %s\n", version_string);
6369 else
6370 notice ("gcc driver version %s executing gcc version %s\n",
6371 version_string, compiler_version);
6373 if (n_infiles == 0)
6374 return (0);
6377 if (n_infiles == added_libraries)
6378 fatal ("no input files");
6380 /* Make a place to record the compiler output file names
6381 that correspond to the input files. */
6383 i = n_infiles;
6384 i += lang_specific_extra_outfiles;
6385 outfiles = xcalloc (i, sizeof (char *));
6387 /* Record which files were specified explicitly as link input. */
6389 explicit_link_files = xcalloc (1, n_infiles);
6391 if (combine_flag)
6392 combine_inputs = true;
6393 else
6394 combine_inputs = false;
6396 for (i = 0; (int) i < n_infiles; i++)
6398 const char *name = infiles[i].name;
6399 struct compiler *compiler = lookup_compiler (name,
6400 strlen (name),
6401 infiles[i].language);
6403 if (compiler && !(compiler->combinable))
6404 combine_inputs = false;
6406 if (lang_n_infiles > 0 && compiler != input_file_compiler
6407 && infiles[i].language && infiles[i].language[0] != '*')
6408 infiles[i].incompiler = compiler;
6409 else if (compiler)
6411 lang_n_infiles++;
6412 input_file_compiler = compiler;
6413 infiles[i].incompiler = compiler;
6415 else
6417 /* Since there is no compiler for this input file, assume it is a
6418 linker file. */
6419 explicit_link_files[i] = 1;
6420 infiles[i].incompiler = NULL;
6422 infiles[i].compiled = false;
6423 infiles[i].preprocessed = false;
6426 if (combine_flag && save_temps_flag)
6428 bool save_combine_inputs = combine_inputs;
6429 /* Must do a separate pre-processing pass for C & Objective-C files, to
6430 obtain individual .i files. */
6432 combine_inputs = false;
6433 for (i = 0; (int) i < n_infiles; i++)
6435 int this_file_error = 0;
6437 input_file_number = i;
6438 set_input (infiles[i].name);
6439 if (infiles[i].incompiler
6440 && (infiles[i].incompiler)->needs_preprocessing)
6441 input_file_compiler = infiles[i].incompiler;
6442 else
6443 continue;
6445 if (input_file_compiler)
6447 if (input_file_compiler->spec[0] == '#')
6449 error ("%s: %s compiler not installed on this system",
6450 input_filename, &input_file_compiler->spec[1]);
6451 this_file_error = 1;
6453 else
6455 value = do_spec (input_file_compiler->spec);
6456 infiles[i].preprocessed = true;
6457 if (!have_o_argbuf_index)
6458 fatal ("spec '%s' is invalid", input_file_compiler->spec);
6459 infiles[i].name = argbuf[have_o_argbuf_index];
6460 infiles[i].incompiler
6461 = lookup_compiler (infiles[i].name,
6462 strlen (infiles[i].name),
6463 infiles[i].language);
6465 if (value < 0)
6466 this_file_error = 1;
6470 if (this_file_error)
6472 delete_failure_queue ();
6473 error_count++;
6474 break;
6476 clear_failure_queue ();
6478 combine_inputs = save_combine_inputs;
6481 for (i = 0; (int) i < n_infiles; i++)
6483 int this_file_error = 0;
6485 /* Tell do_spec what to substitute for %i. */
6487 input_file_number = i;
6488 set_input (infiles[i].name);
6490 if (infiles[i].compiled)
6491 continue;
6493 /* Use the same thing in %o, unless cp->spec says otherwise. */
6495 outfiles[i] = input_filename;
6497 /* Figure out which compiler from the file's suffix. */
6499 if (! combine_inputs)
6500 input_file_compiler
6501 = lookup_compiler (infiles[i].name, input_filename_length,
6502 infiles[i].language);
6503 else
6504 input_file_compiler = infiles[i].incompiler;
6506 if (input_file_compiler)
6508 /* Ok, we found an applicable compiler. Run its spec. */
6510 if (input_file_compiler->spec[0] == '#')
6512 error ("%s: %s compiler not installed on this system",
6513 input_filename, &input_file_compiler->spec[1]);
6514 this_file_error = 1;
6516 else
6518 value = do_spec (input_file_compiler->spec);
6519 infiles[i].compiled = true;
6520 if (value < 0)
6521 this_file_error = 1;
6525 /* If this file's name does not contain a recognized suffix,
6526 record it as explicit linker input. */
6528 else
6529 explicit_link_files[i] = 1;
6531 /* Clear the delete-on-failure queue, deleting the files in it
6532 if this compilation failed. */
6534 if (this_file_error)
6536 delete_failure_queue ();
6537 error_count++;
6539 /* If this compilation succeeded, don't delete those files later. */
6540 clear_failure_queue ();
6543 /* Reset the output file name to the first input file name, for use
6544 with %b in LINK_SPEC on a target that prefers not to emit a.out
6545 by default. */
6546 if (n_infiles > 0)
6547 set_input (infiles[0].name);
6549 if (error_count == 0)
6551 /* Make sure INPUT_FILE_NUMBER points to first available open
6552 slot. */
6553 input_file_number = n_infiles;
6554 if (lang_specific_pre_link ())
6555 error_count++;
6558 /* Determine if there are any linker input files. */
6559 num_linker_inputs = 0;
6560 for (i = 0; (int) i < n_infiles; i++)
6561 if (explicit_link_files[i] || outfiles[i] != NULL)
6562 num_linker_inputs++;
6564 /* Run ld to link all the compiler output files. */
6566 if (num_linker_inputs > 0 && error_count == 0)
6568 int tmp = execution_count;
6570 /* We'll use ld if we can't find collect2. */
6571 if (! strcmp (linker_name_spec, "collect2"))
6573 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6574 if (s == NULL)
6575 linker_name_spec = "ld";
6577 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6578 for collect. */
6579 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6580 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6582 value = do_spec (link_command_spec);
6583 if (value < 0)
6584 error_count = 1;
6585 linker_was_run = (tmp != execution_count);
6588 /* If options said don't run linker,
6589 complain about input files to be given to the linker. */
6591 if (! linker_was_run && error_count == 0)
6592 for (i = 0; (int) i < n_infiles; i++)
6593 if (explicit_link_files[i])
6594 error ("%s: linker input file unused because linking not done",
6595 outfiles[i]);
6597 /* Delete some or all of the temporary files we made. */
6599 if (error_count)
6600 delete_failure_queue ();
6601 delete_temp_files ();
6603 if (print_help_list)
6605 printf (("\nFor bug reporting instructions, please see:\n"));
6606 printf ("%s\n", bug_report_url);
6609 return (signal_count != 0 ? 2
6610 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6611 : 0);
6614 /* Find the proper compilation spec for the file name NAME,
6615 whose length is LENGTH. LANGUAGE is the specified language,
6616 or 0 if this file is to be passed to the linker. */
6618 static struct compiler *
6619 lookup_compiler (const char *name, size_t length, const char *language)
6621 struct compiler *cp;
6623 /* If this was specified by the user to be a linker input, indicate that. */
6624 if (language != 0 && language[0] == '*')
6625 return 0;
6627 /* Otherwise, look for the language, if one is spec'd. */
6628 if (language != 0)
6630 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6631 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6632 return cp;
6634 error ("language %s not recognized", language);
6635 return 0;
6638 /* Look for a suffix. */
6639 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6641 if (/* The suffix `-' matches only the file name `-'. */
6642 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6643 || (strlen (cp->suffix) < length
6644 /* See if the suffix matches the end of NAME. */
6645 && !strcmp (cp->suffix,
6646 name + length - strlen (cp->suffix))
6648 break;
6651 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6652 /* Look again, but case-insensitively this time. */
6653 if (cp < compilers)
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))
6662 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6663 && !strcasecmp (cp->suffix,
6664 name + length - strlen (cp->suffix)))
6666 break;
6668 #endif
6670 if (cp >= compilers)
6672 if (cp->spec[0] != '@')
6673 /* A non-alias entry: return it. */
6674 return cp;
6676 /* An alias entry maps a suffix to a language.
6677 Search for the language; pass 0 for NAME and LENGTH
6678 to avoid infinite recursion if language not found. */
6679 return lookup_compiler (NULL, 0, cp->spec + 1);
6681 return 0;
6684 static char *
6685 save_string (const char *s, int len)
6687 char *result = xmalloc (len + 1);
6689 memcpy (result, s, len);
6690 result[len] = 0;
6691 return result;
6694 void
6695 pfatal_with_name (const char *name)
6697 perror_with_name (name);
6698 delete_temp_files ();
6699 exit (1);
6702 static void
6703 perror_with_name (const char *name)
6705 error ("%s: %s", name, xstrerror (errno));
6708 /* Output an error message and exit. */
6710 void
6711 fancy_abort (const char *file, int line, const char *func)
6713 fatal ("internal gcc abort in %s, at %s:%d", func, file, line);
6716 /* Output an error message and exit. */
6718 void
6719 fatal (const char *cmsgid, ...)
6721 va_list ap;
6723 va_start (ap, cmsgid);
6725 fprintf (stderr, "%s: ", programname);
6726 vfprintf (stderr, _(cmsgid), ap);
6727 va_end (ap);
6728 fprintf (stderr, "\n");
6729 delete_temp_files ();
6730 exit (1);
6733 /* The argument is actually c-format, not gcc-internal-format,
6734 but because functions with identical names are used through
6735 the rest of the compiler with gcc-internal-format, we just
6736 need to hope all users of these functions use the common
6737 subset between c-format and gcc-internal-format. */
6739 void
6740 error (const char *gmsgid, ...)
6742 va_list ap;
6744 va_start (ap, gmsgid);
6745 fprintf (stderr, "%s: ", programname);
6746 vfprintf (stderr, _(gmsgid), ap);
6747 va_end (ap);
6749 fprintf (stderr, "\n");
6752 static void
6753 notice (const char *cmsgid, ...)
6755 va_list ap;
6757 va_start (ap, cmsgid);
6758 vfprintf (stderr, _(cmsgid), ap);
6759 va_end (ap);
6762 static inline void
6763 validate_switches_from_spec (const char *spec)
6765 const char *p = spec;
6766 char c;
6767 while ((c = *p++))
6768 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6769 /* We have a switch spec. */
6770 p = validate_switches (p + 1);
6773 static void
6774 validate_all_switches (void)
6776 struct compiler *comp;
6777 struct spec_list *spec;
6779 for (comp = compilers; comp->spec; comp++)
6780 validate_switches_from_spec (comp->spec);
6782 /* Look through the linked list of specs read from the specs file. */
6783 for (spec = specs; spec; spec = spec->next)
6784 validate_switches_from_spec (*spec->ptr_spec);
6786 validate_switches_from_spec (link_command_spec);
6789 /* Look at the switch-name that comes after START
6790 and mark as valid all supplied switches that match it. */
6792 static const char *
6793 validate_switches (const char *start)
6795 const char *p = start;
6796 const char *atom;
6797 size_t len;
6798 int i;
6799 bool suffix = false;
6800 bool starred = false;
6802 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6804 next_member:
6805 SKIP_WHITE ();
6807 if (*p == '!')
6808 p++;
6810 SKIP_WHITE ();
6811 if (*p == '.')
6812 suffix = true, p++;
6814 atom = p;
6815 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6816 || *p == ',' || *p == '.' || *p == '@')
6817 p++;
6818 len = p - atom;
6820 if (*p == '*')
6821 starred = true, p++;
6823 SKIP_WHITE ();
6825 if (!suffix)
6827 /* Mark all matching switches as valid. */
6828 for (i = 0; i < n_switches; i++)
6829 if (!strncmp (switches[i].part1, atom, len)
6830 && (starred || switches[i].part1[len] == 0))
6831 switches[i].validated = 1;
6834 if (*p) p++;
6835 if (*p && (p[-1] == '|' || p[-1] == '&'))
6836 goto next_member;
6838 if (*p && p[-1] == ':')
6840 while (*p && *p != ';' && *p != '}')
6842 if (*p == '%')
6844 p++;
6845 if (*p == '{' || *p == '<')
6846 p = validate_switches (p+1);
6847 else if (p[0] == 'W' && p[1] == '{')
6848 p = validate_switches (p+2);
6850 else
6851 p++;
6854 if (*p) p++;
6855 if (*p && p[-1] == ';')
6856 goto next_member;
6859 return p;
6860 #undef SKIP_WHITE
6863 struct mdswitchstr
6865 const char *str;
6866 int len;
6869 static struct mdswitchstr *mdswitches;
6870 static int n_mdswitches;
6872 /* Check whether a particular argument was used. The first time we
6873 canonicalize the switches to keep only the ones we care about. */
6875 static int
6876 used_arg (const char *p, int len)
6878 struct mswitchstr
6880 const char *str;
6881 const char *replace;
6882 int len;
6883 int rep_len;
6886 static struct mswitchstr *mswitches;
6887 static int n_mswitches;
6888 int i, j;
6890 if (!mswitches)
6892 struct mswitchstr *matches;
6893 const char *q;
6894 int cnt = 0;
6896 /* Break multilib_matches into the component strings of string
6897 and replacement string. */
6898 for (q = multilib_matches; *q != '\0'; q++)
6899 if (*q == ';')
6900 cnt++;
6902 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
6903 i = 0;
6904 q = multilib_matches;
6905 while (*q != '\0')
6907 matches[i].str = q;
6908 while (*q != ' ')
6910 if (*q == '\0')
6912 invalid_matches:
6913 fatal ("multilib spec '%s' is invalid", multilib_matches);
6915 q++;
6917 matches[i].len = q - matches[i].str;
6919 matches[i].replace = ++q;
6920 while (*q != ';' && *q != '\0')
6922 if (*q == ' ')
6923 goto invalid_matches;
6924 q++;
6926 matches[i].rep_len = q - matches[i].replace;
6927 i++;
6928 if (*q == ';')
6929 q++;
6932 /* Now build a list of the replacement string for switches that we care
6933 about. Make sure we allocate at least one entry. This prevents
6934 xmalloc from calling fatal, and prevents us from re-executing this
6935 block of code. */
6936 mswitches
6937 = xmalloc (sizeof (struct mswitchstr)
6938 * (n_mdswitches + (n_switches ? n_switches : 1)));
6939 for (i = 0; i < n_switches; i++)
6940 if (switches[i].live_cond != SWITCH_IGNORE)
6942 int xlen = strlen (switches[i].part1);
6943 for (j = 0; j < cnt; j++)
6944 if (xlen == matches[j].len
6945 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6947 mswitches[n_mswitches].str = matches[j].replace;
6948 mswitches[n_mswitches].len = matches[j].rep_len;
6949 mswitches[n_mswitches].replace = (char *) 0;
6950 mswitches[n_mswitches].rep_len = 0;
6951 n_mswitches++;
6952 break;
6956 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
6957 on the command line nor any options mutually incompatible with
6958 them. */
6959 for (i = 0; i < n_mdswitches; i++)
6961 const char *r;
6963 for (q = multilib_options; *q != '\0'; q++)
6965 while (*q == ' ')
6966 q++;
6968 r = q;
6969 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
6970 || strchr (" /", q[mdswitches[i].len]) == NULL)
6972 while (*q != ' ' && *q != '/' && *q != '\0')
6973 q++;
6974 if (*q != '/')
6975 break;
6976 q++;
6979 if (*q != ' ' && *q != '\0')
6981 while (*r != ' ' && *r != '\0')
6983 q = r;
6984 while (*q != ' ' && *q != '/' && *q != '\0')
6985 q++;
6987 if (used_arg (r, q - r))
6988 break;
6990 if (*q != '/')
6992 mswitches[n_mswitches].str = mdswitches[i].str;
6993 mswitches[n_mswitches].len = mdswitches[i].len;
6994 mswitches[n_mswitches].replace = (char *) 0;
6995 mswitches[n_mswitches].rep_len = 0;
6996 n_mswitches++;
6997 break;
7000 r = q + 1;
7002 break;
7008 for (i = 0; i < n_mswitches; i++)
7009 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7010 return 1;
7012 return 0;
7015 static int
7016 default_arg (const char *p, int len)
7018 int i;
7020 for (i = 0; i < n_mdswitches; i++)
7021 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7022 return 1;
7024 return 0;
7027 /* Work out the subdirectory to use based on the options. The format of
7028 multilib_select is a list of elements. Each element is a subdirectory
7029 name followed by a list of options followed by a semicolon. The format
7030 of multilib_exclusions is the same, but without the preceding
7031 directory. First gcc will check the exclusions, if none of the options
7032 beginning with an exclamation point are present, and all of the other
7033 options are present, then we will ignore this completely. Passing
7034 that, gcc will consider each multilib_select in turn using the same
7035 rules for matching the options. If a match is found, that subdirectory
7036 will be used. */
7038 static void
7039 set_multilib_dir (void)
7041 const char *p;
7042 unsigned int this_path_len;
7043 const char *this_path, *this_arg;
7044 const char *start, *end;
7045 int not_arg;
7046 int ok, ndfltok, first;
7048 n_mdswitches = 0;
7049 start = multilib_defaults;
7050 while (*start == ' ' || *start == '\t')
7051 start++;
7052 while (*start != '\0')
7054 n_mdswitches++;
7055 while (*start != ' ' && *start != '\t' && *start != '\0')
7056 start++;
7057 while (*start == ' ' || *start == '\t')
7058 start++;
7061 if (n_mdswitches)
7063 int i = 0;
7065 mdswitches = xmalloc (sizeof (struct mdswitchstr) * n_mdswitches);
7066 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7068 while (*start == ' ' || *start == '\t')
7069 start++;
7071 if (*start == '\0')
7072 break;
7074 for (end = start + 1;
7075 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7078 obstack_grow (&multilib_obstack, start, end - start);
7079 obstack_1grow (&multilib_obstack, 0);
7080 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7081 mdswitches[i++].len = end - start;
7083 if (*end == '\0')
7084 break;
7088 p = multilib_exclusions;
7089 while (*p != '\0')
7091 /* Ignore newlines. */
7092 if (*p == '\n')
7094 ++p;
7095 continue;
7098 /* Check the arguments. */
7099 ok = 1;
7100 while (*p != ';')
7102 if (*p == '\0')
7104 invalid_exclusions:
7105 fatal ("multilib exclusions '%s' is invalid",
7106 multilib_exclusions);
7109 if (! ok)
7111 ++p;
7112 continue;
7115 this_arg = p;
7116 while (*p != ' ' && *p != ';')
7118 if (*p == '\0')
7119 goto invalid_exclusions;
7120 ++p;
7123 if (*this_arg != '!')
7124 not_arg = 0;
7125 else
7127 not_arg = 1;
7128 ++this_arg;
7131 ok = used_arg (this_arg, p - this_arg);
7132 if (not_arg)
7133 ok = ! ok;
7135 if (*p == ' ')
7136 ++p;
7139 if (ok)
7140 return;
7142 ++p;
7145 first = 1;
7146 p = multilib_select;
7147 while (*p != '\0')
7149 /* Ignore newlines. */
7150 if (*p == '\n')
7152 ++p;
7153 continue;
7156 /* Get the initial path. */
7157 this_path = p;
7158 while (*p != ' ')
7160 if (*p == '\0')
7162 invalid_select:
7163 fatal ("multilib select '%s' is invalid",
7164 multilib_select);
7166 ++p;
7168 this_path_len = p - this_path;
7170 /* Check the arguments. */
7171 ok = 1;
7172 ndfltok = 1;
7173 ++p;
7174 while (*p != ';')
7176 if (*p == '\0')
7177 goto invalid_select;
7179 if (! ok)
7181 ++p;
7182 continue;
7185 this_arg = p;
7186 while (*p != ' ' && *p != ';')
7188 if (*p == '\0')
7189 goto invalid_select;
7190 ++p;
7193 if (*this_arg != '!')
7194 not_arg = 0;
7195 else
7197 not_arg = 1;
7198 ++this_arg;
7201 /* If this is a default argument, we can just ignore it.
7202 This is true even if this_arg begins with '!'. Beginning
7203 with '!' does not mean that this argument is necessarily
7204 inappropriate for this library: it merely means that
7205 there is a more specific library which uses this
7206 argument. If this argument is a default, we need not
7207 consider that more specific library. */
7208 ok = used_arg (this_arg, p - this_arg);
7209 if (not_arg)
7210 ok = ! ok;
7212 if (! ok)
7213 ndfltok = 0;
7215 if (default_arg (this_arg, p - this_arg))
7216 ok = 1;
7218 if (*p == ' ')
7219 ++p;
7222 if (ok && first)
7224 if (this_path_len != 1
7225 || this_path[0] != '.')
7227 char *new_multilib_dir = xmalloc (this_path_len + 1);
7228 char *q;
7230 strncpy (new_multilib_dir, this_path, this_path_len);
7231 new_multilib_dir[this_path_len] = '\0';
7232 q = strchr (new_multilib_dir, ':');
7233 if (q != NULL)
7234 *q = '\0';
7235 multilib_dir = new_multilib_dir;
7237 first = 0;
7240 if (ndfltok)
7242 const char *q = this_path, *end = this_path + this_path_len;
7244 while (q < end && *q != ':')
7245 q++;
7246 if (q < end)
7248 char *new_multilib_os_dir = xmalloc (end - q);
7249 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7250 new_multilib_os_dir[end - q - 1] = '\0';
7251 multilib_os_dir = new_multilib_os_dir;
7252 break;
7256 ++p;
7259 if (multilib_dir == NULL && multilib_os_dir != NULL
7260 && strcmp (multilib_os_dir, ".") == 0)
7262 free ((char *) multilib_os_dir);
7263 multilib_os_dir = NULL;
7265 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7266 multilib_os_dir = multilib_dir;
7269 /* Print out the multiple library subdirectory selection
7270 information. This prints out a series of lines. Each line looks
7271 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7272 required. Only the desired options are printed out, the negative
7273 matches. The options are print without a leading dash. There are
7274 no spaces to make it easy to use the information in the shell.
7275 Each subdirectory is printed only once. This assumes the ordering
7276 generated by the genmultilib script. Also, we leave out ones that match
7277 the exclusions. */
7279 static void
7280 print_multilib_info (void)
7282 const char *p = multilib_select;
7283 const char *last_path = 0, *this_path;
7284 int skip;
7285 unsigned int last_path_len = 0;
7287 while (*p != '\0')
7289 skip = 0;
7290 /* Ignore newlines. */
7291 if (*p == '\n')
7293 ++p;
7294 continue;
7297 /* Get the initial path. */
7298 this_path = p;
7299 while (*p != ' ')
7301 if (*p == '\0')
7303 invalid_select:
7304 fatal ("multilib select '%s' is invalid", multilib_select);
7307 ++p;
7310 /* When --disable-multilib was used but target defines
7311 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7312 to find multilib_os_dir, so skip them from output. */
7313 if (this_path[0] == '.' && this_path[1] == ':')
7314 skip = 1;
7316 /* Check for matches with the multilib_exclusions. We don't bother
7317 with the '!' in either list. If any of the exclusion rules match
7318 all of its options with the select rule, we skip it. */
7320 const char *e = multilib_exclusions;
7321 const char *this_arg;
7323 while (*e != '\0')
7325 int m = 1;
7326 /* Ignore newlines. */
7327 if (*e == '\n')
7329 ++e;
7330 continue;
7333 /* Check the arguments. */
7334 while (*e != ';')
7336 const char *q;
7337 int mp = 0;
7339 if (*e == '\0')
7341 invalid_exclusion:
7342 fatal ("multilib exclusion '%s' is invalid",
7343 multilib_exclusions);
7346 if (! m)
7348 ++e;
7349 continue;
7352 this_arg = e;
7354 while (*e != ' ' && *e != ';')
7356 if (*e == '\0')
7357 goto invalid_exclusion;
7358 ++e;
7361 q = p + 1;
7362 while (*q != ';')
7364 const char *arg;
7365 int len = e - this_arg;
7367 if (*q == '\0')
7368 goto invalid_select;
7370 arg = q;
7372 while (*q != ' ' && *q != ';')
7374 if (*q == '\0')
7375 goto invalid_select;
7376 ++q;
7379 if (! strncmp (arg, this_arg,
7380 (len < q - arg) ? q - arg : len)
7381 || default_arg (this_arg, e - this_arg))
7383 mp = 1;
7384 break;
7387 if (*q == ' ')
7388 ++q;
7391 if (! mp)
7392 m = 0;
7394 if (*e == ' ')
7395 ++e;
7398 if (m)
7400 skip = 1;
7401 break;
7404 if (*e != '\0')
7405 ++e;
7409 if (! skip)
7411 /* If this is a duplicate, skip it. */
7412 skip = (last_path != 0
7413 && (unsigned int) (p - this_path) == last_path_len
7414 && ! strncmp (last_path, this_path, last_path_len));
7416 last_path = this_path;
7417 last_path_len = p - this_path;
7420 /* If this directory requires any default arguments, we can skip
7421 it. We will already have printed a directory identical to
7422 this one which does not require that default argument. */
7423 if (! skip)
7425 const char *q;
7427 q = p + 1;
7428 while (*q != ';')
7430 const char *arg;
7432 if (*q == '\0')
7433 goto invalid_select;
7435 if (*q == '!')
7436 arg = NULL;
7437 else
7438 arg = q;
7440 while (*q != ' ' && *q != ';')
7442 if (*q == '\0')
7443 goto invalid_select;
7444 ++q;
7447 if (arg != NULL
7448 && default_arg (arg, q - arg))
7450 skip = 1;
7451 break;
7454 if (*q == ' ')
7455 ++q;
7459 if (! skip)
7461 const char *p1;
7463 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7464 putchar (*p1);
7465 putchar (';');
7468 ++p;
7469 while (*p != ';')
7471 int use_arg;
7473 if (*p == '\0')
7474 goto invalid_select;
7476 if (skip)
7478 ++p;
7479 continue;
7482 use_arg = *p != '!';
7484 if (use_arg)
7485 putchar ('@');
7487 while (*p != ' ' && *p != ';')
7489 if (*p == '\0')
7490 goto invalid_select;
7491 if (use_arg)
7492 putchar (*p);
7493 ++p;
7496 if (*p == ' ')
7497 ++p;
7500 if (! skip)
7502 /* If there are extra options, print them now. */
7503 if (multilib_extra && *multilib_extra)
7505 int print_at = TRUE;
7506 const char *q;
7508 for (q = multilib_extra; *q != '\0'; q++)
7510 if (*q == ' ')
7511 print_at = TRUE;
7512 else
7514 if (print_at)
7515 putchar ('@');
7516 putchar (*q);
7517 print_at = FALSE;
7522 putchar ('\n');
7525 ++p;
7529 /* if-exists built-in spec function.
7531 Checks to see if the file specified by the absolute pathname in
7532 ARGS exists. Returns that pathname if found.
7534 The usual use for this function is to check for a library file
7535 (whose name has been expanded with %s). */
7537 static const char *
7538 if_exists_spec_function (int argc, const char **argv)
7540 /* Must have only one argument. */
7541 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7542 return argv[0];
7544 return NULL;
7547 /* if-exists-else built-in spec function.
7549 This is like if-exists, but takes an additional argument which
7550 is returned if the first argument does not exist. */
7552 static const char *
7553 if_exists_else_spec_function (int argc, const char **argv)
7555 /* Must have exactly two arguments. */
7556 if (argc != 2)
7557 return NULL;
7559 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7560 return argv[0];
7562 return argv[1];
7565 /* replace-outfile built-in spec function.
7566 This looks for the first argument in the outfiles array's name and replaces it
7567 with the second argument. */
7569 static const char *
7570 replace_outfile_spec_function (int argc, const char **argv)
7572 int i;
7573 /* Must have exactly two arguments. */
7574 if (argc != 2)
7575 abort ();
7577 for (i = 0; i < n_infiles; i++)
7579 if (outfiles[i] && !strcmp (outfiles[i], argv[0]))
7580 outfiles[i] = xstrdup (argv[1]);
7582 return NULL;