* config/fp-bit.h (LSHIFT): Take shift count parameter.
[official-gcc.git] / gcc / gcc.c
blob0673cb5c4602e14fe09a867d53102e1c3adb7717
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, 51 Franklin Street, Fifth Floor, Boston, MA
21 02110-1301, 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 "xregex.h"
84 #include "obstack.h"
85 #include "intl.h"
86 #include "prefix.h"
87 #include "gcc.h"
88 #include "flags.h"
90 /* By default there is no special suffix for target executables. */
91 /* FIXME: when autoconf is fixed, remove the host check - dj */
92 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
93 #define HAVE_TARGET_EXECUTABLE_SUFFIX
94 #endif
96 /* By default there is no special suffix for host executables. */
97 #ifdef HOST_EXECUTABLE_SUFFIX
98 #define HAVE_HOST_EXECUTABLE_SUFFIX
99 #else
100 #define HOST_EXECUTABLE_SUFFIX ""
101 #endif
103 /* By default, the suffix for target object files is ".o". */
104 #ifdef TARGET_OBJECT_SUFFIX
105 #define HAVE_TARGET_OBJECT_SUFFIX
106 #else
107 #define TARGET_OBJECT_SUFFIX ".o"
108 #endif
110 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
112 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
113 #ifndef LIBRARY_PATH_ENV
114 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
115 #endif
117 #ifndef HAVE_KILL
118 #define kill(p,s) raise(s)
119 #endif
121 /* If a stage of compilation returns an exit status >= 1,
122 compilation of that file ceases. */
124 #define MIN_FATAL_STATUS 1
126 /* Flag set by cppspec.c to 1. */
127 int is_cpp_driver;
129 /* Flag saying to pass the greatest exit code returned by a sub-process
130 to the calling program. */
131 static int pass_exit_codes;
133 /* Definition of string containing the arguments given to configure. */
134 #include "configargs.h"
136 /* Flag saying to print the directories gcc will search through looking for
137 programs, libraries, etc. */
139 static int print_search_dirs;
141 /* Flag saying to print the full filename of this file
142 as found through our usual search mechanism. */
144 static const char *print_file_name = NULL;
146 /* As print_file_name, but search for executable file. */
148 static const char *print_prog_name = NULL;
150 /* Flag saying to print the relative path we'd use to
151 find libgcc.a given the current compiler flags. */
153 static int print_multi_directory;
155 /* Flag saying to print the relative path we'd use to
156 find OS libraries given the current compiler flags. */
158 static int print_multi_os_directory;
160 /* Flag saying to print the list of subdirectories and
161 compiler flags used to select them in a standard form. */
163 static int print_multi_lib;
165 /* Flag saying to print the command line options understood by gcc and its
166 sub-processes. */
168 static int print_help_list;
170 /* Flag indicating whether we should print the command and arguments */
172 static int verbose_flag;
174 /* Flag indicating whether we should ONLY print the command and
175 arguments (like verbose_flag) without executing the command.
176 Displayed arguments are quoted so that the generated command
177 line is suitable for execution. This is intended for use in
178 shell scripts to capture the driver-generated command line. */
179 static int verbose_only_flag;
181 /* Flag indicating to print target specific command line options. */
183 static int target_help_flag;
185 /* Flag indicating whether we should report subprocess execution times
186 (if this is supported by the system - see pexecute.c). */
188 static int report_times;
190 /* Nonzero means place this string before uses of /, so that include
191 and library files can be found in an alternate location. */
193 #ifdef TARGET_SYSTEM_ROOT
194 static const char *target_system_root = TARGET_SYSTEM_ROOT;
195 #else
196 static const char *target_system_root = 0;
197 #endif
199 /* Nonzero means pass the updated target_system_root to the compiler. */
201 static int target_system_root_changed;
203 /* Nonzero means append this string to target_system_root. */
205 static const char *target_sysroot_suffix = 0;
207 /* Nonzero means append this string to target_system_root for headers. */
209 static const char *target_sysroot_hdrs_suffix = 0;
211 /* Nonzero means write "temp" files in source directory
212 and use the source file's name in them, and don't delete them. */
214 static int save_temps_flag;
216 /* Nonzero means pass multiple source files to the compiler at one time. */
218 static int combine_flag = 0;
220 /* Nonzero means use pipes to communicate between subprocesses.
221 Overridden by either of the above two flags. */
223 static int use_pipes;
225 /* The compiler version. */
227 static const char *compiler_version;
229 /* The target version specified with -V */
231 static const char *const spec_version = DEFAULT_TARGET_VERSION;
233 /* The target machine specified with -b. */
235 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
237 /* Nonzero if cross-compiling.
238 When -b is used, the value comes from the `specs' file. */
240 #ifdef CROSS_COMPILE
241 static const char *cross_compile = "1";
242 #else
243 static const char *cross_compile = "0";
244 #endif
246 #ifdef MODIFY_TARGET_NAME
248 /* Information on how to alter the target name based on a command-line
249 switch. The only case we support now is simply appending or deleting a
250 string to or from the end of the first part of the configuration name. */
252 static const struct modify_target
254 const char *const sw;
255 const enum add_del {ADD, DELETE} add_del;
256 const char *const str;
258 modify_target[] = MODIFY_TARGET_NAME;
259 #endif
261 /* The number of errors that have occurred; the link phase will not be
262 run if this is nonzero. */
263 static int error_count = 0;
265 /* Greatest exit code of sub-processes that has been encountered up to
266 now. */
267 static int greatest_status = 1;
269 /* This is the obstack which we use to allocate many strings. */
271 static struct obstack obstack;
273 /* This is the obstack to build an environment variable to pass to
274 collect2 that describes all of the relevant switches of what to
275 pass the compiler in building the list of pointers to constructors
276 and destructors. */
278 static struct obstack collect_obstack;
280 /* Forward declaration for prototypes. */
281 struct path_prefix;
282 struct prefix_list;
284 static void init_spec (void);
285 static void store_arg (const char *, int, int);
286 static char *load_specs (const char *);
287 static void read_specs (const char *, int);
288 static void set_spec (const char *, const char *);
289 static struct compiler *lookup_compiler (const char *, size_t, const char *);
290 static char *build_search_list (struct path_prefix *, const char *, int);
291 static void putenv_from_prefixes (struct path_prefix *, const char *);
292 static int access_check (const char *, int);
293 static char *find_a_file (struct path_prefix *, const char *, int, int);
294 static void add_prefix (struct path_prefix *, const char *, const char *,
295 int, int, int);
296 static void add_sysrooted_prefix (struct path_prefix *, const char *,
297 const char *, int, int, int);
298 static void translate_options (int *, const char *const **);
299 static char *skip_whitespace (char *);
300 static void delete_if_ordinary (const char *);
301 static void delete_temp_files (void);
302 static void delete_failure_queue (void);
303 static void clear_failure_queue (void);
304 static int check_live_switch (int, int);
305 static const char *handle_braces (const char *);
306 static inline bool input_suffix_matches (const char *, const char *);
307 static inline bool switch_matches (const char *, const char *, int);
308 static inline void mark_matching_switches (const char *, const char *, int);
309 static inline void process_marked_switches (void);
310 static const char *process_brace_body (const char *, const char *, const char *, int, int);
311 static const struct spec_function *lookup_spec_function (const char *);
312 static const char *eval_spec_function (const char *, const char *);
313 static const char *handle_spec_function (const char *);
314 static char *save_string (const char *, int);
315 static void set_collect_gcc_options (void);
316 static void do_spec_path (struct prefix_list *, const char *, int, int, int, const char *, const char *);
317 static int do_spec_1 (const char *, int, const char *);
318 static int do_spec_2 (const char *);
319 static void do_option_spec (const char *, const char *);
320 static void do_self_spec (const char *);
321 static const char *find_file (const char *);
322 static int is_directory (const char *, const char *, int);
323 static const char *validate_switches (const char *);
324 static void validate_all_switches (void);
325 static inline void validate_switches_from_spec (const char *);
326 static void give_switch (int, int);
327 static int used_arg (const char *, int);
328 static int default_arg (const char *, int);
329 static void set_multilib_dir (void);
330 static void print_multilib_info (void);
331 static void perror_with_name (const char *);
332 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
333 static void display_help (void);
334 static void add_preprocessor_option (const char *, int);
335 static void add_assembler_option (const char *, int);
336 static void add_linker_option (const char *, int);
337 static void process_command (int, const char **);
338 static int execute (void);
339 static void alloc_args (void);
340 static void clear_args (void);
341 static void fatal_error (int);
342 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
343 static void init_gcc_specs (struct obstack *, const char *, const char *,
344 const char *);
345 #endif
346 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
347 static const char *convert_filename (const char *, int, int);
348 #endif
350 static const char *if_exists_spec_function (int, const char **);
351 static const char *if_exists_else_spec_function (int, const char **);
352 static const char *replace_outfile_spec_function (int, const char **);
353 static const char *version_compare_spec_function (int, const char **);
355 /* The Specs Language
357 Specs are strings containing lines, each of which (if not blank)
358 is made up of a program name, and arguments separated by spaces.
359 The program name must be exact and start from root, since no path
360 is searched and it is unreliable to depend on the current working directory.
361 Redirection of input or output is not supported; the subprograms must
362 accept filenames saying what files to read and write.
364 In addition, the specs can contain %-sequences to substitute variable text
365 or for conditional text. Here is a table of all defined %-sequences.
366 Note that spaces are not generated automatically around the results of
367 expanding these sequences; therefore, you can concatenate them together
368 or with constant text in a single argument.
370 %% substitute one % into the program name or argument.
371 %i substitute the name of the input file being processed.
372 %b substitute the basename of the input file being processed.
373 This is the substring up to (and not including) the last period
374 and not including the directory.
375 %B same as %b, but include the file suffix (text after the last period).
376 %gSUFFIX
377 substitute a file name that has suffix SUFFIX and is chosen
378 once per compilation, and mark the argument a la %d. To reduce
379 exposure to denial-of-service attacks, the file name is now
380 chosen in a way that is hard to predict even when previously
381 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
382 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
383 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
384 had been pre-processed. Previously, %g was simply substituted
385 with a file name chosen once per compilation, without regard
386 to any appended suffix (which was therefore treated just like
387 ordinary text), making such attacks more likely to succeed.
388 %|SUFFIX
389 like %g, but if -pipe is in effect, expands simply to "-".
390 %mSUFFIX
391 like %g, but if -pipe is in effect, expands to nothing. (We have both
392 %| and %m to accommodate differences between system assemblers; see
393 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
394 %uSUFFIX
395 like %g, but generates a new temporary file name even if %uSUFFIX
396 was already seen.
397 %USUFFIX
398 substitutes the last file name generated with %uSUFFIX, generating a
399 new one if there is no such last file name. In the absence of any
400 %uSUFFIX, this is just like %gSUFFIX, except they don't share
401 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
402 would involve the generation of two distinct file names, one
403 for each `%g.s' and another for each `%U.s'. Previously, %U was
404 simply substituted with a file name chosen for the previous %u,
405 without regard to any appended suffix.
406 %jSUFFIX
407 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
408 writable, and if save-temps is off; otherwise, substitute the name
409 of a temporary file, just like %u. This temporary file is not
410 meant for communication between processes, but rather as a junk
411 disposal mechanism.
412 %.SUFFIX
413 substitutes .SUFFIX for the suffixes of a matched switch's args when
414 it is subsequently output with %*. SUFFIX is terminated by the next
415 space or %.
416 %d marks the argument containing or following the %d as a
417 temporary file name, so that that file will be deleted if CC exits
418 successfully. Unlike %g, this contributes no text to the argument.
419 %w marks the argument containing or following the %w as the
420 "output file" of this compilation. This puts the argument
421 into the sequence of arguments that %o will substitute later.
422 %V indicates that this compilation produces no "output file".
423 %W{...}
424 like %{...} but mark last argument supplied within
425 as a file to be deleted on failure.
426 %o substitutes the names of all the output files, with spaces
427 automatically placed around them. You should write spaces
428 around the %o as well or the results are undefined.
429 %o is for use in the specs for running the linker.
430 Input files whose names have no recognized suffix are not compiled
431 at all, but they are included among the output files, so they will
432 be linked.
433 %O substitutes the suffix for object files. Note that this is
434 handled specially when it immediately follows %g, %u, or %U
435 (with or without a suffix argument) because of the need for
436 those to form complete file names. The handling is such that
437 %O is treated exactly as if it had already been substituted,
438 except that %g, %u, and %U do not currently support additional
439 SUFFIX characters following %O as they would following, for
440 example, `.o'.
441 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
442 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
443 and -B options) as necessary.
444 %s current argument is the name of a library or startup file of some sort.
445 Search for that file in a standard list of directories
446 and substitute the full name found.
447 %eSTR Print STR as an error message. STR is terminated by a newline.
448 Use this when inconsistent options are detected.
449 %nSTR Print STR as a notice. STR is terminated by a newline.
450 %x{OPTION} Accumulate an option for %X.
451 %X Output the accumulated linker options specified by compilations.
452 %Y Output the accumulated assembler options specified by compilations.
453 %Z Output the accumulated preprocessor options specified by compilations.
454 %a process ASM_SPEC as a spec.
455 This allows config.h to specify part of the spec for running as.
456 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
457 used here. This can be used to run a post-processor after the
458 assembler has done its job.
459 %D Dump out a -L option for each directory in startfile_prefixes.
460 If multilib_dir is set, extra entries are generated with it affixed.
461 %l process LINK_SPEC as a spec.
462 %L process LIB_SPEC as a spec.
463 %G process LIBGCC_SPEC as a spec.
464 %R Output the concatenation of target_system_root and
465 target_sysroot_suffix.
466 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
467 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
468 %C process CPP_SPEC as a spec.
469 %1 process CC1_SPEC as a spec.
470 %2 process CC1PLUS_SPEC as a spec.
471 %* substitute the variable part of a matched option. (See below.)
472 Note that each comma in the substituted string is replaced by
473 a single space.
474 %<S remove all occurrences of -S from the command line.
475 Note - this command is position dependent. % commands in the
476 spec string before this one will see -S, % commands in the
477 spec string after this one will not.
478 %<S* remove all occurrences of all switches beginning with -S from the
479 command line.
480 %:function(args)
481 Call the named function FUNCTION, passing it ARGS. ARGS is
482 first processed as a nested spec string, then split into an
483 argument vector in the usual fashion. The function returns
484 a string which is processed as if it had appeared literally
485 as part of the current spec.
486 %{S} substitutes the -S switch, if that switch was given to CC.
487 If that switch was not specified, this substitutes nothing.
488 Here S is a metasyntactic variable.
489 %{S*} substitutes all the switches specified to CC whose names start
490 with -S. This is used for -o, -I, etc; switches that take
491 arguments. CC considers `-o foo' as being one switch whose
492 name starts with `o'. %{o*} would substitute this text,
493 including the space; thus, two arguments would be generated.
494 %{S*&T*} likewise, but preserve order of S and T options (the order
495 of S and T in the spec is not significant). Can be any number
496 of ampersand-separated variables; for each the wild card is
497 optional. Useful for CPP as %{D*&U*&A*}.
499 %{S:X} substitutes X, if the -S switch was given to CC.
500 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
501 %{S*:X} substitutes X if one or more switches whose names start
502 with -S was given to CC. Normally X is substituted only
503 once, no matter how many such switches appeared. However,
504 if %* appears somewhere in X, then X will be substituted
505 once for each matching switch, with the %* replaced by the
506 part of that switch that matched the '*'.
507 %{.S:X} substitutes X, if processing a file with suffix S.
508 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
510 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
511 combined with !, ., and * as above binding stronger than the OR.
512 If %* appears in X, all of the alternatives must be starred, and
513 only the first matching alternative is substituted.
514 %{S:X; if S was given to CC, substitutes X;
515 T:Y; else if T was given to CC, substitutes Y;
516 :D} else substitutes D. There can be as many clauses as you need.
517 This may be combined with ., !, |, and * as above.
519 %(Spec) processes a specification defined in a specs file as *Spec:
520 %[Spec] as above, but put __ around -D arguments
522 The conditional text X in a %{S:X} or similar construct may contain
523 other nested % constructs or spaces, or even newlines. They are
524 processed as usual, as described above. Trailing white space in X is
525 ignored. White space may also appear anywhere on the left side of the
526 colon in these constructs, except between . or * and the corresponding
527 word.
529 The -O, -f, -m, and -W switches are handled specifically in these
530 constructs. If another value of -O or the negated form of a -f, -m, or
531 -W switch is found later in the command line, the earlier switch
532 value is ignored, except with {S*} where S is just one letter; this
533 passes all matching options.
535 The character | at the beginning of the predicate text is used to indicate
536 that a command should be piped to the following command, but only if -pipe
537 is specified.
539 Note that it is built into CC which switches take arguments and which
540 do not. You might think it would be useful to generalize this to
541 allow each compiler's spec to say which switches take arguments. But
542 this cannot be done in a consistent fashion. CC cannot even decide
543 which input files have been specified without knowing which switches
544 take arguments, and it must know which input files to compile in order
545 to tell which compilers to run.
547 CC also knows implicitly that arguments starting in `-l' are to be
548 treated as compiler output files, and passed to the linker in their
549 proper position among the other output files. */
551 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
553 /* config.h can define ASM_SPEC to provide extra args to the assembler
554 or extra switch-translations. */
555 #ifndef ASM_SPEC
556 #define ASM_SPEC ""
557 #endif
559 /* config.h can define ASM_FINAL_SPEC to run a post processor after
560 the assembler has run. */
561 #ifndef ASM_FINAL_SPEC
562 #define ASM_FINAL_SPEC ""
563 #endif
565 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
566 or extra switch-translations. */
567 #ifndef CPP_SPEC
568 #define CPP_SPEC ""
569 #endif
571 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
572 or extra switch-translations. */
573 #ifndef CC1_SPEC
574 #define CC1_SPEC ""
575 #endif
577 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
578 or extra switch-translations. */
579 #ifndef CC1PLUS_SPEC
580 #define CC1PLUS_SPEC ""
581 #endif
583 /* config.h can define LINK_SPEC to provide extra args to the linker
584 or extra switch-translations. */
585 #ifndef LINK_SPEC
586 #define LINK_SPEC ""
587 #endif
589 /* config.h can define LIB_SPEC to override the default libraries. */
590 #ifndef LIB_SPEC
591 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
592 #endif
594 /* mudflap specs */
595 #ifndef MFWRAP_SPEC
596 /* XXX: valid only for GNU ld */
597 /* XXX: should exactly match hooks provided by libmudflap.a */
598 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
599 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
600 --wrap=mmap --wrap=munmap --wrap=alloca\
601 } %{fmudflapth: --wrap=pthread_create\
602 }} %{fmudflap|fmudflapth: --wrap=main}"
603 #endif
604 #ifndef MFLIB_SPEC
605 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
606 #endif
608 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
609 included. */
610 #ifndef LIBGCC_SPEC
611 #if defined(REAL_LIBGCC_SPEC)
612 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
613 #elif defined(LINK_LIBGCC_SPECIAL_1)
614 /* Have gcc do the search for libgcc.a. */
615 #define LIBGCC_SPEC "libgcc.a%s"
616 #else
617 #define LIBGCC_SPEC "-lgcc"
618 #endif
619 #endif
621 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
622 #ifndef STARTFILE_SPEC
623 #define STARTFILE_SPEC \
624 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
625 #endif
627 /* config.h can define SWITCHES_NEED_SPACES to control which options
628 require spaces between the option and the argument. */
629 #ifndef SWITCHES_NEED_SPACES
630 #define SWITCHES_NEED_SPACES ""
631 #endif
633 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
634 #ifndef ENDFILE_SPEC
635 #define ENDFILE_SPEC ""
636 #endif
638 #ifndef LINKER_NAME
639 #define LINKER_NAME "collect2"
640 #endif
642 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
643 to the assembler. */
644 #ifndef ASM_DEBUG_SPEC
645 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
646 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
647 # define ASM_DEBUG_SPEC \
648 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
649 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
650 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
651 # else
652 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
653 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
654 # endif
655 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
656 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
657 # endif
658 # endif
659 #endif
660 #ifndef ASM_DEBUG_SPEC
661 # define ASM_DEBUG_SPEC ""
662 #endif
664 /* Here is the spec for running the linker, after compiling all files. */
666 /* This is overridable by the target in case they need to specify the
667 -lgcc and -lc order specially, yet not require them to override all
668 of LINK_COMMAND_SPEC. */
669 #ifndef LINK_GCC_C_SEQUENCE_SPEC
670 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
671 #endif
673 #ifndef LINK_SSP_SPEC
674 #ifdef TARGET_LIBC_PROVIDES_SSP
675 #define LINK_SSP_SPEC "%{fstack-protector:}"
676 #else
677 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
678 #endif
679 #endif
681 #ifndef LINK_PIE_SPEC
682 #ifdef HAVE_LD_PIE
683 #define LINK_PIE_SPEC "%{pie:-pie} "
684 #else
685 #define LINK_PIE_SPEC "%{pie:} "
686 #endif
687 #endif
689 /* -u* was put back because both BSD and SysV seem to support it. */
690 /* %{static:} simply prevents an error message if the target machine
691 doesn't handle -static. */
692 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
693 scripts which exist in user specified directories, or in standard
694 directories. */
695 #ifndef LINK_COMMAND_SPEC
696 #define LINK_COMMAND_SPEC "\
697 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
698 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
699 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
700 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o %(mflib)\
701 %{fprofile-arcs|fprofile-generate|coverage:-lgcov}\
702 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
703 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
704 #endif
706 #ifndef LINK_LIBGCC_SPEC
707 /* Generate -L options for startfile prefix list. */
708 # define LINK_LIBGCC_SPEC "%D"
709 #endif
711 #ifndef STARTFILE_PREFIX_SPEC
712 # define STARTFILE_PREFIX_SPEC ""
713 #endif
715 #ifndef SYSROOT_SPEC
716 # define SYSROOT_SPEC "--sysroot=%R"
717 #endif
719 #ifndef SYSROOT_SUFFIX_SPEC
720 # define SYSROOT_SUFFIX_SPEC ""
721 #endif
723 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
724 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
725 #endif
727 static const char *asm_debug;
728 static const char *cpp_spec = CPP_SPEC;
729 static const char *cc1_spec = CC1_SPEC;
730 static const char *cc1plus_spec = CC1PLUS_SPEC;
731 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
732 static const char *link_ssp_spec = LINK_SSP_SPEC;
733 static const char *asm_spec = ASM_SPEC;
734 static const char *asm_final_spec = ASM_FINAL_SPEC;
735 static const char *link_spec = LINK_SPEC;
736 static const char *lib_spec = LIB_SPEC;
737 static const char *mfwrap_spec = MFWRAP_SPEC;
738 static const char *mflib_spec = MFLIB_SPEC;
739 static const char *libgcc_spec = LIBGCC_SPEC;
740 static const char *endfile_spec = ENDFILE_SPEC;
741 static const char *startfile_spec = STARTFILE_SPEC;
742 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
743 static const char *linker_name_spec = LINKER_NAME;
744 static const char *link_command_spec = LINK_COMMAND_SPEC;
745 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
746 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
747 static const char *sysroot_spec = SYSROOT_SPEC;
748 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
749 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
751 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
752 There should be no need to override these in target dependent files,
753 but we need to copy them to the specs file so that newer versions
754 of the GCC driver can correctly drive older tool chains with the
755 appropriate -B options. */
757 /* When cpplib handles traditional preprocessing, get rid of this, and
758 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
759 that we default the front end language better. */
760 static const char *trad_capable_cpp =
761 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
763 /* We don't wrap .d files in %W{} since a missing .d file, and
764 therefore no dependency entry, confuses make into thinking a .o
765 file that happens to exist is up-to-date. */
766 static const char *cpp_unique_options =
767 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
768 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
769 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
770 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
771 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
772 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
773 %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
774 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
775 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
776 %{E|M|MM:%W{o*}}";
778 /* This contains cpp options which are common with cc1_options and are passed
779 only when preprocessing only to avoid duplication. We pass the cc1 spec
780 options to the preprocessor so that it the cc1 spec may manipulate
781 options used to set target flags. Those special target flags settings may
782 in turn cause preprocessor symbols to be defined specially. */
783 static const char *cpp_options =
784 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
785 %{f*} %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*}\
786 %{undef} %{save-temps:-fpch-preprocess}";
788 /* This contains cpp options which are not passed when the preprocessor
789 output will be used by another program. */
790 static const char *cpp_debug_options = "%{d*}";
792 /* NB: This is shared amongst all front-ends. */
793 static const char *cc1_options =
794 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
795 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
796 %{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}%{!c:%{!S:-auxbase %b}}\
797 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
798 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
799 %{Qn:-fno-ident} %{--help:--help}\
800 %{--target-help:--target-help}\
801 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
802 %{fsyntax-only:-o %j} %{-param*}\
803 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
804 %{coverage:-fprofile-arcs -ftest-coverage}";
806 static const char *asm_options =
807 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
809 static const char *invoke_as =
810 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
811 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
812 #else
813 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
814 #endif
816 /* Some compilers have limits on line lengths, and the multilib_select
817 and/or multilib_matches strings can be very long, so we build them at
818 run time. */
819 static struct obstack multilib_obstack;
820 static const char *multilib_select;
821 static const char *multilib_matches;
822 static const char *multilib_defaults;
823 static const char *multilib_exclusions;
825 /* Check whether a particular argument is a default argument. */
827 #ifndef MULTILIB_DEFAULTS
828 #define MULTILIB_DEFAULTS { "" }
829 #endif
831 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
833 #ifndef DRIVER_SELF_SPECS
834 #define DRIVER_SELF_SPECS ""
835 #endif
837 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
839 #ifndef OPTION_DEFAULT_SPECS
840 #define OPTION_DEFAULT_SPECS { "", "" }
841 #endif
843 struct default_spec
845 const char *name;
846 const char *spec;
849 static const struct default_spec
850 option_default_specs[] = { OPTION_DEFAULT_SPECS };
852 struct user_specs
854 struct user_specs *next;
855 const char *filename;
858 static struct user_specs *user_specs_head, *user_specs_tail;
860 #ifndef SWITCH_TAKES_ARG
861 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
862 #endif
864 #ifndef WORD_SWITCH_TAKES_ARG
865 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
866 #endif
868 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
869 /* This defines which switches stop a full compilation. */
870 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
871 ((CHAR) == 'c' || (CHAR) == 'S')
873 #ifndef SWITCH_CURTAILS_COMPILATION
874 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
875 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
876 #endif
877 #endif
879 /* Record the mapping from file suffixes for compilation specs. */
881 struct compiler
883 const char *suffix; /* Use this compiler for input files
884 whose names end in this suffix. */
886 const char *spec; /* To use this compiler, run this spec. */
888 const char *cpp_spec; /* If non-NULL, substitute this spec
889 for `%C', rather than the usual
890 cpp_spec. */
891 const int combinable; /* If nonzero, compiler can deal with
892 multiple source files at once (IMA). */
893 const int needs_preprocessing; /* If nonzero, source files need to
894 be run through a preprocessor. */
897 /* Pointer to a vector of `struct compiler' that gives the spec for
898 compiling a file, based on its suffix.
899 A file that does not end in any of these suffixes will be passed
900 unchanged to the loader and nothing else will be done to it.
902 An entry containing two 0s is used to terminate the vector.
904 If multiple entries match a file, the last matching one is used. */
906 static struct compiler *compilers;
908 /* Number of entries in `compilers', not counting the null terminator. */
910 static int n_compilers;
912 /* The default list of file name suffixes and their compilation specs. */
914 static const struct compiler default_compilers[] =
916 /* Add lists of suffixes of known languages here. If those languages
917 were not present when we built the driver, we will hit these copies
918 and be given a more meaningful error than "file not used since
919 linking is not done". */
920 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
921 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
922 {".mii", "#Objective-C++", 0, 0, 0},
923 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
924 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
925 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
926 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
927 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
928 {".f", "#Fortran", 0, 0, 0}, {".for", "#Fortran", 0, 0, 0},
929 {".fpp", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
930 {".FOR", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
931 {".f90", "#Fortran", 0, 0, 0}, {".f95", "#Fortran", 0, 0, 0},
932 {".F90", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
933 {".r", "#Ratfor", 0, 0, 0},
934 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
935 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
936 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
937 /* Next come the entries for C. */
938 {".c", "@c", 0, 1, 1},
939 {"@c",
940 /* cc1 has an integrated ISO C preprocessor. We should invoke the
941 external preprocessor if -save-temps is given. */
942 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
943 %{!E:%{!M:%{!MM:\
944 %{traditional|ftraditional:\
945 %eGNU C no longer supports -traditional without -E}\
946 %{!combine:\
947 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
948 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
949 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
950 %(cc1_options)}\
951 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
952 cc1 %(cpp_unique_options) %(cc1_options)}}}\
953 %{!fsyntax-only:%(invoke_as)}} \
954 %{combine:\
955 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
956 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i}}\
957 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
958 cc1 %(cpp_unique_options) %(cc1_options)}}\
959 %{!fsyntax-only:%(invoke_as)}}}}}}", 0, 1, 1},
960 {"-",
961 "%{!E:%e-E or -x required when input is from standard input}\
962 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
963 {".h", "@c-header", 0, 0, 0},
964 {"@c-header",
965 /* cc1 has an integrated ISO C preprocessor. We should invoke the
966 external preprocessor if -save-temps is given. */
967 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
968 %{!E:%{!M:%{!MM:\
969 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
970 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
971 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
972 %(cc1_options)\
973 -o %g.s %{!o*:--output-pch=%i.gch}\
974 %W{o*:--output-pch=%*}%V}\
975 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
976 cc1 %(cpp_unique_options) %(cc1_options)\
977 -o %g.s %{!o*:--output-pch=%i.gch}\
978 %W{o*:--output-pch=%*}%V}}}}}}", 0, 0, 0},
979 {".i", "@cpp-output", 0, 1, 0},
980 {"@cpp-output",
981 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
982 {".s", "@assembler", 0, 1, 0},
983 {"@assembler",
984 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
985 {".S", "@assembler-with-cpp", 0, 1, 0},
986 {"@assembler-with-cpp",
987 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
988 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
989 %{E|M|MM:%(cpp_debug_options)}\
990 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
991 as %(asm_debug) %(asm_options) %|.s %A }}}}"
992 #else
993 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
994 %{E|M|MM:%(cpp_debug_options)}\
995 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
996 as %(asm_debug) %(asm_options) %m.s %A }}}}"
997 #endif
998 , 0, 1, 0},
1000 #include "specs.h"
1001 /* Mark end of table. */
1002 {0, 0, 0, 0, 0}
1005 /* Number of elements in default_compilers, not counting the terminator. */
1007 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1009 /* A vector of options to give to the linker.
1010 These options are accumulated by %x,
1011 and substituted into the linker command with %X. */
1012 static int n_linker_options;
1013 static char **linker_options;
1015 /* A vector of options to give to the assembler.
1016 These options are accumulated by -Wa,
1017 and substituted into the assembler command with %Y. */
1018 static int n_assembler_options;
1019 static char **assembler_options;
1021 /* A vector of options to give to the preprocessor.
1022 These options are accumulated by -Wp,
1023 and substituted into the preprocessor command with %Z. */
1024 static int n_preprocessor_options;
1025 static char **preprocessor_options;
1027 /* Define how to map long options into short ones. */
1029 /* This structure describes one mapping. */
1030 struct option_map
1032 /* The long option's name. */
1033 const char *const name;
1034 /* The equivalent short option. */
1035 const char *const equivalent;
1036 /* Argument info. A string of flag chars; NULL equals no options.
1037 a => argument required.
1038 o => argument optional.
1039 j => join argument to equivalent, making one word.
1040 * => require other text after NAME as an argument. */
1041 const char *const arg_info;
1044 /* This is the table of mappings. Mappings are tried sequentially
1045 for each option encountered; the first one that matches, wins. */
1047 static const struct option_map option_map[] =
1049 {"--all-warnings", "-Wall", 0},
1050 {"--ansi", "-ansi", 0},
1051 {"--assemble", "-S", 0},
1052 {"--assert", "-A", "a"},
1053 {"--classpath", "-fclasspath=", "aj"},
1054 {"--bootclasspath", "-fbootclasspath=", "aj"},
1055 {"--CLASSPATH", "-fclasspath=", "aj"},
1056 {"--combine", "-combine", 0},
1057 {"--comments", "-C", 0},
1058 {"--comments-in-macros", "-CC", 0},
1059 {"--compile", "-c", 0},
1060 {"--debug", "-g", "oj"},
1061 {"--define-macro", "-D", "aj"},
1062 {"--dependencies", "-M", 0},
1063 {"--dump", "-d", "a"},
1064 {"--dumpbase", "-dumpbase", "a"},
1065 {"--encoding", "-fencoding=", "aj"},
1066 {"--entry", "-e", 0},
1067 {"--extra-warnings", "-W", 0},
1068 {"--extdirs", "-fextdirs=", "aj"},
1069 {"--for-assembler", "-Wa", "a"},
1070 {"--for-linker", "-Xlinker", "a"},
1071 {"--force-link", "-u", "a"},
1072 {"--coverage", "-coverage", 0},
1073 {"--imacros", "-imacros", "a"},
1074 {"--include", "-include", "a"},
1075 {"--include-barrier", "-I-", 0},
1076 {"--include-directory", "-I", "aj"},
1077 {"--include-directory-after", "-idirafter", "a"},
1078 {"--include-prefix", "-iprefix", "a"},
1079 {"--include-with-prefix", "-iwithprefix", "a"},
1080 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1081 {"--include-with-prefix-after", "-iwithprefix", "a"},
1082 {"--language", "-x", "a"},
1083 {"--library-directory", "-L", "a"},
1084 {"--machine", "-m", "aj"},
1085 {"--machine-", "-m", "*j"},
1086 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1087 {"--no-line-commands", "-P", 0},
1088 {"--no-precompiled-includes", "-noprecomp", 0},
1089 {"--no-standard-includes", "-nostdinc", 0},
1090 {"--no-standard-libraries", "-nostdlib", 0},
1091 {"--no-warnings", "-w", 0},
1092 {"--optimize", "-O", "oj"},
1093 {"--output", "-o", "a"},
1094 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1095 {"--param", "--param", "a"},
1096 {"--pass-exit-codes", "-pass-exit-codes", 0},
1097 {"--pedantic", "-pedantic", 0},
1098 {"--pedantic-errors", "-pedantic-errors", 0},
1099 {"--pie", "-pie", 0},
1100 {"--pipe", "-pipe", 0},
1101 {"--prefix", "-B", "a"},
1102 {"--preprocess", "-E", 0},
1103 {"--print-search-dirs", "-print-search-dirs", 0},
1104 {"--print-file-name", "-print-file-name=", "aj"},
1105 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1106 {"--print-missing-file-dependencies", "-MG", 0},
1107 {"--print-multi-lib", "-print-multi-lib", 0},
1108 {"--print-multi-directory", "-print-multi-directory", 0},
1109 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1110 {"--print-prog-name", "-print-prog-name=", "aj"},
1111 {"--profile", "-p", 0},
1112 {"--profile-blocks", "-a", 0},
1113 {"--quiet", "-q", 0},
1114 {"--resource", "-fcompile-resource=", "aj"},
1115 {"--save-temps", "-save-temps", 0},
1116 {"--shared", "-shared", 0},
1117 {"--silent", "-q", 0},
1118 {"--specs", "-specs=", "aj"},
1119 {"--static", "-static", 0},
1120 {"--std", "-std=", "aj"},
1121 {"--symbolic", "-symbolic", 0},
1122 {"--sysroot", "--sysroot=", "aj"},
1123 {"--time", "-time", 0},
1124 {"--trace-includes", "-H", 0},
1125 {"--traditional", "-traditional", 0},
1126 {"--traditional-cpp", "-traditional-cpp", 0},
1127 {"--trigraphs", "-trigraphs", 0},
1128 {"--undefine-macro", "-U", "aj"},
1129 {"--user-dependencies", "-MM", 0},
1130 {"--verbose", "-v", 0},
1131 {"--warn-", "-W", "*j"},
1132 {"--write-dependencies", "-MD", 0},
1133 {"--write-user-dependencies", "-MMD", 0},
1134 {"--", "-f", "*j"}
1138 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1139 static const struct {
1140 const char *const option_found;
1141 const char *const replacements;
1142 } target_option_translations[] =
1144 TARGET_OPTION_TRANSLATE_TABLE,
1145 { 0, 0 }
1147 #endif
1149 /* Translate the options described by *ARGCP and *ARGVP.
1150 Make a new vector and store it back in *ARGVP,
1151 and store its length in *ARGVC. */
1153 static void
1154 translate_options (int *argcp, const char *const **argvp)
1156 int i;
1157 int argc = *argcp;
1158 const char *const *argv = *argvp;
1159 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1160 const char **newv = xmalloc (newvsize);
1161 int newindex = 0;
1163 i = 0;
1164 newv[newindex++] = argv[i++];
1166 while (i < argc)
1168 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1169 int tott_idx;
1171 for (tott_idx = 0;
1172 target_option_translations[tott_idx].option_found;
1173 tott_idx++)
1175 if (strcmp (target_option_translations[tott_idx].option_found,
1176 argv[i]) == 0)
1178 int spaces = 1;
1179 const char *sp;
1180 char *np;
1182 for (sp = target_option_translations[tott_idx].replacements;
1183 *sp; sp++)
1185 if (*sp == ' ')
1186 spaces ++;
1189 newvsize += spaces * sizeof (const char *);
1190 newv = xrealloc (newv, newvsize);
1192 sp = target_option_translations[tott_idx].replacements;
1193 np = xstrdup (sp);
1195 while (1)
1197 while (*np == ' ')
1198 np++;
1199 if (*np == 0)
1200 break;
1201 newv[newindex++] = np;
1202 while (*np != ' ' && *np)
1203 np++;
1204 if (*np == 0)
1205 break;
1206 *np++ = 0;
1209 i ++;
1210 break;
1213 if (target_option_translations[tott_idx].option_found)
1214 continue;
1215 #endif
1217 /* Translate -- options. */
1218 if (argv[i][0] == '-' && argv[i][1] == '-')
1220 size_t j;
1221 /* Find a mapping that applies to this option. */
1222 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1224 size_t optlen = strlen (option_map[j].name);
1225 size_t arglen = strlen (argv[i]);
1226 size_t complen = arglen > optlen ? optlen : arglen;
1227 const char *arginfo = option_map[j].arg_info;
1229 if (arginfo == 0)
1230 arginfo = "";
1232 if (!strncmp (argv[i], option_map[j].name, complen))
1234 const char *arg = 0;
1236 if (arglen < optlen)
1238 size_t k;
1239 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1240 if (strlen (option_map[k].name) >= arglen
1241 && !strncmp (argv[i], option_map[k].name, arglen))
1243 error ("ambiguous abbreviation %s", argv[i]);
1244 break;
1247 if (k != ARRAY_SIZE (option_map))
1248 break;
1251 if (arglen > optlen)
1253 /* If the option has an argument, accept that. */
1254 if (argv[i][optlen] == '=')
1255 arg = argv[i] + optlen + 1;
1257 /* If this mapping requires extra text at end of name,
1258 accept that as "argument". */
1259 else if (strchr (arginfo, '*') != 0)
1260 arg = argv[i] + optlen;
1262 /* Otherwise, extra text at end means mismatch.
1263 Try other mappings. */
1264 else
1265 continue;
1268 else if (strchr (arginfo, '*') != 0)
1270 error ("incomplete '%s' option", option_map[j].name);
1271 break;
1274 /* Handle arguments. */
1275 if (strchr (arginfo, 'a') != 0)
1277 if (arg == 0)
1279 if (i + 1 == argc)
1281 error ("missing argument to '%s' option",
1282 option_map[j].name);
1283 break;
1286 arg = argv[++i];
1289 else if (strchr (arginfo, '*') != 0)
1291 else if (strchr (arginfo, 'o') == 0)
1293 if (arg != 0)
1294 error ("extraneous argument to '%s' option",
1295 option_map[j].name);
1296 arg = 0;
1299 /* Store the translation as one argv elt or as two. */
1300 if (arg != 0 && strchr (arginfo, 'j') != 0)
1301 newv[newindex++] = concat (option_map[j].equivalent, arg,
1302 NULL);
1303 else if (arg != 0)
1305 newv[newindex++] = option_map[j].equivalent;
1306 newv[newindex++] = arg;
1308 else
1309 newv[newindex++] = option_map[j].equivalent;
1311 break;
1314 i++;
1317 /* Handle old-fashioned options--just copy them through,
1318 with their arguments. */
1319 else if (argv[i][0] == '-')
1321 const char *p = argv[i] + 1;
1322 int c = *p;
1323 int nskip = 1;
1325 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1326 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1327 else if (WORD_SWITCH_TAKES_ARG (p))
1328 nskip += WORD_SWITCH_TAKES_ARG (p);
1329 else if ((c == 'B' || c == 'b' || c == 'x')
1330 && p[1] == 0)
1331 nskip += 1;
1332 else if (! strcmp (p, "Xlinker"))
1333 nskip += 1;
1334 else if (! strcmp (p, "Xpreprocessor"))
1335 nskip += 1;
1336 else if (! strcmp (p, "Xassembler"))
1337 nskip += 1;
1339 /* Watch out for an option at the end of the command line that
1340 is missing arguments, and avoid skipping past the end of the
1341 command line. */
1342 if (nskip + i > argc)
1343 nskip = argc - i;
1345 while (nskip > 0)
1347 newv[newindex++] = argv[i++];
1348 nskip--;
1351 else
1352 /* Ordinary operands, or +e options. */
1353 newv[newindex++] = argv[i++];
1356 newv[newindex] = 0;
1358 *argvp = newv;
1359 *argcp = newindex;
1362 static char *
1363 skip_whitespace (char *p)
1365 while (1)
1367 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1368 be considered whitespace. */
1369 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1370 return p + 1;
1371 else if (*p == '\n' || *p == ' ' || *p == '\t')
1372 p++;
1373 else if (*p == '#')
1375 while (*p != '\n')
1376 p++;
1377 p++;
1379 else
1380 break;
1383 return p;
1385 /* Structures to keep track of prefixes to try when looking for files. */
1387 struct prefix_list
1389 const char *prefix; /* String to prepend to the path. */
1390 struct prefix_list *next; /* Next in linked list. */
1391 int require_machine_suffix; /* Don't use without machine_suffix. */
1392 /* 2 means try both machine_suffix and just_machine_suffix. */
1393 int priority; /* Sort key - priority within list. */
1394 int os_multilib; /* 1 if OS multilib scheme should be used,
1395 0 for GCC multilib scheme. */
1398 struct path_prefix
1400 struct prefix_list *plist; /* List of prefixes to try */
1401 int max_len; /* Max length of a prefix in PLIST */
1402 const char *name; /* Name of this list (used in config stuff) */
1405 /* List of prefixes to try when looking for executables. */
1407 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1409 /* List of prefixes to try when looking for startup (crt0) files. */
1411 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1413 /* List of prefixes to try when looking for include files. */
1415 static struct path_prefix include_prefixes = { 0, 0, "include" };
1417 /* Suffix to attach to directories searched for commands.
1418 This looks like `MACHINE/VERSION/'. */
1420 static const char *machine_suffix = 0;
1422 /* Suffix to attach to directories searched for commands.
1423 This is just `MACHINE/'. */
1425 static const char *just_machine_suffix = 0;
1427 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1429 static const char *gcc_exec_prefix;
1431 /* Adjusted value of standard_libexec_prefix. */
1433 static const char *gcc_libexec_prefix;
1435 /* Default prefixes to attach to command names. */
1437 #ifndef STANDARD_STARTFILE_PREFIX_1
1438 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1439 #endif
1440 #ifndef STANDARD_STARTFILE_PREFIX_2
1441 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1442 #endif
1444 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1445 #undef MD_EXEC_PREFIX
1446 #undef MD_STARTFILE_PREFIX
1447 #undef MD_STARTFILE_PREFIX_1
1448 #endif
1450 /* If no prefixes defined, use the null string, which will disable them. */
1451 #ifndef MD_EXEC_PREFIX
1452 #define MD_EXEC_PREFIX ""
1453 #endif
1454 #ifndef MD_STARTFILE_PREFIX
1455 #define MD_STARTFILE_PREFIX ""
1456 #endif
1457 #ifndef MD_STARTFILE_PREFIX_1
1458 #define MD_STARTFILE_PREFIX_1 ""
1459 #endif
1461 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1462 static const char *const standard_exec_prefix_1 = "/usr/libexec/gcc/";
1463 static const char *const standard_exec_prefix_2 = "/usr/lib/gcc/";
1464 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1466 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1467 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1468 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1469 static const char *const standard_startfile_prefix_1
1470 = STANDARD_STARTFILE_PREFIX_1;
1471 static const char *const standard_startfile_prefix_2
1472 = STANDARD_STARTFILE_PREFIX_2;
1474 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1475 static const char *tooldir_prefix;
1477 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1479 static const char *standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1481 /* Subdirectory to use for locating libraries. Set by
1482 set_multilib_dir based on the compilation options. */
1484 static const char *multilib_dir;
1486 /* Subdirectory to use for locating libraries in OS conventions. Set by
1487 set_multilib_dir based on the compilation options. */
1489 static const char *multilib_os_dir;
1491 /* Structure to keep track of the specs that have been defined so far.
1492 These are accessed using %(specname) or %[specname] in a compiler
1493 or link spec. */
1495 struct spec_list
1497 /* The following 2 fields must be first */
1498 /* to allow EXTRA_SPECS to be initialized */
1499 const char *name; /* name of the spec. */
1500 const char *ptr; /* available ptr if no static pointer */
1502 /* The following fields are not initialized */
1503 /* by EXTRA_SPECS */
1504 const char **ptr_spec; /* pointer to the spec itself. */
1505 struct spec_list *next; /* Next spec in linked list. */
1506 int name_len; /* length of the name */
1507 int alloc_p; /* whether string was allocated */
1510 #define INIT_STATIC_SPEC(NAME,PTR) \
1511 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1513 /* List of statically defined specs. */
1514 static struct spec_list static_specs[] =
1516 INIT_STATIC_SPEC ("asm", &asm_spec),
1517 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1518 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1519 INIT_STATIC_SPEC ("asm_options", &asm_options),
1520 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1521 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1522 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1523 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1524 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1525 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1526 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1527 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1528 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1529 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1530 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1531 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1532 INIT_STATIC_SPEC ("link", &link_spec),
1533 INIT_STATIC_SPEC ("lib", &lib_spec),
1534 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1535 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1536 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1537 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1538 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1539 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1540 INIT_STATIC_SPEC ("version", &compiler_version),
1541 INIT_STATIC_SPEC ("multilib", &multilib_select),
1542 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1543 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1544 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1545 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1546 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1547 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1548 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1549 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1550 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1551 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1552 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1553 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1554 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1555 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1558 #ifdef EXTRA_SPECS /* additional specs needed */
1559 /* Structure to keep track of just the first two args of a spec_list.
1560 That is all that the EXTRA_SPECS macro gives us. */
1561 struct spec_list_1
1563 const char *const name;
1564 const char *const ptr;
1567 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1568 static struct spec_list *extra_specs = (struct spec_list *) 0;
1569 #endif
1571 /* List of dynamically allocates specs that have been defined so far. */
1573 static struct spec_list *specs = (struct spec_list *) 0;
1575 /* List of static spec functions. */
1577 static const struct spec_function static_spec_functions[] =
1579 { "if-exists", if_exists_spec_function },
1580 { "if-exists-else", if_exists_else_spec_function },
1581 { "replace-outfile", replace_outfile_spec_function },
1582 { "version-compare", version_compare_spec_function },
1583 { 0, 0 }
1586 static int processing_spec_function;
1588 /* Add appropriate libgcc specs to OBSTACK, taking into account
1589 various permutations of -shared-libgcc, -shared, and such. */
1591 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1593 #ifndef USE_LD_AS_NEEDED
1594 #define USE_LD_AS_NEEDED 0
1595 #endif
1597 static void
1598 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1599 const char *static_name, const char *eh_name)
1601 char *buf;
1603 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1604 "}%{!static:%{!static-libgcc:",
1605 #if USE_LD_AS_NEEDED
1606 "%{!shared-libgcc:", static_name,
1607 " --as-needed ", shared_name, " --no-as-needed}"
1608 "%{shared-libgcc:", shared_name, "%{!shared: ", static_name,
1609 "}",
1610 #else
1611 "%{!shared:%{!shared-libgcc:", static_name, " ",
1612 eh_name, "}%{shared-libgcc:", shared_name, " ",
1613 static_name, "}}%{shared:",
1614 #ifdef LINK_EH_SPEC
1615 "%{shared-libgcc:", shared_name,
1616 "}%{!shared-libgcc:", static_name, "}",
1617 #else
1618 shared_name,
1619 #endif
1620 #endif
1621 "}}}", NULL);
1623 obstack_grow (obstack, buf, strlen (buf));
1624 free (buf);
1626 #endif /* ENABLE_SHARED_LIBGCC */
1628 /* Initialize the specs lookup routines. */
1630 static void
1631 init_spec (void)
1633 struct spec_list *next = (struct spec_list *) 0;
1634 struct spec_list *sl = (struct spec_list *) 0;
1635 int i;
1637 if (specs)
1638 return; /* Already initialized. */
1640 if (verbose_flag)
1641 notice ("Using built-in specs.\n");
1643 #ifdef EXTRA_SPECS
1644 extra_specs = xcalloc (sizeof (struct spec_list),
1645 ARRAY_SIZE (extra_specs_1));
1647 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1649 sl = &extra_specs[i];
1650 sl->name = extra_specs_1[i].name;
1651 sl->ptr = extra_specs_1[i].ptr;
1652 sl->next = next;
1653 sl->name_len = strlen (sl->name);
1654 sl->ptr_spec = &sl->ptr;
1655 next = sl;
1657 #endif
1659 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1660 on ?: in file-scope variable initializations. */
1661 asm_debug = ASM_DEBUG_SPEC;
1663 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1665 sl = &static_specs[i];
1666 sl->next = next;
1667 next = sl;
1670 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1671 /* ??? If neither -shared-libgcc nor --static-libgcc was
1672 seen, then we should be making an educated guess. Some proposed
1673 heuristics for ELF include:
1675 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1676 program will be doing dynamic loading, which will likely
1677 need the shared libgcc.
1679 (2) If "-ldl", then it's also a fair bet that we're doing
1680 dynamic loading.
1682 (3) For each ET_DYN we're linking against (either through -lfoo
1683 or /some/path/foo.so), check to see whether it or one of
1684 its dependencies depends on a shared libgcc.
1686 (4) If "-shared"
1688 If the runtime is fixed to look for program headers instead
1689 of calling __register_frame_info at all, for each object,
1690 use the shared libgcc if any EH symbol referenced.
1692 If crtstuff is fixed to not invoke __register_frame_info
1693 automatically, for each object, use the shared libgcc if
1694 any non-empty unwind section found.
1696 Doing any of this probably requires invoking an external program to
1697 do the actual object file scanning. */
1699 const char *p = libgcc_spec;
1700 int in_sep = 1;
1702 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1703 when given the proper command line arguments. */
1704 while (*p)
1706 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1708 init_gcc_specs (&obstack,
1709 "-lgcc_s"
1710 #ifdef USE_LIBUNWIND_EXCEPTIONS
1711 " -lunwind"
1712 #endif
1714 "-lgcc",
1715 "-lgcc_eh"
1716 #ifdef USE_LIBUNWIND_EXCEPTIONS
1717 # ifdef HAVE_LD_STATIC_DYNAMIC
1718 " %{!static:-Bstatic} -lunwind %{!static:-Bdynamic}"
1719 # else
1720 " -lunwind"
1721 # endif
1722 #endif
1725 p += 5;
1726 in_sep = 0;
1728 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1730 /* Ug. We don't know shared library extensions. Hope that
1731 systems that use this form don't do shared libraries. */
1732 init_gcc_specs (&obstack,
1733 "-lgcc_s",
1734 "libgcc.a%s",
1735 "libgcc_eh.a%s"
1736 #ifdef USE_LIBUNWIND_EXCEPTIONS
1737 " -lunwind"
1738 #endif
1740 p += 10;
1741 in_sep = 0;
1743 else
1745 obstack_1grow (&obstack, *p);
1746 in_sep = (*p == ' ');
1747 p += 1;
1751 obstack_1grow (&obstack, '\0');
1752 libgcc_spec = XOBFINISH (&obstack, const char *);
1754 #endif
1755 #ifdef USE_AS_TRADITIONAL_FORMAT
1756 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1758 static const char tf[] = "--traditional-format ";
1759 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1760 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1761 asm_spec = XOBFINISH (&obstack, const char *);
1763 #endif
1764 #ifdef LINK_EH_SPEC
1765 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1766 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1767 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1768 link_spec = XOBFINISH (&obstack, const char *);
1769 #endif
1771 specs = sl;
1774 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1775 removed; If the spec starts with a + then SPEC is added to the end of the
1776 current spec. */
1778 static void
1779 set_spec (const char *name, const char *spec)
1781 struct spec_list *sl;
1782 const char *old_spec;
1783 int name_len = strlen (name);
1784 int i;
1786 /* If this is the first call, initialize the statically allocated specs. */
1787 if (!specs)
1789 struct spec_list *next = (struct spec_list *) 0;
1790 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1792 sl = &static_specs[i];
1793 sl->next = next;
1794 next = sl;
1796 specs = sl;
1799 /* See if the spec already exists. */
1800 for (sl = specs; sl; sl = sl->next)
1801 if (name_len == sl->name_len && !strcmp (sl->name, name))
1802 break;
1804 if (!sl)
1806 /* Not found - make it. */
1807 sl = xmalloc (sizeof (struct spec_list));
1808 sl->name = xstrdup (name);
1809 sl->name_len = name_len;
1810 sl->ptr_spec = &sl->ptr;
1811 sl->alloc_p = 0;
1812 *(sl->ptr_spec) = "";
1813 sl->next = specs;
1814 specs = sl;
1817 old_spec = *(sl->ptr_spec);
1818 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1819 ? concat (old_spec, spec + 1, NULL)
1820 : xstrdup (spec));
1822 #ifdef DEBUG_SPECS
1823 if (verbose_flag)
1824 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1825 #endif
1827 /* Free the old spec. */
1828 if (old_spec && sl->alloc_p)
1829 free ((void *) old_spec);
1831 sl->alloc_p = 1;
1834 /* Accumulate a command (program name and args), and run it. */
1836 /* Vector of pointers to arguments in the current line of specifications. */
1838 static const char **argbuf;
1840 /* Number of elements allocated in argbuf. */
1842 static int argbuf_length;
1844 /* Number of elements in argbuf currently in use (containing args). */
1846 static int argbuf_index;
1848 /* Position in the argbuf array containing the name of the output file
1849 (the value associated with the "-o" flag). */
1851 static int have_o_argbuf_index = 0;
1853 /* Were the options -c or -S passed. */
1854 static int have_c = 0;
1856 /* Was the option -o passed. */
1857 static int have_o = 0;
1859 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1860 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1861 it here. */
1863 static struct temp_name {
1864 const char *suffix; /* suffix associated with the code. */
1865 int length; /* strlen (suffix). */
1866 int unique; /* Indicates whether %g or %u/%U was used. */
1867 const char *filename; /* associated filename. */
1868 int filename_length; /* strlen (filename). */
1869 struct temp_name *next;
1870 } *temp_names;
1872 /* Number of commands executed so far. */
1874 static int execution_count;
1876 /* Number of commands that exited with a signal. */
1878 static int signal_count;
1880 /* Name with which this program was invoked. */
1882 static const char *programname;
1884 /* Allocate the argument vector. */
1886 static void
1887 alloc_args (void)
1889 argbuf_length = 10;
1890 argbuf = xmalloc (argbuf_length * sizeof (const char *));
1893 /* Clear out the vector of arguments (after a command is executed). */
1895 static void
1896 clear_args (void)
1898 argbuf_index = 0;
1901 /* Add one argument to the vector at the end.
1902 This is done when a space is seen or at the end of the line.
1903 If DELETE_ALWAYS is nonzero, the arg is a filename
1904 and the file should be deleted eventually.
1905 If DELETE_FAILURE is nonzero, the arg is a filename
1906 and the file should be deleted if this compilation fails. */
1908 static void
1909 store_arg (const char *arg, int delete_always, int delete_failure)
1911 if (argbuf_index + 1 == argbuf_length)
1912 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1914 argbuf[argbuf_index++] = arg;
1915 argbuf[argbuf_index] = 0;
1917 if (strcmp (arg, "-o") == 0)
1918 have_o_argbuf_index = argbuf_index;
1919 if (delete_always || delete_failure)
1920 record_temp_file (arg, delete_always, delete_failure);
1923 /* Load specs from a file name named FILENAME, replacing occurrences of
1924 various different types of line-endings, \r\n, \n\r and just \r, with
1925 a single \n. */
1927 static char *
1928 load_specs (const char *filename)
1930 int desc;
1931 int readlen;
1932 struct stat statbuf;
1933 char *buffer;
1934 char *buffer_p;
1935 char *specs;
1936 char *specs_p;
1938 if (verbose_flag)
1939 notice ("Reading specs from %s\n", filename);
1941 /* Open and stat the file. */
1942 desc = open (filename, O_RDONLY, 0);
1943 if (desc < 0)
1944 pfatal_with_name (filename);
1945 if (stat (filename, &statbuf) < 0)
1946 pfatal_with_name (filename);
1948 /* Read contents of file into BUFFER. */
1949 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1950 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1951 if (readlen < 0)
1952 pfatal_with_name (filename);
1953 buffer[readlen] = 0;
1954 close (desc);
1956 specs = xmalloc (readlen + 1);
1957 specs_p = specs;
1958 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1960 int skip = 0;
1961 char c = *buffer_p;
1962 if (c == '\r')
1964 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1965 skip = 1;
1966 else if (*(buffer_p + 1) == '\n') /* \r\n */
1967 skip = 1;
1968 else /* \r */
1969 c = '\n';
1971 if (! skip)
1972 *specs_p++ = c;
1974 *specs_p = '\0';
1976 free (buffer);
1977 return (specs);
1980 /* Read compilation specs from a file named FILENAME,
1981 replacing the default ones.
1983 A suffix which starts with `*' is a definition for
1984 one of the machine-specific sub-specs. The "suffix" should be
1985 *asm, *cc1, *cpp, *link, *startfile, etc.
1986 The corresponding spec is stored in asm_spec, etc.,
1987 rather than in the `compilers' vector.
1989 Anything invalid in the file is a fatal error. */
1991 static void
1992 read_specs (const char *filename, int main_p)
1994 char *buffer;
1995 char *p;
1997 buffer = load_specs (filename);
1999 /* Scan BUFFER for specs, putting them in the vector. */
2000 p = buffer;
2001 while (1)
2003 char *suffix;
2004 char *spec;
2005 char *in, *out, *p1, *p2, *p3;
2007 /* Advance P in BUFFER to the next nonblank nocomment line. */
2008 p = skip_whitespace (p);
2009 if (*p == 0)
2010 break;
2012 /* Is this a special command that starts with '%'? */
2013 /* Don't allow this for the main specs file, since it would
2014 encourage people to overwrite it. */
2015 if (*p == '%' && !main_p)
2017 p1 = p;
2018 while (*p && *p != '\n')
2019 p++;
2021 /* Skip '\n'. */
2022 p++;
2024 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2025 && (p1[sizeof "%include" - 1] == ' '
2026 || p1[sizeof "%include" - 1] == '\t'))
2028 char *new_filename;
2030 p1 += sizeof ("%include");
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 read_specs (new_filename ? new_filename : p1, FALSE);
2041 continue;
2043 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2044 && (p1[sizeof "%include_noerr" - 1] == ' '
2045 || p1[sizeof "%include_noerr" - 1] == '\t'))
2047 char *new_filename;
2049 p1 += sizeof "%include_noerr";
2050 while (*p1 == ' ' || *p1 == '\t')
2051 p1++;
2053 if (*p1++ != '<' || p[-2] != '>')
2054 fatal ("specs %%include syntax malformed after %ld characters",
2055 (long) (p1 - buffer + 1));
2057 p[-2] = '\0';
2058 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
2059 if (new_filename)
2060 read_specs (new_filename, FALSE);
2061 else if (verbose_flag)
2062 notice ("could not find specs file %s\n", p1);
2063 continue;
2065 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2066 && (p1[sizeof "%rename" - 1] == ' '
2067 || p1[sizeof "%rename" - 1] == '\t'))
2069 int name_len;
2070 struct spec_list *sl;
2071 struct spec_list *newsl;
2073 /* Get original name. */
2074 p1 += sizeof "%rename";
2075 while (*p1 == ' ' || *p1 == '\t')
2076 p1++;
2078 if (! ISALPHA ((unsigned char) *p1))
2079 fatal ("specs %%rename syntax malformed after %ld characters",
2080 (long) (p1 - buffer));
2082 p2 = p1;
2083 while (*p2 && !ISSPACE ((unsigned char) *p2))
2084 p2++;
2086 if (*p2 != ' ' && *p2 != '\t')
2087 fatal ("specs %%rename syntax malformed after %ld characters",
2088 (long) (p2 - buffer));
2090 name_len = p2 - p1;
2091 *p2++ = '\0';
2092 while (*p2 == ' ' || *p2 == '\t')
2093 p2++;
2095 if (! ISALPHA ((unsigned char) *p2))
2096 fatal ("specs %%rename syntax malformed after %ld characters",
2097 (long) (p2 - buffer));
2099 /* Get new spec name. */
2100 p3 = p2;
2101 while (*p3 && !ISSPACE ((unsigned char) *p3))
2102 p3++;
2104 if (p3 != p - 1)
2105 fatal ("specs %%rename syntax malformed after %ld characters",
2106 (long) (p3 - buffer));
2107 *p3 = '\0';
2109 for (sl = specs; sl; sl = sl->next)
2110 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2111 break;
2113 if (!sl)
2114 fatal ("specs %s spec was not found to be renamed", p1);
2116 if (strcmp (p1, p2) == 0)
2117 continue;
2119 for (newsl = specs; newsl; newsl = newsl->next)
2120 if (strcmp (newsl->name, p2) == 0)
2121 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2122 filename, p1, p2);
2124 if (verbose_flag)
2126 notice ("rename spec %s to %s\n", p1, p2);
2127 #ifdef DEBUG_SPECS
2128 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2129 #endif
2132 set_spec (p2, *(sl->ptr_spec));
2133 if (sl->alloc_p)
2134 free ((void *) *(sl->ptr_spec));
2136 *(sl->ptr_spec) = "";
2137 sl->alloc_p = 0;
2138 continue;
2140 else
2141 fatal ("specs unknown %% command after %ld characters",
2142 (long) (p1 - buffer));
2145 /* Find the colon that should end the suffix. */
2146 p1 = p;
2147 while (*p1 && *p1 != ':' && *p1 != '\n')
2148 p1++;
2150 /* The colon shouldn't be missing. */
2151 if (*p1 != ':')
2152 fatal ("specs file malformed after %ld characters",
2153 (long) (p1 - buffer));
2155 /* Skip back over trailing whitespace. */
2156 p2 = p1;
2157 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2158 p2--;
2160 /* Copy the suffix to a string. */
2161 suffix = save_string (p, p2 - p);
2162 /* Find the next line. */
2163 p = skip_whitespace (p1 + 1);
2164 if (p[1] == 0)
2165 fatal ("specs file malformed after %ld characters",
2166 (long) (p - buffer));
2168 p1 = p;
2169 /* Find next blank line or end of string. */
2170 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2171 p1++;
2173 /* Specs end at the blank line and do not include the newline. */
2174 spec = save_string (p, p1 - p);
2175 p = p1;
2177 /* Delete backslash-newline sequences from the spec. */
2178 in = spec;
2179 out = spec;
2180 while (*in != 0)
2182 if (in[0] == '\\' && in[1] == '\n')
2183 in += 2;
2184 else if (in[0] == '#')
2185 while (*in && *in != '\n')
2186 in++;
2188 else
2189 *out++ = *in++;
2191 *out = 0;
2193 if (suffix[0] == '*')
2195 if (! strcmp (suffix, "*link_command"))
2196 link_command_spec = spec;
2197 else
2198 set_spec (suffix + 1, spec);
2200 else
2202 /* Add this pair to the vector. */
2203 compilers
2204 = xrealloc (compilers,
2205 (n_compilers + 2) * sizeof (struct compiler));
2207 compilers[n_compilers].suffix = suffix;
2208 compilers[n_compilers].spec = spec;
2209 n_compilers++;
2210 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2213 if (*suffix == 0)
2214 link_command_spec = spec;
2217 if (link_command_spec == 0)
2218 fatal ("spec file has no spec for linking");
2221 /* Record the names of temporary files we tell compilers to write,
2222 and delete them at the end of the run. */
2224 /* This is the common prefix we use to make temp file names.
2225 It is chosen once for each run of this program.
2226 It is substituted into a spec by %g or %j.
2227 Thus, all temp file names contain this prefix.
2228 In practice, all temp file names start with this prefix.
2230 This prefix comes from the envvar TMPDIR if it is defined;
2231 otherwise, from the P_tmpdir macro if that is defined;
2232 otherwise, in /usr/tmp or /tmp;
2233 or finally the current directory if all else fails. */
2235 static const char *temp_filename;
2237 /* Length of the prefix. */
2239 static int temp_filename_length;
2241 /* Define the list of temporary files to delete. */
2243 struct temp_file
2245 const char *name;
2246 struct temp_file *next;
2249 /* Queue of files to delete on success or failure of compilation. */
2250 static struct temp_file *always_delete_queue;
2251 /* Queue of files to delete on failure of compilation. */
2252 static struct temp_file *failure_delete_queue;
2254 /* Record FILENAME as a file to be deleted automatically.
2255 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2256 otherwise delete it in any case.
2257 FAIL_DELETE nonzero means delete it if a compilation step fails;
2258 otherwise delete it in any case. */
2260 void
2261 record_temp_file (const char *filename, int always_delete, int fail_delete)
2263 char *const name = xstrdup (filename);
2265 if (always_delete)
2267 struct temp_file *temp;
2268 for (temp = always_delete_queue; temp; temp = temp->next)
2269 if (! strcmp (name, temp->name))
2270 goto already1;
2272 temp = xmalloc (sizeof (struct temp_file));
2273 temp->next = always_delete_queue;
2274 temp->name = name;
2275 always_delete_queue = temp;
2277 already1:;
2280 if (fail_delete)
2282 struct temp_file *temp;
2283 for (temp = failure_delete_queue; temp; temp = temp->next)
2284 if (! strcmp (name, temp->name))
2285 goto already2;
2287 temp = xmalloc (sizeof (struct temp_file));
2288 temp->next = failure_delete_queue;
2289 temp->name = name;
2290 failure_delete_queue = temp;
2292 already2:;
2296 /* Delete all the temporary files whose names we previously recorded. */
2298 #ifndef DELETE_IF_ORDINARY
2299 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2300 do \
2302 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2303 if (unlink (NAME) < 0) \
2304 if (VERBOSE_FLAG) \
2305 perror_with_name (NAME); \
2306 } while (0)
2307 #endif
2309 static void
2310 delete_if_ordinary (const char *name)
2312 struct stat st;
2313 #ifdef DEBUG
2314 int i, c;
2316 printf ("Delete %s? (y or n) ", name);
2317 fflush (stdout);
2318 i = getchar ();
2319 if (i != '\n')
2320 while ((c = getchar ()) != '\n' && c != EOF)
2323 if (i == 'y' || i == 'Y')
2324 #endif /* DEBUG */
2325 DELETE_IF_ORDINARY (name, st, verbose_flag);
2328 static void
2329 delete_temp_files (void)
2331 struct temp_file *temp;
2333 for (temp = always_delete_queue; temp; temp = temp->next)
2334 delete_if_ordinary (temp->name);
2335 always_delete_queue = 0;
2338 /* Delete all the files to be deleted on error. */
2340 static void
2341 delete_failure_queue (void)
2343 struct temp_file *temp;
2345 for (temp = failure_delete_queue; temp; temp = temp->next)
2346 delete_if_ordinary (temp->name);
2349 static void
2350 clear_failure_queue (void)
2352 failure_delete_queue = 0;
2355 /* Build a list of search directories from PATHS.
2356 PREFIX is a string to prepend to the list.
2357 If CHECK_DIR_P is nonzero we ensure the directory exists.
2358 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2359 It is also used by the --print-search-dirs flag. */
2361 static char *
2362 build_search_list (struct path_prefix *paths, const char *prefix,
2363 int check_dir_p)
2365 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2366 int just_suffix_len
2367 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2368 int first_time = TRUE;
2369 struct prefix_list *pprefix;
2371 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2372 obstack_1grow (&collect_obstack, '=');
2374 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2376 int len = strlen (pprefix->prefix);
2378 if (machine_suffix
2379 && (! check_dir_p
2380 || is_directory (pprefix->prefix, machine_suffix, 0)))
2382 if (!first_time)
2383 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2385 first_time = FALSE;
2386 obstack_grow (&collect_obstack, pprefix->prefix, len);
2387 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2390 if (just_machine_suffix
2391 && pprefix->require_machine_suffix == 2
2392 && (! check_dir_p
2393 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2395 if (! first_time)
2396 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2398 first_time = FALSE;
2399 obstack_grow (&collect_obstack, pprefix->prefix, len);
2400 obstack_grow (&collect_obstack, just_machine_suffix,
2401 just_suffix_len);
2404 if (! pprefix->require_machine_suffix)
2406 if (! first_time)
2407 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2409 first_time = FALSE;
2410 obstack_grow (&collect_obstack, pprefix->prefix, len);
2414 obstack_1grow (&collect_obstack, '\0');
2415 return XOBFINISH (&collect_obstack, char *);
2418 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2419 for collect. */
2421 static void
2422 putenv_from_prefixes (struct path_prefix *paths, const char *env_var)
2424 putenv (build_search_list (paths, env_var, 1));
2427 /* Check whether NAME can be accessed in MODE. This is like access,
2428 except that it never considers directories to be executable. */
2430 static int
2431 access_check (const char *name, int mode)
2433 if (mode == X_OK)
2435 struct stat st;
2437 if (stat (name, &st) < 0
2438 || S_ISDIR (st.st_mode))
2439 return -1;
2442 return access (name, mode);
2445 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2446 access to check permissions.
2447 Return 0 if not found, otherwise return its name, allocated with malloc. */
2449 static char *
2450 find_a_file (struct path_prefix *pprefix, const char *name, int mode,
2451 int multilib)
2453 char *temp;
2454 const char *const file_suffix =
2455 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2456 struct prefix_list *pl;
2457 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2458 const char *multilib_name, *multilib_os_name;
2460 #ifdef DEFAULT_ASSEMBLER
2461 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2462 return xstrdup (DEFAULT_ASSEMBLER);
2463 #endif
2465 #ifdef DEFAULT_LINKER
2466 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2467 return xstrdup (DEFAULT_LINKER);
2468 #endif
2470 if (machine_suffix)
2471 len += strlen (machine_suffix);
2473 multilib_name = name;
2474 multilib_os_name = name;
2475 if (multilib && multilib_os_dir)
2477 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2478 int len2 = strlen (multilib_os_dir) + 1;
2480 len += len1 > len2 ? len1 : len2;
2481 if (multilib_dir)
2482 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2483 NULL));
2484 if (strcmp (multilib_os_dir, ".") != 0)
2485 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2486 NULL));
2489 temp = xmalloc (len);
2491 /* Determine the filename to execute (special case for absolute paths). */
2493 if (IS_ABSOLUTE_PATH (name))
2495 if (access (name, mode) == 0)
2497 strcpy (temp, name);
2498 return temp;
2501 else
2502 for (pl = pprefix->plist; pl; pl = pl->next)
2504 const char *this_name
2505 = pl->os_multilib ? multilib_os_name : multilib_name;
2507 if (machine_suffix)
2509 /* Some systems have a suffix for executable files.
2510 So try appending that first. */
2511 if (file_suffix[0] != 0)
2513 strcpy (temp, pl->prefix);
2514 strcat (temp, machine_suffix);
2515 strcat (temp, multilib_name);
2516 strcat (temp, file_suffix);
2517 if (access_check (temp, mode) == 0)
2518 return temp;
2521 /* Now try just the multilib_name. */
2522 strcpy (temp, pl->prefix);
2523 strcat (temp, machine_suffix);
2524 strcat (temp, multilib_name);
2525 if (access_check (temp, mode) == 0)
2526 return temp;
2529 /* Certain prefixes are tried with just the machine type,
2530 not the version. This is used for finding as, ld, etc. */
2531 if (just_machine_suffix && pl->require_machine_suffix == 2)
2533 /* Some systems have a suffix for executable files.
2534 So try appending that first. */
2535 if (file_suffix[0] != 0)
2537 strcpy (temp, pl->prefix);
2538 strcat (temp, just_machine_suffix);
2539 strcat (temp, multilib_name);
2540 strcat (temp, file_suffix);
2541 if (access_check (temp, mode) == 0)
2542 return temp;
2545 strcpy (temp, pl->prefix);
2546 strcat (temp, just_machine_suffix);
2547 strcat (temp, multilib_name);
2548 if (access_check (temp, mode) == 0)
2549 return temp;
2552 /* Certain prefixes can't be used without the machine suffix
2553 when the machine or version is explicitly specified. */
2554 if (! pl->require_machine_suffix)
2556 /* Some systems have a suffix for executable files.
2557 So try appending that first. */
2558 if (file_suffix[0] != 0)
2560 strcpy (temp, pl->prefix);
2561 strcat (temp, this_name);
2562 strcat (temp, file_suffix);
2563 if (access_check (temp, mode) == 0)
2564 return temp;
2567 strcpy (temp, pl->prefix);
2568 strcat (temp, this_name);
2569 if (access_check (temp, mode) == 0)
2570 return temp;
2574 free (temp);
2575 return 0;
2578 /* Ranking of prefixes in the sort list. -B prefixes are put before
2579 all others. */
2581 enum path_prefix_priority
2583 PREFIX_PRIORITY_B_OPT,
2584 PREFIX_PRIORITY_LAST
2587 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2588 order according to PRIORITY. Within each PRIORITY, new entries are
2589 appended.
2591 If WARN is nonzero, we will warn if no file is found
2592 through this prefix. WARN should point to an int
2593 which will be set to 1 if this entry is used.
2595 COMPONENT is the value to be passed to update_path.
2597 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2598 the complete value of machine_suffix.
2599 2 means try both machine_suffix and just_machine_suffix. */
2601 static void
2602 add_prefix (struct path_prefix *pprefix, const char *prefix,
2603 const char *component, /* enum prefix_priority */ int priority,
2604 int require_machine_suffix, int os_multilib)
2606 struct prefix_list *pl, **prev;
2607 int len;
2609 for (prev = &pprefix->plist;
2610 (*prev) != NULL && (*prev)->priority <= priority;
2611 prev = &(*prev)->next)
2614 /* Keep track of the longest prefix. */
2616 prefix = update_path (prefix, component);
2617 len = strlen (prefix);
2618 if (len > pprefix->max_len)
2619 pprefix->max_len = len;
2621 pl = xmalloc (sizeof (struct prefix_list));
2622 pl->prefix = prefix;
2623 pl->require_machine_suffix = require_machine_suffix;
2624 pl->priority = priority;
2625 pl->os_multilib = os_multilib;
2627 /* Insert after PREV. */
2628 pl->next = (*prev);
2629 (*prev) = pl;
2632 /* Same as add_prefix, but prepending target_system_root to prefix. */
2633 static void
2634 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2635 const char *component,
2636 /* enum prefix_priority */ int priority,
2637 int require_machine_suffix, int os_multilib)
2639 if (!IS_ABSOLUTE_PATH (prefix))
2640 fatal ("system path '%s' is not absolute", prefix);
2642 if (target_system_root)
2644 if (target_sysroot_suffix)
2645 prefix = concat (target_sysroot_suffix, prefix, NULL);
2646 prefix = concat (target_system_root, prefix, NULL);
2648 /* We have to override this because GCC's notion of sysroot
2649 moves along with GCC. */
2650 component = "GCC";
2653 add_prefix (pprefix, prefix, component, priority,
2654 require_machine_suffix, os_multilib);
2657 /* Execute the command specified by the arguments on the current line of spec.
2658 When using pipes, this includes several piped-together commands
2659 with `|' between them.
2661 Return 0 if successful, -1 if failed. */
2663 static int
2664 execute (void)
2666 int i;
2667 int n_commands; /* # of command. */
2668 char *string;
2669 struct pex_obj *pex;
2670 struct command
2672 const char *prog; /* program name. */
2673 const char **argv; /* vector of args. */
2676 struct command *commands; /* each command buffer with above info. */
2678 gcc_assert (!processing_spec_function);
2680 /* Count # of piped commands. */
2681 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2682 if (strcmp (argbuf[i], "|") == 0)
2683 n_commands++;
2685 /* Get storage for each command. */
2686 commands = alloca (n_commands * sizeof (struct command));
2688 /* Split argbuf into its separate piped processes,
2689 and record info about each one.
2690 Also search for the programs that are to be run. */
2692 commands[0].prog = argbuf[0]; /* first command. */
2693 commands[0].argv = &argbuf[0];
2694 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2696 if (string)
2697 commands[0].argv[0] = string;
2699 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2700 if (strcmp (argbuf[i], "|") == 0)
2701 { /* each command. */
2702 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2703 fatal ("-pipe not supported");
2704 #endif
2705 argbuf[i] = 0; /* termination of command args. */
2706 commands[n_commands].prog = argbuf[i + 1];
2707 commands[n_commands].argv = &argbuf[i + 1];
2708 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2709 X_OK, 0);
2710 if (string)
2711 commands[n_commands].argv[0] = string;
2712 n_commands++;
2715 argbuf[argbuf_index] = 0;
2717 /* If -v, print what we are about to do, and maybe query. */
2719 if (verbose_flag)
2721 /* For help listings, put a blank line between sub-processes. */
2722 if (print_help_list)
2723 fputc ('\n', stderr);
2725 /* Print each piped command as a separate line. */
2726 for (i = 0; i < n_commands; i++)
2728 const char *const *j;
2730 if (verbose_only_flag)
2732 for (j = commands[i].argv; *j; j++)
2734 const char *p;
2735 fprintf (stderr, " \"");
2736 for (p = *j; *p; ++p)
2738 if (*p == '"' || *p == '\\' || *p == '$')
2739 fputc ('\\', stderr);
2740 fputc (*p, stderr);
2742 fputc ('"', stderr);
2745 else
2746 for (j = commands[i].argv; *j; j++)
2747 fprintf (stderr, " %s", *j);
2749 /* Print a pipe symbol after all but the last command. */
2750 if (i + 1 != n_commands)
2751 fprintf (stderr, " |");
2752 fprintf (stderr, "\n");
2754 fflush (stderr);
2755 if (verbose_only_flag != 0)
2757 /* verbose_only_flag should act as if the spec was
2758 executed, so increment execution_count before
2759 returning. This prevents spurious warnings about
2760 unused linker input files, etc. */
2761 execution_count++;
2762 return 0;
2764 #ifdef DEBUG
2765 notice ("\nGo ahead? (y or n) ");
2766 fflush (stderr);
2767 i = getchar ();
2768 if (i != '\n')
2769 while (getchar () != '\n')
2772 if (i != 'y' && i != 'Y')
2773 return 0;
2774 #endif /* DEBUG */
2777 #ifdef ENABLE_VALGRIND_CHECKING
2778 /* Run the each command through valgrind. To simplify prepending the
2779 path to valgrind and the option "-q" (for quiet operation unless
2780 something triggers), we allocate a separate argv array. */
2782 for (i = 0; i < n_commands; i++)
2784 const char **argv;
2785 int argc;
2786 int j;
2788 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2791 argv = alloca ((argc + 3) * sizeof (char *));
2793 argv[0] = VALGRIND_PATH;
2794 argv[1] = "-q";
2795 for (j = 2; j < argc + 2; j++)
2796 argv[j] = commands[i].argv[j - 2];
2797 argv[j] = NULL;
2799 commands[i].argv = argv;
2800 commands[i].prog = argv[0];
2802 #endif
2804 /* Run each piped subprocess. */
2806 pex = pex_init (PEX_USE_PIPES | (report_times ? PEX_RECORD_TIMES : 0),
2807 programname, temp_filename);
2808 if (pex == NULL)
2809 pfatal_with_name (_("pex_init failed"));
2811 for (i = 0; i < n_commands; i++)
2813 const char *errmsg;
2814 int err;
2815 const char *string = commands[i].argv[0];
2817 errmsg = pex_run (pex,
2818 ((i + 1 == n_commands ? PEX_LAST : 0)
2819 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2820 string, (char * const *) commands[i].argv,
2821 NULL, NULL, &err);
2822 if (errmsg != NULL)
2824 if (err == 0)
2825 fatal (errmsg);
2826 else
2828 errno = err;
2829 pfatal_with_name (errmsg);
2833 if (string != commands[i].prog)
2834 free ((void *) string);
2837 execution_count++;
2839 /* Wait for all the subprocesses to finish. */
2842 int *statuses;
2843 struct pex_time *times = NULL;
2844 int ret_code = 0;
2846 statuses = alloca (n_commands * sizeof (int));
2847 if (!pex_get_status (pex, n_commands, statuses))
2848 pfatal_with_name (_("failed to get exit status"));
2850 if (report_times)
2852 times = alloca (n_commands * sizeof (struct pex_time));
2853 if (!pex_get_times (pex, n_commands, times))
2854 pfatal_with_name (_("failed to get process times"));
2857 pex_free (pex);
2859 for (i = 0; i < n_commands; ++i)
2861 int status = statuses[i];
2863 if (WIFSIGNALED (status))
2865 #ifdef SIGPIPE
2866 /* SIGPIPE is a special case. It happens in -pipe mode
2867 when the compiler dies before the preprocessor is done,
2868 or the assembler dies before the compiler is done.
2869 There's generally been an error already, and this is
2870 just fallout. So don't generate another error unless
2871 we would otherwise have succeeded. */
2872 if (WTERMSIG (status) == SIGPIPE
2873 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2875 else
2876 #endif
2877 fatal ("\
2878 Internal error: %s (program %s)\n\
2879 Please submit a full bug report.\n\
2880 See %s for instructions.",
2881 strsignal (WTERMSIG (status)), commands[i].prog,
2882 bug_report_url);
2883 signal_count++;
2884 ret_code = -1;
2886 else if (WIFEXITED (status)
2887 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2889 if (WEXITSTATUS (status) > greatest_status)
2890 greatest_status = WEXITSTATUS (status);
2891 ret_code = -1;
2894 if (report_times)
2896 struct pex_time *pt = &times[i];
2897 double ut, st;
2899 ut = ((double) pt->user_seconds
2900 + (double) pt->user_microseconds / 1.0e6);
2901 st = ((double) pt->system_seconds
2902 + (double) pt->system_microseconds / 1.0e6);
2904 if (ut + st != 0)
2905 notice ("# %s %.2f %.2f\n", commands[i].prog, ut, st);
2909 return ret_code;
2913 /* Find all the switches given to us
2914 and make a vector describing them.
2915 The elements of the vector are strings, one per switch given.
2916 If a switch uses following arguments, then the `part1' field
2917 is the switch itself and the `args' field
2918 is a null-terminated vector containing the following arguments.
2919 The `live_cond' field is:
2920 0 when initialized
2921 1 if the switch is true in a conditional spec,
2922 -1 if false (overridden by a later switch)
2923 -2 if this switch should be ignored (used in %<S)
2924 The `validated' field is nonzero if any spec has looked at this switch;
2925 if it remains zero at the end of the run, it must be meaningless. */
2927 #define SWITCH_OK 0
2928 #define SWITCH_FALSE -1
2929 #define SWITCH_IGNORE -2
2930 #define SWITCH_LIVE 1
2932 struct switchstr
2934 const char *part1;
2935 const char **args;
2936 int live_cond;
2937 unsigned char validated;
2938 unsigned char ordering;
2941 static struct switchstr *switches;
2943 static int n_switches;
2945 /* Language is one of three things:
2947 1) The name of a real programming language.
2948 2) NULL, indicating that no one has figured out
2949 what it is yet.
2950 3) '*', indicating that the file should be passed
2951 to the linker. */
2952 struct infile
2954 const char *name;
2955 const char *language;
2956 struct compiler *incompiler;
2957 bool compiled;
2958 bool preprocessed;
2961 /* Also a vector of input files specified. */
2963 static struct infile *infiles;
2965 int n_infiles;
2967 /* True if multiple input files are being compiled to a single
2968 assembly file. */
2970 static bool combine_inputs;
2972 /* This counts the number of libraries added by lang_specific_driver, so that
2973 we can tell if there were any user supplied any files or libraries. */
2975 static int added_libraries;
2977 /* And a vector of corresponding output files is made up later. */
2979 const char **outfiles;
2981 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2983 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2984 is true if we should look for an executable suffix. DO_OBJ
2985 is true if we should look for an object suffix. */
2987 static const char *
2988 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2989 int do_obj ATTRIBUTE_UNUSED)
2991 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2992 int i;
2993 #endif
2994 int len;
2996 if (name == NULL)
2997 return NULL;
2999 len = strlen (name);
3001 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3002 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3003 if (do_obj && len > 2
3004 && name[len - 2] == '.'
3005 && name[len - 1] == 'o')
3007 obstack_grow (&obstack, name, len - 2);
3008 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3009 name = XOBFINISH (&obstack, const char *);
3011 #endif
3013 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3014 /* If there is no filetype, make it the executable suffix (which includes
3015 the "."). But don't get confused if we have just "-o". */
3016 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3017 return name;
3019 for (i = len - 1; i >= 0; i--)
3020 if (IS_DIR_SEPARATOR (name[i]))
3021 break;
3023 for (i++; i < len; i++)
3024 if (name[i] == '.')
3025 return name;
3027 obstack_grow (&obstack, name, len);
3028 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3029 strlen (TARGET_EXECUTABLE_SUFFIX));
3030 name = XOBFINISH (&obstack, const char *);
3031 #endif
3033 return name;
3035 #endif
3037 /* Display the command line switches accepted by gcc. */
3038 static void
3039 display_help (void)
3041 printf (_("Usage: %s [options] file...\n"), programname);
3042 fputs (_("Options:\n"), stdout);
3044 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3045 fputs (_(" --help Display this information\n"), stdout);
3046 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3047 if (! verbose_flag)
3048 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3049 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3050 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3051 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3052 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3053 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3054 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3055 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3056 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3057 fputs (_("\
3058 -print-multi-lib Display the mapping between command line options and\n\
3059 multiple library search directories\n"), stdout);
3060 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3061 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3062 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3063 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3064 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3065 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3066 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3067 fputs (_(" -combine Pass multiple source files to compiler at once\n"), stdout);
3068 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3069 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3070 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3071 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3072 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3073 fputs (_("\
3074 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3075 for headers and libraries\n"), stdout);
3076 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3077 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3078 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3079 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3080 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3081 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3082 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3083 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3084 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3085 fputs (_("\
3086 -x <language> Specify the language of the following input files\n\
3087 Permissible languages include: c c++ assembler none\n\
3088 'none' means revert to the default behavior of\n\
3089 guessing the language based on the file's extension\n\
3090 "), stdout);
3092 printf (_("\
3093 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3094 passed on to the various sub-processes invoked by %s. In order to pass\n\
3095 other options on to these processes the -W<letter> options must be used.\n\
3096 "), programname);
3098 /* The rest of the options are displayed by invocations of the various
3099 sub-processes. */
3102 static void
3103 add_preprocessor_option (const char *option, int len)
3105 n_preprocessor_options++;
3107 if (! preprocessor_options)
3108 preprocessor_options = xmalloc (n_preprocessor_options * sizeof (char *));
3109 else
3110 preprocessor_options = xrealloc (preprocessor_options,
3111 n_preprocessor_options * sizeof (char *));
3113 preprocessor_options [n_preprocessor_options - 1] =
3114 save_string (option, len);
3117 static void
3118 add_assembler_option (const char *option, int len)
3120 n_assembler_options++;
3122 if (! assembler_options)
3123 assembler_options = xmalloc (n_assembler_options * sizeof (char *));
3124 else
3125 assembler_options = xrealloc (assembler_options,
3126 n_assembler_options * sizeof (char *));
3128 assembler_options [n_assembler_options - 1] = save_string (option, len);
3131 static void
3132 add_linker_option (const char *option, int len)
3134 n_linker_options++;
3136 if (! linker_options)
3137 linker_options = xmalloc (n_linker_options * sizeof (char *));
3138 else
3139 linker_options = xrealloc (linker_options,
3140 n_linker_options * sizeof (char *));
3142 linker_options [n_linker_options - 1] = save_string (option, len);
3145 /* Create the vector `switches' and its contents.
3146 Store its length in `n_switches'. */
3148 static void
3149 process_command (int argc, const char **argv)
3151 int i;
3152 const char *temp;
3153 char *temp1;
3154 const char *spec_lang = 0;
3155 int last_language_n_infiles;
3156 int lang_n_infiles = 0;
3157 #ifdef MODIFY_TARGET_NAME
3158 int is_modify_target_name;
3159 int j;
3160 #endif
3162 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3164 n_switches = 0;
3165 n_infiles = 0;
3166 added_libraries = 0;
3168 /* Figure compiler version from version string. */
3170 compiler_version = temp1 = xstrdup (version_string);
3172 for (; *temp1; ++temp1)
3174 if (*temp1 == ' ')
3176 *temp1 = '\0';
3177 break;
3181 /* If there is a -V or -b option (or both), process it now, before
3182 trying to interpret the rest of the command line.
3183 Use heuristic that all configuration names must have at least
3184 one dash '-'. This allows us to pass options starting with -b. */
3185 if (argc > 1 && argv[1][0] == '-'
3186 && (argv[1][1] == 'V' ||
3187 ((argv[1][1] == 'b') && (NULL != strchr(argv[1] + 2,'-')))))
3189 const char *new_version = DEFAULT_TARGET_VERSION;
3190 const char *new_machine = DEFAULT_TARGET_MACHINE;
3191 const char *progname = argv[0];
3192 char **new_argv;
3193 char *new_argv0;
3194 int baselen;
3196 while (argc > 1 && argv[1][0] == '-'
3197 && (argv[1][1] == 'V' ||
3198 ((argv[1][1] == 'b') && ( NULL != strchr(argv[1] + 2,'-')))))
3200 char opt = argv[1][1];
3201 const char *arg;
3202 if (argv[1][2] != '\0')
3204 arg = argv[1] + 2;
3205 argc -= 1;
3206 argv += 1;
3208 else if (argc > 2)
3210 arg = argv[2];
3211 argc -= 2;
3212 argv += 2;
3214 else
3215 fatal ("'-%c' option must have argument", opt);
3216 if (opt == 'V')
3217 new_version = arg;
3218 else
3219 new_machine = arg;
3222 for (baselen = strlen (progname); baselen > 0; baselen--)
3223 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3224 break;
3225 new_argv0 = xmemdup (progname, baselen,
3226 baselen + concat_length (new_version, new_machine,
3227 "-gcc-", NULL) + 1);
3228 strcpy (new_argv0 + baselen, new_machine);
3229 strcat (new_argv0, "-gcc-");
3230 strcat (new_argv0, new_version);
3232 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3233 (argc + 1) * sizeof (argv[0]));
3234 new_argv[0] = new_argv0;
3236 execvp (new_argv0, new_argv);
3237 fatal ("couldn't run '%s': %s", new_argv0, xstrerror (errno));
3240 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3241 see if we can create it from the pathname specified in argv[0]. */
3243 gcc_libexec_prefix = standard_libexec_prefix;
3244 #ifndef VMS
3245 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3246 if (!gcc_exec_prefix)
3248 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3249 standard_exec_prefix);
3250 gcc_libexec_prefix = make_relative_prefix (argv[0],
3251 standard_bindir_prefix,
3252 standard_libexec_prefix);
3253 if (gcc_exec_prefix)
3254 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3256 else
3257 gcc_libexec_prefix = make_relative_prefix (gcc_exec_prefix,
3258 standard_exec_prefix,
3259 standard_libexec_prefix);
3260 #else
3261 #endif
3263 if (gcc_exec_prefix)
3265 int len = strlen (gcc_exec_prefix);
3267 if (len > (int) sizeof ("/lib/gcc/") - 1
3268 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3270 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3271 if (IS_DIR_SEPARATOR (*temp)
3272 && strncmp (temp + 1, "lib", 3) == 0
3273 && IS_DIR_SEPARATOR (temp[4])
3274 && strncmp (temp + 5, "gcc", 3) == 0)
3275 len -= sizeof ("/lib/gcc/") - 1;
3278 set_std_prefix (gcc_exec_prefix, len);
3279 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3280 PREFIX_PRIORITY_LAST, 0, 0);
3281 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3282 PREFIX_PRIORITY_LAST, 0, 0);
3285 /* COMPILER_PATH and LIBRARY_PATH have values
3286 that are lists of directory names with colons. */
3288 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3289 if (temp)
3291 const char *startp, *endp;
3292 char *nstore = alloca (strlen (temp) + 3);
3294 startp = endp = temp;
3295 while (1)
3297 if (*endp == PATH_SEPARATOR || *endp == 0)
3299 strncpy (nstore, startp, endp - startp);
3300 if (endp == startp)
3301 strcpy (nstore, concat (".", dir_separator_str, NULL));
3302 else if (!IS_DIR_SEPARATOR (endp[-1]))
3304 nstore[endp - startp] = DIR_SEPARATOR;
3305 nstore[endp - startp + 1] = 0;
3307 else
3308 nstore[endp - startp] = 0;
3309 add_prefix (&exec_prefixes, nstore, 0,
3310 PREFIX_PRIORITY_LAST, 0, 0);
3311 add_prefix (&include_prefixes, nstore, 0,
3312 PREFIX_PRIORITY_LAST, 0, 0);
3313 if (*endp == 0)
3314 break;
3315 endp = startp = endp + 1;
3317 else
3318 endp++;
3322 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3323 if (temp && *cross_compile == '0')
3325 const char *startp, *endp;
3326 char *nstore = alloca (strlen (temp) + 3);
3328 startp = endp = temp;
3329 while (1)
3331 if (*endp == PATH_SEPARATOR || *endp == 0)
3333 strncpy (nstore, startp, endp - startp);
3334 if (endp == startp)
3335 strcpy (nstore, concat (".", dir_separator_str, NULL));
3336 else if (!IS_DIR_SEPARATOR (endp[-1]))
3338 nstore[endp - startp] = DIR_SEPARATOR;
3339 nstore[endp - startp + 1] = 0;
3341 else
3342 nstore[endp - startp] = 0;
3343 add_prefix (&startfile_prefixes, nstore, NULL,
3344 PREFIX_PRIORITY_LAST, 0, 1);
3345 if (*endp == 0)
3346 break;
3347 endp = startp = endp + 1;
3349 else
3350 endp++;
3354 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3355 GET_ENVIRONMENT (temp, "LPATH");
3356 if (temp && *cross_compile == '0')
3358 const char *startp, *endp;
3359 char *nstore = alloca (strlen (temp) + 3);
3361 startp = endp = temp;
3362 while (1)
3364 if (*endp == PATH_SEPARATOR || *endp == 0)
3366 strncpy (nstore, startp, endp - startp);
3367 if (endp == startp)
3368 strcpy (nstore, concat (".", dir_separator_str, NULL));
3369 else if (!IS_DIR_SEPARATOR (endp[-1]))
3371 nstore[endp - startp] = DIR_SEPARATOR;
3372 nstore[endp - startp + 1] = 0;
3374 else
3375 nstore[endp - startp] = 0;
3376 add_prefix (&startfile_prefixes, nstore, NULL,
3377 PREFIX_PRIORITY_LAST, 0, 1);
3378 if (*endp == 0)
3379 break;
3380 endp = startp = endp + 1;
3382 else
3383 endp++;
3387 /* Convert new-style -- options to old-style. */
3388 translate_options (&argc, (const char *const **) &argv);
3390 /* Do language-specific adjustment/addition of flags. */
3391 lang_specific_driver (&argc, (const char *const **) &argv, &added_libraries);
3393 /* Scan argv twice. Here, the first time, just count how many switches
3394 there will be in their vector, and how many input files in theirs.
3395 Here we also parse the switches that cc itself uses (e.g. -v). */
3397 for (i = 1; i < argc; i++)
3399 if (! strcmp (argv[i], "-dumpspecs"))
3401 struct spec_list *sl;
3402 init_spec ();
3403 for (sl = specs; sl; sl = sl->next)
3404 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3405 if (link_command_spec)
3406 printf ("*link_command:\n%s\n\n", link_command_spec);
3407 exit (0);
3409 else if (! strcmp (argv[i], "-dumpversion"))
3411 printf ("%s\n", spec_version);
3412 exit (0);
3414 else if (! strcmp (argv[i], "-dumpmachine"))
3416 printf ("%s\n", spec_machine);
3417 exit (0);
3419 else if (strcmp (argv[i], "-fversion") == 0)
3421 /* translate_options () has turned --version into -fversion. */
3422 printf (_("%s (GCC) %s\n"), programname, version_string);
3423 printf ("Copyright %s 2005 Free Software Foundation, Inc.\n",
3424 _("(C)"));
3425 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3426 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3427 stdout);
3428 exit (0);
3430 else if (strcmp (argv[i], "-fhelp") == 0)
3432 /* translate_options () has turned --help into -fhelp. */
3433 print_help_list = 1;
3435 /* We will be passing a dummy file on to the sub-processes. */
3436 n_infiles++;
3437 n_switches++;
3439 /* CPP driver cannot obtain switch from cc1_options. */
3440 if (is_cpp_driver)
3441 add_preprocessor_option ("--help", 6);
3442 add_assembler_option ("--help", 6);
3443 add_linker_option ("--help", 6);
3445 else if (strcmp (argv[i], "-ftarget-help") == 0)
3447 /* translate_options() has turned --target-help into -ftarget-help. */
3448 target_help_flag = 1;
3450 /* We will be passing a dummy file on to the sub-processes. */
3451 n_infiles++;
3452 n_switches++;
3454 /* CPP driver cannot obtain switch from cc1_options. */
3455 if (is_cpp_driver)
3456 add_preprocessor_option ("--target-help", 13);
3457 add_assembler_option ("--target-help", 13);
3458 add_linker_option ("--target-help", 13);
3460 else if (! strcmp (argv[i], "-pass-exit-codes"))
3462 pass_exit_codes = 1;
3463 n_switches++;
3465 else if (! strcmp (argv[i], "-print-search-dirs"))
3466 print_search_dirs = 1;
3467 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3468 print_file_name = "libgcc.a";
3469 else if (! strncmp (argv[i], "-print-file-name=", 17))
3470 print_file_name = argv[i] + 17;
3471 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3472 print_prog_name = argv[i] + 17;
3473 else if (! strcmp (argv[i], "-print-multi-lib"))
3474 print_multi_lib = 1;
3475 else if (! strcmp (argv[i], "-print-multi-directory"))
3476 print_multi_directory = 1;
3477 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3478 print_multi_os_directory = 1;
3479 else if (! strncmp (argv[i], "-Wa,", 4))
3481 int prev, j;
3482 /* Pass the rest of this option to the assembler. */
3484 /* Split the argument at commas. */
3485 prev = 4;
3486 for (j = 4; argv[i][j]; j++)
3487 if (argv[i][j] == ',')
3489 add_assembler_option (argv[i] + prev, j - prev);
3490 prev = j + 1;
3493 /* Record the part after the last comma. */
3494 add_assembler_option (argv[i] + prev, j - prev);
3496 else if (! strncmp (argv[i], "-Wp,", 4))
3498 int prev, j;
3499 /* Pass the rest of this option to the preprocessor. */
3501 /* Split the argument at commas. */
3502 prev = 4;
3503 for (j = 4; argv[i][j]; j++)
3504 if (argv[i][j] == ',')
3506 add_preprocessor_option (argv[i] + prev, j - prev);
3507 prev = j + 1;
3510 /* Record the part after the last comma. */
3511 add_preprocessor_option (argv[i] + prev, j - prev);
3513 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3514 /* The +e options to the C++ front-end. */
3515 n_switches++;
3516 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3518 int j;
3519 /* Split the argument at commas. */
3520 for (j = 3; argv[i][j]; j++)
3521 n_infiles += (argv[i][j] == ',');
3523 else if (strcmp (argv[i], "-Xlinker") == 0)
3525 if (i + 1 == argc)
3526 fatal ("argument to '-Xlinker' is missing");
3528 n_infiles++;
3529 i++;
3531 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3533 if (i + 1 == argc)
3534 fatal ("argument to '-Xpreprocessor' is missing");
3536 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3538 else if (strcmp (argv[i], "-Xassembler") == 0)
3540 if (i + 1 == argc)
3541 fatal ("argument to '-Xassembler' is missing");
3543 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3545 else if (strcmp (argv[i], "-l") == 0)
3547 if (i + 1 == argc)
3548 fatal ("argument to '-l' is missing");
3550 n_infiles++;
3551 i++;
3553 else if (strncmp (argv[i], "-l", 2) == 0)
3554 n_infiles++;
3555 else if (strcmp (argv[i], "-save-temps") == 0)
3557 save_temps_flag = 1;
3558 n_switches++;
3560 else if (strcmp (argv[i], "-combine") == 0)
3562 combine_flag = 1;
3563 n_switches++;
3565 else if (strcmp (argv[i], "-specs") == 0)
3567 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3568 if (++i >= argc)
3569 fatal ("argument to '-specs' is missing");
3571 user->next = (struct user_specs *) 0;
3572 user->filename = argv[i];
3573 if (user_specs_tail)
3574 user_specs_tail->next = user;
3575 else
3576 user_specs_head = user;
3577 user_specs_tail = user;
3579 else if (strncmp (argv[i], "-specs=", 7) == 0)
3581 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3582 if (strlen (argv[i]) == 7)
3583 fatal ("argument to '-specs=' is missing");
3585 user->next = (struct user_specs *) 0;
3586 user->filename = argv[i] + 7;
3587 if (user_specs_tail)
3588 user_specs_tail->next = user;
3589 else
3590 user_specs_head = user;
3591 user_specs_tail = user;
3593 else if (strcmp (argv[i], "-time") == 0)
3594 report_times = 1;
3595 else if (strcmp (argv[i], "-pipe") == 0)
3597 /* -pipe has to go into the switches array as well as
3598 setting a flag. */
3599 use_pipes = 1;
3600 n_switches++;
3602 else if (strcmp (argv[i], "-###") == 0)
3604 /* This is similar to -v except that there is no execution
3605 of the commands and the echoed arguments are quoted. It
3606 is intended for use in shell scripts to capture the
3607 driver-generated command line. */
3608 verbose_only_flag++;
3609 verbose_flag++;
3611 else if (argv[i][0] == '-' && argv[i][1] != 0)
3613 const char *p = &argv[i][1];
3614 int c = *p;
3616 switch (c)
3618 case 'b':
3619 if (NULL == strchr(argv[i] + 2, '-')) break;
3620 case 'V':
3621 fatal ("'-%c' must come at the start of the command line", c);
3622 break;
3624 case 'B':
3626 const char *value;
3627 int len;
3629 if (p[1] == 0 && i + 1 == argc)
3630 fatal ("argument to '-B' is missing");
3631 if (p[1] == 0)
3632 value = argv[++i];
3633 else
3634 value = p + 1;
3636 len = strlen (value);
3638 /* Catch the case where the user has forgotten to append a
3639 directory separator to the path. Note, they may be using
3640 -B to add an executable name prefix, eg "i386-elf-", in
3641 order to distinguish between multiple installations of
3642 GCC in the same directory. Hence we must check to see
3643 if appending a directory separator actually makes a
3644 valid directory name. */
3645 if (! IS_DIR_SEPARATOR (value [len - 1])
3646 && is_directory (value, "", 0))
3648 char *tmp = xmalloc (len + 2);
3649 strcpy (tmp, value);
3650 tmp[len] = DIR_SEPARATOR;
3651 tmp[++ len] = 0;
3652 value = tmp;
3655 /* As a kludge, if the arg is "[foo/]stageN/", just
3656 add "[foo/]include" to the include prefix. */
3657 if ((len == 7
3658 || (len > 7
3659 && (IS_DIR_SEPARATOR (value[len - 8]))))
3660 && strncmp (value + len - 7, "stage", 5) == 0
3661 && ISDIGIT (value[len - 2])
3662 && (IS_DIR_SEPARATOR (value[len - 1])))
3664 if (len == 7)
3665 add_prefix (&include_prefixes, "./", NULL,
3666 PREFIX_PRIORITY_B_OPT, 0, 0);
3667 else
3669 char *string = xmalloc (len - 6);
3670 memcpy (string, value, len - 7);
3671 string[len - 7] = 0;
3672 add_prefix (&include_prefixes, string, NULL,
3673 PREFIX_PRIORITY_B_OPT, 0, 0);
3677 add_prefix (&exec_prefixes, value, NULL,
3678 PREFIX_PRIORITY_B_OPT, 0, 0);
3679 add_prefix (&startfile_prefixes, value, NULL,
3680 PREFIX_PRIORITY_B_OPT, 0, 0);
3681 add_prefix (&include_prefixes, value, NULL,
3682 PREFIX_PRIORITY_B_OPT, 0, 0);
3683 n_switches++;
3685 break;
3687 case 'v': /* Print our subcommands and print versions. */
3688 n_switches++;
3689 /* If they do anything other than exactly `-v', don't set
3690 verbose_flag; rather, continue on to give the error. */
3691 if (p[1] != 0)
3692 break;
3693 verbose_flag++;
3694 break;
3696 case 'S':
3697 case 'c':
3698 if (p[1] == 0)
3700 have_c = 1;
3701 n_switches++;
3702 break;
3704 goto normal_switch;
3706 case 'o':
3707 have_o = 1;
3708 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3709 if (! have_c)
3711 int skip;
3713 /* Forward scan, just in case -S or -c is specified
3714 after -o. */
3715 int j = i + 1;
3716 if (p[1] == 0)
3717 ++j;
3718 while (j < argc)
3720 if (argv[j][0] == '-')
3722 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3723 && argv[j][2] == 0)
3725 have_c = 1;
3726 break;
3728 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3729 j += skip - (argv[j][2] != 0);
3730 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3731 j += skip;
3733 j++;
3736 #endif
3737 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3738 if (p[1] == 0)
3739 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3740 else
3741 argv[i] = convert_filename (argv[i], ! have_c, 0);
3742 #endif
3743 goto normal_switch;
3745 default:
3746 normal_switch:
3748 #ifdef MODIFY_TARGET_NAME
3749 is_modify_target_name = 0;
3751 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3752 if (! strcmp (argv[i], modify_target[j].sw))
3754 char *new_name = xmalloc (strlen (modify_target[j].str)
3755 + strlen (spec_machine));
3756 const char *p, *r;
3757 char *q;
3758 int made_addition = 0;
3760 is_modify_target_name = 1;
3761 for (p = spec_machine, q = new_name; *p != 0; )
3763 if (modify_target[j].add_del == DELETE
3764 && (! strncmp (q, modify_target[j].str,
3765 strlen (modify_target[j].str))))
3766 p += strlen (modify_target[j].str);
3767 else if (modify_target[j].add_del == ADD
3768 && ! made_addition && *p == '-')
3770 for (r = modify_target[j].str; *r != 0; )
3771 *q++ = *r++;
3772 made_addition = 1;
3775 *q++ = *p++;
3778 spec_machine = new_name;
3781 if (is_modify_target_name)
3782 break;
3783 #endif
3785 n_switches++;
3787 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3788 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3789 else if (WORD_SWITCH_TAKES_ARG (p))
3790 i += WORD_SWITCH_TAKES_ARG (p);
3793 else
3795 n_infiles++;
3796 lang_n_infiles++;
3800 if (save_temps_flag && use_pipes)
3802 /* -save-temps overrides -pipe, so that temp files are produced */
3803 if (save_temps_flag)
3804 error ("warning: -pipe ignored because -save-temps specified");
3805 use_pipes = 0;
3808 /* Set up the search paths before we go looking for config files. */
3810 /* These come before the md prefixes so that we will find gcc's subcommands
3811 (such as cpp) rather than those of the host system. */
3812 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3813 as well as trying the machine and the version. */
3814 #ifndef OS2
3815 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3816 PREFIX_PRIORITY_LAST, 1, 0);
3817 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3818 PREFIX_PRIORITY_LAST, 2, 0);
3819 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3820 PREFIX_PRIORITY_LAST, 2, 0);
3821 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3822 PREFIX_PRIORITY_LAST, 2, 0);
3823 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
3824 PREFIX_PRIORITY_LAST, 2, 0);
3825 #endif
3827 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3828 PREFIX_PRIORITY_LAST, 1, 0);
3829 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
3830 PREFIX_PRIORITY_LAST, 1, 0);
3832 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3833 dir_separator_str, NULL);
3835 /* If tooldir is relative, base it on exec_prefixes. A relative
3836 tooldir lets us move the installed tree as a unit.
3838 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3839 directories, so that we can search both the user specified directory
3840 and the standard place. */
3842 if (!IS_ABSOLUTE_PATH (tooldir_prefix))
3844 if (gcc_exec_prefix)
3846 char *gcc_exec_tooldir_prefix
3847 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3848 spec_version, dir_separator_str, tooldir_prefix, NULL);
3850 add_prefix (&exec_prefixes,
3851 concat (gcc_exec_tooldir_prefix, "bin",
3852 dir_separator_str, NULL),
3853 NULL, PREFIX_PRIORITY_LAST, 0, 0);
3854 add_prefix (&startfile_prefixes,
3855 concat (gcc_exec_tooldir_prefix, "lib",
3856 dir_separator_str, NULL),
3857 NULL, PREFIX_PRIORITY_LAST, 0, 1);
3860 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3861 dir_separator_str, spec_version,
3862 dir_separator_str, tooldir_prefix, NULL);
3865 add_prefix (&exec_prefixes,
3866 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3867 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3868 add_prefix (&startfile_prefixes,
3869 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3870 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3872 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3873 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3874 then consider it to relocate with the rest of the GCC installation
3875 if GCC_EXEC_PREFIX is set.
3876 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3877 if (target_system_root && gcc_exec_prefix)
3879 char *tmp_prefix = make_relative_prefix (argv[0],
3880 standard_bindir_prefix,
3881 target_system_root);
3882 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3884 target_system_root = tmp_prefix;
3885 target_system_root_changed = 1;
3888 #endif
3890 /* More prefixes are enabled in main, after we read the specs file
3891 and determine whether this is cross-compilation or not. */
3893 /* Then create the space for the vectors and scan again. */
3895 switches = xmalloc ((n_switches + 1) * sizeof (struct switchstr));
3896 infiles = xmalloc ((n_infiles + 1) * sizeof (struct infile));
3897 n_switches = 0;
3898 n_infiles = 0;
3899 last_language_n_infiles = -1;
3901 /* This, time, copy the text of each switch and store a pointer
3902 to the copy in the vector of switches.
3903 Store all the infiles in their vector. */
3905 for (i = 1; i < argc; i++)
3907 /* Just skip the switches that were handled by the preceding loop. */
3908 #ifdef MODIFY_TARGET_NAME
3909 is_modify_target_name = 0;
3911 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3912 if (! strcmp (argv[i], modify_target[j].sw))
3913 is_modify_target_name = 1;
3915 if (is_modify_target_name)
3917 else
3918 #endif
3919 if (! strncmp (argv[i], "-Wa,", 4))
3921 else if (! strncmp (argv[i], "-Wp,", 4))
3923 else if (! strcmp (argv[i], "-pass-exit-codes"))
3925 else if (! strcmp (argv[i], "-print-search-dirs"))
3927 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3929 else if (! strncmp (argv[i], "-print-file-name=", 17))
3931 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3933 else if (! strcmp (argv[i], "-print-multi-lib"))
3935 else if (! strcmp (argv[i], "-print-multi-directory"))
3937 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3939 else if (! strcmp (argv[i], "-ftarget-help"))
3941 else if (! strcmp (argv[i], "-fhelp"))
3943 else if (! strncmp (argv[i], "--sysroot=", strlen ("--sysroot=")))
3945 target_system_root = argv[i] + strlen ("--sysroot=");
3946 target_system_root_changed = 1;
3948 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3950 /* Compensate for the +e options to the C++ front-end;
3951 they're there simply for cfront call-compatibility. We do
3952 some magic in default_compilers to pass them down properly.
3953 Note we deliberately start at the `+' here, to avoid passing
3954 -e0 or -e1 down into the linker. */
3955 switches[n_switches].part1 = &argv[i][0];
3956 switches[n_switches].args = 0;
3957 switches[n_switches].live_cond = SWITCH_OK;
3958 switches[n_switches].validated = 0;
3959 n_switches++;
3961 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3963 int prev, j;
3964 /* Split the argument at commas. */
3965 prev = 4;
3966 for (j = 4; argv[i][j]; j++)
3967 if (argv[i][j] == ',')
3969 infiles[n_infiles].language = "*";
3970 infiles[n_infiles++].name
3971 = save_string (argv[i] + prev, j - prev);
3972 prev = j + 1;
3974 /* Record the part after the last comma. */
3975 infiles[n_infiles].language = "*";
3976 infiles[n_infiles++].name = argv[i] + prev;
3978 else if (strcmp (argv[i], "-Xlinker") == 0)
3980 infiles[n_infiles].language = "*";
3981 infiles[n_infiles++].name = argv[++i];
3983 /* Xassembler and Xpreprocessor were already handled in the first argv
3984 scan, so all we need to do here is ignore them and their argument. */
3985 else if (strcmp (argv[i], "-Xassembler") == 0)
3986 i++;
3987 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3988 i++;
3989 else if (strcmp (argv[i], "-l") == 0)
3990 { /* POSIX allows separation of -l and the lib arg;
3991 canonicalize by concatenating -l with its arg */
3992 infiles[n_infiles].language = "*";
3993 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3995 else if (strncmp (argv[i], "-l", 2) == 0)
3997 infiles[n_infiles].language = "*";
3998 infiles[n_infiles++].name = argv[i];
4000 else if (strcmp (argv[i], "-specs") == 0)
4001 i++;
4002 else if (strncmp (argv[i], "-specs=", 7) == 0)
4004 else if (strcmp (argv[i], "-time") == 0)
4006 else if (strcmp (argv[i], "-###") == 0)
4008 else if (argv[i][0] == '-' && argv[i][1] != 0)
4010 const char *p = &argv[i][1];
4011 int c = *p;
4013 if (c == 'x')
4015 if (p[1] == 0 && i + 1 == argc)
4016 fatal ("argument to '-x' is missing");
4017 if (p[1] == 0)
4018 spec_lang = argv[++i];
4019 else
4020 spec_lang = p + 1;
4021 if (! strcmp (spec_lang, "none"))
4022 /* Suppress the warning if -xnone comes after the last input
4023 file, because alternate command interfaces like g++ might
4024 find it useful to place -xnone after each input file. */
4025 spec_lang = 0;
4026 else
4027 last_language_n_infiles = n_infiles;
4028 continue;
4030 switches[n_switches].part1 = p;
4031 /* Deal with option arguments in separate argv elements. */
4032 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
4033 || WORD_SWITCH_TAKES_ARG (p))
4035 int j = 0;
4036 int n_args = WORD_SWITCH_TAKES_ARG (p);
4038 if (n_args == 0)
4040 /* Count only the option arguments in separate argv elements. */
4041 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4043 if (i + n_args >= argc)
4044 fatal ("argument to '-%s' is missing", p);
4045 switches[n_switches].args
4046 = xmalloc ((n_args + 1) * sizeof(const char *));
4047 while (j < n_args)
4048 switches[n_switches].args[j++] = argv[++i];
4049 /* Null-terminate the vector. */
4050 switches[n_switches].args[j] = 0;
4052 else if (strchr (switches_need_spaces, c))
4054 /* On some systems, ld cannot handle some options without
4055 a space. So split the option from its argument. */
4056 char *part1 = xmalloc (2);
4057 part1[0] = c;
4058 part1[1] = '\0';
4060 switches[n_switches].part1 = part1;
4061 switches[n_switches].args = xmalloc (2 * sizeof (const char *));
4062 switches[n_switches].args[0] = xstrdup (p+1);
4063 switches[n_switches].args[1] = 0;
4065 else
4066 switches[n_switches].args = 0;
4068 switches[n_switches].live_cond = SWITCH_OK;
4069 switches[n_switches].validated = 0;
4070 switches[n_switches].ordering = 0;
4071 /* These are always valid, since gcc.c itself understands them. */
4072 if (!strcmp (p, "save-temps")
4073 || !strcmp (p, "static-libgcc")
4074 || !strcmp (p, "shared-libgcc")
4075 || !strcmp (p, "pipe"))
4076 switches[n_switches].validated = 1;
4077 else
4079 char ch = switches[n_switches].part1[0];
4080 if (ch == 'B')
4081 switches[n_switches].validated = 1;
4083 n_switches++;
4085 else
4087 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4088 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4089 #endif
4091 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4093 perror_with_name (argv[i]);
4094 error_count++;
4096 else
4098 infiles[n_infiles].language = spec_lang;
4099 infiles[n_infiles++].name = argv[i];
4104 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4105 error ("warning: '-x %s' after last input file has no effect", spec_lang);
4107 /* Ensure we only invoke each subprocess once. */
4108 if (target_help_flag || print_help_list)
4110 n_infiles = 1;
4112 /* Create a dummy input file, so that we can pass --target-help on to
4113 the various sub-processes. */
4114 infiles[0].language = "c";
4115 infiles[0].name = "help-dummy";
4117 if (target_help_flag)
4119 switches[n_switches].part1 = "--target-help";
4120 switches[n_switches].args = 0;
4121 switches[n_switches].live_cond = SWITCH_OK;
4122 switches[n_switches].validated = 0;
4124 n_switches++;
4127 if (print_help_list)
4129 switches[n_switches].part1 = "--help";
4130 switches[n_switches].args = 0;
4131 switches[n_switches].live_cond = SWITCH_OK;
4132 switches[n_switches].validated = 0;
4134 n_switches++;
4138 switches[n_switches].part1 = 0;
4139 infiles[n_infiles].name = 0;
4142 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4143 and place that in the environment. */
4145 static void
4146 set_collect_gcc_options (void)
4148 int i;
4149 int first_time;
4151 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4152 the compiler. */
4153 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4154 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4156 first_time = TRUE;
4157 for (i = 0; (int) i < n_switches; i++)
4159 const char *const *args;
4160 const char *p, *q;
4161 if (!first_time)
4162 obstack_grow (&collect_obstack, " ", 1);
4164 first_time = FALSE;
4166 /* Ignore elided switches. */
4167 if (switches[i].live_cond == SWITCH_IGNORE)
4168 continue;
4170 obstack_grow (&collect_obstack, "'-", 2);
4171 q = switches[i].part1;
4172 while ((p = strchr (q, '\'')))
4174 obstack_grow (&collect_obstack, q, p - q);
4175 obstack_grow (&collect_obstack, "'\\''", 4);
4176 q = ++p;
4178 obstack_grow (&collect_obstack, q, strlen (q));
4179 obstack_grow (&collect_obstack, "'", 1);
4181 for (args = switches[i].args; args && *args; args++)
4183 obstack_grow (&collect_obstack, " '", 2);
4184 q = *args;
4185 while ((p = strchr (q, '\'')))
4187 obstack_grow (&collect_obstack, q, p - q);
4188 obstack_grow (&collect_obstack, "'\\''", 4);
4189 q = ++p;
4191 obstack_grow (&collect_obstack, q, strlen (q));
4192 obstack_grow (&collect_obstack, "'", 1);
4195 obstack_grow (&collect_obstack, "\0", 1);
4196 putenv (XOBFINISH (&collect_obstack, char *));
4199 /* Process a spec string, accumulating and running commands. */
4201 /* These variables describe the input file name.
4202 input_file_number is the index on outfiles of this file,
4203 so that the output file name can be stored for later use by %o.
4204 input_basename is the start of the part of the input file
4205 sans all directory names, and basename_length is the number
4206 of characters starting there excluding the suffix .c or whatever. */
4208 static const char *input_filename;
4209 static int input_file_number;
4210 size_t input_filename_length;
4211 static int basename_length;
4212 static int suffixed_basename_length;
4213 static const char *input_basename;
4214 static const char *input_suffix;
4215 #ifndef HOST_LACKS_INODE_NUMBERS
4216 static struct stat input_stat;
4217 #endif
4218 static int input_stat_set;
4220 /* The compiler used to process the current input file. */
4221 static struct compiler *input_file_compiler;
4223 /* These are variables used within do_spec and do_spec_1. */
4225 /* Nonzero if an arg has been started and not yet terminated
4226 (with space, tab or newline). */
4227 static int arg_going;
4229 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4230 is a temporary file name. */
4231 static int delete_this_arg;
4233 /* Nonzero means %w has been seen; the next arg to be terminated
4234 is the output file name of this compilation. */
4235 static int this_is_output_file;
4237 /* Nonzero means %s has been seen; the next arg to be terminated
4238 is the name of a library file and we should try the standard
4239 search dirs for it. */
4240 static int this_is_library_file;
4242 /* Nonzero means that the input of this command is coming from a pipe. */
4243 static int input_from_pipe;
4245 /* Nonnull means substitute this for any suffix when outputting a switches
4246 arguments. */
4247 static const char *suffix_subst;
4249 /* Process the spec SPEC and run the commands specified therein.
4250 Returns 0 if the spec is successfully processed; -1 if failed. */
4253 do_spec (const char *spec)
4255 int value;
4257 value = do_spec_2 (spec);
4259 /* Force out any unfinished command.
4260 If -pipe, this forces out the last command if it ended in `|'. */
4261 if (value == 0)
4263 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4264 argbuf_index--;
4266 set_collect_gcc_options ();
4268 if (argbuf_index > 0)
4269 value = execute ();
4272 return value;
4275 static int
4276 do_spec_2 (const char *spec)
4278 const char *string;
4279 int result;
4281 clear_args ();
4282 arg_going = 0;
4283 delete_this_arg = 0;
4284 this_is_output_file = 0;
4285 this_is_library_file = 0;
4286 input_from_pipe = 0;
4287 suffix_subst = NULL;
4289 result = do_spec_1 (spec, 0, NULL);
4291 /* End any pending argument. */
4292 if (arg_going)
4294 obstack_1grow (&obstack, 0);
4295 string = XOBFINISH (&obstack, const char *);
4296 if (this_is_library_file)
4297 string = find_file (string);
4298 store_arg (string, delete_this_arg, this_is_output_file);
4299 if (this_is_output_file)
4300 outfiles[input_file_number] = string;
4301 arg_going = 0;
4304 return result;
4308 /* Process the given spec string and add any new options to the end
4309 of the switches/n_switches array. */
4311 static void
4312 do_option_spec (const char *name, const char *spec)
4314 unsigned int i, value_count, value_len;
4315 const char *p, *q, *value;
4316 char *tmp_spec, *tmp_spec_p;
4318 if (configure_default_options[0].name == NULL)
4319 return;
4321 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4322 if (strcmp (configure_default_options[i].name, name) == 0)
4323 break;
4324 if (i == ARRAY_SIZE (configure_default_options))
4325 return;
4327 value = configure_default_options[i].value;
4328 value_len = strlen (value);
4330 /* Compute the size of the final spec. */
4331 value_count = 0;
4332 p = spec;
4333 while ((p = strstr (p, "%(VALUE)")) != NULL)
4335 p ++;
4336 value_count ++;
4339 /* Replace each %(VALUE) by the specified value. */
4340 tmp_spec = alloca (strlen (spec) + 1
4341 + value_count * (value_len - strlen ("%(VALUE)")));
4342 tmp_spec_p = tmp_spec;
4343 q = spec;
4344 while ((p = strstr (q, "%(VALUE)")) != NULL)
4346 memcpy (tmp_spec_p, q, p - q);
4347 tmp_spec_p = tmp_spec_p + (p - q);
4348 memcpy (tmp_spec_p, value, value_len);
4349 tmp_spec_p += value_len;
4350 q = p + strlen ("%(VALUE)");
4352 strcpy (tmp_spec_p, q);
4354 do_self_spec (tmp_spec);
4357 /* Process the given spec string and add any new options to the end
4358 of the switches/n_switches array. */
4360 static void
4361 do_self_spec (const char *spec)
4363 do_spec_2 (spec);
4364 do_spec_1 (" ", 0, NULL);
4366 if (argbuf_index > 0)
4368 int i, first;
4370 first = n_switches;
4371 n_switches += argbuf_index;
4372 switches = xrealloc (switches,
4373 sizeof (struct switchstr) * (n_switches + 1));
4375 switches[n_switches] = switches[first];
4376 for (i = 0; i < argbuf_index; i++)
4378 struct switchstr *sw;
4380 /* Each switch should start with '-'. */
4381 if (argbuf[i][0] != '-')
4382 fatal ("switch '%s' does not start with '-'", argbuf[i]);
4384 sw = &switches[i + first];
4385 sw->part1 = &argbuf[i][1];
4386 sw->args = 0;
4387 sw->live_cond = SWITCH_OK;
4388 sw->validated = 0;
4389 sw->ordering = 0;
4394 void
4395 do_spec_path (struct prefix_list *pl, const char *option,
4396 int omit_if_relative, int separate_options,
4397 int only_subdir,
4398 const char *dir_for_machine_suffix,
4399 const char *dir_for_no_suffix)
4401 static size_t bufsize = 0;
4402 static char *buffer;
4403 int idx;
4404 bool multilib_p = false;
4406 /* Used on systems which record the specified -L dirs
4407 and use them to search for dynamic linking. */
4408 /* Relative directories always come from -B,
4409 and it is better not to use them for searching
4410 at run time. In particular, stage1 loses. */
4411 if (omit_if_relative
4412 && !IS_ABSOLUTE_PATH (pl->prefix))
4413 return;
4415 /* Try subdirectory if there is one. */
4416 if (machine_suffix && dir_for_machine_suffix)
4418 if (strlen (pl->prefix) + strlen (machine_suffix)
4419 >= bufsize)
4420 bufsize = (strlen (pl->prefix)
4421 + strlen (machine_suffix)) * 2 + 1;
4422 buffer = xrealloc (buffer, bufsize);
4423 strcpy (buffer, pl->prefix);
4424 strcat (buffer, machine_suffix);
4425 if (is_directory (buffer, dir_for_machine_suffix, 1))
4427 multilib_p = true;
4428 do_spec_1 (option, separate_options, NULL);
4429 if (separate_options)
4430 do_spec_1 (" ", 0, NULL);
4431 do_spec_1 (buffer, 1, NULL);
4432 do_spec_1 (dir_for_machine_suffix, 1, NULL);
4433 /* Make this a separate argument. */
4434 do_spec_1 (" ", 0, NULL);
4437 if (!pl->require_machine_suffix && dir_for_no_suffix)
4439 if (is_directory (pl->prefix, dir_for_no_suffix, 1))
4441 multilib_p = true;
4442 do_spec_1 (option, separate_options, NULL);
4443 if (separate_options)
4444 do_spec_1 (" ", 0, NULL);
4445 do_spec_1 (pl->prefix, 1, NULL);
4446 do_spec_1 (dir_for_no_suffix, 1, NULL);
4447 /* Make this a separate argument. */
4448 do_spec_1 (" ", 0, NULL);
4452 if (only_subdir || multilib_p)
4453 return;
4455 if (machine_suffix)
4457 if (is_directory (pl->prefix, machine_suffix, 1))
4459 do_spec_1 (option, separate_options, NULL);
4460 if (separate_options)
4461 do_spec_1 (" ", 0, NULL);
4462 do_spec_1 (pl->prefix, 1, NULL);
4463 /* Remove slash from machine_suffix. */
4464 if (strlen (machine_suffix) >= bufsize)
4465 bufsize = strlen (machine_suffix) * 2 + 1;
4466 buffer = xrealloc (buffer, bufsize);
4467 strcpy (buffer, machine_suffix);
4468 idx = strlen (buffer);
4469 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4470 buffer[idx - 1] = 0;
4471 do_spec_1 (buffer, 1, NULL);
4472 /* Make this a separate argument. */
4473 do_spec_1 (" ", 0, NULL);
4476 if (!pl->require_machine_suffix)
4478 if (is_directory (pl->prefix, "", 1))
4480 do_spec_1 (option, separate_options, NULL);
4481 if (separate_options)
4482 do_spec_1 (" ", 0, NULL);
4483 /* Remove slash from pl->prefix. */
4484 if (strlen (pl->prefix) >= bufsize)
4485 bufsize = strlen (pl->prefix) * 2 + 1;
4486 buffer = xrealloc (buffer, bufsize);
4487 strcpy (buffer, pl->prefix);
4488 idx = strlen (buffer);
4489 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4490 buffer[idx - 1] = 0;
4491 do_spec_1 (buffer, 1, NULL);
4492 /* Make this a separate argument. */
4493 do_spec_1 (" ", 0, NULL);
4498 /* Process the sub-spec SPEC as a portion of a larger spec.
4499 This is like processing a whole spec except that we do
4500 not initialize at the beginning and we do not supply a
4501 newline by default at the end.
4502 INSWITCH nonzero means don't process %-sequences in SPEC;
4503 in this case, % is treated as an ordinary character.
4504 This is used while substituting switches.
4505 INSWITCH nonzero also causes SPC not to terminate an argument.
4507 Value is zero unless a line was finished
4508 and the command on that line reported an error. */
4510 static int
4511 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4513 const char *p = spec;
4514 int c;
4515 int i;
4516 const char *string;
4517 int value;
4519 while ((c = *p++))
4520 /* If substituting a switch, treat all chars like letters.
4521 Otherwise, NL, SPC, TAB and % are special. */
4522 switch (inswitch ? 'a' : c)
4524 case '\n':
4525 /* End of line: finish any pending argument,
4526 then run the pending command if one has been started. */
4527 if (arg_going)
4529 obstack_1grow (&obstack, 0);
4530 string = XOBFINISH (&obstack, const char *);
4531 if (this_is_library_file)
4532 string = find_file (string);
4533 store_arg (string, delete_this_arg, this_is_output_file);
4534 if (this_is_output_file)
4535 outfiles[input_file_number] = string;
4537 arg_going = 0;
4539 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4541 /* A `|' before the newline means use a pipe here,
4542 but only if -pipe was specified.
4543 Otherwise, execute now and don't pass the `|' as an arg. */
4544 if (use_pipes)
4546 input_from_pipe = 1;
4547 break;
4549 else
4550 argbuf_index--;
4553 set_collect_gcc_options ();
4555 if (argbuf_index > 0)
4557 value = execute ();
4558 if (value)
4559 return value;
4561 /* Reinitialize for a new command, and for a new argument. */
4562 clear_args ();
4563 arg_going = 0;
4564 delete_this_arg = 0;
4565 this_is_output_file = 0;
4566 this_is_library_file = 0;
4567 input_from_pipe = 0;
4568 break;
4570 case '|':
4571 /* End any pending argument. */
4572 if (arg_going)
4574 obstack_1grow (&obstack, 0);
4575 string = XOBFINISH (&obstack, const char *);
4576 if (this_is_library_file)
4577 string = find_file (string);
4578 store_arg (string, delete_this_arg, this_is_output_file);
4579 if (this_is_output_file)
4580 outfiles[input_file_number] = string;
4583 /* Use pipe */
4584 obstack_1grow (&obstack, c);
4585 arg_going = 1;
4586 break;
4588 case '\t':
4589 case ' ':
4590 /* Space or tab ends an argument if one is pending. */
4591 if (arg_going)
4593 obstack_1grow (&obstack, 0);
4594 string = XOBFINISH (&obstack, const char *);
4595 if (this_is_library_file)
4596 string = find_file (string);
4597 store_arg (string, delete_this_arg, this_is_output_file);
4598 if (this_is_output_file)
4599 outfiles[input_file_number] = string;
4601 /* Reinitialize for a new argument. */
4602 arg_going = 0;
4603 delete_this_arg = 0;
4604 this_is_output_file = 0;
4605 this_is_library_file = 0;
4606 break;
4608 case '%':
4609 switch (c = *p++)
4611 case 0:
4612 fatal ("spec '%s' invalid", spec);
4614 case 'b':
4615 obstack_grow (&obstack, input_basename, basename_length);
4616 arg_going = 1;
4617 break;
4619 case 'B':
4620 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4621 arg_going = 1;
4622 break;
4624 case 'd':
4625 delete_this_arg = 2;
4626 break;
4628 /* Dump out the directories specified with LIBRARY_PATH,
4629 followed by the absolute directories
4630 that we search for startfiles. */
4631 case 'D':
4633 struct prefix_list *pl = startfile_prefixes.plist;
4635 for (; pl; pl = pl->next)
4637 const char *no_suffix_multilib_dir;
4639 no_suffix_multilib_dir = pl->os_multilib ? multilib_os_dir
4640 : multilib_dir;
4641 /* Do not separate options, include non-multilibbed variant. */
4642 do_spec_path (pl, "-L",
4643 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4645 #else
4647 #endif
4648 0, 0, multilib_dir, no_suffix_multilib_dir);
4651 break;
4653 case 'e':
4654 /* %efoo means report an error with `foo' as error message
4655 and don't execute any more commands for this file. */
4657 const char *q = p;
4658 char *buf;
4659 while (*p != 0 && *p != '\n')
4660 p++;
4661 buf = alloca (p - q + 1);
4662 strncpy (buf, q, p - q);
4663 buf[p - q] = 0;
4664 error ("%s", buf);
4665 return -1;
4667 break;
4668 case 'n':
4669 /* %nfoo means report a notice with `foo' on stderr. */
4671 const char *q = p;
4672 char *buf;
4673 while (*p != 0 && *p != '\n')
4674 p++;
4675 buf = alloca (p - q + 1);
4676 strncpy (buf, q, p - q);
4677 buf[p - q] = 0;
4678 notice ("%s\n", buf);
4679 if (*p)
4680 p++;
4682 break;
4684 case 'j':
4686 struct stat st;
4688 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4689 defined, and it is not a directory, and it is
4690 writable, use it. Otherwise, treat this like any
4691 other temporary file. */
4693 if ((!save_temps_flag)
4694 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4695 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4697 obstack_grow (&obstack, HOST_BIT_BUCKET,
4698 strlen (HOST_BIT_BUCKET));
4699 delete_this_arg = 0;
4700 arg_going = 1;
4701 break;
4704 goto create_temp_file;
4705 case '|':
4706 if (use_pipes)
4708 obstack_1grow (&obstack, '-');
4709 delete_this_arg = 0;
4710 arg_going = 1;
4712 /* consume suffix */
4713 while (*p == '.' || ISALNUM ((unsigned char) *p))
4714 p++;
4715 if (p[0] == '%' && p[1] == 'O')
4716 p += 2;
4718 break;
4720 goto create_temp_file;
4721 case 'm':
4722 if (use_pipes)
4724 /* consume suffix */
4725 while (*p == '.' || ISALNUM ((unsigned char) *p))
4726 p++;
4727 if (p[0] == '%' && p[1] == 'O')
4728 p += 2;
4730 break;
4732 goto create_temp_file;
4733 case 'g':
4734 case 'u':
4735 case 'U':
4736 create_temp_file:
4738 struct temp_name *t;
4739 int suffix_length;
4740 const char *suffix = p;
4741 char *saved_suffix = NULL;
4743 while (*p == '.' || ISALNUM ((unsigned char) *p))
4744 p++;
4745 suffix_length = p - suffix;
4746 if (p[0] == '%' && p[1] == 'O')
4748 p += 2;
4749 /* We don't support extra suffix characters after %O. */
4750 if (*p == '.' || ISALNUM ((unsigned char) *p))
4751 fatal ("spec '%s' has invalid '%%0%c'", spec, *p);
4752 if (suffix_length == 0)
4753 suffix = TARGET_OBJECT_SUFFIX;
4754 else
4756 saved_suffix
4757 = xmalloc (suffix_length
4758 + strlen (TARGET_OBJECT_SUFFIX));
4759 strncpy (saved_suffix, suffix, suffix_length);
4760 strcpy (saved_suffix + suffix_length,
4761 TARGET_OBJECT_SUFFIX);
4763 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4766 /* If the input_filename has the same suffix specified
4767 for the %g, %u, or %U, and -save-temps is specified,
4768 we could end up using that file as an intermediate
4769 thus clobbering the user's source file (.e.g.,
4770 gcc -save-temps foo.s would clobber foo.s with the
4771 output of cpp0). So check for this condition and
4772 generate a temp file as the intermediate. */
4774 if (save_temps_flag)
4776 temp_filename_length = basename_length + suffix_length;
4777 temp_filename = alloca (temp_filename_length + 1);
4778 strncpy ((char *) temp_filename, input_basename, basename_length);
4779 strncpy ((char *) temp_filename + basename_length, suffix,
4780 suffix_length);
4781 *((char *) temp_filename + temp_filename_length) = '\0';
4782 if (strcmp (temp_filename, input_filename) != 0)
4784 #ifndef HOST_LACKS_INODE_NUMBERS
4785 struct stat st_temp;
4787 /* Note, set_input() resets input_stat_set to 0. */
4788 if (input_stat_set == 0)
4790 input_stat_set = stat (input_filename, &input_stat);
4791 if (input_stat_set >= 0)
4792 input_stat_set = 1;
4795 /* If we have the stat for the input_filename
4796 and we can do the stat for the temp_filename
4797 then the they could still refer to the same
4798 file if st_dev/st_ino's are the same. */
4799 if (input_stat_set != 1
4800 || stat (temp_filename, &st_temp) < 0
4801 || input_stat.st_dev != st_temp.st_dev
4802 || input_stat.st_ino != st_temp.st_ino)
4803 #else
4804 /* Just compare canonical pathnames. */
4805 char* input_realname = lrealpath (input_filename);
4806 char* temp_realname = lrealpath (temp_filename);
4807 bool files_differ = strcmp (input_realname, temp_realname);
4808 free (input_realname);
4809 free (temp_realname);
4810 if (files_differ)
4811 #endif
4813 temp_filename = save_string (temp_filename,
4814 temp_filename_length + 1);
4815 obstack_grow (&obstack, temp_filename,
4816 temp_filename_length);
4817 arg_going = 1;
4818 delete_this_arg = 0;
4819 break;
4824 /* See if we already have an association of %g/%u/%U and
4825 suffix. */
4826 for (t = temp_names; t; t = t->next)
4827 if (t->length == suffix_length
4828 && strncmp (t->suffix, suffix, suffix_length) == 0
4829 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4830 break;
4832 /* Make a new association if needed. %u and %j
4833 require one. */
4834 if (t == 0 || c == 'u' || c == 'j')
4836 if (t == 0)
4838 t = xmalloc (sizeof (struct temp_name));
4839 t->next = temp_names;
4840 temp_names = t;
4842 t->length = suffix_length;
4843 if (saved_suffix)
4845 t->suffix = saved_suffix;
4846 saved_suffix = NULL;
4848 else
4849 t->suffix = save_string (suffix, suffix_length);
4850 t->unique = (c == 'u' || c == 'U' || c == 'j');
4851 temp_filename = make_temp_file (t->suffix);
4852 temp_filename_length = strlen (temp_filename);
4853 t->filename = temp_filename;
4854 t->filename_length = temp_filename_length;
4857 if (saved_suffix)
4858 free (saved_suffix);
4860 obstack_grow (&obstack, t->filename, t->filename_length);
4861 delete_this_arg = 1;
4863 arg_going = 1;
4864 break;
4866 case 'i':
4867 if (combine_inputs)
4869 for (i = 0; (int) i < n_infiles; i++)
4870 if ((!infiles[i].language) || (infiles[i].language[0] != '*'))
4871 if (infiles[i].incompiler == input_file_compiler)
4873 store_arg (infiles[i].name, 0, 0);
4874 infiles[i].compiled = true;
4877 else
4879 obstack_grow (&obstack, input_filename, input_filename_length);
4880 arg_going = 1;
4882 break;
4884 case 'I':
4886 struct prefix_list *pl = include_prefixes.plist;
4888 if (gcc_exec_prefix)
4890 do_spec_1 ("-iprefix", 1, NULL);
4891 /* Make this a separate argument. */
4892 do_spec_1 (" ", 0, NULL);
4893 do_spec_1 (gcc_exec_prefix, 1, NULL);
4894 do_spec_1 (" ", 0, NULL);
4897 if (target_system_root_changed ||
4898 (target_system_root && target_sysroot_hdrs_suffix))
4900 do_spec_1 ("-isysroot", 1, NULL);
4901 /* Make this a separate argument. */
4902 do_spec_1 (" ", 0, NULL);
4903 do_spec_1 (target_system_root, 1, NULL);
4904 if (target_sysroot_hdrs_suffix)
4905 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4906 do_spec_1 (" ", 0, NULL);
4909 for (; pl; pl = pl->next)
4910 /* Separate options, don't include non-suffixed variant. */
4911 do_spec_path (pl, "-isystem", 0, 1, 1, "include", "include");
4913 break;
4915 case 'o':
4917 int max = n_infiles;
4918 max += lang_specific_extra_outfiles;
4920 for (i = 0; i < max; i++)
4921 if (outfiles[i])
4922 store_arg (outfiles[i], 0, 0);
4923 break;
4926 case 'O':
4927 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4928 arg_going = 1;
4929 break;
4931 case 's':
4932 this_is_library_file = 1;
4933 break;
4935 case 'V':
4936 outfiles[input_file_number] = NULL;
4937 break;
4939 case 'w':
4940 this_is_output_file = 1;
4941 break;
4943 case 'W':
4945 int cur_index = argbuf_index;
4946 /* Handle the {...} following the %W. */
4947 if (*p != '{')
4948 fatal ("spec '%s' has invalid '%%W%c", spec, *p);
4949 p = handle_braces (p + 1);
4950 if (p == 0)
4951 return -1;
4952 /* End any pending argument. */
4953 if (arg_going)
4955 obstack_1grow (&obstack, 0);
4956 string = XOBFINISH (&obstack, const char *);
4957 if (this_is_library_file)
4958 string = find_file (string);
4959 store_arg (string, delete_this_arg, this_is_output_file);
4960 if (this_is_output_file)
4961 outfiles[input_file_number] = string;
4962 arg_going = 0;
4964 /* If any args were output, mark the last one for deletion
4965 on failure. */
4966 if (argbuf_index != cur_index)
4967 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4968 break;
4971 /* %x{OPTION} records OPTION for %X to output. */
4972 case 'x':
4974 const char *p1 = p;
4975 char *string;
4977 /* Skip past the option value and make a copy. */
4978 if (*p != '{')
4979 fatal ("spec '%s' has invalid '%%x%c'", spec, *p);
4980 while (*p++ != '}')
4982 string = save_string (p1 + 1, p - p1 - 2);
4984 /* See if we already recorded this option. */
4985 for (i = 0; i < n_linker_options; i++)
4986 if (! strcmp (string, linker_options[i]))
4988 free (string);
4989 return 0;
4992 /* This option is new; add it. */
4993 add_linker_option (string, strlen (string));
4995 break;
4997 /* Dump out the options accumulated previously using %x. */
4998 case 'X':
4999 for (i = 0; i < n_linker_options; i++)
5001 do_spec_1 (linker_options[i], 1, NULL);
5002 /* Make each accumulated option a separate argument. */
5003 do_spec_1 (" ", 0, NULL);
5005 break;
5007 /* Dump out the options accumulated previously using -Wa,. */
5008 case 'Y':
5009 for (i = 0; i < n_assembler_options; i++)
5011 do_spec_1 (assembler_options[i], 1, NULL);
5012 /* Make each accumulated option a separate argument. */
5013 do_spec_1 (" ", 0, NULL);
5015 break;
5017 /* Dump out the options accumulated previously using -Wp,. */
5018 case 'Z':
5019 for (i = 0; i < n_preprocessor_options; i++)
5021 do_spec_1 (preprocessor_options[i], 1, NULL);
5022 /* Make each accumulated option a separate argument. */
5023 do_spec_1 (" ", 0, NULL);
5025 break;
5027 /* Here are digits and numbers that just process
5028 a certain constant string as a spec. */
5030 case '1':
5031 value = do_spec_1 (cc1_spec, 0, NULL);
5032 if (value != 0)
5033 return value;
5034 break;
5036 case '2':
5037 value = do_spec_1 (cc1plus_spec, 0, NULL);
5038 if (value != 0)
5039 return value;
5040 break;
5042 case 'a':
5043 value = do_spec_1 (asm_spec, 0, NULL);
5044 if (value != 0)
5045 return value;
5046 break;
5048 case 'A':
5049 value = do_spec_1 (asm_final_spec, 0, NULL);
5050 if (value != 0)
5051 return value;
5052 break;
5054 case 'C':
5056 const char *const spec
5057 = (input_file_compiler->cpp_spec
5058 ? input_file_compiler->cpp_spec
5059 : cpp_spec);
5060 value = do_spec_1 (spec, 0, NULL);
5061 if (value != 0)
5062 return value;
5064 break;
5066 case 'E':
5067 value = do_spec_1 (endfile_spec, 0, NULL);
5068 if (value != 0)
5069 return value;
5070 break;
5072 case 'l':
5073 value = do_spec_1 (link_spec, 0, NULL);
5074 if (value != 0)
5075 return value;
5076 break;
5078 case 'L':
5079 value = do_spec_1 (lib_spec, 0, NULL);
5080 if (value != 0)
5081 return value;
5082 break;
5084 case 'G':
5085 value = do_spec_1 (libgcc_spec, 0, NULL);
5086 if (value != 0)
5087 return value;
5088 break;
5090 case 'R':
5091 /* We assume there is a directory
5092 separator at the end of this string. */
5093 if (target_system_root)
5095 obstack_grow (&obstack, target_system_root,
5096 strlen (target_system_root));
5097 if (target_sysroot_suffix)
5098 obstack_grow (&obstack, target_sysroot_suffix,
5099 strlen (target_sysroot_suffix));
5101 break;
5103 case 'S':
5104 value = do_spec_1 (startfile_spec, 0, NULL);
5105 if (value != 0)
5106 return value;
5107 break;
5109 /* Here we define characters other than letters and digits. */
5111 case '{':
5112 p = handle_braces (p);
5113 if (p == 0)
5114 return -1;
5115 break;
5117 case ':':
5118 p = handle_spec_function (p);
5119 if (p == 0)
5120 return -1;
5121 break;
5123 case '%':
5124 obstack_1grow (&obstack, '%');
5125 break;
5127 case '.':
5129 unsigned len = 0;
5131 while (p[len] && p[len] != ' ' && p[len] != '%')
5132 len++;
5133 suffix_subst = save_string (p - 1, len + 1);
5134 p += len;
5136 break;
5138 /* Henceforth ignore the option(s) matching the pattern
5139 after the %<. */
5140 case '<':
5142 unsigned len = 0;
5143 int have_wildcard = 0;
5144 int i;
5146 while (p[len] && p[len] != ' ' && p[len] != '\t')
5147 len++;
5149 if (p[len-1] == '*')
5150 have_wildcard = 1;
5152 for (i = 0; i < n_switches; i++)
5153 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5154 && (have_wildcard || switches[i].part1[len] == '\0'))
5156 switches[i].live_cond = SWITCH_IGNORE;
5157 switches[i].validated = 1;
5160 p += len;
5162 break;
5164 case '*':
5165 if (soft_matched_part)
5167 do_spec_1 (soft_matched_part, 1, NULL);
5168 do_spec_1 (" ", 0, NULL);
5170 else
5171 /* Catch the case where a spec string contains something like
5172 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5173 hand side of the :. */
5174 error ("spec failure: '%%*' has not been initialized by pattern match");
5175 break;
5177 /* Process a string found as the value of a spec given by name.
5178 This feature allows individual machine descriptions
5179 to add and use their own specs.
5180 %[...] modifies -D options the way %P does;
5181 %(...) uses the spec unmodified. */
5182 case '[':
5183 error ("warning: use of obsolete %%[ operator in specs");
5184 case '(':
5186 const char *name = p;
5187 struct spec_list *sl;
5188 int len;
5190 /* The string after the S/P is the name of a spec that is to be
5191 processed. */
5192 while (*p && *p != ')' && *p != ']')
5193 p++;
5195 /* See if it's in the list. */
5196 for (len = p - name, sl = specs; sl; sl = sl->next)
5197 if (sl->name_len == len && !strncmp (sl->name, name, len))
5199 name = *(sl->ptr_spec);
5200 #ifdef DEBUG_SPECS
5201 notice ("Processing spec %c%s%c, which is '%s'\n",
5202 c, sl->name, (c == '(') ? ')' : ']', name);
5203 #endif
5204 break;
5207 if (sl)
5209 if (c == '(')
5211 value = do_spec_1 (name, 0, NULL);
5212 if (value != 0)
5213 return value;
5215 else
5217 char *x = alloca (strlen (name) * 2 + 1);
5218 char *buf = x;
5219 const char *y = name;
5220 int flag = 0;
5222 /* Copy all of NAME into BUF, but put __ after
5223 every -D and at the end of each arg. */
5224 while (1)
5226 if (! strncmp (y, "-D", 2))
5228 *x++ = '-';
5229 *x++ = 'D';
5230 *x++ = '_';
5231 *x++ = '_';
5232 y += 2;
5233 flag = 1;
5234 continue;
5236 else if (flag
5237 && (*y == ' ' || *y == '\t' || *y == '='
5238 || *y == '}' || *y == 0))
5240 *x++ = '_';
5241 *x++ = '_';
5242 flag = 0;
5244 if (*y == 0)
5245 break;
5246 else
5247 *x++ = *y++;
5249 *x = 0;
5251 value = do_spec_1 (buf, 0, NULL);
5252 if (value != 0)
5253 return value;
5257 /* Discard the closing paren or bracket. */
5258 if (*p)
5259 p++;
5261 break;
5263 default:
5264 error ("spec failure: unrecognized spec option '%c'", c);
5265 break;
5267 break;
5269 case '\\':
5270 /* Backslash: treat next character as ordinary. */
5271 c = *p++;
5273 /* Fall through. */
5274 default:
5275 /* Ordinary character: put it into the current argument. */
5276 obstack_1grow (&obstack, c);
5277 arg_going = 1;
5280 /* End of string. If we are processing a spec function, we need to
5281 end any pending argument. */
5282 if (processing_spec_function && arg_going)
5284 obstack_1grow (&obstack, 0);
5285 string = XOBFINISH (&obstack, const char *);
5286 if (this_is_library_file)
5287 string = find_file (string);
5288 store_arg (string, delete_this_arg, this_is_output_file);
5289 if (this_is_output_file)
5290 outfiles[input_file_number] = string;
5291 arg_going = 0;
5294 return 0;
5297 /* Look up a spec function. */
5299 static const struct spec_function *
5300 lookup_spec_function (const char *name)
5302 static const struct spec_function * const spec_function_tables[] =
5304 static_spec_functions,
5305 lang_specific_spec_functions,
5307 const struct spec_function *sf;
5308 unsigned int i;
5310 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5312 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5313 if (strcmp (sf->name, name) == 0)
5314 return sf;
5317 return NULL;
5320 /* Evaluate a spec function. */
5322 static const char *
5323 eval_spec_function (const char *func, const char *args)
5325 const struct spec_function *sf;
5326 const char *funcval;
5328 /* Saved spec processing context. */
5329 int save_argbuf_index;
5330 int save_argbuf_length;
5331 const char **save_argbuf;
5333 int save_arg_going;
5334 int save_delete_this_arg;
5335 int save_this_is_output_file;
5336 int save_this_is_library_file;
5337 int save_input_from_pipe;
5338 const char *save_suffix_subst;
5341 sf = lookup_spec_function (func);
5342 if (sf == NULL)
5343 fatal ("unknown spec function '%s'", func);
5345 /* Push the spec processing context. */
5346 save_argbuf_index = argbuf_index;
5347 save_argbuf_length = argbuf_length;
5348 save_argbuf = argbuf;
5350 save_arg_going = arg_going;
5351 save_delete_this_arg = delete_this_arg;
5352 save_this_is_output_file = this_is_output_file;
5353 save_this_is_library_file = this_is_library_file;
5354 save_input_from_pipe = input_from_pipe;
5355 save_suffix_subst = suffix_subst;
5357 /* Create a new spec processing context, and build the function
5358 arguments. */
5360 alloc_args ();
5361 if (do_spec_2 (args) < 0)
5362 fatal ("error in args to spec function '%s'", func);
5364 /* argbuf_index is an index for the next argument to be inserted, and
5365 so contains the count of the args already inserted. */
5367 funcval = (*sf->func) (argbuf_index, argbuf);
5369 /* Pop the spec processing context. */
5370 argbuf_index = save_argbuf_index;
5371 argbuf_length = save_argbuf_length;
5372 free (argbuf);
5373 argbuf = save_argbuf;
5375 arg_going = save_arg_going;
5376 delete_this_arg = save_delete_this_arg;
5377 this_is_output_file = save_this_is_output_file;
5378 this_is_library_file = save_this_is_library_file;
5379 input_from_pipe = save_input_from_pipe;
5380 suffix_subst = save_suffix_subst;
5382 return funcval;
5385 /* Handle a spec function call of the form:
5387 %:function(args)
5389 ARGS is processed as a spec in a separate context and split into an
5390 argument vector in the normal fashion. The function returns a string
5391 containing a spec which we then process in the caller's context, or
5392 NULL if no processing is required. */
5394 static const char *
5395 handle_spec_function (const char *p)
5397 char *func, *args;
5398 const char *endp, *funcval;
5399 int count;
5401 processing_spec_function++;
5403 /* Get the function name. */
5404 for (endp = p; *endp != '\0'; endp++)
5406 if (*endp == '(') /* ) */
5407 break;
5408 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5409 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5410 fatal ("malformed spec function name");
5412 if (*endp != '(') /* ) */
5413 fatal ("no arguments for spec function");
5414 func = save_string (p, endp - p);
5415 p = ++endp;
5417 /* Get the arguments. */
5418 for (count = 0; *endp != '\0'; endp++)
5420 /* ( */
5421 if (*endp == ')')
5423 if (count == 0)
5424 break;
5425 count--;
5427 else if (*endp == '(') /* ) */
5428 count++;
5430 /* ( */
5431 if (*endp != ')')
5432 fatal ("malformed spec function arguments");
5433 args = save_string (p, endp - p);
5434 p = ++endp;
5436 /* p now points to just past the end of the spec function expression. */
5438 funcval = eval_spec_function (func, args);
5439 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5440 p = NULL;
5442 free (func);
5443 free (args);
5445 processing_spec_function--;
5447 return p;
5450 /* Inline subroutine of handle_braces. Returns true if the current
5451 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5452 static inline bool
5453 input_suffix_matches (const char *atom, const char *end_atom)
5455 /* We special case the semantics of {.s:...} and {.S:...} and their
5456 negative variants. Instead of testing the input filename suffix,
5457 we test whether the input source file is an assembler file or an
5458 assembler-with-cpp file respectively. This allows us to correctly
5459 handle the -x command line option. */
5461 if (atom + 1 == end_atom
5462 && input_file_compiler
5463 && input_file_compiler->suffix)
5465 if (*atom == 's')
5466 return !strcmp (input_file_compiler->suffix, "@assembler");
5467 if (*atom == 'S')
5468 return !strcmp (input_file_compiler->suffix, "@assembler-with-cpp");
5471 return (input_suffix
5472 && !strncmp (input_suffix, atom, end_atom - atom)
5473 && input_suffix[end_atom - atom] == '\0');
5476 /* Inline subroutine of handle_braces. Returns true if a switch
5477 matching the atom bracketed by ATOM and END_ATOM appeared on the
5478 command line. */
5479 static inline bool
5480 switch_matches (const char *atom, const char *end_atom, int starred)
5482 int i;
5483 int len = end_atom - atom;
5484 int plen = starred ? len : -1;
5486 for (i = 0; i < n_switches; i++)
5487 if (!strncmp (switches[i].part1, atom, len)
5488 && (starred || switches[i].part1[len] == '\0')
5489 && check_live_switch (i, plen))
5490 return true;
5492 return false;
5495 /* Inline subroutine of handle_braces. Mark all of the switches which
5496 match ATOM (extends to END_ATOM; STARRED indicates whether there
5497 was a star after the atom) for later processing. */
5498 static inline void
5499 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5501 int i;
5502 int len = end_atom - atom;
5503 int plen = starred ? len : -1;
5505 for (i = 0; i < n_switches; i++)
5506 if (!strncmp (switches[i].part1, atom, len)
5507 && (starred || switches[i].part1[len] == '\0')
5508 && check_live_switch (i, plen))
5509 switches[i].ordering = 1;
5512 /* Inline subroutine of handle_braces. Process all the currently
5513 marked switches through give_switch, and clear the marks. */
5514 static inline void
5515 process_marked_switches (void)
5517 int i;
5519 for (i = 0; i < n_switches; i++)
5520 if (switches[i].ordering == 1)
5522 switches[i].ordering = 0;
5523 give_switch (i, 0);
5527 /* Handle a %{ ... } construct. P points just inside the leading {.
5528 Returns a pointer one past the end of the brace block, or 0
5529 if we call do_spec_1 and that returns -1. */
5531 static const char *
5532 handle_braces (const char *p)
5534 const char *atom, *end_atom;
5535 const char *d_atom = NULL, *d_end_atom = NULL;
5536 const char *orig = p;
5538 bool a_is_suffix;
5539 bool a_is_starred;
5540 bool a_is_negated;
5541 bool a_matched;
5543 bool a_must_be_last = false;
5544 bool ordered_set = false;
5545 bool disjunct_set = false;
5546 bool disj_matched = false;
5547 bool disj_starred = true;
5548 bool n_way_choice = false;
5549 bool n_way_matched = false;
5551 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5555 if (a_must_be_last)
5556 goto invalid;
5558 /* Scan one "atom" (S in the description above of %{}, possibly
5559 with !, ., or * modifiers). */
5560 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5562 SKIP_WHITE();
5563 if (*p == '!')
5564 p++, a_is_negated = true;
5566 SKIP_WHITE();
5567 if (*p == '.')
5568 p++, a_is_suffix = true;
5570 atom = p;
5571 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5572 || *p == ',' || *p == '.' || *p == '@')
5573 p++;
5574 end_atom = p;
5576 if (*p == '*')
5577 p++, a_is_starred = 1;
5579 SKIP_WHITE();
5580 switch (*p)
5582 case '&': case '}':
5583 /* Substitute the switch(es) indicated by the current atom. */
5584 ordered_set = true;
5585 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5586 || atom == end_atom)
5587 goto invalid;
5589 mark_matching_switches (atom, end_atom, a_is_starred);
5591 if (*p == '}')
5592 process_marked_switches ();
5593 break;
5595 case '|': case ':':
5596 /* Substitute some text if the current atom appears as a switch
5597 or suffix. */
5598 disjunct_set = true;
5599 if (ordered_set)
5600 goto invalid;
5602 if (atom == end_atom)
5604 if (!n_way_choice || disj_matched || *p == '|'
5605 || a_is_negated || a_is_suffix || a_is_starred)
5606 goto invalid;
5608 /* An empty term may appear as the last choice of an
5609 N-way choice set; it means "otherwise". */
5610 a_must_be_last = true;
5611 disj_matched = !n_way_matched;
5612 disj_starred = false;
5614 else
5616 if (a_is_suffix && a_is_starred)
5617 goto invalid;
5619 if (!a_is_starred)
5620 disj_starred = false;
5622 /* Don't bother testing this atom if we already have a
5623 match. */
5624 if (!disj_matched && !n_way_matched)
5626 if (a_is_suffix)
5627 a_matched = input_suffix_matches (atom, end_atom);
5628 else
5629 a_matched = switch_matches (atom, end_atom, a_is_starred);
5631 if (a_matched != a_is_negated)
5633 disj_matched = true;
5634 d_atom = atom;
5635 d_end_atom = end_atom;
5640 if (*p == ':')
5642 /* Found the body, that is, the text to substitute if the
5643 current disjunction matches. */
5644 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5645 disj_matched && !n_way_matched);
5646 if (p == 0)
5647 return 0;
5649 /* If we have an N-way choice, reset state for the next
5650 disjunction. */
5651 if (*p == ';')
5653 n_way_choice = true;
5654 n_way_matched |= disj_matched;
5655 disj_matched = false;
5656 disj_starred = true;
5657 d_atom = d_end_atom = NULL;
5660 break;
5662 default:
5663 goto invalid;
5666 while (*p++ != '}');
5668 return p;
5670 invalid:
5671 fatal ("braced spec '%s' is invalid at '%c'", orig, *p);
5673 #undef SKIP_WHITE
5676 /* Subroutine of handle_braces. Scan and process a brace substitution body
5677 (X in the description of %{} syntax). P points one past the colon;
5678 ATOM and END_ATOM bracket the first atom which was found to be true
5679 (present) in the current disjunction; STARRED indicates whether all
5680 the atoms in the current disjunction were starred (for syntax validation);
5681 MATCHED indicates whether the disjunction matched or not, and therefore
5682 whether or not the body is to be processed through do_spec_1 or just
5683 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5684 returns -1. */
5686 static const char *
5687 process_brace_body (const char *p, const char *atom, const char *end_atom,
5688 int starred, int matched)
5690 const char *body, *end_body;
5691 unsigned int nesting_level;
5692 bool have_subst = false;
5694 /* Locate the closing } or ;, honoring nested braces.
5695 Trim trailing whitespace. */
5696 body = p;
5697 nesting_level = 1;
5698 for (;;)
5700 if (*p == '{')
5701 nesting_level++;
5702 else if (*p == '}')
5704 if (!--nesting_level)
5705 break;
5707 else if (*p == ';' && nesting_level == 1)
5708 break;
5709 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5710 have_subst = true;
5711 else if (*p == '\0')
5712 goto invalid;
5713 p++;
5716 end_body = p;
5717 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5718 end_body--;
5720 if (have_subst && !starred)
5721 goto invalid;
5723 if (matched)
5725 /* Copy the substitution body to permanent storage and execute it.
5726 If have_subst is false, this is a simple matter of running the
5727 body through do_spec_1... */
5728 char *string = save_string (body, end_body - body);
5729 if (!have_subst)
5731 if (do_spec_1 (string, 0, NULL) < 0)
5732 return 0;
5734 else
5736 /* ... but if have_subst is true, we have to process the
5737 body once for each matching switch, with %* set to the
5738 variant part of the switch. */
5739 unsigned int hard_match_len = end_atom - atom;
5740 int i;
5742 for (i = 0; i < n_switches; i++)
5743 if (!strncmp (switches[i].part1, atom, hard_match_len)
5744 && check_live_switch (i, hard_match_len))
5746 if (do_spec_1 (string, 0,
5747 &switches[i].part1[hard_match_len]) < 0)
5748 return 0;
5749 /* Pass any arguments this switch has. */
5750 give_switch (i, 1);
5751 suffix_subst = NULL;
5756 return p;
5758 invalid:
5759 fatal ("braced spec body '%s' is invalid", body);
5762 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5763 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5764 spec, or -1 if either exact match or %* is used.
5766 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5767 whose value does not begin with "no-" is obsoleted by the same value
5768 with the "no-", similarly for a switch with the "no-" prefix. */
5770 static int
5771 check_live_switch (int switchnum, int prefix_length)
5773 const char *name = switches[switchnum].part1;
5774 int i;
5776 /* In the common case of {<at-most-one-letter>*}, a negating
5777 switch would always match, so ignore that case. We will just
5778 send the conflicting switches to the compiler phase. */
5779 if (prefix_length >= 0 && prefix_length <= 1)
5780 return 1;
5782 /* If we already processed this switch and determined if it was
5783 live or not, return our past determination. */
5784 if (switches[switchnum].live_cond != 0)
5785 return switches[switchnum].live_cond > 0;
5787 /* Now search for duplicate in a manner that depends on the name. */
5788 switch (*name)
5790 case 'O':
5791 for (i = switchnum + 1; i < n_switches; i++)
5792 if (switches[i].part1[0] == 'O')
5794 switches[switchnum].validated = 1;
5795 switches[switchnum].live_cond = SWITCH_FALSE;
5796 return 0;
5798 break;
5800 case 'W': case 'f': case 'm':
5801 if (! strncmp (name + 1, "no-", 3))
5803 /* We have Xno-YYY, search for XYYY. */
5804 for (i = switchnum + 1; i < n_switches; i++)
5805 if (switches[i].part1[0] == name[0]
5806 && ! strcmp (&switches[i].part1[1], &name[4]))
5808 switches[switchnum].validated = 1;
5809 switches[switchnum].live_cond = SWITCH_FALSE;
5810 return 0;
5813 else
5815 /* We have XYYY, search for Xno-YYY. */
5816 for (i = switchnum + 1; i < n_switches; i++)
5817 if (switches[i].part1[0] == name[0]
5818 && switches[i].part1[1] == 'n'
5819 && switches[i].part1[2] == 'o'
5820 && switches[i].part1[3] == '-'
5821 && !strcmp (&switches[i].part1[4], &name[1]))
5823 switches[switchnum].validated = 1;
5824 switches[switchnum].live_cond = SWITCH_FALSE;
5825 return 0;
5828 break;
5831 /* Otherwise the switch is live. */
5832 switches[switchnum].live_cond = SWITCH_LIVE;
5833 return 1;
5836 /* Pass a switch to the current accumulating command
5837 in the same form that we received it.
5838 SWITCHNUM identifies the switch; it is an index into
5839 the vector of switches gcc received, which is `switches'.
5840 This cannot fail since it never finishes a command line.
5842 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5844 static void
5845 give_switch (int switchnum, int omit_first_word)
5847 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5848 return;
5850 if (!omit_first_word)
5852 do_spec_1 ("-", 0, NULL);
5853 do_spec_1 (switches[switchnum].part1, 1, NULL);
5856 if (switches[switchnum].args != 0)
5858 const char **p;
5859 for (p = switches[switchnum].args; *p; p++)
5861 const char *arg = *p;
5863 do_spec_1 (" ", 0, NULL);
5864 if (suffix_subst)
5866 unsigned length = strlen (arg);
5867 int dot = 0;
5869 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5870 if (arg[length] == '.')
5872 ((char *)arg)[length] = 0;
5873 dot = 1;
5874 break;
5876 do_spec_1 (arg, 1, NULL);
5877 if (dot)
5878 ((char *)arg)[length] = '.';
5879 do_spec_1 (suffix_subst, 1, NULL);
5881 else
5882 do_spec_1 (arg, 1, NULL);
5886 do_spec_1 (" ", 0, NULL);
5887 switches[switchnum].validated = 1;
5890 /* Search for a file named NAME trying various prefixes including the
5891 user's -B prefix and some standard ones.
5892 Return the absolute file name found. If nothing is found, return NAME. */
5894 static const char *
5895 find_file (const char *name)
5897 char *newname;
5899 /* Try multilib_dir if it is defined. */
5900 if (multilib_os_dir != NULL)
5902 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
5904 /* If we don't find it in the multi library dir, then fall
5905 through and look for it in the normal places. */
5906 if (newname != NULL)
5907 return newname;
5910 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
5911 return newname ? newname : name;
5914 /* Determine whether a directory exists. If LINKER, return 0 for
5915 certain fixed names not needed by the linker. If not LINKER, it is
5916 only important to return 0 if the host machine has a small ARG_MAX
5917 limit. */
5919 static int
5920 is_directory (const char *path1, const char *path2, int linker)
5922 int len1 = strlen (path1);
5923 int len2 = strlen (path2);
5924 char *path = alloca (3 + len1 + len2);
5925 char *cp;
5926 struct stat st;
5928 #ifndef SMALL_ARG_MAX
5929 if (! linker)
5930 return 1;
5931 #endif
5933 /* Construct the path from the two parts. Ensure the string ends with "/.".
5934 The resulting path will be a directory even if the given path is a
5935 symbolic link. */
5936 memcpy (path, path1, len1);
5937 memcpy (path + len1, path2, len2);
5938 cp = path + len1 + len2;
5939 if (!IS_DIR_SEPARATOR (cp[-1]))
5940 *cp++ = DIR_SEPARATOR;
5941 *cp++ = '.';
5942 *cp = '\0';
5944 /* Exclude directories that the linker is known to search. */
5945 if (linker
5946 && ((cp - path == 6
5947 && strcmp (path, concat (dir_separator_str, "lib",
5948 dir_separator_str, ".", NULL)) == 0)
5949 || (cp - path == 10
5950 && strcmp (path, concat (dir_separator_str, "usr",
5951 dir_separator_str, "lib",
5952 dir_separator_str, ".", NULL)) == 0)))
5953 return 0;
5955 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5958 /* Set up the various global variables to indicate that we're processing
5959 the input file named FILENAME. */
5961 void
5962 set_input (const char *filename)
5964 const char *p;
5966 input_filename = filename;
5967 input_filename_length = strlen (input_filename);
5969 input_basename = input_filename;
5970 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5971 /* Skip drive name so 'x:foo' is handled properly. */
5972 if (input_basename[1] == ':')
5973 input_basename += 2;
5974 #endif
5975 for (p = input_basename; *p; p++)
5976 if (IS_DIR_SEPARATOR (*p))
5977 input_basename = p + 1;
5979 /* Find a suffix starting with the last period,
5980 and set basename_length to exclude that suffix. */
5981 basename_length = strlen (input_basename);
5982 suffixed_basename_length = basename_length;
5983 p = input_basename + basename_length;
5984 while (p != input_basename && *p != '.')
5985 --p;
5986 if (*p == '.' && p != input_basename)
5988 basename_length = p - input_basename;
5989 input_suffix = p + 1;
5991 else
5992 input_suffix = "";
5994 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5995 we will need to do a stat on the input_filename. The
5996 INPUT_STAT_SET signals that the stat is needed. */
5997 input_stat_set = 0;
6000 /* On fatal signals, delete all the temporary files. */
6002 static void
6003 fatal_error (int signum)
6005 signal (signum, SIG_DFL);
6006 delete_failure_queue ();
6007 delete_temp_files ();
6008 /* Get the same signal again, this time not handled,
6009 so its normal effect occurs. */
6010 kill (getpid (), signum);
6013 extern int main (int, char **);
6016 main (int argc, char **argv)
6018 size_t i;
6019 int value;
6020 int linker_was_run = 0;
6021 int lang_n_infiles = 0;
6022 int num_linker_inputs = 0;
6023 char *explicit_link_files;
6024 char *specs_file;
6025 const char *p;
6026 struct user_specs *uptr;
6028 p = argv[0] + strlen (argv[0]);
6029 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6030 --p;
6031 programname = p;
6033 xmalloc_set_program_name (programname);
6035 expandargv (&argc, &argv);
6037 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6038 /* Perform host dependent initialization when needed. */
6039 GCC_DRIVER_HOST_INITIALIZATION;
6040 #endif
6042 /* Unlock the stdio streams. */
6043 unlock_std_streams ();
6045 gcc_init_libintl ();
6047 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6048 signal (SIGINT, fatal_error);
6049 #ifdef SIGHUP
6050 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6051 signal (SIGHUP, fatal_error);
6052 #endif
6053 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6054 signal (SIGTERM, fatal_error);
6055 #ifdef SIGPIPE
6056 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6057 signal (SIGPIPE, fatal_error);
6058 #endif
6059 #ifdef SIGCHLD
6060 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6061 receive the signal. A different setting is inheritable */
6062 signal (SIGCHLD, SIG_DFL);
6063 #endif
6065 /* Allocate the argument vector. */
6066 alloc_args ();
6068 obstack_init (&obstack);
6070 /* Build multilib_select, et. al from the separate lines that make up each
6071 multilib selection. */
6073 const char *const *q = multilib_raw;
6074 int need_space;
6076 obstack_init (&multilib_obstack);
6077 while ((p = *q++) != (char *) 0)
6078 obstack_grow (&multilib_obstack, p, strlen (p));
6080 obstack_1grow (&multilib_obstack, 0);
6081 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6083 q = multilib_matches_raw;
6084 while ((p = *q++) != (char *) 0)
6085 obstack_grow (&multilib_obstack, p, strlen (p));
6087 obstack_1grow (&multilib_obstack, 0);
6088 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6090 q = multilib_exclusions_raw;
6091 while ((p = *q++) != (char *) 0)
6092 obstack_grow (&multilib_obstack, p, strlen (p));
6094 obstack_1grow (&multilib_obstack, 0);
6095 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6097 need_space = FALSE;
6098 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6100 if (need_space)
6101 obstack_1grow (&multilib_obstack, ' ');
6102 obstack_grow (&multilib_obstack,
6103 multilib_defaults_raw[i],
6104 strlen (multilib_defaults_raw[i]));
6105 need_space = TRUE;
6108 obstack_1grow (&multilib_obstack, 0);
6109 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6112 /* Set up to remember the pathname of gcc and any options
6113 needed for collect. We use argv[0] instead of programname because
6114 we need the complete pathname. */
6115 obstack_init (&collect_obstack);
6116 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6117 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6118 putenv (XOBFINISH (&collect_obstack, char *));
6120 #ifdef INIT_ENVIRONMENT
6121 /* Set up any other necessary machine specific environment variables. */
6122 putenv (INIT_ENVIRONMENT);
6123 #endif
6125 /* Make a table of what switches there are (switches, n_switches).
6126 Make a table of specified input files (infiles, n_infiles).
6127 Decode switches that are handled locally. */
6129 process_command (argc, (const char **) argv);
6131 /* Initialize the vector of specs to just the default.
6132 This means one element containing 0s, as a terminator. */
6134 compilers = xmalloc (sizeof default_compilers);
6135 memcpy (compilers, default_compilers, sizeof default_compilers);
6136 n_compilers = n_default_compilers;
6138 /* Read specs from a file if there is one. */
6140 machine_suffix = concat (spec_machine, dir_separator_str,
6141 spec_version, dir_separator_str, NULL);
6142 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6144 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6145 /* Read the specs file unless it is a default one. */
6146 if (specs_file != 0 && strcmp (specs_file, "specs"))
6147 read_specs (specs_file, TRUE);
6148 else
6149 init_spec ();
6151 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6152 for any override of as, ld and libraries. */
6153 specs_file = alloca (strlen (standard_exec_prefix)
6154 + strlen (just_machine_suffix) + sizeof ("specs"));
6156 strcpy (specs_file, standard_exec_prefix);
6157 strcat (specs_file, just_machine_suffix);
6158 strcat (specs_file, "specs");
6159 if (access (specs_file, R_OK) == 0)
6160 read_specs (specs_file, TRUE);
6162 /* Process any configure-time defaults specified for the command line
6163 options, via OPTION_DEFAULT_SPECS. */
6164 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6165 do_option_spec (option_default_specs[i].name,
6166 option_default_specs[i].spec);
6168 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6169 of the command line. */
6171 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6172 do_self_spec (driver_self_specs[i]);
6174 /* If not cross-compiling, look for executables in the standard
6175 places. */
6176 if (*cross_compile == '0')
6178 if (*md_exec_prefix)
6180 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6181 PREFIX_PRIORITY_LAST, 0, 0);
6185 /* Process sysroot_suffix_spec. */
6186 if (*sysroot_suffix_spec != 0
6187 && do_spec_2 (sysroot_suffix_spec) == 0)
6189 if (argbuf_index > 1)
6190 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6191 else if (argbuf_index == 1)
6192 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6195 #ifdef HAVE_LD_SYSROOT
6196 /* Pass the --sysroot option to the linker, if it supports that. If
6197 there is a sysroot_suffix_spec, it has already been processed by
6198 this point, so target_system_root really is the system root we
6199 should be using. */
6200 if (target_system_root)
6202 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6203 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6204 set_spec ("link", XOBFINISH (&obstack, const char *));
6206 #endif
6208 /* Process sysroot_hdrs_suffix_spec. */
6209 if (*sysroot_hdrs_suffix_spec != 0
6210 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6212 if (argbuf_index > 1)
6213 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6214 else if (argbuf_index == 1)
6215 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6218 /* Look for startfiles in the standard places. */
6219 if (*startfile_prefix_spec != 0
6220 && do_spec_2 (startfile_prefix_spec) == 0
6221 && do_spec_1 (" ", 0, NULL) == 0)
6223 int ndx;
6224 for (ndx = 0; ndx < argbuf_index; ndx++)
6225 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6226 PREFIX_PRIORITY_LAST, 0, 1);
6228 /* We should eventually get rid of all these and stick to
6229 startfile_prefix_spec exclusively. */
6230 else if (*cross_compile == '0' || target_system_root)
6232 if (*md_startfile_prefix)
6233 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6234 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6236 if (*md_startfile_prefix_1)
6237 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6238 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6240 /* If standard_startfile_prefix is relative, base it on
6241 standard_exec_prefix. This lets us move the installed tree
6242 as a unit. If GCC_EXEC_PREFIX is defined, base
6243 standard_startfile_prefix on that as well.
6245 If the prefix is relative, only search it for native compilers;
6246 otherwise we will search a directory containing host libraries. */
6247 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6248 add_sysrooted_prefix (&startfile_prefixes,
6249 standard_startfile_prefix, "BINUTILS",
6250 PREFIX_PRIORITY_LAST, 0, 1);
6251 else if (*cross_compile == '0')
6253 if (gcc_exec_prefix)
6254 add_prefix (&startfile_prefixes,
6255 concat (gcc_exec_prefix, machine_suffix,
6256 standard_startfile_prefix, NULL),
6257 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6258 add_prefix (&startfile_prefixes,
6259 concat (standard_exec_prefix,
6260 machine_suffix,
6261 standard_startfile_prefix, NULL),
6262 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6265 if (*standard_startfile_prefix_1)
6266 add_sysrooted_prefix (&startfile_prefixes,
6267 standard_startfile_prefix_1, "BINUTILS",
6268 PREFIX_PRIORITY_LAST, 0, 1);
6269 if (*standard_startfile_prefix_2)
6270 add_sysrooted_prefix (&startfile_prefixes,
6271 standard_startfile_prefix_2, "BINUTILS",
6272 PREFIX_PRIORITY_LAST, 0, 1);
6275 /* Process any user specified specs in the order given on the command
6276 line. */
6277 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6279 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6280 R_OK, 0);
6281 read_specs (filename ? filename : uptr->filename, FALSE);
6284 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6285 if (gcc_exec_prefix)
6286 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6287 spec_version, dir_separator_str, NULL);
6289 /* Now we have the specs.
6290 Set the `valid' bits for switches that match anything in any spec. */
6292 validate_all_switches ();
6294 /* Now that we have the switches and the specs, set
6295 the subdirectory based on the options. */
6296 set_multilib_dir ();
6298 /* Warn about any switches that no pass was interested in. */
6300 for (i = 0; (int) i < n_switches; i++)
6301 if (! switches[i].validated)
6302 error ("unrecognized option '-%s'", switches[i].part1);
6304 /* Obey some of the options. */
6306 if (print_search_dirs)
6308 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6309 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6310 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6311 return (0);
6314 if (print_file_name)
6316 printf ("%s\n", find_file (print_file_name));
6317 return (0);
6320 if (print_prog_name)
6322 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6323 printf ("%s\n", (newname ? newname : print_prog_name));
6324 return (0);
6327 if (print_multi_lib)
6329 print_multilib_info ();
6330 return (0);
6333 if (print_multi_directory)
6335 if (multilib_dir == NULL)
6336 printf (".\n");
6337 else
6338 printf ("%s\n", multilib_dir);
6339 return (0);
6342 if (print_multi_os_directory)
6344 if (multilib_os_dir == NULL)
6345 printf (".\n");
6346 else
6347 printf ("%s\n", multilib_os_dir);
6348 return (0);
6351 if (target_help_flag)
6353 /* Print if any target specific options. */
6355 /* We do not exit here. Instead we have created a fake input file
6356 called 'target-dummy' which needs to be compiled, and we pass this
6357 on to the various sub-processes, along with the --target-help
6358 switch. */
6361 if (print_help_list)
6363 display_help ();
6365 if (! verbose_flag)
6367 printf (_("\nFor bug reporting instructions, please see:\n"));
6368 printf ("%s.\n", bug_report_url);
6370 return (0);
6373 /* We do not exit here. Instead we have created a fake input file
6374 called 'help-dummy' which needs to be compiled, and we pass this
6375 on the various sub-processes, along with the --help switch. */
6378 if (verbose_flag)
6380 int n;
6381 const char *thrmod;
6383 notice ("Target: %s\n", spec_machine);
6384 notice ("Configured with: %s\n", configuration_arguments);
6386 #ifdef THREAD_MODEL_SPEC
6387 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6388 but there's no point in doing all this processing just to get
6389 thread_model back. */
6390 obstack_init (&obstack);
6391 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6392 obstack_1grow (&obstack, '\0');
6393 thrmod = XOBFINISH (&obstack, const char *);
6394 #else
6395 thrmod = thread_model;
6396 #endif
6398 notice ("Thread model: %s\n", thrmod);
6400 /* compiler_version is truncated at the first space when initialized
6401 from version string, so truncate version_string at the first space
6402 before comparing. */
6403 for (n = 0; version_string[n]; n++)
6404 if (version_string[n] == ' ')
6405 break;
6407 if (! strncmp (version_string, compiler_version, n)
6408 && compiler_version[n] == 0)
6409 notice ("gcc version %s\n", version_string);
6410 else
6411 notice ("gcc driver version %s executing gcc version %s\n",
6412 version_string, compiler_version);
6414 if (n_infiles == 0)
6415 return (0);
6418 if (n_infiles == added_libraries)
6419 fatal ("no input files");
6421 /* Make a place to record the compiler output file names
6422 that correspond to the input files. */
6424 i = n_infiles;
6425 i += lang_specific_extra_outfiles;
6426 outfiles = xcalloc (i, sizeof (char *));
6428 /* Record which files were specified explicitly as link input. */
6430 explicit_link_files = xcalloc (1, n_infiles);
6432 if (combine_flag)
6433 combine_inputs = true;
6434 else
6435 combine_inputs = false;
6437 for (i = 0; (int) i < n_infiles; i++)
6439 const char *name = infiles[i].name;
6440 struct compiler *compiler = lookup_compiler (name,
6441 strlen (name),
6442 infiles[i].language);
6444 if (compiler && !(compiler->combinable))
6445 combine_inputs = false;
6447 if (lang_n_infiles > 0 && compiler != input_file_compiler
6448 && infiles[i].language && infiles[i].language[0] != '*')
6449 infiles[i].incompiler = compiler;
6450 else if (compiler)
6452 lang_n_infiles++;
6453 input_file_compiler = compiler;
6454 infiles[i].incompiler = compiler;
6456 else
6458 /* Since there is no compiler for this input file, assume it is a
6459 linker file. */
6460 explicit_link_files[i] = 1;
6461 infiles[i].incompiler = NULL;
6463 infiles[i].compiled = false;
6464 infiles[i].preprocessed = false;
6467 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6468 fatal ("cannot specify -o with -c or -S with multiple files");
6470 if (combine_flag && save_temps_flag)
6472 bool save_combine_inputs = combine_inputs;
6473 /* Must do a separate pre-processing pass for C & Objective-C files, to
6474 obtain individual .i files. */
6476 combine_inputs = false;
6477 for (i = 0; (int) i < n_infiles; i++)
6479 int this_file_error = 0;
6481 input_file_number = i;
6482 set_input (infiles[i].name);
6483 if (infiles[i].incompiler
6484 && (infiles[i].incompiler)->needs_preprocessing)
6485 input_file_compiler = infiles[i].incompiler;
6486 else
6487 continue;
6489 if (input_file_compiler)
6491 if (input_file_compiler->spec[0] == '#')
6493 error ("%s: %s compiler not installed on this system",
6494 input_filename, &input_file_compiler->spec[1]);
6495 this_file_error = 1;
6497 else
6499 value = do_spec (input_file_compiler->spec);
6500 infiles[i].preprocessed = true;
6501 if (!have_o_argbuf_index)
6502 fatal ("spec '%s' is invalid", input_file_compiler->spec);
6503 infiles[i].name = argbuf[have_o_argbuf_index];
6504 infiles[i].incompiler
6505 = lookup_compiler (infiles[i].name,
6506 strlen (infiles[i].name),
6507 infiles[i].language);
6509 if (value < 0)
6510 this_file_error = 1;
6514 if (this_file_error)
6516 delete_failure_queue ();
6517 error_count++;
6518 break;
6520 clear_failure_queue ();
6522 combine_inputs = save_combine_inputs;
6525 for (i = 0; (int) i < n_infiles; i++)
6527 int this_file_error = 0;
6529 /* Tell do_spec what to substitute for %i. */
6531 input_file_number = i;
6532 set_input (infiles[i].name);
6534 if (infiles[i].compiled)
6535 continue;
6537 /* Use the same thing in %o, unless cp->spec says otherwise. */
6539 outfiles[i] = input_filename;
6541 /* Figure out which compiler from the file's suffix. */
6543 if (! combine_inputs)
6544 input_file_compiler
6545 = lookup_compiler (infiles[i].name, input_filename_length,
6546 infiles[i].language);
6547 else
6548 input_file_compiler = infiles[i].incompiler;
6550 if (input_file_compiler)
6552 /* Ok, we found an applicable compiler. Run its spec. */
6554 if (input_file_compiler->spec[0] == '#')
6556 error ("%s: %s compiler not installed on this system",
6557 input_filename, &input_file_compiler->spec[1]);
6558 this_file_error = 1;
6560 else
6562 value = do_spec (input_file_compiler->spec);
6563 infiles[i].compiled = true;
6564 if (value < 0)
6565 this_file_error = 1;
6569 /* If this file's name does not contain a recognized suffix,
6570 record it as explicit linker input. */
6572 else
6573 explicit_link_files[i] = 1;
6575 /* Clear the delete-on-failure queue, deleting the files in it
6576 if this compilation failed. */
6578 if (this_file_error)
6580 delete_failure_queue ();
6581 error_count++;
6583 /* If this compilation succeeded, don't delete those files later. */
6584 clear_failure_queue ();
6587 /* Reset the input file name to the first compile/object file name, for use
6588 with %b in LINK_SPEC. We use the first input file that we can find
6589 a compiler to compile it instead of using infiles.language since for
6590 languages other than C we use aliases that we then lookup later. */
6591 if (n_infiles > 0)
6593 int i;
6595 for (i = 0; i < n_infiles ; i++)
6596 if (infiles[i].language && infiles[i].language[0] != '*')
6598 set_input (infiles[i].name);
6599 break;
6603 if (error_count == 0)
6605 /* Make sure INPUT_FILE_NUMBER points to first available open
6606 slot. */
6607 input_file_number = n_infiles;
6608 if (lang_specific_pre_link ())
6609 error_count++;
6612 /* Determine if there are any linker input files. */
6613 num_linker_inputs = 0;
6614 for (i = 0; (int) i < n_infiles; i++)
6615 if (explicit_link_files[i] || outfiles[i] != NULL)
6616 num_linker_inputs++;
6618 /* Run ld to link all the compiler output files. */
6620 if (num_linker_inputs > 0 && error_count == 0)
6622 int tmp = execution_count;
6624 /* We'll use ld if we can't find collect2. */
6625 if (! strcmp (linker_name_spec, "collect2"))
6627 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6628 if (s == NULL)
6629 linker_name_spec = "ld";
6631 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6632 for collect. */
6633 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6634 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6636 value = do_spec (link_command_spec);
6637 if (value < 0)
6638 error_count = 1;
6639 linker_was_run = (tmp != execution_count);
6642 /* If options said don't run linker,
6643 complain about input files to be given to the linker. */
6645 if (! linker_was_run && error_count == 0)
6646 for (i = 0; (int) i < n_infiles; i++)
6647 if (explicit_link_files[i])
6648 error ("%s: linker input file unused because linking not done",
6649 outfiles[i]);
6651 /* Delete some or all of the temporary files we made. */
6653 if (error_count)
6654 delete_failure_queue ();
6655 delete_temp_files ();
6657 if (print_help_list)
6659 printf (("\nFor bug reporting instructions, please see:\n"));
6660 printf ("%s\n", bug_report_url);
6663 return (signal_count != 0 ? 2
6664 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6665 : 0);
6668 /* Find the proper compilation spec for the file name NAME,
6669 whose length is LENGTH. LANGUAGE is the specified language,
6670 or 0 if this file is to be passed to the linker. */
6672 static struct compiler *
6673 lookup_compiler (const char *name, size_t length, const char *language)
6675 struct compiler *cp;
6677 /* If this was specified by the user to be a linker input, indicate that. */
6678 if (language != 0 && language[0] == '*')
6679 return 0;
6681 /* Otherwise, look for the language, if one is spec'd. */
6682 if (language != 0)
6684 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6685 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6686 return cp;
6688 error ("language %s not recognized", language);
6689 return 0;
6692 /* Look for a suffix. */
6693 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6695 if (/* The suffix `-' matches only the file name `-'. */
6696 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6697 || (strlen (cp->suffix) < length
6698 /* See if the suffix matches the end of NAME. */
6699 && !strcmp (cp->suffix,
6700 name + length - strlen (cp->suffix))
6702 break;
6705 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6706 /* Look again, but case-insensitively this time. */
6707 if (cp < compilers)
6708 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6710 if (/* The suffix `-' matches only the file name `-'. */
6711 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6712 || (strlen (cp->suffix) < length
6713 /* See if the suffix matches the end of NAME. */
6714 && ((!strcmp (cp->suffix,
6715 name + length - strlen (cp->suffix))
6716 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6717 && !strcasecmp (cp->suffix,
6718 name + length - strlen (cp->suffix)))
6720 break;
6722 #endif
6724 if (cp >= compilers)
6726 if (cp->spec[0] != '@')
6727 /* A non-alias entry: return it. */
6728 return cp;
6730 /* An alias entry maps a suffix to a language.
6731 Search for the language; pass 0 for NAME and LENGTH
6732 to avoid infinite recursion if language not found. */
6733 return lookup_compiler (NULL, 0, cp->spec + 1);
6735 return 0;
6738 static char *
6739 save_string (const char *s, int len)
6741 char *result = xmalloc (len + 1);
6743 memcpy (result, s, len);
6744 result[len] = 0;
6745 return result;
6748 void
6749 pfatal_with_name (const char *name)
6751 perror_with_name (name);
6752 delete_temp_files ();
6753 exit (1);
6756 static void
6757 perror_with_name (const char *name)
6759 error ("%s: %s", name, xstrerror (errno));
6762 /* Output an error message and exit. */
6764 void
6765 fancy_abort (const char *file, int line, const char *func)
6767 fatal ("internal gcc abort in %s, at %s:%d", func, file, line);
6770 /* Output an error message and exit. */
6772 void
6773 fatal (const char *cmsgid, ...)
6775 va_list ap;
6777 va_start (ap, cmsgid);
6779 fprintf (stderr, "%s: ", programname);
6780 vfprintf (stderr, _(cmsgid), ap);
6781 va_end (ap);
6782 fprintf (stderr, "\n");
6783 delete_temp_files ();
6784 exit (1);
6787 /* The argument is actually c-format, not gcc-internal-format,
6788 but because functions with identical names are used through
6789 the rest of the compiler with gcc-internal-format, we just
6790 need to hope all users of these functions use the common
6791 subset between c-format and gcc-internal-format. */
6793 void
6794 error (const char *gmsgid, ...)
6796 va_list ap;
6798 va_start (ap, gmsgid);
6799 fprintf (stderr, "%s: ", programname);
6800 vfprintf (stderr, _(gmsgid), ap);
6801 va_end (ap);
6803 fprintf (stderr, "\n");
6806 static void
6807 notice (const char *cmsgid, ...)
6809 va_list ap;
6811 va_start (ap, cmsgid);
6812 vfprintf (stderr, _(cmsgid), ap);
6813 va_end (ap);
6816 static inline void
6817 validate_switches_from_spec (const char *spec)
6819 const char *p = spec;
6820 char c;
6821 while ((c = *p++))
6822 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6823 /* We have a switch spec. */
6824 p = validate_switches (p + 1);
6827 static void
6828 validate_all_switches (void)
6830 struct compiler *comp;
6831 struct spec_list *spec;
6833 for (comp = compilers; comp->spec; comp++)
6834 validate_switches_from_spec (comp->spec);
6836 /* Look through the linked list of specs read from the specs file. */
6837 for (spec = specs; spec; spec = spec->next)
6838 validate_switches_from_spec (*spec->ptr_spec);
6840 validate_switches_from_spec (link_command_spec);
6843 /* Look at the switch-name that comes after START
6844 and mark as valid all supplied switches that match it. */
6846 static const char *
6847 validate_switches (const char *start)
6849 const char *p = start;
6850 const char *atom;
6851 size_t len;
6852 int i;
6853 bool suffix = false;
6854 bool starred = false;
6856 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6858 next_member:
6859 SKIP_WHITE ();
6861 if (*p == '!')
6862 p++;
6864 SKIP_WHITE ();
6865 if (*p == '.')
6866 suffix = true, p++;
6868 atom = p;
6869 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6870 || *p == ',' || *p == '.' || *p == '@')
6871 p++;
6872 len = p - atom;
6874 if (*p == '*')
6875 starred = true, p++;
6877 SKIP_WHITE ();
6879 if (!suffix)
6881 /* Mark all matching switches as valid. */
6882 for (i = 0; i < n_switches; i++)
6883 if (!strncmp (switches[i].part1, atom, len)
6884 && (starred || switches[i].part1[len] == 0))
6885 switches[i].validated = 1;
6888 if (*p) p++;
6889 if (*p && (p[-1] == '|' || p[-1] == '&'))
6890 goto next_member;
6892 if (*p && p[-1] == ':')
6894 while (*p && *p != ';' && *p != '}')
6896 if (*p == '%')
6898 p++;
6899 if (*p == '{' || *p == '<')
6900 p = validate_switches (p+1);
6901 else if (p[0] == 'W' && p[1] == '{')
6902 p = validate_switches (p+2);
6904 else
6905 p++;
6908 if (*p) p++;
6909 if (*p && p[-1] == ';')
6910 goto next_member;
6913 return p;
6914 #undef SKIP_WHITE
6917 struct mdswitchstr
6919 const char *str;
6920 int len;
6923 static struct mdswitchstr *mdswitches;
6924 static int n_mdswitches;
6926 /* Check whether a particular argument was used. The first time we
6927 canonicalize the switches to keep only the ones we care about. */
6929 static int
6930 used_arg (const char *p, int len)
6932 struct mswitchstr
6934 const char *str;
6935 const char *replace;
6936 int len;
6937 int rep_len;
6940 static struct mswitchstr *mswitches;
6941 static int n_mswitches;
6942 int i, j;
6944 if (!mswitches)
6946 struct mswitchstr *matches;
6947 const char *q;
6948 int cnt = 0;
6950 /* Break multilib_matches into the component strings of string
6951 and replacement string. */
6952 for (q = multilib_matches; *q != '\0'; q++)
6953 if (*q == ';')
6954 cnt++;
6956 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
6957 i = 0;
6958 q = multilib_matches;
6959 while (*q != '\0')
6961 matches[i].str = q;
6962 while (*q != ' ')
6964 if (*q == '\0')
6966 invalid_matches:
6967 fatal ("multilib spec '%s' is invalid", multilib_matches);
6969 q++;
6971 matches[i].len = q - matches[i].str;
6973 matches[i].replace = ++q;
6974 while (*q != ';' && *q != '\0')
6976 if (*q == ' ')
6977 goto invalid_matches;
6978 q++;
6980 matches[i].rep_len = q - matches[i].replace;
6981 i++;
6982 if (*q == ';')
6983 q++;
6986 /* Now build a list of the replacement string for switches that we care
6987 about. Make sure we allocate at least one entry. This prevents
6988 xmalloc from calling fatal, and prevents us from re-executing this
6989 block of code. */
6990 mswitches
6991 = xmalloc (sizeof (struct mswitchstr)
6992 * (n_mdswitches + (n_switches ? n_switches : 1)));
6993 for (i = 0; i < n_switches; i++)
6994 if (switches[i].live_cond != SWITCH_IGNORE)
6996 int xlen = strlen (switches[i].part1);
6997 for (j = 0; j < cnt; j++)
6998 if (xlen == matches[j].len
6999 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7001 mswitches[n_mswitches].str = matches[j].replace;
7002 mswitches[n_mswitches].len = matches[j].rep_len;
7003 mswitches[n_mswitches].replace = (char *) 0;
7004 mswitches[n_mswitches].rep_len = 0;
7005 n_mswitches++;
7006 break;
7010 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7011 on the command line nor any options mutually incompatible with
7012 them. */
7013 for (i = 0; i < n_mdswitches; i++)
7015 const char *r;
7017 for (q = multilib_options; *q != '\0'; q++)
7019 while (*q == ' ')
7020 q++;
7022 r = q;
7023 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7024 || strchr (" /", q[mdswitches[i].len]) == NULL)
7026 while (*q != ' ' && *q != '/' && *q != '\0')
7027 q++;
7028 if (*q != '/')
7029 break;
7030 q++;
7033 if (*q != ' ' && *q != '\0')
7035 while (*r != ' ' && *r != '\0')
7037 q = r;
7038 while (*q != ' ' && *q != '/' && *q != '\0')
7039 q++;
7041 if (used_arg (r, q - r))
7042 break;
7044 if (*q != '/')
7046 mswitches[n_mswitches].str = mdswitches[i].str;
7047 mswitches[n_mswitches].len = mdswitches[i].len;
7048 mswitches[n_mswitches].replace = (char *) 0;
7049 mswitches[n_mswitches].rep_len = 0;
7050 n_mswitches++;
7051 break;
7054 r = q + 1;
7056 break;
7062 for (i = 0; i < n_mswitches; i++)
7063 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7064 return 1;
7066 return 0;
7069 static int
7070 default_arg (const char *p, int len)
7072 int i;
7074 for (i = 0; i < n_mdswitches; i++)
7075 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7076 return 1;
7078 return 0;
7081 /* Work out the subdirectory to use based on the options. The format of
7082 multilib_select is a list of elements. Each element is a subdirectory
7083 name followed by a list of options followed by a semicolon. The format
7084 of multilib_exclusions is the same, but without the preceding
7085 directory. First gcc will check the exclusions, if none of the options
7086 beginning with an exclamation point are present, and all of the other
7087 options are present, then we will ignore this completely. Passing
7088 that, gcc will consider each multilib_select in turn using the same
7089 rules for matching the options. If a match is found, that subdirectory
7090 will be used. */
7092 static void
7093 set_multilib_dir (void)
7095 const char *p;
7096 unsigned int this_path_len;
7097 const char *this_path, *this_arg;
7098 const char *start, *end;
7099 int not_arg;
7100 int ok, ndfltok, first;
7102 n_mdswitches = 0;
7103 start = multilib_defaults;
7104 while (*start == ' ' || *start == '\t')
7105 start++;
7106 while (*start != '\0')
7108 n_mdswitches++;
7109 while (*start != ' ' && *start != '\t' && *start != '\0')
7110 start++;
7111 while (*start == ' ' || *start == '\t')
7112 start++;
7115 if (n_mdswitches)
7117 int i = 0;
7119 mdswitches = xmalloc (sizeof (struct mdswitchstr) * n_mdswitches);
7120 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7122 while (*start == ' ' || *start == '\t')
7123 start++;
7125 if (*start == '\0')
7126 break;
7128 for (end = start + 1;
7129 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7132 obstack_grow (&multilib_obstack, start, end - start);
7133 obstack_1grow (&multilib_obstack, 0);
7134 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7135 mdswitches[i++].len = end - start;
7137 if (*end == '\0')
7138 break;
7142 p = multilib_exclusions;
7143 while (*p != '\0')
7145 /* Ignore newlines. */
7146 if (*p == '\n')
7148 ++p;
7149 continue;
7152 /* Check the arguments. */
7153 ok = 1;
7154 while (*p != ';')
7156 if (*p == '\0')
7158 invalid_exclusions:
7159 fatal ("multilib exclusions '%s' is invalid",
7160 multilib_exclusions);
7163 if (! ok)
7165 ++p;
7166 continue;
7169 this_arg = p;
7170 while (*p != ' ' && *p != ';')
7172 if (*p == '\0')
7173 goto invalid_exclusions;
7174 ++p;
7177 if (*this_arg != '!')
7178 not_arg = 0;
7179 else
7181 not_arg = 1;
7182 ++this_arg;
7185 ok = used_arg (this_arg, p - this_arg);
7186 if (not_arg)
7187 ok = ! ok;
7189 if (*p == ' ')
7190 ++p;
7193 if (ok)
7194 return;
7196 ++p;
7199 first = 1;
7200 p = multilib_select;
7201 while (*p != '\0')
7203 /* Ignore newlines. */
7204 if (*p == '\n')
7206 ++p;
7207 continue;
7210 /* Get the initial path. */
7211 this_path = p;
7212 while (*p != ' ')
7214 if (*p == '\0')
7216 invalid_select:
7217 fatal ("multilib select '%s' is invalid",
7218 multilib_select);
7220 ++p;
7222 this_path_len = p - this_path;
7224 /* Check the arguments. */
7225 ok = 1;
7226 ndfltok = 1;
7227 ++p;
7228 while (*p != ';')
7230 if (*p == '\0')
7231 goto invalid_select;
7233 if (! ok)
7235 ++p;
7236 continue;
7239 this_arg = p;
7240 while (*p != ' ' && *p != ';')
7242 if (*p == '\0')
7243 goto invalid_select;
7244 ++p;
7247 if (*this_arg != '!')
7248 not_arg = 0;
7249 else
7251 not_arg = 1;
7252 ++this_arg;
7255 /* If this is a default argument, we can just ignore it.
7256 This is true even if this_arg begins with '!'. Beginning
7257 with '!' does not mean that this argument is necessarily
7258 inappropriate for this library: it merely means that
7259 there is a more specific library which uses this
7260 argument. If this argument is a default, we need not
7261 consider that more specific library. */
7262 ok = used_arg (this_arg, p - this_arg);
7263 if (not_arg)
7264 ok = ! ok;
7266 if (! ok)
7267 ndfltok = 0;
7269 if (default_arg (this_arg, p - this_arg))
7270 ok = 1;
7272 if (*p == ' ')
7273 ++p;
7276 if (ok && first)
7278 if (this_path_len != 1
7279 || this_path[0] != '.')
7281 char *new_multilib_dir = xmalloc (this_path_len + 1);
7282 char *q;
7284 strncpy (new_multilib_dir, this_path, this_path_len);
7285 new_multilib_dir[this_path_len] = '\0';
7286 q = strchr (new_multilib_dir, ':');
7287 if (q != NULL)
7288 *q = '\0';
7289 multilib_dir = new_multilib_dir;
7291 first = 0;
7294 if (ndfltok)
7296 const char *q = this_path, *end = this_path + this_path_len;
7298 while (q < end && *q != ':')
7299 q++;
7300 if (q < end)
7302 char *new_multilib_os_dir = xmalloc (end - q);
7303 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7304 new_multilib_os_dir[end - q - 1] = '\0';
7305 multilib_os_dir = new_multilib_os_dir;
7306 break;
7310 ++p;
7313 if (multilib_dir == NULL && multilib_os_dir != NULL
7314 && strcmp (multilib_os_dir, ".") == 0)
7316 free ((char *) multilib_os_dir);
7317 multilib_os_dir = NULL;
7319 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7320 multilib_os_dir = multilib_dir;
7323 /* Print out the multiple library subdirectory selection
7324 information. This prints out a series of lines. Each line looks
7325 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7326 required. Only the desired options are printed out, the negative
7327 matches. The options are print without a leading dash. There are
7328 no spaces to make it easy to use the information in the shell.
7329 Each subdirectory is printed only once. This assumes the ordering
7330 generated by the genmultilib script. Also, we leave out ones that match
7331 the exclusions. */
7333 static void
7334 print_multilib_info (void)
7336 const char *p = multilib_select;
7337 const char *last_path = 0, *this_path;
7338 int skip;
7339 unsigned int last_path_len = 0;
7341 while (*p != '\0')
7343 skip = 0;
7344 /* Ignore newlines. */
7345 if (*p == '\n')
7347 ++p;
7348 continue;
7351 /* Get the initial path. */
7352 this_path = p;
7353 while (*p != ' ')
7355 if (*p == '\0')
7357 invalid_select:
7358 fatal ("multilib select '%s' is invalid", multilib_select);
7361 ++p;
7364 /* When --disable-multilib was used but target defines
7365 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7366 to find multilib_os_dir, so skip them from output. */
7367 if (this_path[0] == '.' && this_path[1] == ':')
7368 skip = 1;
7370 /* Check for matches with the multilib_exclusions. We don't bother
7371 with the '!' in either list. If any of the exclusion rules match
7372 all of its options with the select rule, we skip it. */
7374 const char *e = multilib_exclusions;
7375 const char *this_arg;
7377 while (*e != '\0')
7379 int m = 1;
7380 /* Ignore newlines. */
7381 if (*e == '\n')
7383 ++e;
7384 continue;
7387 /* Check the arguments. */
7388 while (*e != ';')
7390 const char *q;
7391 int mp = 0;
7393 if (*e == '\0')
7395 invalid_exclusion:
7396 fatal ("multilib exclusion '%s' is invalid",
7397 multilib_exclusions);
7400 if (! m)
7402 ++e;
7403 continue;
7406 this_arg = e;
7408 while (*e != ' ' && *e != ';')
7410 if (*e == '\0')
7411 goto invalid_exclusion;
7412 ++e;
7415 q = p + 1;
7416 while (*q != ';')
7418 const char *arg;
7419 int len = e - this_arg;
7421 if (*q == '\0')
7422 goto invalid_select;
7424 arg = q;
7426 while (*q != ' ' && *q != ';')
7428 if (*q == '\0')
7429 goto invalid_select;
7430 ++q;
7433 if (! strncmp (arg, this_arg,
7434 (len < q - arg) ? q - arg : len)
7435 || default_arg (this_arg, e - this_arg))
7437 mp = 1;
7438 break;
7441 if (*q == ' ')
7442 ++q;
7445 if (! mp)
7446 m = 0;
7448 if (*e == ' ')
7449 ++e;
7452 if (m)
7454 skip = 1;
7455 break;
7458 if (*e != '\0')
7459 ++e;
7463 if (! skip)
7465 /* If this is a duplicate, skip it. */
7466 skip = (last_path != 0
7467 && (unsigned int) (p - this_path) == last_path_len
7468 && ! strncmp (last_path, this_path, last_path_len));
7470 last_path = this_path;
7471 last_path_len = p - this_path;
7474 /* If this directory requires any default arguments, we can skip
7475 it. We will already have printed a directory identical to
7476 this one which does not require that default argument. */
7477 if (! skip)
7479 const char *q;
7481 q = p + 1;
7482 while (*q != ';')
7484 const char *arg;
7486 if (*q == '\0')
7487 goto invalid_select;
7489 if (*q == '!')
7490 arg = NULL;
7491 else
7492 arg = q;
7494 while (*q != ' ' && *q != ';')
7496 if (*q == '\0')
7497 goto invalid_select;
7498 ++q;
7501 if (arg != NULL
7502 && default_arg (arg, q - arg))
7504 skip = 1;
7505 break;
7508 if (*q == ' ')
7509 ++q;
7513 if (! skip)
7515 const char *p1;
7517 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7518 putchar (*p1);
7519 putchar (';');
7522 ++p;
7523 while (*p != ';')
7525 int use_arg;
7527 if (*p == '\0')
7528 goto invalid_select;
7530 if (skip)
7532 ++p;
7533 continue;
7536 use_arg = *p != '!';
7538 if (use_arg)
7539 putchar ('@');
7541 while (*p != ' ' && *p != ';')
7543 if (*p == '\0')
7544 goto invalid_select;
7545 if (use_arg)
7546 putchar (*p);
7547 ++p;
7550 if (*p == ' ')
7551 ++p;
7554 if (! skip)
7556 /* If there are extra options, print them now. */
7557 if (multilib_extra && *multilib_extra)
7559 int print_at = TRUE;
7560 const char *q;
7562 for (q = multilib_extra; *q != '\0'; q++)
7564 if (*q == ' ')
7565 print_at = TRUE;
7566 else
7568 if (print_at)
7569 putchar ('@');
7570 putchar (*q);
7571 print_at = FALSE;
7576 putchar ('\n');
7579 ++p;
7583 /* if-exists built-in spec function.
7585 Checks to see if the file specified by the absolute pathname in
7586 ARGS exists. Returns that pathname if found.
7588 The usual use for this function is to check for a library file
7589 (whose name has been expanded with %s). */
7591 static const char *
7592 if_exists_spec_function (int argc, const char **argv)
7594 /* Must have only one argument. */
7595 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7596 return argv[0];
7598 return NULL;
7601 /* if-exists-else built-in spec function.
7603 This is like if-exists, but takes an additional argument which
7604 is returned if the first argument does not exist. */
7606 static const char *
7607 if_exists_else_spec_function (int argc, const char **argv)
7609 /* Must have exactly two arguments. */
7610 if (argc != 2)
7611 return NULL;
7613 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7614 return argv[0];
7616 return argv[1];
7619 /* replace-outfile built-in spec function.
7621 This looks for the first argument in the outfiles array's name and
7622 replaces it with the second argument. */
7624 static const char *
7625 replace_outfile_spec_function (int argc, const char **argv)
7627 int i;
7628 /* Must have exactly two arguments. */
7629 if (argc != 2)
7630 abort ();
7632 for (i = 0; i < n_infiles; i++)
7634 if (outfiles[i] && !strcmp (outfiles[i], argv[0]))
7635 outfiles[i] = xstrdup (argv[1]);
7637 return NULL;
7640 /* Given two version numbers, compares the two numbers.
7641 A version number must match the regular expression
7642 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
7644 static int
7645 compare_version_strings (const char *v1, const char *v2)
7647 int rresult;
7648 regex_t r;
7650 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
7651 REG_EXTENDED | REG_NOSUB) != 0)
7652 abort ();
7653 rresult = regexec (&r, v1, 0, NULL, 0);
7654 if (rresult == REG_NOMATCH)
7655 fatal ("invalid version number `%s'", v1);
7656 else if (rresult != 0)
7657 abort ();
7658 rresult = regexec (&r, v2, 0, NULL, 0);
7659 if (rresult == REG_NOMATCH)
7660 fatal ("invalid version number `%s'", v2);
7661 else if (rresult != 0)
7662 abort ();
7664 return strverscmp (v1, v2);
7668 /* version_compare built-in spec function.
7670 This takes an argument of the following form:
7672 <comparison-op> <arg1> [<arg2>] <switch> <result>
7674 and produces "result" if the comparison evaluates to true,
7675 and nothing if it doesn't.
7677 The supported <comparison-op> values are:
7679 >= true if switch is a later (or same) version than arg1
7680 !> opposite of >=
7681 < true if switch is an earlier version than arg1
7682 !< opposite of <
7683 >< true if switch is arg1 or later, and earlier than arg2
7684 <> true if switch is earlier than arg1 or is arg2 or later
7686 If the switch is not present, the condition is false unless
7687 the first character of the <comparison-op> is '!'.
7689 For example,
7690 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
7691 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
7693 static const char *
7694 version_compare_spec_function (int argc, const char **argv)
7696 int comp1, comp2;
7697 size_t switch_len;
7698 const char *switch_value = NULL;
7699 int nargs = 1, i;
7700 bool result;
7702 if (argc < 3)
7703 fatal ("too few arguments to %%:version-compare");
7704 if (argv[0][0] == '\0')
7705 abort ();
7706 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
7707 nargs = 2;
7708 if (argc != nargs + 3)
7709 fatal ("too many arguments to %%:version-compare");
7711 switch_len = strlen (argv[nargs + 1]);
7712 for (i = 0; i < n_switches; i++)
7713 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
7714 && check_live_switch (i, switch_len))
7715 switch_value = switches[i].part1 + switch_len;
7717 if (switch_value == NULL)
7718 comp1 = comp2 = -1;
7719 else
7721 comp1 = compare_version_strings (switch_value, argv[1]);
7722 if (nargs == 2)
7723 comp2 = compare_version_strings (switch_value, argv[2]);
7724 else
7725 comp2 = -1; /* This value unused. */
7728 switch (argv[0][0] << 8 | argv[0][1])
7730 case '>' << 8 | '=':
7731 result = comp1 >= 0;
7732 break;
7733 case '!' << 8 | '<':
7734 result = comp1 >= 0 || switch_value == NULL;
7735 break;
7736 case '<' << 8:
7737 result = comp1 < 0;
7738 break;
7739 case '!' << 8 | '>':
7740 result = comp1 < 0 || switch_value == NULL;
7741 break;
7742 case '>' << 8 | '<':
7743 result = comp1 >= 0 && comp2 < 0;
7744 break;
7745 case '<' << 8 | '>':
7746 result = comp1 < 0 || comp2 >= 0;
7747 break;
7749 default:
7750 fatal ("unknown operator '%s' in %%:version-compare", argv[0]);
7752 if (! result)
7753 return NULL;
7755 return argv[nargs + 2];