* c-parse.in (array_declarator): New. Handle C99 constructs.
[official-gcc.git] / gcc / gcc.c
blobe613291b0c5e86cb9cc931c0d8637ef181aedd65
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 Free Software Foundation, Inc.
5 This file is part of GNU CC.
7 GNU CC is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
12 GNU CC is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GNU CC; see the file COPYING. If not, write to
19 the Free Software Foundation, 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA.
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!! */
25 /* This program is the user interface to the C compiler and possibly to
26 other compilers. It is used because compilation is a complicated procedure
27 which involves running several programs and passing temporary files between
28 them, forwarding the users switches to those programs selectively,
29 and deleting the temporary files at the end.
31 CC recognizes how to compile each input file by suffixes in the file names.
32 Once it knows which kind of compilation to perform, the procedure for
33 compilation is specified by a string called a "spec". */
35 /* A Short Introduction to Adding a Command-Line Option.
37 Before adding a command-line option, consider if it is really
38 necessary. Each additional command-line option adds complexity and
39 is difficult to remove in subsequent versions.
41 In the following, consider adding the command-line argument
42 `--bar'.
44 1. Each command-line option is specified in the specs file. The
45 notation is described below in the comment entitled "The Specs
46 Language". Read it.
48 2. In this file, add an entry to "option_map" equating the long
49 `--' argument version and any shorter, single letter version. Read
50 the comments in the declaration of "struct option_map" for an
51 explanation. Do not omit the first `-'.
53 3. Look in the "specs" file to determine which program or option
54 list should be given the argument, e.g., "cc1_options". Add the
55 appropriate syntax for the shorter option version to the
56 corresponding "const char *" entry in this file. Omit the first
57 `-' from the option. For example, use `-bar', rather than `--bar'.
59 4. If the argument takes an argument, e.g., `--baz argument1',
60 modify either DEFAULT_SWITCH_TAKES_ARG or
61 DEFAULT_WORD_SWITCH_TAKES_ARG in this file. Omit the first `-'
62 from `--baz'.
64 5. Document the option in this file's display_help(). If the
65 option is passed to a subprogram, modify its corresponding
66 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
67 instead.
69 6. Compile and test. Make sure that your new specs file is being
70 read. For example, use a debugger to investigate the value of
71 "specs_file" in main(). */
73 #include "config.h"
74 #include "system.h"
75 #include <signal.h>
76 #if ! defined( SIGCHLD ) && defined( SIGCLD )
77 # define SIGCHLD SIGCLD
78 #endif
79 #include "obstack.h"
80 #include "intl.h"
81 #include "prefix.h"
82 #include "gcc.h"
84 #ifdef VMS
85 #define exit __posix_exit
86 #endif
88 #ifdef HAVE_SYS_RESOURCE_H
89 #include <sys/resource.h>
90 #endif
91 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
92 extern int getrusage PARAMS ((int, struct rusage *));
93 #endif
95 /* By default there is no special suffix for target executables. */
96 /* FIXME: when autoconf is fixed, remove the host check - dj */
97 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
98 #define HAVE_TARGET_EXECUTABLE_SUFFIX
99 #else
100 #define TARGET_EXECUTABLE_SUFFIX ""
101 #endif
103 /* By default there is no special suffix for host executables. */
104 #ifdef HOST_EXECUTABLE_SUFFIX
105 #define HAVE_HOST_EXECUTABLE_SUFFIX
106 #else
107 #define HOST_EXECUTABLE_SUFFIX ""
108 #endif
110 /* By default, the suffix for target object files is ".o". */
111 #ifdef TARGET_OBJECT_SUFFIX
112 #define HAVE_TARGET_OBJECT_SUFFIX
113 #else
114 #define TARGET_OBJECT_SUFFIX ".o"
115 #endif
117 #ifndef VMS
118 /* FIXME: the location independence code for VMS is hairier than this,
119 and hasn't been written. */
120 #ifndef DIR_UP
121 #define DIR_UP ".."
122 #endif /* DIR_UP */
123 #endif /* VMS */
125 static char dir_separator_str[] = { DIR_SEPARATOR, 0 };
127 #define obstack_chunk_alloc xmalloc
128 #define obstack_chunk_free free
130 #ifndef GET_ENV_PATH_LIST
131 #define GET_ENV_PATH_LIST(VAR,NAME) do { (VAR) = getenv (NAME); } while (0)
132 #endif
134 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
135 #ifndef LIBRARY_PATH_ENV
136 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
137 #endif
139 #ifndef HAVE_KILL
140 #define kill(p,s) raise(s)
141 #endif
143 /* If a stage of compilation returns an exit status >= 1,
144 compilation of that file ceases. */
146 #define MIN_FATAL_STATUS 1
148 /* Flag saying to pass the greatest exit code returned by a sub-process
149 to the calling program. */
150 static int pass_exit_codes;
152 /* Definition of string containing the arguments given to configure. */
153 #include "configargs.h"
155 /* Flag saying to print the directories gcc will search through looking for
156 programs, libraries, etc. */
158 static int print_search_dirs;
160 /* Flag saying to print the full filename of this file
161 as found through our usual search mechanism. */
163 static const char *print_file_name = NULL;
165 /* As print_file_name, but search for executable file. */
167 static const char *print_prog_name = NULL;
169 /* Flag saying to print the relative path we'd use to
170 find libgcc.a given the current compiler flags. */
172 static int print_multi_directory;
174 /* Flag saying to print the list of subdirectories and
175 compiler flags used to select them in a standard form. */
177 static int print_multi_lib;
179 /* Flag saying to print the command line options understood by gcc and its
180 sub-processes. */
182 static int print_help_list;
184 /* Flag indicating whether we should print the command and arguments */
186 static int verbose_flag;
188 /* Flag indicating to print target specific command line options. */
190 static int target_help_flag;
192 /* Flag indicating whether we should report subprocess execution times
193 (if this is supported by the system - see pexecute.c). */
195 static int report_times;
197 /* Nonzero means write "temp" files in source directory
198 and use the source file's name in them, and don't delete them. */
200 static int save_temps_flag;
202 /* The compiler version. */
204 static const char *compiler_version;
206 /* The target version specified with -V */
208 static const char *spec_version = DEFAULT_TARGET_VERSION;
210 /* The target machine specified with -b. */
212 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
214 /* Nonzero if cross-compiling.
215 When -b is used, the value comes from the `specs' file. */
217 #ifdef CROSS_COMPILE
218 static const char *cross_compile = "1";
219 #else
220 static const char *cross_compile = "0";
221 #endif
223 #ifdef MODIFY_TARGET_NAME
225 /* Information on how to alter the target name based on a command-line
226 switch. The only case we support now is simply appending or deleting a
227 string to or from the end of the first part of the configuration name. */
229 struct modify_target
231 const char *sw;
232 enum add_del {ADD, DELETE} add_del;
233 const char *str;
235 modify_target[] = MODIFY_TARGET_NAME;
236 #endif
238 /* The number of errors that have occurred; the link phase will not be
239 run if this is non-zero. */
240 static int error_count = 0;
242 /* Greatest exit code of sub-processes that has been encountered up to
243 now. */
244 static int greatest_status = 1;
246 /* This is the obstack which we use to allocate many strings. */
248 static struct obstack obstack;
250 /* This is the obstack to build an environment variable to pass to
251 collect2 that describes all of the relevant switches of what to
252 pass the compiler in building the list of pointers to constructors
253 and destructors. */
255 static struct obstack collect_obstack;
257 /* These structs are used to collect resource usage information for
258 subprocesses. */
259 #ifdef HAVE_GETRUSAGE
260 static struct rusage rus, prus;
261 #endif
263 /* Forward declaration for prototypes. */
264 struct path_prefix;
266 static void init_spec PARAMS ((void));
267 #ifndef VMS
268 static char **split_directories PARAMS ((const char *, int *));
269 static void free_split_directories PARAMS ((char **));
270 static char *make_relative_prefix PARAMS ((const char *, const char *, const char *));
271 #endif /* VMS */
272 static void store_arg PARAMS ((const char *, int, int));
273 static char *load_specs PARAMS ((const char *));
274 static void read_specs PARAMS ((const char *, int));
275 static void set_spec PARAMS ((const char *, const char *));
276 static struct compiler *lookup_compiler PARAMS ((const char *, size_t, const char *));
277 static char *build_search_list PARAMS ((struct path_prefix *, const char *, int));
278 static void putenv_from_prefixes PARAMS ((struct path_prefix *, const char *));
279 static int access_check PARAMS ((const char *, int));
280 static char *find_a_file PARAMS ((struct path_prefix *, const char *, int));
281 static void add_prefix PARAMS ((struct path_prefix *, const char *,
282 const char *, int, int, int *));
283 static void translate_options PARAMS ((int *, const char *const **));
284 static char *skip_whitespace PARAMS ((char *));
285 static void delete_if_ordinary PARAMS ((const char *));
286 static void delete_temp_files PARAMS ((void));
287 static void delete_failure_queue PARAMS ((void));
288 static void clear_failure_queue PARAMS ((void));
289 static int check_live_switch PARAMS ((int, int));
290 static const char *handle_braces PARAMS ((const char *));
291 static char *save_string PARAMS ((const char *, int));
292 static int do_spec_1 PARAMS ((const char *, int, const char *));
293 static const char *find_file PARAMS ((const char *));
294 static int is_directory PARAMS ((const char *, const char *, int));
295 static void validate_switches PARAMS ((const char *));
296 static void validate_all_switches PARAMS ((void));
297 static void give_switch PARAMS ((int, int, int));
298 static int used_arg PARAMS ((const char *, int));
299 static int default_arg PARAMS ((const char *, int));
300 static void set_multilib_dir PARAMS ((void));
301 static void print_multilib_info PARAMS ((void));
302 static void perror_with_name PARAMS ((const char *));
303 static void pfatal_pexecute PARAMS ((const char *, const char *))
304 ATTRIBUTE_NORETURN;
305 static void notice PARAMS ((const char *, ...))
306 ATTRIBUTE_PRINTF_1;
307 static void display_help PARAMS ((void));
308 static void add_preprocessor_option PARAMS ((const char *, int));
309 static void add_assembler_option PARAMS ((const char *, int));
310 static void add_linker_option PARAMS ((const char *, int));
311 static void process_command PARAMS ((int, const char *const *));
312 static int execute PARAMS ((void));
313 static void clear_args PARAMS ((void));
314 static void fatal_error PARAMS ((int));
315 static void set_input PARAMS ((const char *));
316 static void init_gcc_specs PARAMS ((struct obstack *,
317 const char *,
318 const char *));
320 /* The Specs Language
322 Specs are strings containing lines, each of which (if not blank)
323 is made up of a program name, and arguments separated by spaces.
324 The program name must be exact and start from root, since no path
325 is searched and it is unreliable to depend on the current working directory.
326 Redirection of input or output is not supported; the subprograms must
327 accept filenames saying what files to read and write.
329 In addition, the specs can contain %-sequences to substitute variable text
330 or for conditional text. Here is a table of all defined %-sequences.
331 Note that spaces are not generated automatically around the results of
332 expanding these sequences; therefore, you can concatenate them together
333 or with constant text in a single argument.
335 %% substitute one % into the program name or argument.
336 %i substitute the name of the input file being processed.
337 %b substitute the basename of the input file being processed.
338 This is the substring up to (and not including) the last period
339 and not including the directory.
340 %B same as %b, but include the file suffix (text after the last period).
341 %gSUFFIX
342 substitute a file name that has suffix SUFFIX and is chosen
343 once per compilation, and mark the argument a la %d. To reduce
344 exposure to denial-of-service attacks, the file name is now
345 chosen in a way that is hard to predict even when previously
346 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
347 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
348 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
349 had been pre-processed. Previously, %g was simply substituted
350 with a file name chosen once per compilation, without regard
351 to any appended suffix (which was therefore treated just like
352 ordinary text), making such attacks more likely to succeed.
353 %uSUFFIX
354 like %g, but generates a new temporary file name even if %uSUFFIX
355 was already seen.
356 %USUFFIX
357 substitutes the last file name generated with %uSUFFIX, generating a
358 new one if there is no such last file name. In the absence of any
359 %uSUFFIX, this is just like %gSUFFIX, except they don't share
360 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
361 would involve the generation of two distinct file names, one
362 for each `%g.s' and another for each `%U.s'. Previously, %U was
363 simply substituted with a file name chosen for the previous %u,
364 without regard to any appended suffix.
365 %jSUFFIX
366 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
367 writable, and if save-temps is off; otherwise, substitute the name
368 of a temporary file, just like %u. This temporary file is not
369 meant for communication between processes, but rather as a junk
370 disposal mechanism.
371 %.SUFFIX
372 substitutes .SUFFIX for the suffixes of a matched switch's args when
373 it is subsequently output with %*. SUFFIX is terminated by the next
374 space or %.
375 %d marks the argument containing or following the %d as a
376 temporary file name, so that that file will be deleted if CC exits
377 successfully. Unlike %g, this contributes no text to the argument.
378 %w marks the argument containing or following the %w as the
379 "output file" of this compilation. This puts the argument
380 into the sequence of arguments that %o will substitute later.
381 %W{...}
382 like %{...} but mark last argument supplied within
383 as a file to be deleted on failure.
384 %o substitutes the names of all the output files, with spaces
385 automatically placed around them. You should write spaces
386 around the %o as well or the results are undefined.
387 %o is for use in the specs for running the linker.
388 Input files whose names have no recognized suffix are not compiled
389 at all, but they are included among the output files, so they will
390 be linked.
391 %O substitutes the suffix for object files. Note that this is
392 handled specially when it immediately follows %g, %u, or %U
393 (with or without a suffix argument) because of the need for
394 those to form complete file names. The handling is such that
395 %O is treated exactly as if it had already been substituted,
396 except that %g, %u, and %U do not currently support additional
397 SUFFIX characters following %O as they would following, for
398 example, `.o'.
399 %p substitutes the standard macro predefinitions for the
400 current target machine. Use this when running cpp.
401 %P like %p, but puts `__' before and after the name of each macro.
402 (Except macros that already have __.)
403 This is for ANSI C.
404 %I Substitute a -iprefix option made from GCC_EXEC_PREFIX.
405 %s current argument is the name of a library or startup file of some sort.
406 Search for that file in a standard list of directories
407 and substitute the full name found.
408 %eSTR Print STR as an error message. STR is terminated by a newline.
409 Use this when inconsistent options are detected.
410 %nSTR Print STR as an notice. STR is terminated by a newline.
411 %x{OPTION} Accumulate an option for %X.
412 %X Output the accumulated linker options specified by compilations.
413 %Y Output the accumulated assembler options specified by compilations.
414 %Z Output the accumulated preprocessor options specified by compilations.
415 %v1 Substitute the major version number of GCC.
416 (For version 2.5.3, this is 2.)
417 %v2 Substitute the minor version number of GCC.
418 (For version 2.5.3, this is 5.)
419 %v3 Substitute the patch level number of GCC.
420 (For version 2.5.3, this is 3.)
421 %a process ASM_SPEC as a spec.
422 This allows config.h to specify part of the spec for running as.
423 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
424 used here. This can be used to run a post-processor after the
425 assembler has done its job.
426 %D Dump out a -L option for each directory in startfile_prefixes.
427 If multilib_dir is set, extra entries are generated with it affixed.
428 %l process LINK_SPEC as a spec.
429 %L process LIB_SPEC as a spec.
430 %G process LIBGCC_SPEC as a spec.
431 %M output multilib_dir with directory separators replaced with "_";
432 if multilib_dir is not set or is ".", output "".
433 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
434 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
435 %c process SIGNED_CHAR_SPEC as a spec.
436 %C process CPP_SPEC as a spec.
437 %1 process CC1_SPEC as a spec.
438 %2 process CC1PLUS_SPEC as a spec.
439 %| output "-" if the input for the current command is coming from a pipe.
440 %* substitute the variable part of a matched option. (See below.)
441 Note that each comma in the substituted string is replaced by
442 a single space.
443 %{S} substitutes the -S switch, if that switch was given to CC.
444 If that switch was not specified, this substitutes nothing.
445 Here S is a metasyntactic variable.
446 %{S*} substitutes all the switches specified to CC whose names start
447 with -S. This is used for -o, -I, etc; switches that take
448 arguments. CC considers `-o foo' as being one switch whose
449 name starts with `o'. %{o*} would substitute this text,
450 including the space; thus, two arguments would be generated.
451 %{^S*} likewise, but don't put a blank between a switch and any args.
452 %{S*&T*} likewise, but preserve order of S and T options (the order
453 of S and T in the spec is not significant). Can be any number
454 of ampersand-separated variables; for each the wild card is
455 optional. Useful for CPP as %{D*&U*&A*}.
456 %{S*:X} substitutes X if one or more switches whose names start with -S are
457 specified to CC. Note that the tail part of the -S option
458 (i.e. the part matched by the `*') will be substituted for each
459 occurrence of %* within X.
460 %{<S} remove all occurences of -S from the command line.
461 Note - this option is position dependent. % commands in the
462 spec string before this option will see -S, % commands in the
463 spec string after this option will not.
464 %{S:X} substitutes X, but only if the -S switch was given to CC.
465 %{!S:X} substitutes X, but only if the -S switch was NOT given to CC.
466 %{|S:X} like %{S:X}, but if no S switch, substitute `-'.
467 %{|!S:X} like %{!S:X}, but if there is an S switch, substitute `-'.
468 %{.S:X} substitutes X, but only if processing a file with suffix S.
469 %{!.S:X} substitutes X, but only if NOT processing a file with suffix S.
470 %{S|P:X} substitutes X if either -S or -P was given to CC. This may be
471 combined with ! and . as above binding stronger than the OR.
472 %(Spec) processes a specification defined in a specs file as *Spec:
473 %[Spec] as above, but put __ around -D arguments
475 The conditional text X in a %{S:X} or %{!S:X} construct may contain
476 other nested % constructs or spaces, or even newlines. They are
477 processed as usual, as described above.
479 The -O, -f, -m, and -W switches are handled specifically in these
480 constructs. If another value of -O or the negated form of a -f, -m, or
481 -W switch is found later in the command line, the earlier switch
482 value is ignored, except with {S*} where S is just one letter; this
483 passes all matching options.
485 The character | at the beginning of the predicate text is used to indicate
486 that a command should be piped to the following command, but only if -pipe
487 is specified.
489 Note that it is built into CC which switches take arguments and which
490 do not. You might think it would be useful to generalize this to
491 allow each compiler's spec to say which switches take arguments. But
492 this cannot be done in a consistent fashion. CC cannot even decide
493 which input files have been specified without knowing which switches
494 take arguments, and it must know which input files to compile in order
495 to tell which compilers to run.
497 CC also knows implicitly that arguments starting in `-l' are to be
498 treated as compiler output files, and passed to the linker in their
499 proper position among the other output files. */
501 /* Define the macros used for specs %a, %l, %L, %S, %c, %C, %1. */
503 /* config.h can define ASM_SPEC to provide extra args to the assembler
504 or extra switch-translations. */
505 #ifndef ASM_SPEC
506 #define ASM_SPEC ""
507 #endif
509 /* config.h can define ASM_FINAL_SPEC to run a post processor after
510 the assembler has run. */
511 #ifndef ASM_FINAL_SPEC
512 #define ASM_FINAL_SPEC ""
513 #endif
515 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
516 or extra switch-translations. */
517 #ifndef CPP_SPEC
518 #define CPP_SPEC ""
519 #endif
521 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
522 or extra switch-translations. */
523 #ifndef CC1_SPEC
524 #define CC1_SPEC ""
525 #endif
527 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
528 or extra switch-translations. */
529 #ifndef CC1PLUS_SPEC
530 #define CC1PLUS_SPEC ""
531 #endif
533 /* config.h can define LINK_SPEC to provide extra args to the linker
534 or extra switch-translations. */
535 #ifndef LINK_SPEC
536 #define LINK_SPEC ""
537 #endif
539 /* config.h can define LIB_SPEC to override the default libraries. */
540 #ifndef LIB_SPEC
541 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
542 #endif
544 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
545 included. */
546 #ifndef LIBGCC_SPEC
547 #if defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
548 /* Have gcc do the search for libgcc.a. */
549 #define LIBGCC_SPEC "libgcc.a%s"
550 #else
551 #define LIBGCC_SPEC "-lgcc"
552 #endif
553 #endif
555 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
556 #ifndef STARTFILE_SPEC
557 #define STARTFILE_SPEC \
558 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
559 #endif
561 /* config.h can define SWITCHES_NEED_SPACES to control which options
562 require spaces between the option and the argument. */
563 #ifndef SWITCHES_NEED_SPACES
564 #define SWITCHES_NEED_SPACES ""
565 #endif
567 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
568 #ifndef ENDFILE_SPEC
569 #define ENDFILE_SPEC ""
570 #endif
572 /* This spec is used for telling cpp whether char is signed or not. */
573 #ifndef SIGNED_CHAR_SPEC
574 /* Use #if rather than ?:
575 because MIPS C compiler rejects like ?: in initializers. */
576 #if DEFAULT_SIGNED_CHAR
577 #define SIGNED_CHAR_SPEC "%{funsigned-char:-D__CHAR_UNSIGNED__}"
578 #else
579 #define SIGNED_CHAR_SPEC "%{!fsigned-char:-D__CHAR_UNSIGNED__}"
580 #endif
581 #endif
583 #ifndef LINKER_NAME
584 #define LINKER_NAME "collect2"
585 #endif
587 /* Here is the spec for running the linker, after compiling all files. */
589 /* -u* was put back because both BSD and SysV seem to support it. */
590 /* %{static:} simply prevents an error message if the target machine
591 doesn't handle -static. */
592 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
593 scripts which exist in user specified directories, or in standard
594 directories. */
595 #ifndef LINK_COMMAND_SPEC
596 #define LINK_COMMAND_SPEC "\
597 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
598 %(linker) %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r} %{s} %{t}\
599 %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
600 %{static:} %{L*} %(link_libgcc) %o %{!nostdlib:%{!nodefaultlibs:%G %L %G}}\
601 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
602 #endif
604 #ifndef LINK_LIBGCC_SPEC
605 # ifdef LINK_LIBGCC_SPECIAL
606 /* Don't generate -L options for startfile prefix list. */
607 # define LINK_LIBGCC_SPEC ""
608 # else
609 /* Do generate them. */
610 # define LINK_LIBGCC_SPEC "%D"
611 # endif
612 #endif
614 static const char *cpp_spec = CPP_SPEC;
615 static const char *cpp_predefines = CPP_PREDEFINES;
616 static const char *cc1_spec = CC1_SPEC;
617 static const char *cc1plus_spec = CC1PLUS_SPEC;
618 static const char *signed_char_spec = SIGNED_CHAR_SPEC;
619 static const char *asm_spec = ASM_SPEC;
620 static const char *asm_final_spec = ASM_FINAL_SPEC;
621 static const char *link_spec = LINK_SPEC;
622 static const char *lib_spec = LIB_SPEC;
623 static const char *libgcc_spec = LIBGCC_SPEC;
624 static const char *endfile_spec = ENDFILE_SPEC;
625 static const char *startfile_spec = STARTFILE_SPEC;
626 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
627 static const char *linker_name_spec = LINKER_NAME;
628 static const char *link_command_spec = LINK_COMMAND_SPEC;
629 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
631 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
632 There should be no need to override these in target dependent files,
633 but we need to copy them to the specs file so that newer versions
634 of the GCC driver can correctly drive older tool chains with the
635 appropriate -B options. */
637 static const char *trad_capable_cpp =
638 "%{traditional|ftraditional|traditional-cpp:trad}cpp0";
640 static const char *cpp_options =
641 "%{C:%{!E:%eGNU C does not support -C without using -E}}\
642 %{std*} %{nostdinc*}\
643 %{C} %{v} %{I*} %{P} %{$} %I\
644 %{MD:-M -MF %W{!o: %b.d}%W{o*:%.d%*}}\
645 %{MMD:-MM -MF %W{!o: %b.d}%W{o*:%.d%*}}\
646 %{M} %{MM} %W{MF*} %{MG} %{MP} %{MQ*} %{MT*} %{M|MD|MM|MMD:%{o*:-MQ %*}}\
647 %{!no-gcc:-D__GNUC__=%v1 -D__GNUC_MINOR__=%v2 -D__GNUC_PATCHLEVEL__=%v3}\
648 %{!undef:%{!ansi:%{!std=*:%p}%{std=gnu*:%p}} %P} %{trigraphs}\
649 %c %{Os:-D__OPTIMIZE_SIZE__} %{O*:%{!O0:-D__OPTIMIZE__}}\
650 %{fno-inline|O0|!O*:-D__NO_INLINE__} %{ffast-math:-D__FAST_MATH__}\
651 %{fshort-wchar:-U__WCHAR_TYPE__ -D__WCHAR_TYPE__=short\\ unsigned\\ int}\
652 %{ffreestanding:-D__STDC_HOSTED__=0} %{fno-hosted:-D__STDC_HOSTED__=0}\
653 %{!ffreestanding:%{!fno-hosted:-D__STDC_HOSTED__=1}}\
654 %{fshow-column} %{fno-show-column}\
655 %{fleading-underscore} %{fno-leading-underscore}\
656 %{fno-operator-names} %{ftabstop=*} %{remap}\
657 %{g3:-dD} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*&U*&A*} %{i*} %Z %i\
658 %{E:%{!M*:%W{o*}}}";
660 /* NB: This is shared amongst all front-ends. */
661 static const char *cc1_options =
662 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
663 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
664 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{std*} %{ansi}\
665 %{traditional} %{v:-version} %{pg:-p} %{p} %{f*}\
666 %{aux-info*} %{Qn:-fno-ident} %{--help:--help}\
667 %{--target-help:--target-help}\
668 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
669 %{fsyntax-only:-o %j} %{-param*}";
671 static const char *asm_options =
672 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
674 static const char *invoke_as =
675 "%{!S:-o %{|!pipe:%g.s} |\n as %(asm_options) %{!pipe:%g.s} %A }";
677 /* Some compilers have limits on line lengths, and the multilib_select
678 and/or multilib_matches strings can be very long, so we build them at
679 run time. */
680 static struct obstack multilib_obstack;
681 static const char *multilib_select;
682 static const char *multilib_matches;
683 static const char *multilib_defaults;
684 static const char *multilib_exclusions;
685 #include "multilib.h"
687 /* Check whether a particular argument is a default argument. */
689 #ifndef MULTILIB_DEFAULTS
690 #define MULTILIB_DEFAULTS { "" }
691 #endif
693 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
695 struct user_specs
697 struct user_specs *next;
698 const char *filename;
701 static struct user_specs *user_specs_head, *user_specs_tail;
703 /* This defines which switch letters take arguments. */
705 #define DEFAULT_SWITCH_TAKES_ARG(CHAR) \
706 ((CHAR) == 'D' || (CHAR) == 'U' || (CHAR) == 'o' \
707 || (CHAR) == 'e' || (CHAR) == 'T' || (CHAR) == 'u' \
708 || (CHAR) == 'I' || (CHAR) == 'm' || (CHAR) == 'x' \
709 || (CHAR) == 'L' || (CHAR) == 'A' || (CHAR) == 'V' \
710 || (CHAR) == 'B' || (CHAR) == 'b')
712 #ifndef SWITCH_TAKES_ARG
713 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
714 #endif
716 /* This defines which multi-letter switches take arguments. */
718 #define DEFAULT_WORD_SWITCH_TAKES_ARG(STR) \
719 (!strcmp (STR, "Tdata") || !strcmp (STR, "Ttext") \
720 || !strcmp (STR, "Tbss") || !strcmp (STR, "include") \
721 || !strcmp (STR, "imacros") || !strcmp (STR, "aux-info") \
722 || !strcmp (STR, "idirafter") || !strcmp (STR, "iprefix") \
723 || !strcmp (STR, "iwithprefix") || !strcmp (STR, "iwithprefixbefore") \
724 || !strcmp (STR, "isystem") || !strcmp (STR, "-param") \
725 || !strcmp (STR, "specs") \
726 || !strcmp (STR, "MF") || !strcmp (STR, "MT") || !strcmp (STR, "MQ"))
728 #ifndef WORD_SWITCH_TAKES_ARG
729 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
730 #endif
732 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
733 /* This defines which switches stop a full compilation. */
734 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
735 ((CHAR) == 'c' || (CHAR) == 'S')
737 #ifndef SWITCH_CURTAILS_COMPILATION
738 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
739 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
740 #endif
741 #endif
743 /* Record the mapping from file suffixes for compilation specs. */
745 struct compiler
747 const char *suffix; /* Use this compiler for input files
748 whose names end in this suffix. */
750 const char *spec; /* To use this compiler, run this spec. */
752 const char *cpp_spec; /* If non-NULL, substitute this spec
753 for `%C', rather than the usual
754 cpp_spec. */
757 /* Pointer to a vector of `struct compiler' that gives the spec for
758 compiling a file, based on its suffix.
759 A file that does not end in any of these suffixes will be passed
760 unchanged to the loader and nothing else will be done to it.
762 An entry containing two 0s is used to terminate the vector.
764 If multiple entries match a file, the last matching one is used. */
766 static struct compiler *compilers;
768 /* Number of entries in `compilers', not counting the null terminator. */
770 static int n_compilers;
772 /* The default list of file name suffixes and their compilation specs. */
774 static struct compiler default_compilers[] =
776 /* Add lists of suffixes of known languages here. If those languages
777 were not present when we built the driver, we will hit these copies
778 and be given a more meaningful error than "file not used since
779 linking is not done". */
780 {".m", "#Objective-C", 0}, {".mi", "#Objective-C", 0},
781 {".cc", "#C++", 0}, {".cxx", "#C++", 0}, {".cpp", "#C++", 0},
782 {".cp", "#C++", 0}, {".c++", "#C++", 0}, {".C", "#C++", 0},
783 {".ii", "#C++", 0},
784 {".ads", "#Ada", 0}, {".adb", "#Ada", 0}, {".ada", "#Ada", 0},
785 {".f", "#Fortran", 0}, {".for", "#Fortran", 0}, {".fpp", "#Fortran", 0},
786 {".F", "#Fortran", 0}, {".FOR", "#Fortran", 0}, {".FPP", "#Fortran", 0},
787 {".r", "#Ratfor", 0},
788 {".p", "#Pascal", 0}, {".pas", "#Pascal", 0},
789 {".ch", "#Chill", 0}, {".chi", "#Chill", 0},
790 {".java", "#Java", 0}, {".class", "#Java", 0},
791 {".zip", "#Java", 0}, {".jar", "#Java", 0},
792 /* Next come the entries for C. */
793 {".c", "@c", 0},
794 {"@c",
795 /* cc1 has an integrated ISO C preprocessor. We should invoke the
796 external preprocessor if -save-temps or -traditional is given. */
797 "%{E|M|MM:%(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)}\
798 %{!E:%{!M:%{!MM:\
799 %{save-temps:%(trad_capable_cpp) -lang-c %{ansi:-std=c89}\
800 %(cpp_options) %b.i \n\
801 cc1 -fpreprocessed %b.i %(cc1_options)}\
802 %{!save-temps:\
803 %{traditional|ftraditional|traditional-cpp:\
804 tradcpp0 -lang-c %{ansi:-std=c89} %(cpp_options) %{!pipe:%g.i} |\n\
805 cc1 -fpreprocessed %{!pipe:%g.i} %(cc1_options)}\
806 %{!traditional:%{!ftraditional:%{!traditional-cpp:\
807 cc1 -lang-c %{ansi:-std=c89} %(cpp_options) %(cc1_options)}}}}\
808 %{!fsyntax-only:%(invoke_as)}}}}", 0},
809 {"-",
810 "%{!E:%e-E required when input is from standard input}\
811 %(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)", 0},
812 {".h", "@c-header", 0},
813 {"@c-header",
814 "%{!E:%eCompilation of header file requested} \
815 %(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)", 0},
816 {".i", "@cpp-output", 0},
817 {"@cpp-output",
818 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0},
819 {".s", "@assembler", 0},
820 {"@assembler",
821 "%{!M:%{!MM:%{!E:%{!S:as %(asm_options) %i %A }}}}", 0},
822 {".S", "@assembler-with-cpp", 0},
823 {"@assembler-with-cpp",
824 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
825 %{!M:%{!MM:%{!E:%(invoke_as)}}}", 0},
826 #include "specs.h"
827 /* Mark end of table */
828 {0, 0, 0}
831 /* Number of elements in default_compilers, not counting the terminator. */
833 static int n_default_compilers
834 = (sizeof default_compilers / sizeof (struct compiler)) - 1;
836 /* A vector of options to give to the linker.
837 These options are accumulated by %x,
838 and substituted into the linker command with %X. */
839 static int n_linker_options;
840 static char **linker_options;
842 /* A vector of options to give to the assembler.
843 These options are accumulated by -Wa,
844 and substituted into the assembler command with %Y. */
845 static int n_assembler_options;
846 static char **assembler_options;
848 /* A vector of options to give to the preprocessor.
849 These options are accumulated by -Wp,
850 and substituted into the preprocessor command with %Z. */
851 static int n_preprocessor_options;
852 static char **preprocessor_options;
854 /* Define how to map long options into short ones. */
856 /* This structure describes one mapping. */
857 struct option_map
859 /* The long option's name. */
860 const char *name;
861 /* The equivalent short option. */
862 const char *equivalent;
863 /* Argument info. A string of flag chars; NULL equals no options.
864 a => argument required.
865 o => argument optional.
866 j => join argument to equivalent, making one word.
867 * => require other text after NAME as an argument. */
868 const char *arg_info;
871 /* This is the table of mappings. Mappings are tried sequentially
872 for each option encountered; the first one that matches, wins. */
874 struct option_map option_map[] =
876 {"--all-warnings", "-Wall", 0},
877 {"--ansi", "-ansi", 0},
878 {"--assemble", "-S", 0},
879 {"--assert", "-A", "a"},
880 {"--classpath", "-fclasspath=", "aj"},
881 {"--CLASSPATH", "-fCLASSPATH=", "aj"},
882 {"--comments", "-C", 0},
883 {"--compile", "-c", 0},
884 {"--debug", "-g", "oj"},
885 {"--define-macro", "-D", "aj"},
886 {"--dependencies", "-M", 0},
887 {"--dump", "-d", "a"},
888 {"--dumpbase", "-dumpbase", "a"},
889 {"--entry", "-e", 0},
890 {"--extra-warnings", "-W", 0},
891 {"--for-assembler", "-Wa", "a"},
892 {"--for-linker", "-Xlinker", "a"},
893 {"--force-link", "-u", "a"},
894 {"--imacros", "-imacros", "a"},
895 {"--include", "-include", "a"},
896 {"--include-barrier", "-I-", 0},
897 {"--include-directory", "-I", "aj"},
898 {"--include-directory-after", "-idirafter", "a"},
899 {"--include-prefix", "-iprefix", "a"},
900 {"--include-with-prefix", "-iwithprefix", "a"},
901 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
902 {"--include-with-prefix-after", "-iwithprefix", "a"},
903 {"--language", "-x", "a"},
904 {"--library-directory", "-L", "a"},
905 {"--machine", "-m", "aj"},
906 {"--machine-", "-m", "*j"},
907 {"--no-line-commands", "-P", 0},
908 {"--no-precompiled-includes", "-noprecomp", 0},
909 {"--no-standard-includes", "-nostdinc", 0},
910 {"--no-standard-libraries", "-nostdlib", 0},
911 {"--no-warnings", "-w", 0},
912 {"--optimize", "-O", "oj"},
913 {"--output", "-o", "a"},
914 {"--output-class-directory", "-foutput-class-dir=", "ja"},
915 {"--param", "--param", "a"},
916 {"--pedantic", "-pedantic", 0},
917 {"--pedantic-errors", "-pedantic-errors", 0},
918 {"--pipe", "-pipe", 0},
919 {"--prefix", "-B", "a"},
920 {"--preprocess", "-E", 0},
921 {"--print-search-dirs", "-print-search-dirs", 0},
922 {"--print-file-name", "-print-file-name=", "aj"},
923 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
924 {"--print-missing-file-dependencies", "-MG", 0},
925 {"--print-multi-lib", "-print-multi-lib", 0},
926 {"--print-multi-directory", "-print-multi-directory", 0},
927 {"--print-prog-name", "-print-prog-name=", "aj"},
928 {"--profile", "-p", 0},
929 {"--profile-blocks", "-a", 0},
930 {"--quiet", "-q", 0},
931 {"--save-temps", "-save-temps", 0},
932 {"--shared", "-shared", 0},
933 {"--silent", "-q", 0},
934 {"--specs", "-specs=", "aj"},
935 {"--static", "-static", 0},
936 {"--std", "-std=", "aj"},
937 {"--symbolic", "-symbolic", 0},
938 {"--target", "-b", "a"},
939 {"--time", "-time", 0},
940 {"--trace-includes", "-H", 0},
941 {"--traditional", "-traditional", 0},
942 {"--traditional-cpp", "-traditional-cpp", 0},
943 {"--trigraphs", "-trigraphs", 0},
944 {"--undefine-macro", "-U", "aj"},
945 {"--use-version", "-V", "a"},
946 {"--user-dependencies", "-MM", 0},
947 {"--verbose", "-v", 0},
948 {"--version", "-dumpversion", 0},
949 {"--warn-", "-W", "*j"},
950 {"--write-dependencies", "-MD", 0},
951 {"--write-user-dependencies", "-MMD", 0},
952 {"--", "-f", "*j"}
955 /* Translate the options described by *ARGCP and *ARGVP.
956 Make a new vector and store it back in *ARGVP,
957 and store its length in *ARGVC. */
959 static void
960 translate_options (argcp, argvp)
961 int *argcp;
962 const char *const **argvp;
964 int i;
965 int argc = *argcp;
966 const char *const *argv = *argvp;
967 const char **newv =
968 (const char **) xmalloc ((argc + 2) * 2 * sizeof (const char *));
969 int newindex = 0;
971 i = 0;
972 newv[newindex++] = argv[i++];
974 while (i < argc)
976 /* Translate -- options. */
977 if (argv[i][0] == '-' && argv[i][1] == '-')
979 size_t j;
980 /* Find a mapping that applies to this option. */
981 for (j = 0; j < ARRAY_SIZE (option_map); j++)
983 size_t optlen = strlen (option_map[j].name);
984 size_t arglen = strlen (argv[i]);
985 size_t complen = arglen > optlen ? optlen : arglen;
986 const char *arginfo = option_map[j].arg_info;
988 if (arginfo == 0)
989 arginfo = "";
991 if (!strncmp (argv[i], option_map[j].name, complen))
993 const char *arg = 0;
995 if (arglen < optlen)
997 size_t k;
998 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
999 if (strlen (option_map[k].name) >= arglen
1000 && !strncmp (argv[i], option_map[k].name, arglen))
1002 error ("Ambiguous abbreviation %s", argv[i]);
1003 break;
1006 if (k != ARRAY_SIZE (option_map))
1007 break;
1010 if (arglen > optlen)
1012 /* If the option has an argument, accept that. */
1013 if (argv[i][optlen] == '=')
1014 arg = argv[i] + optlen + 1;
1016 /* If this mapping requires extra text at end of name,
1017 accept that as "argument". */
1018 else if (strchr (arginfo, '*') != 0)
1019 arg = argv[i] + optlen;
1021 /* Otherwise, extra text at end means mismatch.
1022 Try other mappings. */
1023 else
1024 continue;
1027 else if (strchr (arginfo, '*') != 0)
1029 error ("Incomplete `%s' option", option_map[j].name);
1030 break;
1033 /* Handle arguments. */
1034 if (strchr (arginfo, 'a') != 0)
1036 if (arg == 0)
1038 if (i + 1 == argc)
1040 error ("Missing argument to `%s' option",
1041 option_map[j].name);
1042 break;
1045 arg = argv[++i];
1048 else if (strchr (arginfo, '*') != 0)
1050 else if (strchr (arginfo, 'o') == 0)
1052 if (arg != 0)
1053 error ("Extraneous argument to `%s' option",
1054 option_map[j].name);
1055 arg = 0;
1058 /* Store the translation as one argv elt or as two. */
1059 if (arg != 0 && strchr (arginfo, 'j') != 0)
1060 newv[newindex++] = concat (option_map[j].equivalent, arg,
1061 NULL);
1062 else if (arg != 0)
1064 newv[newindex++] = option_map[j].equivalent;
1065 newv[newindex++] = arg;
1067 else
1068 newv[newindex++] = option_map[j].equivalent;
1070 break;
1073 i++;
1076 /* Handle old-fashioned options--just copy them through,
1077 with their arguments. */
1078 else if (argv[i][0] == '-')
1080 const char *p = argv[i] + 1;
1081 int c = *p;
1082 int nskip = 1;
1084 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1085 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1086 else if (WORD_SWITCH_TAKES_ARG (p))
1087 nskip += WORD_SWITCH_TAKES_ARG (p);
1088 else if ((c == 'B' || c == 'b' || c == 'V' || c == 'x')
1089 && p[1] == 0)
1090 nskip += 1;
1091 else if (! strcmp (p, "Xlinker"))
1092 nskip += 1;
1094 /* Watch out for an option at the end of the command line that
1095 is missing arguments, and avoid skipping past the end of the
1096 command line. */
1097 if (nskip + i > argc)
1098 nskip = argc - i;
1100 while (nskip > 0)
1102 newv[newindex++] = argv[i++];
1103 nskip--;
1106 else
1107 /* Ordinary operands, or +e options. */
1108 newv[newindex++] = argv[i++];
1111 newv[newindex] = 0;
1113 *argvp = newv;
1114 *argcp = newindex;
1117 static char *
1118 skip_whitespace (p)
1119 char *p;
1121 while (1)
1123 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1124 be considered whitespace. */
1125 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1126 return p + 1;
1127 else if (*p == '\n' || *p == ' ' || *p == '\t')
1128 p++;
1129 else if (*p == '#')
1131 while (*p != '\n')
1132 p++;
1133 p++;
1135 else
1136 break;
1139 return p;
1141 /* Structures to keep track of prefixes to try when looking for files. */
1143 struct prefix_list
1145 char *prefix; /* String to prepend to the path. */
1146 struct prefix_list *next; /* Next in linked list. */
1147 int require_machine_suffix; /* Don't use without machine_suffix. */
1148 /* 2 means try both machine_suffix and just_machine_suffix. */
1149 int *used_flag_ptr; /* 1 if a file was found with this prefix. */
1150 int priority; /* Sort key - priority within list */
1153 struct path_prefix
1155 struct prefix_list *plist; /* List of prefixes to try */
1156 int max_len; /* Max length of a prefix in PLIST */
1157 const char *name; /* Name of this list (used in config stuff) */
1160 /* List of prefixes to try when looking for executables. */
1162 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1164 /* List of prefixes to try when looking for startup (crt0) files. */
1166 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1168 /* List of prefixes to try when looking for include files. */
1170 static struct path_prefix include_prefixes = { 0, 0, "include" };
1172 /* Suffix to attach to directories searched for commands.
1173 This looks like `MACHINE/VERSION/'. */
1175 static const char *machine_suffix = 0;
1177 /* Suffix to attach to directories searched for commands.
1178 This is just `MACHINE/'. */
1180 static const char *just_machine_suffix = 0;
1182 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1184 static const char *gcc_exec_prefix;
1186 /* Default prefixes to attach to command names. */
1188 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1189 #undef MD_EXEC_PREFIX
1190 #undef MD_STARTFILE_PREFIX
1191 #undef MD_STARTFILE_PREFIX_1
1192 #endif
1194 /* If no prefixes defined, use the null string, which will disable them. */
1195 #ifndef MD_EXEC_PREFIX
1196 #define MD_EXEC_PREFIX ""
1197 #endif
1198 #ifndef MD_STARTFILE_PREFIX
1199 #define MD_STARTFILE_PREFIX ""
1200 #endif
1201 #ifndef MD_STARTFILE_PREFIX_1
1202 #define MD_STARTFILE_PREFIX_1 ""
1203 #endif
1205 /* Supply defaults for the standard prefixes. */
1207 #ifndef STANDARD_EXEC_PREFIX
1208 #define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
1209 #endif
1210 #ifndef STANDARD_STARTFILE_PREFIX
1211 #define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
1212 #endif
1213 #ifndef TOOLDIR_BASE_PREFIX
1214 #define TOOLDIR_BASE_PREFIX "/usr/local/"
1215 #endif
1216 #ifndef STANDARD_BINDIR_PREFIX
1217 #define STANDARD_BINDIR_PREFIX "/usr/local/bin"
1218 #endif
1220 static const char *standard_exec_prefix = STANDARD_EXEC_PREFIX;
1221 static const char *standard_exec_prefix_1 = "/usr/lib/gcc/";
1222 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1224 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1225 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1226 static const char *standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1227 static const char *standard_startfile_prefix_1 = "/lib/";
1228 static const char *standard_startfile_prefix_2 = "/usr/lib/";
1230 static const char *tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1231 static const char *tooldir_prefix;
1233 static const char *standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1235 /* Subdirectory to use for locating libraries. Set by
1236 set_multilib_dir based on the compilation options. */
1238 static const char *multilib_dir;
1240 /* Structure to keep track of the specs that have been defined so far.
1241 These are accessed using %(specname) or %[specname] in a compiler
1242 or link spec. */
1244 struct spec_list
1246 /* The following 2 fields must be first */
1247 /* to allow EXTRA_SPECS to be initialized */
1248 const char *name; /* name of the spec. */
1249 const char *ptr; /* available ptr if no static pointer */
1251 /* The following fields are not initialized */
1252 /* by EXTRA_SPECS */
1253 const char **ptr_spec; /* pointer to the spec itself. */
1254 struct spec_list *next; /* Next spec in linked list. */
1255 int name_len; /* length of the name */
1256 int alloc_p; /* whether string was allocated */
1259 #define INIT_STATIC_SPEC(NAME,PTR) \
1260 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1262 /* List of statically defined specs. */
1263 static struct spec_list static_specs[] =
1265 INIT_STATIC_SPEC ("asm", &asm_spec),
1266 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1267 INIT_STATIC_SPEC ("asm_options", &asm_options),
1268 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1269 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1270 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1271 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1272 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1273 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1274 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1275 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1276 INIT_STATIC_SPEC ("link", &link_spec),
1277 INIT_STATIC_SPEC ("lib", &lib_spec),
1278 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1279 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1280 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1281 INIT_STATIC_SPEC ("signed_char", &signed_char_spec),
1282 INIT_STATIC_SPEC ("predefines", &cpp_predefines),
1283 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1284 INIT_STATIC_SPEC ("version", &compiler_version),
1285 INIT_STATIC_SPEC ("multilib", &multilib_select),
1286 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1287 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1288 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1289 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1290 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1291 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1292 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1293 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1294 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1297 #ifdef EXTRA_SPECS /* additional specs needed */
1298 /* Structure to keep track of just the first two args of a spec_list.
1299 That is all that the EXTRA_SPECS macro gives us. */
1300 struct spec_list_1
1302 const char *name;
1303 const char *ptr;
1306 static struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1307 static struct spec_list *extra_specs = (struct spec_list *) 0;
1308 #endif
1310 /* List of dynamically allocates specs that have been defined so far. */
1312 static struct spec_list *specs = (struct spec_list *) 0;
1314 /* Add appropriate libgcc specs to OBSTACK, taking into account
1315 various permutations of -shared-libgcc, -shared, and such. */
1317 static void
1318 init_gcc_specs (obstack, shared_name, static_name)
1319 struct obstack *obstack;
1320 const char *shared_name;
1321 const char *static_name;
1323 char buffer[128];
1325 /* If we see -shared-libgcc, then use the shared version. */
1326 sprintf (buffer, "%%{shared-libgcc:%s}", shared_name);
1327 obstack_grow (obstack, buffer, strlen (buffer));
1328 /* If we see -static-libgcc, then use the static version. */
1329 sprintf (buffer, "%%{static-libgcc:%s}", static_name);
1330 obstack_grow (obstack, buffer, strlen (buffer));
1331 /* Otherwise, if we see -shared, then use the shared version. */
1332 sprintf (buffer,
1333 "%%{!shared-libgcc:%%{!static-libgcc:%%{shared:%s}}}",
1334 shared_name);
1335 obstack_grow (obstack, buffer, strlen (buffer));
1336 /* Otherwise, use the static version. */
1337 sprintf (buffer,
1338 "%%{!shared-libgcc:%%{!static-libgcc:%%{!shared:%s}}}",
1339 static_name);
1340 obstack_grow (obstack, buffer, strlen (buffer));
1343 /* Initialize the specs lookup routines. */
1345 static void
1346 init_spec ()
1348 struct spec_list *next = (struct spec_list *) 0;
1349 struct spec_list *sl = (struct spec_list *) 0;
1350 int i;
1352 if (specs)
1353 return; /* Already initialized. */
1355 if (verbose_flag)
1356 notice ("Using builtin specs.\n");
1358 #ifdef EXTRA_SPECS
1359 extra_specs = (struct spec_list *)
1360 xcalloc (sizeof (struct spec_list), ARRAY_SIZE (extra_specs_1));
1362 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1364 sl = &extra_specs[i];
1365 sl->name = extra_specs_1[i].name;
1366 sl->ptr = extra_specs_1[i].ptr;
1367 sl->next = next;
1368 sl->name_len = strlen (sl->name);
1369 sl->ptr_spec = &sl->ptr;
1370 next = sl;
1372 #endif
1374 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1376 sl = &static_specs[i];
1377 sl->next = next;
1378 next = sl;
1381 #ifdef ENABLE_SHARED_LIBGCC
1382 /* ??? If neither -shared-libgcc nor --static-libgcc was
1383 seen, then we should be making an educated guess. Some proposed
1384 heuristics for ELF include:
1386 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1387 program will be doing dynamic loading, which will likely
1388 need the shared libgcc.
1390 (2) If "-ldl", then it's also a fair bet that we're doing
1391 dynamic loading.
1393 (3) For each ET_DYN we're linking against (either through -lfoo
1394 or /some/path/foo.so), check to see whether it or one of
1395 its dependancies depends on a shared libgcc.
1397 (4) If "-shared"
1399 If the runtime is fixed to look for program headers instead
1400 of calling __register_frame_info at all, for each object,
1401 use the shared libgcc if any EH symbol referenced.
1403 If crtstuff is fixed to not invoke __register_frame_info
1404 automatically, for each object, use the shared libgcc if
1405 any non-empty unwind section found.
1407 Doing any of this probably requires invoking an external program to
1408 do the actual object file scanning. */
1410 const char *p = libgcc_spec;
1411 int in_sep = 1;
1413 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1414 when given the proper command line arguments. */
1415 while (*p)
1417 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1419 init_gcc_specs (&obstack,
1420 #ifdef NO_SHARED_LIBGCC_MULTILIB
1421 "-lgcc_s"
1422 #else
1423 "-lgcc_s%M"
1424 #endif
1426 "-lgcc");
1427 p += 5;
1428 in_sep = 0;
1430 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1432 /* Ug. We don't know shared library extensions. Hope that
1433 systems that use this form don't do shared libraries. */
1434 init_gcc_specs (&obstack,
1435 #ifdef NO_SHARED_LIBGCC_MULTILIB
1436 "-lgcc_s"
1437 #else
1438 "-lgcc_s%M"
1439 #endif
1441 "libgcc.a%s");
1442 p += 10;
1443 in_sep = 0;
1445 else
1447 obstack_1grow (&obstack, *p);
1448 in_sep = (*p == ' ');
1449 p += 1;
1453 obstack_1grow (&obstack, '\0');
1454 libgcc_spec = obstack_finish (&obstack);
1456 #endif
1457 #ifdef USE_AS_TRADITIONAL_FORMAT
1458 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1460 static char tf[] = "--traditional-format ";
1461 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1462 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1463 asm_spec = obstack_finish (&obstack);
1465 #endif
1467 specs = sl;
1470 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1471 removed; If the spec starts with a + then SPEC is added to the end of the
1472 current spec. */
1474 static void
1475 set_spec (name, spec)
1476 const char *name;
1477 const char *spec;
1479 struct spec_list *sl;
1480 const char *old_spec;
1481 int name_len = strlen (name);
1482 int i;
1484 /* If this is the first call, initialize the statically allocated specs. */
1485 if (!specs)
1487 struct spec_list *next = (struct spec_list *) 0;
1488 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1490 sl = &static_specs[i];
1491 sl->next = next;
1492 next = sl;
1494 specs = sl;
1497 /* See if the spec already exists. */
1498 for (sl = specs; sl; sl = sl->next)
1499 if (name_len == sl->name_len && !strcmp (sl->name, name))
1500 break;
1502 if (!sl)
1504 /* Not found - make it. */
1505 sl = (struct spec_list *) xmalloc (sizeof (struct spec_list));
1506 sl->name = xstrdup (name);
1507 sl->name_len = name_len;
1508 sl->ptr_spec = &sl->ptr;
1509 sl->alloc_p = 0;
1510 *(sl->ptr_spec) = "";
1511 sl->next = specs;
1512 specs = sl;
1515 old_spec = *(sl->ptr_spec);
1516 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1517 ? concat (old_spec, spec + 1, NULL)
1518 : xstrdup (spec));
1520 #ifdef DEBUG_SPECS
1521 if (verbose_flag)
1522 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1523 #endif
1525 /* Free the old spec. */
1526 if (old_spec && sl->alloc_p)
1527 free ((PTR) old_spec);
1529 sl->alloc_p = 1;
1532 /* Accumulate a command (program name and args), and run it. */
1534 /* Vector of pointers to arguments in the current line of specifications. */
1536 static const char **argbuf;
1538 /* Number of elements allocated in argbuf. */
1540 static int argbuf_length;
1542 /* Number of elements in argbuf currently in use (containing args). */
1544 static int argbuf_index;
1546 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1547 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1548 it here. */
1550 static struct temp_name {
1551 const char *suffix; /* suffix associated with the code. */
1552 int length; /* strlen (suffix). */
1553 int unique; /* Indicates whether %g or %u/%U was used. */
1554 const char *filename; /* associated filename. */
1555 int filename_length; /* strlen (filename). */
1556 struct temp_name *next;
1557 } *temp_names;
1559 /* Number of commands executed so far. */
1561 static int execution_count;
1563 /* Number of commands that exited with a signal. */
1565 static int signal_count;
1567 /* Name with which this program was invoked. */
1569 static const char *programname;
1571 /* Clear out the vector of arguments (after a command is executed). */
1573 static void
1574 clear_args ()
1576 argbuf_index = 0;
1579 /* Add one argument to the vector at the end.
1580 This is done when a space is seen or at the end of the line.
1581 If DELETE_ALWAYS is nonzero, the arg is a filename
1582 and the file should be deleted eventually.
1583 If DELETE_FAILURE is nonzero, the arg is a filename
1584 and the file should be deleted if this compilation fails. */
1586 static void
1587 store_arg (arg, delete_always, delete_failure)
1588 const char *arg;
1589 int delete_always, delete_failure;
1591 if (argbuf_index + 1 == argbuf_length)
1592 argbuf
1593 = (const char **) xrealloc (argbuf,
1594 (argbuf_length *= 2) * sizeof (const char *));
1596 argbuf[argbuf_index++] = arg;
1597 argbuf[argbuf_index] = 0;
1599 if (delete_always || delete_failure)
1600 record_temp_file (arg, delete_always, delete_failure);
1603 /* Load specs from a file name named FILENAME, replacing occurances of
1604 various different types of line-endings, \r\n, \n\r and just \r, with
1605 a single \n. */
1607 static char *
1608 load_specs (filename)
1609 const char *filename;
1611 int desc;
1612 int readlen;
1613 struct stat statbuf;
1614 char *buffer;
1615 char *buffer_p;
1616 char *specs;
1617 char *specs_p;
1619 if (verbose_flag)
1620 notice ("Reading specs from %s\n", filename);
1622 /* Open and stat the file. */
1623 desc = open (filename, O_RDONLY, 0);
1624 if (desc < 0)
1625 pfatal_with_name (filename);
1626 if (stat (filename, &statbuf) < 0)
1627 pfatal_with_name (filename);
1629 /* Read contents of file into BUFFER. */
1630 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1631 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1632 if (readlen < 0)
1633 pfatal_with_name (filename);
1634 buffer[readlen] = 0;
1635 close (desc);
1637 specs = xmalloc (readlen + 1);
1638 specs_p = specs;
1639 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1641 int skip = 0;
1642 char c = *buffer_p;
1643 if (c == '\r')
1645 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1646 skip = 1;
1647 else if (*(buffer_p + 1) == '\n') /* \r\n */
1648 skip = 1;
1649 else /* \r */
1650 c = '\n';
1652 if (! skip)
1653 *specs_p++ = c;
1655 *specs_p = '\0';
1657 free (buffer);
1658 return (specs);
1661 /* Read compilation specs from a file named FILENAME,
1662 replacing the default ones.
1664 A suffix which starts with `*' is a definition for
1665 one of the machine-specific sub-specs. The "suffix" should be
1666 *asm, *cc1, *cpp, *link, *startfile, *signed_char, etc.
1667 The corresponding spec is stored in asm_spec, etc.,
1668 rather than in the `compilers' vector.
1670 Anything invalid in the file is a fatal error. */
1672 static void
1673 read_specs (filename, main_p)
1674 const char *filename;
1675 int main_p;
1677 char *buffer;
1678 register char *p;
1680 buffer = load_specs (filename);
1682 /* Scan BUFFER for specs, putting them in the vector. */
1683 p = buffer;
1684 while (1)
1686 char *suffix;
1687 char *spec;
1688 char *in, *out, *p1, *p2, *p3;
1690 /* Advance P in BUFFER to the next nonblank nocomment line. */
1691 p = skip_whitespace (p);
1692 if (*p == 0)
1693 break;
1695 /* Is this a special command that starts with '%'? */
1696 /* Don't allow this for the main specs file, since it would
1697 encourage people to overwrite it. */
1698 if (*p == '%' && !main_p)
1700 p1 = p;
1701 while (*p && *p != '\n')
1702 p++;
1704 /* Skip '\n'. */
1705 p++;
1707 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1708 && (p1[sizeof "%include" - 1] == ' '
1709 || p1[sizeof "%include" - 1] == '\t'))
1711 char *new_filename;
1713 p1 += sizeof ("%include");
1714 while (*p1 == ' ' || *p1 == '\t')
1715 p1++;
1717 if (*p1++ != '<' || p[-2] != '>')
1718 fatal ("specs %%include syntax malformed after %ld characters",
1719 (long) (p1 - buffer + 1));
1721 p[-2] = '\0';
1722 new_filename = find_a_file (&startfile_prefixes, p1, R_OK);
1723 read_specs (new_filename ? new_filename : p1, FALSE);
1724 continue;
1726 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1727 && (p1[sizeof "%include_noerr" - 1] == ' '
1728 || p1[sizeof "%include_noerr" - 1] == '\t'))
1730 char *new_filename;
1732 p1 += sizeof "%include_noerr";
1733 while (*p1 == ' ' || *p1 == '\t')
1734 p1++;
1736 if (*p1++ != '<' || p[-2] != '>')
1737 fatal ("specs %%include syntax malformed after %ld characters",
1738 (long) (p1 - buffer + 1));
1740 p[-2] = '\0';
1741 new_filename = find_a_file (&startfile_prefixes, p1, R_OK);
1742 if (new_filename)
1743 read_specs (new_filename, FALSE);
1744 else if (verbose_flag)
1745 notice ("Could not find specs file %s\n", p1);
1746 continue;
1748 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1749 && (p1[sizeof "%rename" - 1] == ' '
1750 || p1[sizeof "%rename" - 1] == '\t'))
1752 int name_len;
1753 struct spec_list *sl;
1755 /* Get original name */
1756 p1 += sizeof "%rename";
1757 while (*p1 == ' ' || *p1 == '\t')
1758 p1++;
1760 if (! ISALPHA ((unsigned char) *p1))
1761 fatal ("specs %%rename syntax malformed after %ld characters",
1762 (long) (p1 - buffer));
1764 p2 = p1;
1765 while (*p2 && !ISSPACE ((unsigned char) *p2))
1766 p2++;
1768 if (*p2 != ' ' && *p2 != '\t')
1769 fatal ("specs %%rename syntax malformed after %ld characters",
1770 (long) (p2 - buffer));
1772 name_len = p2 - p1;
1773 *p2++ = '\0';
1774 while (*p2 == ' ' || *p2 == '\t')
1775 p2++;
1777 if (! ISALPHA ((unsigned char) *p2))
1778 fatal ("specs %%rename syntax malformed after %ld characters",
1779 (long) (p2 - buffer));
1781 /* Get new spec name. */
1782 p3 = p2;
1783 while (*p3 && !ISSPACE ((unsigned char) *p3))
1784 p3++;
1786 if (p3 != p - 1)
1787 fatal ("specs %%rename syntax malformed after %ld characters",
1788 (long) (p3 - buffer));
1789 *p3 = '\0';
1791 for (sl = specs; sl; sl = sl->next)
1792 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1793 break;
1795 if (!sl)
1796 fatal ("specs %s spec was not found to be renamed", p1);
1798 if (strcmp (p1, p2) == 0)
1799 continue;
1801 if (verbose_flag)
1803 notice ("rename spec %s to %s\n", p1, p2);
1804 #ifdef DEBUG_SPECS
1805 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
1806 #endif
1809 set_spec (p2, *(sl->ptr_spec));
1810 if (sl->alloc_p)
1811 free ((PTR) *(sl->ptr_spec));
1813 *(sl->ptr_spec) = "";
1814 sl->alloc_p = 0;
1815 continue;
1817 else
1818 fatal ("specs unknown %% command after %ld characters",
1819 (long) (p1 - buffer));
1822 /* Find the colon that should end the suffix. */
1823 p1 = p;
1824 while (*p1 && *p1 != ':' && *p1 != '\n')
1825 p1++;
1827 /* The colon shouldn't be missing. */
1828 if (*p1 != ':')
1829 fatal ("specs file malformed after %ld characters",
1830 (long) (p1 - buffer));
1832 /* Skip back over trailing whitespace. */
1833 p2 = p1;
1834 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1835 p2--;
1837 /* Copy the suffix to a string. */
1838 suffix = save_string (p, p2 - p);
1839 /* Find the next line. */
1840 p = skip_whitespace (p1 + 1);
1841 if (p[1] == 0)
1842 fatal ("specs file malformed after %ld characters",
1843 (long) (p - buffer));
1845 p1 = p;
1846 /* Find next blank line or end of string. */
1847 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1848 p1++;
1850 /* Specs end at the blank line and do not include the newline. */
1851 spec = save_string (p, p1 - p);
1852 p = p1;
1854 /* Delete backslash-newline sequences from the spec. */
1855 in = spec;
1856 out = spec;
1857 while (*in != 0)
1859 if (in[0] == '\\' && in[1] == '\n')
1860 in += 2;
1861 else if (in[0] == '#')
1862 while (*in && *in != '\n')
1863 in++;
1865 else
1866 *out++ = *in++;
1868 *out = 0;
1870 if (suffix[0] == '*')
1872 if (! strcmp (suffix, "*link_command"))
1873 link_command_spec = spec;
1874 else
1875 set_spec (suffix + 1, spec);
1877 else
1879 /* Add this pair to the vector. */
1880 compilers
1881 = ((struct compiler *)
1882 xrealloc (compilers,
1883 (n_compilers + 2) * sizeof (struct compiler)));
1885 compilers[n_compilers].suffix = suffix;
1886 compilers[n_compilers].spec = spec;
1887 n_compilers++;
1888 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1891 if (*suffix == 0)
1892 link_command_spec = spec;
1895 if (link_command_spec == 0)
1896 fatal ("spec file has no spec for linking");
1899 /* Record the names of temporary files we tell compilers to write,
1900 and delete them at the end of the run. */
1902 /* This is the common prefix we use to make temp file names.
1903 It is chosen once for each run of this program.
1904 It is substituted into a spec by %g or %j.
1905 Thus, all temp file names contain this prefix.
1906 In practice, all temp file names start with this prefix.
1908 This prefix comes from the envvar TMPDIR if it is defined;
1909 otherwise, from the P_tmpdir macro if that is defined;
1910 otherwise, in /usr/tmp or /tmp;
1911 or finally the current directory if all else fails. */
1913 static const char *temp_filename;
1915 /* Length of the prefix. */
1917 static int temp_filename_length;
1919 /* Define the list of temporary files to delete. */
1921 struct temp_file
1923 const char *name;
1924 struct temp_file *next;
1927 /* Queue of files to delete on success or failure of compilation. */
1928 static struct temp_file *always_delete_queue;
1929 /* Queue of files to delete on failure of compilation. */
1930 static struct temp_file *failure_delete_queue;
1932 /* Record FILENAME as a file to be deleted automatically.
1933 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
1934 otherwise delete it in any case.
1935 FAIL_DELETE nonzero means delete it if a compilation step fails;
1936 otherwise delete it in any case. */
1938 void
1939 record_temp_file (filename, always_delete, fail_delete)
1940 const char *filename;
1941 int always_delete;
1942 int fail_delete;
1944 register char *const name = xstrdup (filename);
1946 if (always_delete)
1948 register struct temp_file *temp;
1949 for (temp = always_delete_queue; temp; temp = temp->next)
1950 if (! strcmp (name, temp->name))
1951 goto already1;
1953 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
1954 temp->next = always_delete_queue;
1955 temp->name = name;
1956 always_delete_queue = temp;
1958 already1:;
1961 if (fail_delete)
1963 register struct temp_file *temp;
1964 for (temp = failure_delete_queue; temp; temp = temp->next)
1965 if (! strcmp (name, temp->name))
1966 goto already2;
1968 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
1969 temp->next = failure_delete_queue;
1970 temp->name = name;
1971 failure_delete_queue = temp;
1973 already2:;
1977 /* Delete all the temporary files whose names we previously recorded. */
1979 static void
1980 delete_if_ordinary (name)
1981 const char *name;
1983 struct stat st;
1984 #ifdef DEBUG
1985 int i, c;
1987 printf ("Delete %s? (y or n) ", name);
1988 fflush (stdout);
1989 i = getchar ();
1990 if (i != '\n')
1991 while ((c = getchar ()) != '\n' && c != EOF)
1994 if (i == 'y' || i == 'Y')
1995 #endif /* DEBUG */
1996 if (stat (name, &st) >= 0 && S_ISREG (st.st_mode))
1997 if (unlink (name) < 0)
1998 if (verbose_flag)
1999 perror_with_name (name);
2002 static void
2003 delete_temp_files ()
2005 register struct temp_file *temp;
2007 for (temp = always_delete_queue; temp; temp = temp->next)
2008 delete_if_ordinary (temp->name);
2009 always_delete_queue = 0;
2012 /* Delete all the files to be deleted on error. */
2014 static void
2015 delete_failure_queue ()
2017 register struct temp_file *temp;
2019 for (temp = failure_delete_queue; temp; temp = temp->next)
2020 delete_if_ordinary (temp->name);
2023 static void
2024 clear_failure_queue ()
2026 failure_delete_queue = 0;
2029 /* Build a list of search directories from PATHS.
2030 PREFIX is a string to prepend to the list.
2031 If CHECK_DIR_P is non-zero we ensure the directory exists.
2032 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2033 It is also used by the --print-search-dirs flag. */
2035 static char *
2036 build_search_list (paths, prefix, check_dir_p)
2037 struct path_prefix *paths;
2038 const char *prefix;
2039 int check_dir_p;
2041 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2042 int just_suffix_len
2043 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2044 int first_time = TRUE;
2045 struct prefix_list *pprefix;
2047 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2048 obstack_1grow (&collect_obstack, '=');
2050 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2052 int len = strlen (pprefix->prefix);
2054 if (machine_suffix
2055 && (! check_dir_p
2056 || is_directory (pprefix->prefix, machine_suffix, 0)))
2058 if (!first_time)
2059 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2061 first_time = FALSE;
2062 obstack_grow (&collect_obstack, pprefix->prefix, len);
2063 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2066 if (just_machine_suffix
2067 && pprefix->require_machine_suffix == 2
2068 && (! check_dir_p
2069 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2071 if (! first_time)
2072 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2074 first_time = FALSE;
2075 obstack_grow (&collect_obstack, pprefix->prefix, len);
2076 obstack_grow (&collect_obstack, just_machine_suffix,
2077 just_suffix_len);
2080 if (! pprefix->require_machine_suffix)
2082 if (! first_time)
2083 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2085 first_time = FALSE;
2086 obstack_grow (&collect_obstack, pprefix->prefix, len);
2090 obstack_1grow (&collect_obstack, '\0');
2091 return obstack_finish (&collect_obstack);
2094 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2095 for collect. */
2097 static void
2098 putenv_from_prefixes (paths, env_var)
2099 struct path_prefix *paths;
2100 const char *env_var;
2102 putenv (build_search_list (paths, env_var, 1));
2105 #ifndef VMS
2107 /* FIXME: the location independence code for VMS is hairier than this,
2108 and hasn't been written. */
2110 /* Split a filename into component directories. */
2112 static char **
2113 split_directories (name, ptr_num_dirs)
2114 const char *name;
2115 int *ptr_num_dirs;
2117 int num_dirs = 0;
2118 char **dirs;
2119 const char *p, *q;
2120 int ch;
2122 /* Count the number of directories. Special case MSDOS disk names as part
2123 of the initial directory. */
2124 p = name;
2125 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2126 if (name[1] == ':' && IS_DIR_SEPARATOR (name[2]))
2128 p += 3;
2129 num_dirs++;
2131 #endif /* HAVE_DOS_BASED_FILE_SYSTEM */
2133 while ((ch = *p++) != '\0')
2135 if (IS_DIR_SEPARATOR (ch))
2137 num_dirs++;
2138 while (IS_DIR_SEPARATOR (*p))
2139 p++;
2143 dirs = (char **) xmalloc (sizeof (char *) * (num_dirs + 2));
2145 /* Now copy the directory parts. */
2146 num_dirs = 0;
2147 p = name;
2148 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2149 if (name[1] == ':' && IS_DIR_SEPARATOR (name[2]))
2151 dirs[num_dirs++] = save_string (p, 3);
2152 p += 3;
2154 #endif /* HAVE_DOS_BASED_FILE_SYSTEM */
2156 q = p;
2157 while ((ch = *p++) != '\0')
2159 if (IS_DIR_SEPARATOR (ch))
2161 while (IS_DIR_SEPARATOR (*p))
2162 p++;
2164 dirs[num_dirs++] = save_string (q, p - q);
2165 q = p;
2169 if (p - 1 - q > 0)
2170 dirs[num_dirs++] = save_string (q, p - 1 - q);
2172 dirs[num_dirs] = NULL;
2173 if (ptr_num_dirs)
2174 *ptr_num_dirs = num_dirs;
2176 return dirs;
2179 /* Release storage held by split directories. */
2181 static void
2182 free_split_directories (dirs)
2183 char **dirs;
2185 int i = 0;
2187 while (dirs[i] != NULL)
2188 free (dirs[i++]);
2190 free ((char *) dirs);
2193 /* Given three strings PROGNAME, BIN_PREFIX, PREFIX, return a string that gets
2194 to PREFIX starting with the directory portion of PROGNAME and a relative
2195 pathname of the difference between BIN_PREFIX and PREFIX.
2197 For example, if BIN_PREFIX is /alpha/beta/gamma/gcc/delta, PREFIX is
2198 /alpha/beta/gamma/omega/, and PROGNAME is /red/green/blue/gcc, then this
2199 function will return /red/green/blue/../omega.
2201 If no relative prefix can be found, return NULL. */
2203 static char *
2204 make_relative_prefix (progname, bin_prefix, prefix)
2205 const char *progname;
2206 const char *bin_prefix;
2207 const char *prefix;
2209 char **prog_dirs, **bin_dirs, **prefix_dirs;
2210 int prog_num, bin_num, prefix_num, std_loc_p;
2211 int i, n, common;
2213 prog_dirs = split_directories (progname, &prog_num);
2214 bin_dirs = split_directories (bin_prefix, &bin_num);
2216 /* If there is no full pathname, try to find the program by checking in each
2217 of the directories specified in the PATH environment variable. */
2218 if (prog_num == 1)
2220 char *temp;
2222 GET_ENV_PATH_LIST (temp, "PATH");
2223 if (temp)
2225 char *startp, *endp;
2226 char *nstore = (char *) alloca (strlen (temp) + strlen (progname) + 1);
2228 startp = endp = temp;
2229 while (1)
2231 if (*endp == PATH_SEPARATOR || *endp == 0)
2233 if (endp == startp)
2235 nstore[0] = '.';
2236 nstore[1] = DIR_SEPARATOR;
2237 nstore[2] = '\0';
2239 else
2241 strncpy (nstore, startp, endp - startp);
2242 if (! IS_DIR_SEPARATOR (endp[-1]))
2244 nstore[endp - startp] = DIR_SEPARATOR;
2245 nstore[endp - startp + 1] = 0;
2247 else
2248 nstore[endp - startp] = 0;
2250 strcat (nstore, progname);
2251 if (! access (nstore, X_OK)
2252 #ifdef HAVE_HOST_EXECUTABLE_SUFFIX
2253 || ! access (strcat (nstore, HOST_EXECUTABLE_SUFFIX), X_OK)
2254 #endif
2257 free_split_directories (prog_dirs);
2258 progname = nstore;
2259 prog_dirs = split_directories (progname, &prog_num);
2260 break;
2263 if (*endp == 0)
2264 break;
2265 endp = startp = endp + 1;
2267 else
2268 endp++;
2273 /* Remove the program name from comparison of directory names. */
2274 prog_num--;
2276 /* Determine if the compiler is installed in the standard location, and if
2277 so, we don't need to specify relative directories. Also, if argv[0]
2278 doesn't contain any directory specifiers, there is not much we can do. */
2279 std_loc_p = 0;
2280 if (prog_num == bin_num)
2282 for (i = 0; i < bin_num; i++)
2284 if (strcmp (prog_dirs[i], bin_dirs[i]) != 0)
2285 break;
2288 if (prog_num <= 0 || i == bin_num)
2290 std_loc_p = 1;
2291 free_split_directories (prog_dirs);
2292 free_split_directories (bin_dirs);
2293 prog_dirs = bin_dirs = (char **) 0;
2294 return NULL;
2298 prefix_dirs = split_directories (prefix, &prefix_num);
2300 /* Find how many directories are in common between bin_prefix & prefix. */
2301 n = (prefix_num < bin_num) ? prefix_num : bin_num;
2302 for (common = 0; common < n; common++)
2304 if (strcmp (bin_dirs[common], prefix_dirs[common]) != 0)
2305 break;
2308 /* If there are no common directories, there can be no relative prefix. */
2309 if (common == 0)
2311 free_split_directories (prog_dirs);
2312 free_split_directories (bin_dirs);
2313 free_split_directories (prefix_dirs);
2314 return NULL;
2317 /* Build up the pathnames in argv[0]. */
2318 for (i = 0; i < prog_num; i++)
2319 obstack_grow (&obstack, prog_dirs[i], strlen (prog_dirs[i]));
2321 /* Now build up the ..'s. */
2322 for (i = common; i < n; i++)
2324 obstack_grow (&obstack, DIR_UP, sizeof (DIR_UP) - 1);
2325 obstack_1grow (&obstack, DIR_SEPARATOR);
2328 /* Put in directories to move over to prefix. */
2329 for (i = common; i < prefix_num; i++)
2330 obstack_grow (&obstack, prefix_dirs[i], strlen (prefix_dirs[i]));
2332 free_split_directories (prog_dirs);
2333 free_split_directories (bin_dirs);
2334 free_split_directories (prefix_dirs);
2336 obstack_1grow (&obstack, '\0');
2337 return obstack_finish (&obstack);
2339 #endif /* VMS */
2341 /* Check whether NAME can be accessed in MODE. This is like access,
2342 except that it never considers directories to be executable. */
2344 static int
2345 access_check (name, mode)
2346 const char *name;
2347 int mode;
2349 if (mode == X_OK)
2351 struct stat st;
2353 if (stat (name, &st) < 0
2354 || S_ISDIR (st.st_mode))
2355 return -1;
2358 return access (name, mode);
2361 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2362 access to check permissions.
2363 Return 0 if not found, otherwise return its name, allocated with malloc. */
2365 static char *
2366 find_a_file (pprefix, name, mode)
2367 struct path_prefix *pprefix;
2368 const char *name;
2369 int mode;
2371 char *temp;
2372 const char *file_suffix = ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2373 struct prefix_list *pl;
2374 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2376 #ifdef DEFAULT_ASSEMBLER
2377 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2378 return xstrdup (DEFAULT_ASSEMBLER);
2379 #endif
2381 #ifdef DEFAULT_LINKER
2382 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2383 return xstrdup (DEFAULT_LINKER);
2384 #endif
2386 if (machine_suffix)
2387 len += strlen (machine_suffix);
2389 temp = xmalloc (len);
2391 /* Determine the filename to execute (special case for absolute paths). */
2393 if (IS_ABSOLUTE_PATHNAME (name))
2395 if (access (name, mode) == 0)
2397 strcpy (temp, name);
2398 return temp;
2401 else
2402 for (pl = pprefix->plist; pl; pl = pl->next)
2404 if (machine_suffix)
2406 /* Some systems have a suffix for executable files.
2407 So try appending that first. */
2408 if (file_suffix[0] != 0)
2410 strcpy (temp, pl->prefix);
2411 strcat (temp, machine_suffix);
2412 strcat (temp, name);
2413 strcat (temp, file_suffix);
2414 if (access_check (temp, mode) == 0)
2416 if (pl->used_flag_ptr != 0)
2417 *pl->used_flag_ptr = 1;
2418 return temp;
2422 /* Now try just the name. */
2423 strcpy (temp, pl->prefix);
2424 strcat (temp, machine_suffix);
2425 strcat (temp, name);
2426 if (access_check (temp, mode) == 0)
2428 if (pl->used_flag_ptr != 0)
2429 *pl->used_flag_ptr = 1;
2430 return temp;
2434 /* Certain prefixes are tried with just the machine type,
2435 not the version. This is used for finding as, ld, etc. */
2436 if (just_machine_suffix && pl->require_machine_suffix == 2)
2438 /* Some systems have a suffix for executable files.
2439 So try appending that first. */
2440 if (file_suffix[0] != 0)
2442 strcpy (temp, pl->prefix);
2443 strcat (temp, just_machine_suffix);
2444 strcat (temp, name);
2445 strcat (temp, file_suffix);
2446 if (access_check (temp, mode) == 0)
2448 if (pl->used_flag_ptr != 0)
2449 *pl->used_flag_ptr = 1;
2450 return temp;
2454 strcpy (temp, pl->prefix);
2455 strcat (temp, just_machine_suffix);
2456 strcat (temp, name);
2457 if (access_check (temp, mode) == 0)
2459 if (pl->used_flag_ptr != 0)
2460 *pl->used_flag_ptr = 1;
2461 return temp;
2465 /* Certain prefixes can't be used without the machine suffix
2466 when the machine or version is explicitly specified. */
2467 if (! pl->require_machine_suffix)
2469 /* Some systems have a suffix for executable files.
2470 So try appending that first. */
2471 if (file_suffix[0] != 0)
2473 strcpy (temp, pl->prefix);
2474 strcat (temp, name);
2475 strcat (temp, file_suffix);
2476 if (access_check (temp, mode) == 0)
2478 if (pl->used_flag_ptr != 0)
2479 *pl->used_flag_ptr = 1;
2480 return temp;
2484 strcpy (temp, pl->prefix);
2485 strcat (temp, name);
2486 if (access_check (temp, mode) == 0)
2488 if (pl->used_flag_ptr != 0)
2489 *pl->used_flag_ptr = 1;
2490 return temp;
2495 free (temp);
2496 return 0;
2499 /* Ranking of prefixes in the sort list. -B prefixes are put before
2500 all others. */
2502 enum path_prefix_priority
2504 PREFIX_PRIORITY_B_OPT,
2505 PREFIX_PRIORITY_LAST
2508 /* Add an entry for PREFIX in PLIST. The PLIST is kept in assending
2509 order according to PRIORITY. Within each PRIORITY, new entries are
2510 appended.
2512 If WARN is nonzero, we will warn if no file is found
2513 through this prefix. WARN should point to an int
2514 which will be set to 1 if this entry is used.
2516 COMPONENT is the value to be passed to update_path.
2518 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2519 the complete value of machine_suffix.
2520 2 means try both machine_suffix and just_machine_suffix. */
2522 static void
2523 add_prefix (pprefix, prefix, component, priority, require_machine_suffix, warn)
2524 struct path_prefix *pprefix;
2525 const char *prefix;
2526 const char *component;
2527 /* enum prefix_priority */ int priority;
2528 int require_machine_suffix;
2529 int *warn;
2531 struct prefix_list *pl, **prev;
2532 int len;
2534 for (prev = &pprefix->plist;
2535 (*prev) != NULL && (*prev)->priority <= priority;
2536 prev = &(*prev)->next)
2539 /* Keep track of the longest prefix */
2541 prefix = update_path (prefix, component);
2542 len = strlen (prefix);
2543 if (len > pprefix->max_len)
2544 pprefix->max_len = len;
2546 pl = (struct prefix_list *) xmalloc (sizeof (struct prefix_list));
2547 pl->prefix = save_string (prefix, len);
2548 pl->require_machine_suffix = require_machine_suffix;
2549 pl->used_flag_ptr = warn;
2550 pl->priority = priority;
2551 if (warn)
2552 *warn = 0;
2554 /* Insert after PREV */
2555 pl->next = (*prev);
2556 (*prev) = pl;
2559 /* Execute the command specified by the arguments on the current line of spec.
2560 When using pipes, this includes several piped-together commands
2561 with `|' between them.
2563 Return 0 if successful, -1 if failed. */
2565 static int
2566 execute ()
2568 int i;
2569 int n_commands; /* # of command. */
2570 char *string;
2571 struct command
2573 const char *prog; /* program name. */
2574 const char **argv; /* vector of args. */
2575 int pid; /* pid of process for this command. */
2578 struct command *commands; /* each command buffer with above info. */
2580 /* Count # of piped commands. */
2581 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2582 if (strcmp (argbuf[i], "|") == 0)
2583 n_commands++;
2585 /* Get storage for each command. */
2586 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2588 /* Split argbuf into its separate piped processes,
2589 and record info about each one.
2590 Also search for the programs that are to be run. */
2592 commands[0].prog = argbuf[0]; /* first command. */
2593 commands[0].argv = &argbuf[0];
2594 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK);
2596 if (string)
2597 commands[0].argv[0] = string;
2599 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2600 if (strcmp (argbuf[i], "|") == 0)
2601 { /* each command. */
2602 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2603 fatal ("-pipe not supported");
2604 #endif
2605 argbuf[i] = 0; /* termination of command args. */
2606 commands[n_commands].prog = argbuf[i + 1];
2607 commands[n_commands].argv = &argbuf[i + 1];
2608 string = find_a_file (&exec_prefixes, commands[n_commands].prog, X_OK);
2609 if (string)
2610 commands[n_commands].argv[0] = string;
2611 n_commands++;
2614 argbuf[argbuf_index] = 0;
2616 /* If -v, print what we are about to do, and maybe query. */
2618 if (verbose_flag)
2620 /* For help listings, put a blank line between sub-processes. */
2621 if (print_help_list)
2622 fputc ('\n', stderr);
2624 /* Print each piped command as a separate line. */
2625 for (i = 0; i < n_commands; i++)
2627 const char *const *j;
2629 for (j = commands[i].argv; *j; j++)
2630 fprintf (stderr, " %s", *j);
2632 /* Print a pipe symbol after all but the last command. */
2633 if (i + 1 != n_commands)
2634 fprintf (stderr, " |");
2635 fprintf (stderr, "\n");
2637 fflush (stderr);
2638 #ifdef DEBUG
2639 notice ("\nGo ahead? (y or n) ");
2640 fflush (stderr);
2641 i = getchar ();
2642 if (i != '\n')
2643 while (getchar () != '\n')
2646 if (i != 'y' && i != 'Y')
2647 return 0;
2648 #endif /* DEBUG */
2651 /* Run each piped subprocess. */
2653 for (i = 0; i < n_commands; i++)
2655 char *errmsg_fmt, *errmsg_arg;
2656 const char *string = commands[i].argv[0];
2658 /* For some bizarre reason, the second argument of execvp() is
2659 char *const *, not const char *const *. */
2660 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2661 programname, temp_filename,
2662 &errmsg_fmt, &errmsg_arg,
2663 ((i == 0 ? PEXECUTE_FIRST : 0)
2664 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2665 | (string == commands[i].prog
2666 ? PEXECUTE_SEARCH : 0)
2667 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2669 if (commands[i].pid == -1)
2670 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2672 if (string != commands[i].prog)
2673 free ((PTR) string);
2676 execution_count++;
2678 /* Wait for all the subprocesses to finish.
2679 We don't care what order they finish in;
2680 we know that N_COMMANDS waits will get them all.
2681 Ignore subprocesses that we don't know about,
2682 since they can be spawned by the process that exec'ed us. */
2685 int ret_code = 0;
2686 #ifdef HAVE_GETRUSAGE
2687 struct timeval d;
2688 double ut = 0.0, st = 0.0;
2689 #endif
2691 for (i = 0; i < n_commands;)
2693 int j;
2694 int status;
2695 int pid;
2697 pid = pwait (commands[i].pid, &status, 0);
2698 if (pid < 0)
2699 abort ();
2701 #ifdef HAVE_GETRUSAGE
2702 if (report_times)
2704 /* getrusage returns the total resource usage of all children
2705 up to now. Copy the previous values into prus, get the
2706 current statistics, then take the difference. */
2708 prus = rus;
2709 getrusage (RUSAGE_CHILDREN, &rus);
2710 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2711 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2712 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2714 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2715 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2716 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2718 #endif
2720 for (j = 0; j < n_commands; j++)
2721 if (commands[j].pid == pid)
2723 i++;
2724 if (WIFSIGNALED (status))
2726 #ifdef SIGPIPE
2727 /* SIGPIPE is a special case. It happens in -pipe mode
2728 when the compiler dies before the preprocessor is
2729 done, or the assembler dies before the compiler is
2730 done. There's generally been an error already, and
2731 this is just fallout. So don't generate another error
2732 unless we would otherwise have succeeded. */
2733 if (WTERMSIG (status) == SIGPIPE
2734 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2736 else
2737 #endif
2738 fatal ("\
2739 Internal error: %s (program %s)\n\
2740 Please submit a full bug report.\n\
2741 See %s for instructions.",
2742 strsignal (WTERMSIG (status)), commands[j].prog,
2743 GCCBUGURL);
2744 signal_count++;
2745 ret_code = -1;
2747 else if (WIFEXITED (status)
2748 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2750 if (WEXITSTATUS (status) > greatest_status)
2751 greatest_status = WEXITSTATUS (status);
2752 ret_code = -1;
2754 #ifdef HAVE_GETRUSAGE
2755 if (report_times && ut + st != 0)
2756 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2757 #endif
2758 break;
2761 return ret_code;
2765 /* Find all the switches given to us
2766 and make a vector describing them.
2767 The elements of the vector are strings, one per switch given.
2768 If a switch uses following arguments, then the `part1' field
2769 is the switch itself and the `args' field
2770 is a null-terminated vector containing the following arguments.
2771 The `live_cond' field is:
2772 0 when initialized
2773 1 if the switch is true in a conditional spec,
2774 -1 if false (overridden by a later switch)
2775 -2 if this switch should be ignored (used in %{<S})
2776 The `validated' field is nonzero if any spec has looked at this switch;
2777 if it remains zero at the end of the run, it must be meaningless. */
2779 #define SWITCH_OK 0
2780 #define SWITCH_FALSE -1
2781 #define SWITCH_IGNORE -2
2782 #define SWITCH_LIVE 1
2784 struct switchstr
2786 const char *part1;
2787 const char **args;
2788 int live_cond;
2789 unsigned char validated;
2790 unsigned char ordering;
2793 static struct switchstr *switches;
2795 static int n_switches;
2797 struct infile
2799 const char *name;
2800 const char *language;
2803 /* Also a vector of input files specified. */
2805 static struct infile *infiles;
2807 int n_infiles;
2809 /* This counts the number of libraries added by lang_specific_driver, so that
2810 we can tell if there were any user supplied any files or libraries. */
2812 static int added_libraries;
2814 /* And a vector of corresponding output files is made up later. */
2816 const char **outfiles;
2818 /* Used to track if none of the -B paths are used. */
2819 static int warn_B;
2821 /* Used to track if standard path isn't used and -b or -V is specified. */
2822 static int warn_std;
2824 /* Gives value to pass as "warn" to add_prefix for standard prefixes. */
2825 static int *warn_std_ptr = 0;
2827 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2829 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2830 is true if we should look for an executable suffix as well. */
2832 static char *
2833 convert_filename (name, do_exe)
2834 char *name;
2835 int do_exe;
2837 int i;
2838 int len;
2840 if (name == NULL)
2841 return NULL;
2843 len = strlen (name);
2845 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2846 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2847 if (len > 2
2848 && name[len - 2] == '.'
2849 && name[len - 1] == 'o')
2851 obstack_grow (&obstack, name, len - 2);
2852 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2853 name = obstack_finish (&obstack);
2855 #endif
2857 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2858 /* If there is no filetype, make it the executable suffix (which includes
2859 the "."). But don't get confused if we have just "-o". */
2860 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2861 return name;
2863 for (i = len - 1; i >= 0; i--)
2864 if (IS_DIR_SEPARATOR (name[i]))
2865 break;
2867 for (i++; i < len; i++)
2868 if (name[i] == '.')
2869 return name;
2871 obstack_grow (&obstack, name, len);
2872 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX, strlen (TARGET_EXECUTABLE_SUFFIX));
2873 name = obstack_finish (&obstack);
2874 #endif
2876 return name;
2878 #endif
2880 /* Display the command line switches accepted by gcc. */
2881 static void
2882 display_help ()
2884 printf (_("Usage: %s [options] file...\n"), programname);
2885 fputs (_("Options:\n"), stdout);
2887 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
2888 fputs (_(" --help Display this information\n"), stdout);
2889 fputs (_(" --target-help Display target specific command line options\n"), stdout);
2890 if (! verbose_flag)
2891 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2892 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
2893 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
2894 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
2895 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
2896 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
2897 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
2898 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
2899 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
2900 fputs (_("\
2901 -print-multi-lib Display the mapping between command line options and\n\
2902 multiple library search directories\n"), stdout);
2903 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
2904 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
2905 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
2906 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
2907 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
2908 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
2909 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
2910 fputs (_(" -specs=<file> Override builtin specs with the contents of <file>\n"), stdout);
2911 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
2912 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
2913 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
2914 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
2915 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
2916 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
2917 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
2918 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
2919 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
2920 fputs (_("\
2921 -x <language> Specify the language of the following input files\n\
2922 Permissable languages include: c c++ assembler none\n\
2923 'none' means revert to the default behaviour of\n\
2924 guessing the language based on the file's extension\n\
2925 "), stdout);
2927 printf (_("\
2928 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
2929 passed on to the various sub-processes invoked by %s. In order to pass\n\
2930 other options on to these processes the -W<letter> options must be used.\n\
2931 "), programname);
2933 /* The rest of the options are displayed by invocations of the various
2934 sub-processes. */
2937 static void
2938 add_preprocessor_option (option, len)
2939 const char *option;
2940 int len;
2942 n_preprocessor_options++;
2944 if (! preprocessor_options)
2945 preprocessor_options
2946 = (char **) xmalloc (n_preprocessor_options * sizeof (char *));
2947 else
2948 preprocessor_options
2949 = (char **) xrealloc (preprocessor_options,
2950 n_preprocessor_options * sizeof (char *));
2952 preprocessor_options [n_preprocessor_options - 1] =
2953 save_string (option, len);
2956 static void
2957 add_assembler_option (option, len)
2958 const char *option;
2959 int len;
2961 n_assembler_options++;
2963 if (! assembler_options)
2964 assembler_options
2965 = (char **) xmalloc (n_assembler_options * sizeof (char *));
2966 else
2967 assembler_options
2968 = (char **) xrealloc (assembler_options,
2969 n_assembler_options * sizeof (char *));
2971 assembler_options [n_assembler_options - 1] = save_string (option, len);
2974 static void
2975 add_linker_option (option, len)
2976 const char *option;
2977 int len;
2979 n_linker_options++;
2981 if (! linker_options)
2982 linker_options
2983 = (char **) xmalloc (n_linker_options * sizeof (char *));
2984 else
2985 linker_options
2986 = (char **) xrealloc (linker_options,
2987 n_linker_options * sizeof (char *));
2989 linker_options [n_linker_options - 1] = save_string (option, len);
2992 /* Create the vector `switches' and its contents.
2993 Store its length in `n_switches'. */
2995 static void
2996 process_command (argc, argv)
2997 int argc;
2998 const char *const *argv;
3000 register int i;
3001 const char *temp;
3002 char *temp1;
3003 const char *spec_lang = 0;
3004 int last_language_n_infiles;
3005 int have_c = 0;
3006 int have_o = 0;
3007 int lang_n_infiles = 0;
3008 #ifdef MODIFY_TARGET_NAME
3009 int is_modify_target_name;
3010 int j;
3011 #endif
3013 GET_ENV_PATH_LIST (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3015 n_switches = 0;
3016 n_infiles = 0;
3017 added_libraries = 0;
3019 /* Figure compiler version from version string. */
3021 compiler_version = temp1 = xstrdup (version_string);
3023 for (; *temp1; ++temp1)
3025 if (*temp1 == ' ')
3027 *temp1 = '\0';
3028 break;
3032 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3033 see if we can create it from the pathname specified in argv[0]. */
3035 #ifndef VMS
3036 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3037 if (!gcc_exec_prefix)
3039 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3040 standard_exec_prefix);
3041 if (gcc_exec_prefix)
3042 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3044 #endif
3046 if (gcc_exec_prefix)
3048 int len = strlen (gcc_exec_prefix);
3050 if (len > (int) sizeof ("/lib/gcc-lib/") - 1
3051 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3053 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc-lib/") + 1;
3054 if (IS_DIR_SEPARATOR (*temp)
3055 && strncmp (temp + 1, "lib", 3) == 0
3056 && IS_DIR_SEPARATOR (temp[4])
3057 && strncmp (temp + 5, "gcc-lib", 7) == 0)
3058 len -= sizeof ("/lib/gcc-lib/") - 1;
3061 set_std_prefix (gcc_exec_prefix, len);
3062 add_prefix (&exec_prefixes, gcc_exec_prefix, "GCC",
3063 PREFIX_PRIORITY_LAST, 0, NULL);
3064 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3065 PREFIX_PRIORITY_LAST, 0, NULL);
3068 /* COMPILER_PATH and LIBRARY_PATH have values
3069 that are lists of directory names with colons. */
3071 GET_ENV_PATH_LIST (temp, "COMPILER_PATH");
3072 if (temp)
3074 const char *startp, *endp;
3075 char *nstore = (char *) alloca (strlen (temp) + 3);
3077 startp = endp = temp;
3078 while (1)
3080 if (*endp == PATH_SEPARATOR || *endp == 0)
3082 strncpy (nstore, startp, endp - startp);
3083 if (endp == startp)
3084 strcpy (nstore, concat (".", dir_separator_str, NULL));
3085 else if (!IS_DIR_SEPARATOR (endp[-1]))
3087 nstore[endp - startp] = DIR_SEPARATOR;
3088 nstore[endp - startp + 1] = 0;
3090 else
3091 nstore[endp - startp] = 0;
3092 add_prefix (&exec_prefixes, nstore, 0,
3093 PREFIX_PRIORITY_LAST, 0, NULL);
3094 add_prefix (&include_prefixes,
3095 concat (nstore, "include", NULL),
3096 0, PREFIX_PRIORITY_LAST, 0, NULL);
3097 if (*endp == 0)
3098 break;
3099 endp = startp = endp + 1;
3101 else
3102 endp++;
3106 GET_ENV_PATH_LIST (temp, LIBRARY_PATH_ENV);
3107 if (temp && *cross_compile == '0')
3109 const char *startp, *endp;
3110 char *nstore = (char *) alloca (strlen (temp) + 3);
3112 startp = endp = temp;
3113 while (1)
3115 if (*endp == PATH_SEPARATOR || *endp == 0)
3117 strncpy (nstore, startp, endp - startp);
3118 if (endp == startp)
3119 strcpy (nstore, concat (".", dir_separator_str, NULL));
3120 else if (!IS_DIR_SEPARATOR (endp[-1]))
3122 nstore[endp - startp] = DIR_SEPARATOR;
3123 nstore[endp - startp + 1] = 0;
3125 else
3126 nstore[endp - startp] = 0;
3127 add_prefix (&startfile_prefixes, nstore, NULL,
3128 PREFIX_PRIORITY_LAST, 0, NULL);
3129 if (*endp == 0)
3130 break;
3131 endp = startp = endp + 1;
3133 else
3134 endp++;
3138 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3139 GET_ENV_PATH_LIST (temp, "LPATH");
3140 if (temp && *cross_compile == '0')
3142 const char *startp, *endp;
3143 char *nstore = (char *) alloca (strlen (temp) + 3);
3145 startp = endp = temp;
3146 while (1)
3148 if (*endp == PATH_SEPARATOR || *endp == 0)
3150 strncpy (nstore, startp, endp - startp);
3151 if (endp == startp)
3152 strcpy (nstore, concat (".", dir_separator_str, NULL));
3153 else if (!IS_DIR_SEPARATOR (endp[-1]))
3155 nstore[endp - startp] = DIR_SEPARATOR;
3156 nstore[endp - startp + 1] = 0;
3158 else
3159 nstore[endp - startp] = 0;
3160 add_prefix (&startfile_prefixes, nstore, NULL,
3161 PREFIX_PRIORITY_LAST, 0, NULL);
3162 if (*endp == 0)
3163 break;
3164 endp = startp = endp + 1;
3166 else
3167 endp++;
3171 /* Convert new-style -- options to old-style. */
3172 translate_options (&argc, &argv);
3174 /* Do language-specific adjustment/addition of flags. */
3175 lang_specific_driver (&argc, &argv, &added_libraries);
3177 /* Scan argv twice. Here, the first time, just count how many switches
3178 there will be in their vector, and how many input files in theirs.
3179 Also parse any switches that determine the configuration name, such as -b.
3180 Here we also parse the switches that cc itself uses (e.g. -v). */
3182 for (i = 1; i < argc; i++)
3184 if (! strcmp (argv[i], "-dumpspecs"))
3186 struct spec_list *sl;
3187 init_spec ();
3188 for (sl = specs; sl; sl = sl->next)
3189 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3190 if (link_command_spec)
3191 printf ("*link_command:\n%s\n\n", link_command_spec);
3192 exit (0);
3194 else if (! strcmp (argv[i], "-dumpversion"))
3196 printf ("%s\n", spec_version);
3197 exit (0);
3199 else if (! strcmp (argv[i], "-dumpmachine"))
3201 printf ("%s\n", spec_machine);
3202 exit (0);
3204 else if (strcmp (argv[i], "-fhelp") == 0)
3206 /* translate_options () has turned --help into -fhelp. */
3207 print_help_list = 1;
3209 /* We will be passing a dummy file on to the sub-processes. */
3210 n_infiles++;
3211 n_switches++;
3213 add_preprocessor_option ("--help", 6);
3214 add_assembler_option ("--help", 6);
3215 add_linker_option ("--help", 6);
3217 else if (strcmp (argv[i], "-ftarget-help") == 0)
3219 /* translate_options() has turned --target-help into -ftarget-help. */
3220 target_help_flag = 1;
3222 /* We will be passing a dummy file on to the sub-processes. */
3223 n_infiles++;
3224 n_switches++;
3226 add_preprocessor_option ("--target-help", 13);
3227 add_assembler_option ("--target-help", 13);
3228 add_linker_option ("--target-help", 13);
3230 else if (! strcmp (argv[i], "-pass-exit-codes"))
3232 pass_exit_codes = 1;
3233 n_switches++;
3235 else if (! strcmp (argv[i], "-print-search-dirs"))
3236 print_search_dirs = 1;
3237 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3238 print_file_name = "libgcc.a";
3239 else if (! strncmp (argv[i], "-print-file-name=", 17))
3240 print_file_name = argv[i] + 17;
3241 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3242 print_prog_name = argv[i] + 17;
3243 else if (! strcmp (argv[i], "-print-multi-lib"))
3244 print_multi_lib = 1;
3245 else if (! strcmp (argv[i], "-print-multi-directory"))
3246 print_multi_directory = 1;
3247 else if (! strncmp (argv[i], "-Wa,", 4))
3249 int prev, j;
3250 /* Pass the rest of this option to the assembler. */
3252 /* Split the argument at commas. */
3253 prev = 4;
3254 for (j = 4; argv[i][j]; j++)
3255 if (argv[i][j] == ',')
3257 add_assembler_option (argv[i] + prev, j - prev);
3258 prev = j + 1;
3261 /* Record the part after the last comma. */
3262 add_assembler_option (argv[i] + prev, j - prev);
3264 else if (! strncmp (argv[i], "-Wp,", 4))
3266 int prev, j;
3267 /* Pass the rest of this option to the preprocessor. */
3269 /* Split the argument at commas. */
3270 prev = 4;
3271 for (j = 4; argv[i][j]; j++)
3272 if (argv[i][j] == ',')
3274 add_preprocessor_option (argv[i] + prev, j - prev);
3275 prev = j + 1;
3278 /* Record the part after the last comma. */
3279 add_preprocessor_option (argv[i] + prev, j - prev);
3281 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3282 /* The +e options to the C++ front-end. */
3283 n_switches++;
3284 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3286 int j;
3287 /* Split the argument at commas. */
3288 for (j = 3; argv[i][j]; j++)
3289 n_infiles += (argv[i][j] == ',');
3291 else if (strcmp (argv[i], "-Xlinker") == 0)
3293 if (i + 1 == argc)
3294 fatal ("argument to `-Xlinker' is missing");
3296 n_infiles++;
3297 i++;
3299 else if (strcmp (argv[i], "-l") == 0)
3301 if (i + 1 == argc)
3302 fatal ("argument to `-l' is missing");
3304 n_infiles++;
3305 i++;
3307 else if (strncmp (argv[i], "-l", 2) == 0)
3308 n_infiles++;
3309 else if (strcmp (argv[i], "-save-temps") == 0)
3311 save_temps_flag = 1;
3312 n_switches++;
3314 else if (strcmp (argv[i], "-specs") == 0)
3316 struct user_specs *user = (struct user_specs *)
3317 xmalloc (sizeof (struct user_specs));
3318 if (++i >= argc)
3319 fatal ("argument to `-specs' is missing");
3321 user->next = (struct user_specs *) 0;
3322 user->filename = argv[i];
3323 if (user_specs_tail)
3324 user_specs_tail->next = user;
3325 else
3326 user_specs_head = user;
3327 user_specs_tail = user;
3329 else if (strncmp (argv[i], "-specs=", 7) == 0)
3331 struct user_specs *user = (struct user_specs *)
3332 xmalloc (sizeof (struct user_specs));
3333 if (strlen (argv[i]) == 7)
3334 fatal ("argument to `-specs=' is missing");
3336 user->next = (struct user_specs *) 0;
3337 user->filename = argv[i] + 7;
3338 if (user_specs_tail)
3339 user_specs_tail->next = user;
3340 else
3341 user_specs_head = user;
3342 user_specs_tail = user;
3344 else if (strcmp (argv[i], "-time") == 0)
3345 report_times = 1;
3346 else if (argv[i][0] == '-' && argv[i][1] != 0)
3348 register const char *p = &argv[i][1];
3349 register int c = *p;
3351 switch (c)
3353 case 'b':
3354 n_switches++;
3355 if (p[1] == 0 && i + 1 == argc)
3356 fatal ("argument to `-b' is missing");
3357 if (p[1] == 0)
3358 spec_machine = argv[++i];
3359 else
3360 spec_machine = p + 1;
3362 warn_std_ptr = &warn_std;
3363 break;
3365 case 'B':
3367 const char *value;
3368 if (p[1] == 0 && i + 1 == argc)
3369 fatal ("argument to `-B' is missing");
3370 if (p[1] == 0)
3371 value = argv[++i];
3372 else
3373 value = p + 1;
3375 /* As a kludge, if the arg is "[foo/]stageN/", just
3376 add "[foo/]include" to the include prefix. */
3377 int len = strlen (value);
3378 if ((len == 7
3379 || (len > 7
3380 && (IS_DIR_SEPARATOR (value[len - 8]))))
3381 && strncmp (value + len - 7, "stage", 5) == 0
3382 && ISDIGIT (value[len - 2])
3383 && (IS_DIR_SEPARATOR (value[len - 1])))
3385 if (len == 7)
3386 add_prefix (&include_prefixes, "include", NULL,
3387 PREFIX_PRIORITY_B_OPT, 0, NULL);
3388 else
3390 char *string = xmalloc (len + 1);
3391 strncpy (string, value, len-7);
3392 strcpy (string+len-7, "include");
3393 add_prefix (&include_prefixes, string, NULL,
3394 PREFIX_PRIORITY_B_OPT, 0, NULL);
3398 add_prefix (&exec_prefixes, value, NULL,
3399 PREFIX_PRIORITY_B_OPT, 0, &warn_B);
3400 add_prefix (&startfile_prefixes, value, NULL,
3401 PREFIX_PRIORITY_B_OPT, 0, &warn_B);
3402 add_prefix (&include_prefixes, concat (value, "include", NULL),
3403 NULL, PREFIX_PRIORITY_B_OPT, 0, NULL);
3404 n_switches++;
3406 break;
3408 case 'v': /* Print our subcommands and print versions. */
3409 n_switches++;
3410 /* If they do anything other than exactly `-v', don't set
3411 verbose_flag; rather, continue on to give the error. */
3412 if (p[1] != 0)
3413 break;
3414 verbose_flag++;
3415 break;
3417 case 'V':
3418 n_switches++;
3419 if (p[1] == 0 && i + 1 == argc)
3420 fatal ("argument to `-V' is missing");
3421 if (p[1] == 0)
3422 spec_version = argv[++i];
3423 else
3424 spec_version = p + 1;
3425 compiler_version = spec_version;
3426 warn_std_ptr = &warn_std;
3428 /* Validate the version number. Use the same checks
3429 done when inserting it into a spec.
3431 The format of the version string is
3432 ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)? */
3434 const char *v = compiler_version;
3436 /* Ignore leading non-digits. i.e. "foo-" in "foo-2.7.2". */
3437 while (! ISDIGIT (*v))
3438 v++;
3440 if (v > compiler_version && v[-1] != '-')
3441 fatal ("invalid version number format");
3443 /* Set V after the first period. */
3444 while (ISDIGIT (*v))
3445 v++;
3447 if (*v != '.')
3448 fatal ("invalid version number format");
3450 v++;
3451 while (ISDIGIT (*v))
3452 v++;
3454 if (*v != 0 && *v != ' ' && *v != '.' && *v != '-')
3455 fatal ("invalid version number format");
3457 break;
3459 case 'S':
3460 case 'c':
3461 if (p[1] == 0)
3463 have_c = 1;
3464 n_switches++;
3465 break;
3467 goto normal_switch;
3469 case 'o':
3470 have_o = 1;
3471 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3472 if (! have_c)
3474 int skip;
3476 /* Forward scan, just in case -S or -c is specified
3477 after -o. */
3478 int j = i + 1;
3479 if (p[1] == 0)
3480 ++j;
3481 while (j < argc)
3483 if (argv[j][0] == '-')
3485 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3486 && argv[j][2] == 0)
3488 have_c = 1;
3489 break;
3491 else if (skip = SWITCH_TAKES_ARG (argv[j][1]))
3492 j += skip - (argv[j][2] != 0);
3493 else if (skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1))
3494 j += skip;
3496 j++;
3499 #endif
3500 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3501 if (p[1] == 0)
3502 argv[i + 1] = convert_filename (argv[i + 1], ! have_c);
3503 else
3504 argv[i] = convert_filename (argv[i], ! have_c);
3505 #endif
3506 goto normal_switch;
3508 default:
3509 normal_switch:
3511 #ifdef MODIFY_TARGET_NAME
3512 is_modify_target_name = 0;
3514 for (j = 0;
3515 j < sizeof modify_target / sizeof modify_target[0]; j++)
3516 if (! strcmp (argv[i], modify_target[j].sw))
3518 char *new_name
3519 = (char *) xmalloc (strlen (modify_target[j].str)
3520 + strlen (spec_machine));
3521 const char *p, *r;
3522 char *q;
3523 int made_addition = 0;
3525 is_modify_target_name = 1;
3526 for (p = spec_machine, q = new_name; *p != 0; )
3528 if (modify_target[j].add_del == DELETE
3529 && (! strncmp (q, modify_target[j].str,
3530 strlen (modify_target[j].str))))
3531 p += strlen (modify_target[j].str);
3532 else if (modify_target[j].add_del == ADD
3533 && ! made_addition && *p == '-')
3535 for (r = modify_target[j].str; *r != 0; )
3536 *q++ = *r++;
3537 made_addition = 1;
3540 *q++ = *p++;
3543 spec_machine = new_name;
3546 if (is_modify_target_name)
3547 break;
3548 #endif
3550 n_switches++;
3552 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3553 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3554 else if (WORD_SWITCH_TAKES_ARG (p))
3555 i += WORD_SWITCH_TAKES_ARG (p);
3558 else
3560 n_infiles++;
3561 lang_n_infiles++;
3565 if (have_c && have_o && lang_n_infiles > 1)
3566 fatal ("cannot specify -o with -c or -S and multiple compilations");
3568 /* Set up the search paths before we go looking for config files. */
3570 /* These come before the md prefixes so that we will find gcc's subcommands
3571 (such as cpp) rather than those of the host system. */
3572 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3573 as well as trying the machine and the version. */
3574 #ifndef OS2
3575 add_prefix (&exec_prefixes, standard_exec_prefix, "GCC",
3576 PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3577 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3578 PREFIX_PRIORITY_LAST, 2, warn_std_ptr);
3579 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3580 PREFIX_PRIORITY_LAST, 2, warn_std_ptr);
3581 #endif
3583 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3584 PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3585 add_prefix (&startfile_prefixes, standard_exec_prefix_1, "BINUTILS",
3586 PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3588 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3589 dir_separator_str, NULL);
3591 /* If tooldir is relative, base it on exec_prefixes. A relative
3592 tooldir lets us move the installed tree as a unit.
3594 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3595 directories, so that we can search both the user specified directory
3596 and the standard place. */
3598 if (!IS_ABSOLUTE_PATHNAME (tooldir_prefix))
3600 if (gcc_exec_prefix)
3602 char *gcc_exec_tooldir_prefix
3603 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3604 spec_version, dir_separator_str, tooldir_prefix, NULL);
3606 add_prefix (&exec_prefixes,
3607 concat (gcc_exec_tooldir_prefix, "bin",
3608 dir_separator_str, NULL),
3609 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
3610 add_prefix (&startfile_prefixes,
3611 concat (gcc_exec_tooldir_prefix, "lib",
3612 dir_separator_str, NULL),
3613 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
3616 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3617 dir_separator_str, spec_version,
3618 dir_separator_str, tooldir_prefix, NULL);
3621 add_prefix (&exec_prefixes,
3622 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3623 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
3624 add_prefix (&startfile_prefixes,
3625 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3626 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
3628 /* More prefixes are enabled in main, after we read the specs file
3629 and determine whether this is cross-compilation or not. */
3631 /* Then create the space for the vectors and scan again. */
3633 switches = ((struct switchstr *)
3634 xmalloc ((n_switches + 1) * sizeof (struct switchstr)));
3635 infiles = (struct infile *) xmalloc ((n_infiles + 1) * sizeof (struct infile));
3636 n_switches = 0;
3637 n_infiles = 0;
3638 last_language_n_infiles = -1;
3640 /* This, time, copy the text of each switch and store a pointer
3641 to the copy in the vector of switches.
3642 Store all the infiles in their vector. */
3644 for (i = 1; i < argc; i++)
3646 /* Just skip the switches that were handled by the preceding loop. */
3647 #ifdef MODIFY_TARGET_NAME
3648 is_modify_target_name = 0;
3650 for (j = 0; j < sizeof modify_target / sizeof modify_target[0]; j++)
3651 if (! strcmp (argv[i], modify_target[j].sw))
3652 is_modify_target_name = 1;
3654 if (is_modify_target_name)
3656 else
3657 #endif
3658 if (! strncmp (argv[i], "-Wa,", 4))
3660 else if (! strncmp (argv[i], "-Wp,", 4))
3662 else if (! strcmp (argv[i], "-pass-exit-codes"))
3664 else if (! strcmp (argv[i], "-print-search-dirs"))
3666 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3668 else if (! strncmp (argv[i], "-print-file-name=", 17))
3670 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3672 else if (! strcmp (argv[i], "-print-multi-lib"))
3674 else if (! strcmp (argv[i], "-print-multi-directory"))
3676 else if (strcmp (argv[i], "-ftarget-help") == 0)
3678 /* Create a dummy input file, so that we can pass --target-help on to
3679 the various sub-processes. */
3680 infiles[n_infiles].language = "c";
3681 infiles[n_infiles++].name = "target-dummy";
3683 /* Preserve the --target-help switch so that it can be caught by
3684 the cc1 spec string. */
3685 switches[n_switches].part1 = "--target-help";
3686 switches[n_switches].args = 0;
3687 switches[n_switches].live_cond = SWITCH_OK;
3688 switches[n_switches].validated = 0;
3690 n_switches++;
3692 else if (strcmp (argv[i], "-fhelp") == 0)
3694 if (verbose_flag)
3696 /* Create a dummy input file, so that we can pass --help on to
3697 the various sub-processes. */
3698 infiles[n_infiles].language = "c";
3699 infiles[n_infiles++].name = "help-dummy";
3701 /* Preserve the --help switch so that it can be caught by the
3702 cc1 spec string. */
3703 switches[n_switches].part1 = "--help";
3704 switches[n_switches].args = 0;
3705 switches[n_switches].live_cond = SWITCH_OK;
3706 switches[n_switches].validated = 0;
3708 n_switches++;
3711 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3713 /* Compensate for the +e options to the C++ front-end;
3714 they're there simply for cfront call-compatibility. We do
3715 some magic in default_compilers to pass them down properly.
3716 Note we deliberately start at the `+' here, to avoid passing
3717 -e0 or -e1 down into the linker. */
3718 switches[n_switches].part1 = &argv[i][0];
3719 switches[n_switches].args = 0;
3720 switches[n_switches].live_cond = SWITCH_OK;
3721 switches[n_switches].validated = 0;
3722 n_switches++;
3724 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3726 int prev, j;
3727 /* Split the argument at commas. */
3728 prev = 4;
3729 for (j = 4; argv[i][j]; j++)
3730 if (argv[i][j] == ',')
3732 infiles[n_infiles].language = "*";
3733 infiles[n_infiles++].name
3734 = save_string (argv[i] + prev, j - prev);
3735 prev = j + 1;
3737 /* Record the part after the last comma. */
3738 infiles[n_infiles].language = "*";
3739 infiles[n_infiles++].name = argv[i] + prev;
3741 else if (strcmp (argv[i], "-Xlinker") == 0)
3743 infiles[n_infiles].language = "*";
3744 infiles[n_infiles++].name = argv[++i];
3746 else if (strcmp (argv[i], "-l") == 0)
3747 { /* POSIX allows separation of -l and the lib arg;
3748 canonicalize by concatenating -l with its arg */
3749 infiles[n_infiles].language = "*";
3750 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3752 else if (strncmp (argv[i], "-l", 2) == 0)
3754 infiles[n_infiles].language = "*";
3755 infiles[n_infiles++].name = argv[i];
3757 else if (strcmp (argv[i], "-specs") == 0)
3758 i++;
3759 else if (strncmp (argv[i], "-specs=", 7) == 0)
3761 else if (strcmp (argv[i], "-time") == 0)
3763 else if ((save_temps_flag || report_times)
3764 && strcmp (argv[i], "-pipe") == 0)
3766 /* -save-temps overrides -pipe, so that temp files are produced */
3767 if (save_temps_flag)
3768 error ("Warning: -pipe ignored because -save-temps specified");
3769 /* -time overrides -pipe because we can't get correct stats when
3770 multiple children are running at once. */
3771 else if (report_times)
3772 error ("Warning: -pipe ignored because -time specified");
3774 else if (argv[i][0] == '-' && argv[i][1] != 0)
3776 const char *p = &argv[i][1];
3777 int c = *p;
3779 if (c == 'x')
3781 if (p[1] == 0 && i + 1 == argc)
3782 fatal ("argument to `-x' is missing");
3783 if (p[1] == 0)
3784 spec_lang = argv[++i];
3785 else
3786 spec_lang = p + 1;
3787 if (! strcmp (spec_lang, "none"))
3788 /* Suppress the warning if -xnone comes after the last input
3789 file, because alternate command interfaces like g++ might
3790 find it useful to place -xnone after each input file. */
3791 spec_lang = 0;
3792 else
3793 last_language_n_infiles = n_infiles;
3794 continue;
3796 switches[n_switches].part1 = p;
3797 /* Deal with option arguments in separate argv elements. */
3798 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
3799 || WORD_SWITCH_TAKES_ARG (p))
3801 int j = 0;
3802 int n_args = WORD_SWITCH_TAKES_ARG (p);
3804 if (n_args == 0)
3806 /* Count only the option arguments in separate argv elements. */
3807 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
3809 if (i + n_args >= argc)
3810 fatal ("argument to `-%s' is missing", p);
3811 switches[n_switches].args
3812 = (const char **) xmalloc ((n_args + 1) * sizeof(const char *));
3813 while (j < n_args)
3814 switches[n_switches].args[j++] = argv[++i];
3815 /* Null-terminate the vector. */
3816 switches[n_switches].args[j] = 0;
3818 else if (strchr (switches_need_spaces, c))
3820 /* On some systems, ld cannot handle some options without
3821 a space. So split the option from its argument. */
3822 char *part1 = (char *) xmalloc (2);
3823 char *tmp;
3824 part1[0] = c;
3825 part1[1] = '\0';
3827 switches[n_switches].part1 = part1;
3828 switches[n_switches].args
3829 = (const char **) xmalloc (2 * sizeof (const char *));
3830 switches[n_switches].args[0] = tmp = xmalloc (strlen (p));
3831 strcpy (tmp, &p[1]);
3832 switches[n_switches].args[1] = 0;
3834 else
3835 switches[n_switches].args = 0;
3837 switches[n_switches].live_cond = SWITCH_OK;
3838 switches[n_switches].validated = 0;
3839 switches[n_switches].ordering = 0;
3840 /* These are always valid, since gcc.c itself understands it. */
3841 if (!strcmp (p, "save-temps")
3842 || !strcmp (p, "static-libgcc")
3843 || !strcmp (p, "shared-libgcc"))
3844 switches[n_switches].validated = 1;
3845 else
3847 char ch = switches[n_switches].part1[0];
3848 if (ch == 'V' || ch == 'b' || ch == 'B')
3849 switches[n_switches].validated = 1;
3851 n_switches++;
3853 else
3855 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3856 argv[i] = convert_filename (argv[i], 0);
3857 #endif
3859 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
3861 perror_with_name (argv[i]);
3862 error_count++;
3864 else
3866 infiles[n_infiles].language = spec_lang;
3867 infiles[n_infiles++].name = argv[i];
3872 if (n_infiles == last_language_n_infiles && spec_lang != 0)
3873 error ("Warning: `-x %s' after last input file has no effect", spec_lang);
3875 switches[n_switches].part1 = 0;
3876 infiles[n_infiles].name = 0;
3879 /* Process a spec string, accumulating and running commands. */
3881 /* These variables describe the input file name.
3882 input_file_number is the index on outfiles of this file,
3883 so that the output file name can be stored for later use by %o.
3884 input_basename is the start of the part of the input file
3885 sans all directory names, and basename_length is the number
3886 of characters starting there excluding the suffix .c or whatever. */
3888 const char *input_filename;
3889 static int input_file_number;
3890 size_t input_filename_length;
3891 static int basename_length;
3892 static int suffixed_basename_length;
3893 static const char *input_basename;
3894 static const char *input_suffix;
3896 /* The compiler used to process the current input file. */
3897 static struct compiler *input_file_compiler;
3899 /* These are variables used within do_spec and do_spec_1. */
3901 /* Nonzero if an arg has been started and not yet terminated
3902 (with space, tab or newline). */
3903 static int arg_going;
3905 /* Nonzero means %d or %g has been seen; the next arg to be terminated
3906 is a temporary file name. */
3907 static int delete_this_arg;
3909 /* Nonzero means %w has been seen; the next arg to be terminated
3910 is the output file name of this compilation. */
3911 static int this_is_output_file;
3913 /* Nonzero means %s has been seen; the next arg to be terminated
3914 is the name of a library file and we should try the standard
3915 search dirs for it. */
3916 static int this_is_library_file;
3918 /* Nonzero means that the input of this command is coming from a pipe. */
3919 static int input_from_pipe;
3921 /* Nonnull means substitute this for any suffix when outputting a switches
3922 arguments. */
3923 static const char *suffix_subst;
3925 /* Process the spec SPEC and run the commands specified therein.
3926 Returns 0 if the spec is successfully processed; -1 if failed. */
3929 do_spec (spec)
3930 const char *spec;
3932 int value;
3934 clear_args ();
3935 arg_going = 0;
3936 delete_this_arg = 0;
3937 this_is_output_file = 0;
3938 this_is_library_file = 0;
3939 input_from_pipe = 0;
3940 suffix_subst = NULL;
3942 value = do_spec_1 (spec, 0, NULL);
3944 /* Force out any unfinished command.
3945 If -pipe, this forces out the last command if it ended in `|'. */
3946 if (value == 0)
3948 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
3949 argbuf_index--;
3951 if (argbuf_index > 0)
3952 value = execute ();
3955 return value;
3958 /* Process the sub-spec SPEC as a portion of a larger spec.
3959 This is like processing a whole spec except that we do
3960 not initialize at the beginning and we do not supply a
3961 newline by default at the end.
3962 INSWITCH nonzero means don't process %-sequences in SPEC;
3963 in this case, % is treated as an ordinary character.
3964 This is used while substituting switches.
3965 INSWITCH nonzero also causes SPC not to terminate an argument.
3967 Value is zero unless a line was finished
3968 and the command on that line reported an error. */
3970 static int
3971 do_spec_1 (spec, inswitch, soft_matched_part)
3972 const char *spec;
3973 int inswitch;
3974 const char *soft_matched_part;
3976 register const char *p = spec;
3977 register int c;
3978 int i;
3979 const char *string;
3980 int value;
3982 while ((c = *p++))
3983 /* If substituting a switch, treat all chars like letters.
3984 Otherwise, NL, SPC, TAB and % are special. */
3985 switch (inswitch ? 'a' : c)
3987 case '\n':
3988 /* End of line: finish any pending argument,
3989 then run the pending command if one has been started. */
3990 if (arg_going)
3992 obstack_1grow (&obstack, 0);
3993 string = obstack_finish (&obstack);
3994 if (this_is_library_file)
3995 string = find_file (string);
3996 store_arg (string, delete_this_arg, this_is_output_file);
3997 if (this_is_output_file)
3998 outfiles[input_file_number] = string;
4000 arg_going = 0;
4002 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4004 for (i = 0; i < n_switches; i++)
4005 if (!strcmp (switches[i].part1, "pipe"))
4006 break;
4008 /* A `|' before the newline means use a pipe here,
4009 but only if -pipe was specified.
4010 Otherwise, execute now and don't pass the `|' as an arg. */
4011 if (i < n_switches)
4013 input_from_pipe = 1;
4014 switches[i].validated = 1;
4015 break;
4017 else
4018 argbuf_index--;
4021 if (argbuf_index > 0)
4023 value = execute ();
4024 if (value)
4025 return value;
4027 /* Reinitialize for a new command, and for a new argument. */
4028 clear_args ();
4029 arg_going = 0;
4030 delete_this_arg = 0;
4031 this_is_output_file = 0;
4032 this_is_library_file = 0;
4033 input_from_pipe = 0;
4034 break;
4036 case '|':
4037 /* End any pending argument. */
4038 if (arg_going)
4040 obstack_1grow (&obstack, 0);
4041 string = obstack_finish (&obstack);
4042 if (this_is_library_file)
4043 string = find_file (string);
4044 store_arg (string, delete_this_arg, this_is_output_file);
4045 if (this_is_output_file)
4046 outfiles[input_file_number] = string;
4049 /* Use pipe */
4050 obstack_1grow (&obstack, c);
4051 arg_going = 1;
4052 break;
4054 case '\t':
4055 case ' ':
4056 /* Space or tab ends an argument if one is pending. */
4057 if (arg_going)
4059 obstack_1grow (&obstack, 0);
4060 string = obstack_finish (&obstack);
4061 if (this_is_library_file)
4062 string = find_file (string);
4063 store_arg (string, delete_this_arg, this_is_output_file);
4064 if (this_is_output_file)
4065 outfiles[input_file_number] = string;
4067 /* Reinitialize for a new argument. */
4068 arg_going = 0;
4069 delete_this_arg = 0;
4070 this_is_output_file = 0;
4071 this_is_library_file = 0;
4072 break;
4074 case '%':
4075 switch (c = *p++)
4077 case 0:
4078 fatal ("Invalid specification! Bug in cc.");
4080 case 'b':
4081 obstack_grow (&obstack, input_basename, basename_length);
4082 arg_going = 1;
4083 break;
4085 case 'B':
4086 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4087 arg_going = 1;
4088 break;
4090 case 'd':
4091 delete_this_arg = 2;
4092 break;
4094 /* Dump out the directories specified with LIBRARY_PATH,
4095 followed by the absolute directories
4096 that we search for startfiles. */
4097 case 'D':
4099 struct prefix_list *pl = startfile_prefixes.plist;
4100 size_t bufsize = 100;
4101 char *buffer = (char *) xmalloc (bufsize);
4102 int idx;
4104 for (; pl; pl = pl->next)
4106 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4107 /* Used on systems which record the specified -L dirs
4108 and use them to search for dynamic linking. */
4109 /* Relative directories always come from -B,
4110 and it is better not to use them for searching
4111 at run time. In particular, stage1 loses. */
4112 if (!IS_ABSOLUTE_PATHNAME (pl->prefix))
4113 continue;
4114 #endif
4115 /* Try subdirectory if there is one. */
4116 if (multilib_dir != NULL)
4118 if (machine_suffix)
4120 if (strlen (pl->prefix) + strlen (machine_suffix)
4121 >= bufsize)
4122 bufsize = (strlen (pl->prefix)
4123 + strlen (machine_suffix)) * 2 + 1;
4124 buffer = (char *) xrealloc (buffer, bufsize);
4125 strcpy (buffer, pl->prefix);
4126 strcat (buffer, machine_suffix);
4127 if (is_directory (buffer, multilib_dir, 1))
4129 do_spec_1 ("-L", 0, NULL);
4130 #ifdef SPACE_AFTER_L_OPTION
4131 do_spec_1 (" ", 0, NULL);
4132 #endif
4133 do_spec_1 (buffer, 1, NULL);
4134 do_spec_1 (multilib_dir, 1, NULL);
4135 /* Make this a separate argument. */
4136 do_spec_1 (" ", 0, NULL);
4139 if (!pl->require_machine_suffix)
4141 if (is_directory (pl->prefix, multilib_dir, 1))
4143 do_spec_1 ("-L", 0, NULL);
4144 #ifdef SPACE_AFTER_L_OPTION
4145 do_spec_1 (" ", 0, NULL);
4146 #endif
4147 do_spec_1 (pl->prefix, 1, NULL);
4148 do_spec_1 (multilib_dir, 1, NULL);
4149 /* Make this a separate argument. */
4150 do_spec_1 (" ", 0, NULL);
4154 if (machine_suffix)
4156 if (is_directory (pl->prefix, machine_suffix, 1))
4158 do_spec_1 ("-L", 0, NULL);
4159 #ifdef SPACE_AFTER_L_OPTION
4160 do_spec_1 (" ", 0, NULL);
4161 #endif
4162 do_spec_1 (pl->prefix, 1, NULL);
4163 /* Remove slash from machine_suffix. */
4164 if (strlen (machine_suffix) >= bufsize)
4165 bufsize = strlen (machine_suffix) * 2 + 1;
4166 buffer = (char *) xrealloc (buffer, bufsize);
4167 strcpy (buffer, machine_suffix);
4168 idx = strlen (buffer);
4169 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4170 buffer[idx - 1] = 0;
4171 do_spec_1 (buffer, 1, NULL);
4172 /* Make this a separate argument. */
4173 do_spec_1 (" ", 0, NULL);
4176 if (!pl->require_machine_suffix)
4178 if (is_directory (pl->prefix, "", 1))
4180 do_spec_1 ("-L", 0, NULL);
4181 #ifdef SPACE_AFTER_L_OPTION
4182 do_spec_1 (" ", 0, NULL);
4183 #endif
4184 /* Remove slash from pl->prefix. */
4185 if (strlen (pl->prefix) >= bufsize)
4186 bufsize = strlen (pl->prefix) * 2 + 1;
4187 buffer = (char *) xrealloc (buffer, bufsize);
4188 strcpy (buffer, pl->prefix);
4189 idx = strlen (buffer);
4190 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4191 buffer[idx - 1] = 0;
4192 do_spec_1 (buffer, 1, NULL);
4193 /* Make this a separate argument. */
4194 do_spec_1 (" ", 0, NULL);
4198 free (buffer);
4200 break;
4202 case 'e':
4203 /* %efoo means report an error with `foo' as error message
4204 and don't execute any more commands for this file. */
4206 const char *q = p;
4207 char *buf;
4208 while (*p != 0 && *p != '\n')
4209 p++;
4210 buf = (char *) alloca (p - q + 1);
4211 strncpy (buf, q, p - q);
4212 buf[p - q] = 0;
4213 error ("%s", buf);
4214 return -1;
4216 break;
4217 case 'n':
4218 /* %nfoo means report an notice with `foo' on stderr. */
4220 const char *q = p;
4221 char *buf;
4222 while (*p != 0 && *p != '\n')
4223 p++;
4224 buf = (char *) alloca (p - q + 1);
4225 strncpy (buf, q, p - q);
4226 buf[p - q] = 0;
4227 notice ("%s\n", buf);
4228 if (*p)
4229 p++;
4231 break;
4233 case 'j':
4235 struct stat st;
4237 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is defined,
4238 and it is not a directory, and it is writable, use it.
4239 Otherwise, fall through and treat this like any other
4240 temporary file. */
4242 if ((!save_temps_flag)
4243 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4244 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4246 obstack_grow (&obstack, HOST_BIT_BUCKET,
4247 strlen (HOST_BIT_BUCKET));
4248 delete_this_arg = 0;
4249 arg_going = 1;
4250 break;
4253 case 'g':
4254 case 'u':
4255 case 'U':
4256 if (save_temps_flag)
4258 obstack_grow (&obstack, input_basename, basename_length);
4259 delete_this_arg = 0;
4261 else
4263 struct temp_name *t;
4264 int suffix_length;
4265 const char *suffix = p;
4266 char *saved_suffix = NULL;
4268 while (*p == '.' || ISALPHA ((unsigned char) *p))
4269 p++;
4270 suffix_length = p - suffix;
4271 if (p[0] == '%' && p[1] == 'O')
4273 p += 2;
4274 /* We don't support extra suffix characters after %O. */
4275 if (*p == '.' || ISALPHA ((unsigned char) *p))
4276 abort ();
4277 if (suffix_length == 0)
4278 suffix = TARGET_OBJECT_SUFFIX;
4279 else
4281 saved_suffix
4282 = (char *) xmalloc (suffix_length
4283 + strlen (TARGET_OBJECT_SUFFIX));
4284 strncpy (saved_suffix, suffix, suffix_length);
4285 strcpy (saved_suffix + suffix_length,
4286 TARGET_OBJECT_SUFFIX);
4288 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4291 /* See if we already have an association of %g/%u/%U and
4292 suffix. */
4293 for (t = temp_names; t; t = t->next)
4294 if (t->length == suffix_length
4295 && strncmp (t->suffix, suffix, suffix_length) == 0
4296 && t->unique == (c != 'g'))
4297 break;
4299 /* Make a new association if needed. %u and %j require one. */
4300 if (t == 0 || c == 'u' || c == 'j')
4302 if (t == 0)
4304 t = (struct temp_name *) xmalloc (sizeof (struct temp_name));
4305 t->next = temp_names;
4306 temp_names = t;
4308 t->length = suffix_length;
4309 t->suffix = save_string (suffix, suffix_length);
4310 t->unique = (c != 'g');
4311 temp_filename = make_temp_file (t->suffix);
4312 temp_filename_length = strlen (temp_filename);
4313 t->filename = temp_filename;
4314 t->filename_length = temp_filename_length;
4317 if (saved_suffix)
4318 free (saved_suffix);
4320 obstack_grow (&obstack, t->filename, t->filename_length);
4321 delete_this_arg = 1;
4323 arg_going = 1;
4324 break;
4326 case 'i':
4327 obstack_grow (&obstack, input_filename, input_filename_length);
4328 arg_going = 1;
4329 break;
4331 case 'I':
4333 struct prefix_list *pl = include_prefixes.plist;
4335 if (gcc_exec_prefix)
4337 do_spec_1 ("-iprefix", 1, NULL);
4338 /* Make this a separate argument. */
4339 do_spec_1 (" ", 0, NULL);
4340 do_spec_1 (gcc_exec_prefix, 1, NULL);
4341 do_spec_1 (" ", 0, NULL);
4344 for (; pl; pl = pl->next)
4346 do_spec_1 ("-isystem", 1, NULL);
4347 /* Make this a separate argument. */
4348 do_spec_1 (" ", 0, NULL);
4349 do_spec_1 (pl->prefix, 1, NULL);
4350 do_spec_1 (" ", 0, NULL);
4353 break;
4355 case 'o':
4357 int max = n_infiles;
4358 max += lang_specific_extra_outfiles;
4360 for (i = 0; i < max; i++)
4361 if (outfiles[i])
4362 store_arg (outfiles[i], 0, 0);
4363 break;
4366 case 'O':
4367 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4368 arg_going = 1;
4369 break;
4371 case 's':
4372 this_is_library_file = 1;
4373 break;
4375 case 'w':
4376 this_is_output_file = 1;
4377 break;
4379 case 'W':
4381 int cur_index = argbuf_index;
4382 /* Handle the {...} following the %W. */
4383 if (*p != '{')
4384 abort ();
4385 p = handle_braces (p + 1);
4386 if (p == 0)
4387 return -1;
4388 /* If any args were output, mark the last one for deletion
4389 on failure. */
4390 if (argbuf_index != cur_index)
4391 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4392 break;
4395 /* %x{OPTION} records OPTION for %X to output. */
4396 case 'x':
4398 const char *p1 = p;
4399 char *string;
4401 /* Skip past the option value and make a copy. */
4402 if (*p != '{')
4403 abort ();
4404 while (*p++ != '}')
4406 string = save_string (p1 + 1, p - p1 - 2);
4408 /* See if we already recorded this option. */
4409 for (i = 0; i < n_linker_options; i++)
4410 if (! strcmp (string, linker_options[i]))
4412 free (string);
4413 return 0;
4416 /* This option is new; add it. */
4417 add_linker_option (string, strlen (string));
4419 break;
4421 /* Dump out the options accumulated previously using %x. */
4422 case 'X':
4423 for (i = 0; i < n_linker_options; i++)
4425 do_spec_1 (linker_options[i], 1, NULL);
4426 /* Make each accumulated option a separate argument. */
4427 do_spec_1 (" ", 0, NULL);
4429 break;
4431 /* Dump out the options accumulated previously using -Wa,. */
4432 case 'Y':
4433 for (i = 0; i < n_assembler_options; i++)
4435 do_spec_1 (assembler_options[i], 1, NULL);
4436 /* Make each accumulated option a separate argument. */
4437 do_spec_1 (" ", 0, NULL);
4439 break;
4441 /* Dump out the options accumulated previously using -Wp,. */
4442 case 'Z':
4443 for (i = 0; i < n_preprocessor_options; i++)
4445 do_spec_1 (preprocessor_options[i], 1, NULL);
4446 /* Make each accumulated option a separate argument. */
4447 do_spec_1 (" ", 0, NULL);
4449 break;
4451 /* Here are digits and numbers that just process
4452 a certain constant string as a spec. */
4454 case '1':
4455 value = do_spec_1 (cc1_spec, 0, NULL);
4456 if (value != 0)
4457 return value;
4458 break;
4460 case '2':
4461 value = do_spec_1 (cc1plus_spec, 0, NULL);
4462 if (value != 0)
4463 return value;
4464 break;
4466 case 'a':
4467 value = do_spec_1 (asm_spec, 0, NULL);
4468 if (value != 0)
4469 return value;
4470 break;
4472 case 'A':
4473 value = do_spec_1 (asm_final_spec, 0, NULL);
4474 if (value != 0)
4475 return value;
4476 break;
4478 case 'c':
4479 value = do_spec_1 (signed_char_spec, 0, NULL);
4480 if (value != 0)
4481 return value;
4482 break;
4484 case 'C':
4486 const char* spec
4487 = (input_file_compiler->cpp_spec
4488 ? input_file_compiler->cpp_spec
4489 : cpp_spec);
4490 value = do_spec_1 (spec, 0, NULL);
4491 if (value != 0)
4492 return value;
4494 break;
4496 case 'E':
4497 value = do_spec_1 (endfile_spec, 0, NULL);
4498 if (value != 0)
4499 return value;
4500 break;
4502 case 'l':
4503 value = do_spec_1 (link_spec, 0, NULL);
4504 if (value != 0)
4505 return value;
4506 break;
4508 case 'L':
4509 value = do_spec_1 (lib_spec, 0, NULL);
4510 if (value != 0)
4511 return value;
4512 break;
4514 case 'G':
4515 value = do_spec_1 (libgcc_spec, 0, NULL);
4516 if (value != 0)
4517 return value;
4518 break;
4520 case 'M':
4521 if (multilib_dir && strcmp (multilib_dir, ".") != 0)
4523 char *p;
4524 const char *q;
4525 size_t len;
4527 len = strlen (multilib_dir);
4528 obstack_blank (&obstack, len + 1);
4529 p = obstack_next_free (&obstack) - (len + 1);
4531 *p++ = '_';
4532 for (q = multilib_dir; *q ; ++q, ++p)
4533 *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
4535 break;
4537 case 'p':
4539 char *x = (char *) alloca (strlen (cpp_predefines) + 1);
4540 char *buf = x;
4541 const char *y;
4543 /* Copy all of the -D options in CPP_PREDEFINES into BUF. */
4544 y = cpp_predefines;
4545 while (*y != 0)
4547 if (! strncmp (y, "-D", 2))
4548 /* Copy the whole option. */
4549 while (*y && *y != ' ' && *y != '\t')
4550 *x++ = *y++;
4551 else if (*y == ' ' || *y == '\t')
4552 /* Copy whitespace to the result. */
4553 *x++ = *y++;
4554 /* Don't copy other options. */
4555 else
4556 y++;
4559 *x = 0;
4561 value = do_spec_1 (buf, 0, NULL);
4562 if (value != 0)
4563 return value;
4565 break;
4567 case 'P':
4569 char *x = (char *) alloca (strlen (cpp_predefines) * 4 + 1);
4570 char *buf = x;
4571 const char *y;
4573 /* Copy all of CPP_PREDEFINES into BUF,
4574 but force them all into the reserved name space if they
4575 aren't already there. The reserved name space is all
4576 identifiers beginning with two underscores or with one
4577 underscore and a capital letter. We do the forcing by
4578 adding up to two underscores to the beginning and end
4579 of each symbol. e.g. mips, _mips, mips_, and _mips_ all
4580 become __mips__. */
4581 y = cpp_predefines;
4582 while (*y != 0)
4584 if (! strncmp (y, "-D", 2))
4586 int flag = 0;
4588 *x++ = *y++;
4589 *x++ = *y++;
4591 if (*y != '_'
4592 || (*(y + 1) != '_'
4593 && ! ISUPPER ((unsigned char) *(y + 1))))
4595 /* Stick __ at front of macro name. */
4596 if (*y != '_')
4597 *x++ = '_';
4598 *x++ = '_';
4599 /* Arrange to stick __ at the end as well. */
4600 flag = 1;
4603 /* Copy the macro name. */
4604 while (*y && *y != '=' && *y != ' ' && *y != '\t')
4605 *x++ = *y++;
4607 if (flag)
4609 if (x[-1] != '_')
4611 if (x[-2] != '_')
4612 *x++ = '_';
4613 *x++ = '_';
4617 /* Copy the value given, if any. */
4618 while (*y && *y != ' ' && *y != '\t')
4619 *x++ = *y++;
4621 else if (*y == ' ' || *y == '\t')
4622 /* Copy whitespace to the result. */
4623 *x++ = *y++;
4624 /* Don't copy -A options */
4625 else
4626 y++;
4628 *x++ = ' ';
4630 /* Copy all of CPP_PREDEFINES into BUF,
4631 but put __ after every -D. */
4632 y = cpp_predefines;
4633 while (*y != 0)
4635 if (! strncmp (y, "-D", 2))
4637 y += 2;
4639 if (*y != '_'
4640 || (*(y + 1) != '_'
4641 && ! ISUPPER ((unsigned char) *(y + 1))))
4643 /* Stick -D__ at front of macro name. */
4644 *x++ = '-';
4645 *x++ = 'D';
4646 if (*y != '_')
4647 *x++ = '_';
4648 *x++ = '_';
4650 /* Copy the macro name. */
4651 while (*y && *y != '=' && *y != ' ' && *y != '\t')
4652 *x++ = *y++;
4654 /* Copy the value given, if any. */
4655 while (*y && *y != ' ' && *y != '\t')
4656 *x++ = *y++;
4658 else
4660 /* Do not copy this macro - we have just done it before */
4661 while (*y && *y != ' ' && *y != '\t')
4662 y++;
4665 else if (*y == ' ' || *y == '\t')
4666 /* Copy whitespace to the result. */
4667 *x++ = *y++;
4668 /* Don't copy -A options. */
4669 else
4670 y++;
4672 *x++ = ' ';
4674 /* Copy all of the -A options in CPP_PREDEFINES into BUF. */
4675 y = cpp_predefines;
4676 while (*y != 0)
4678 if (! strncmp (y, "-A", 2))
4679 /* Copy the whole option. */
4680 while (*y && *y != ' ' && *y != '\t')
4681 *x++ = *y++;
4682 else if (*y == ' ' || *y == '\t')
4683 /* Copy whitespace to the result. */
4684 *x++ = *y++;
4685 /* Don't copy other options. */
4686 else
4687 y++;
4690 *x = 0;
4692 value = do_spec_1 (buf, 0, NULL);
4693 if (value != 0)
4694 return value;
4696 break;
4698 case 'S':
4699 value = do_spec_1 (startfile_spec, 0, NULL);
4700 if (value != 0)
4701 return value;
4702 break;
4704 /* Here we define characters other than letters and digits. */
4706 case '{':
4707 p = handle_braces (p);
4708 if (p == 0)
4709 return -1;
4710 break;
4712 case '%':
4713 obstack_1grow (&obstack, '%');
4714 break;
4716 case '.':
4718 unsigned len = 0;
4720 while (p[len] && p[len] != ' ' && p[len] != '%')
4721 len++;
4722 suffix_subst = save_string (p - 1, len + 1);
4723 p += len;
4725 break;
4727 case '*':
4728 if (soft_matched_part)
4730 do_spec_1 (soft_matched_part, 1, NULL);
4731 do_spec_1 (" ", 0, NULL);
4733 else
4734 /* Catch the case where a spec string contains something like
4735 '%{foo:%*}'. ie there is no * in the pattern on the left
4736 hand side of the :. */
4737 error ("Spec failure: '%%*' has not been initialised by pattern match");
4738 break;
4740 /* Process a string found as the value of a spec given by name.
4741 This feature allows individual machine descriptions
4742 to add and use their own specs.
4743 %[...] modifies -D options the way %P does;
4744 %(...) uses the spec unmodified. */
4745 case '[':
4746 error ("Warning: use of obsolete %%[ operator in specs");
4747 case '(':
4749 const char *name = p;
4750 struct spec_list *sl;
4751 int len;
4753 /* The string after the S/P is the name of a spec that is to be
4754 processed. */
4755 while (*p && *p != ')' && *p != ']')
4756 p++;
4758 /* See if it's in the list. */
4759 for (len = p - name, sl = specs; sl; sl = sl->next)
4760 if (sl->name_len == len && !strncmp (sl->name, name, len))
4762 name = *(sl->ptr_spec);
4763 #ifdef DEBUG_SPECS
4764 notice ("Processing spec %c%s%c, which is '%s'\n",
4765 c, sl->name, (c == '(') ? ')' : ']', name);
4766 #endif
4767 break;
4770 if (sl)
4772 if (c == '(')
4774 value = do_spec_1 (name, 0, NULL);
4775 if (value != 0)
4776 return value;
4778 else
4780 char *x = (char *) alloca (strlen (name) * 2 + 1);
4781 char *buf = x;
4782 const char *y = name;
4783 int flag = 0;
4785 /* Copy all of NAME into BUF, but put __ after
4786 every -D and at the end of each arg. */
4787 while (1)
4789 if (! strncmp (y, "-D", 2))
4791 *x++ = '-';
4792 *x++ = 'D';
4793 *x++ = '_';
4794 *x++ = '_';
4795 y += 2;
4796 flag = 1;
4797 continue;
4799 else if (flag
4800 && (*y == ' ' || *y == '\t' || *y == '='
4801 || *y == '}' || *y == 0))
4803 *x++ = '_';
4804 *x++ = '_';
4805 flag = 0;
4807 if (*y == 0)
4808 break;
4809 else
4810 *x++ = *y++;
4812 *x = 0;
4814 value = do_spec_1 (buf, 0, NULL);
4815 if (value != 0)
4816 return value;
4820 /* Discard the closing paren or bracket. */
4821 if (*p)
4822 p++;
4824 break;
4826 case 'v':
4828 int c1 = *p++; /* Select first or second version number. */
4829 const char *v = compiler_version;
4830 const char *q;
4831 static const char zeroc = '0';
4833 /* The format of the version string is
4834 ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)? */
4836 /* Ignore leading non-digits. i.e. "foo-" in "foo-2.7.2". */
4837 while (! ISDIGIT (*v))
4838 v++;
4839 if (v > compiler_version && v[-1] != '-')
4840 abort ();
4842 /* If desired, advance to second version number. */
4843 if (c1 >= '2')
4845 /* Set V after the first period. */
4846 while (ISDIGIT (*v))
4847 v++;
4848 if (*v != '.')
4849 abort ();
4850 v++;
4853 /* If desired, advance to third version number.
4854 But don't complain if it's not present */
4855 if (c1 == '3')
4857 /* Set V after the second period. */
4858 while (ISDIGIT (*v))
4859 v++;
4860 if ((*v != 0) && (*v != ' ') && (*v != '.') && (*v != '-'))
4861 abort ();
4862 if (*v != 0)
4863 v++;
4866 /* Set Q at the next period or at the end. */
4867 q = v;
4868 while (ISDIGIT (*q))
4869 q++;
4870 if (*q != 0 && q > v && *q != ' ' && *q != '.' && *q != '-')
4871 abort ();
4873 if (q > v)
4874 /* Put that part into the command. */
4875 obstack_grow (&obstack, v, q - v);
4876 else
4877 /* Default to "0" */
4878 obstack_grow (&obstack, &zeroc, 1);
4879 arg_going = 1;
4881 break;
4883 case '|':
4884 if (input_from_pipe)
4885 do_spec_1 ("-", 0, NULL);
4886 break;
4888 default:
4889 error ("Spec failure: Unrecognised spec option '%c'", c);
4890 break;
4892 break;
4894 case '\\':
4895 /* Backslash: treat next character as ordinary. */
4896 c = *p++;
4898 /* fall through */
4899 default:
4900 /* Ordinary character: put it into the current argument. */
4901 obstack_1grow (&obstack, c);
4902 arg_going = 1;
4905 /* End of string. */
4906 return 0;
4909 /* Return 0 if we call do_spec_1 and that returns -1. */
4911 static const char *
4912 handle_braces (p)
4913 register const char *p;
4915 const char *filter, *body = NULL, *endbody = NULL;
4916 int pipe_p = 0;
4917 int true_once = 0; /* If, in %{a|b:d}, at least one of a,b was seen. */
4918 int negate;
4919 int suffix;
4920 int include_blanks = 1;
4921 int elide_switch = 0;
4922 int ordered = 0;
4924 if (*p == '^')
4926 /* A '^' after the open-brace means to not give blanks before args. */
4927 include_blanks = 0;
4928 ++p;
4931 if (*p == '|')
4933 /* A `|' after the open-brace means,
4934 if the test fails, output a single minus sign rather than nothing.
4935 This is used in %{|!pipe:...}. */
4936 pipe_p = 1;
4937 ++p;
4940 if (*p == '<')
4942 /* A `<' after the open-brace means that the switch should be
4943 removed from the command-line. */
4944 elide_switch = 1;
4945 ++p;
4948 next_member:
4949 negate = suffix = 0;
4951 if (*p == '!')
4952 /* A `!' after the open-brace negates the condition:
4953 succeed if the specified switch is not present. */
4954 negate = 1, ++p;
4956 if (*p == '.')
4957 /* A `.' after the open-brace means test against the current suffix. */
4959 if (pipe_p)
4960 abort ();
4962 suffix = 1;
4963 ++p;
4966 if (elide_switch && (negate || pipe_p || suffix))
4968 /* It doesn't make sense to mix elision with other flags. We
4969 could fatal() here, but the standard seems to be to abort. */
4970 abort ();
4973 next_ampersand:
4974 filter = p;
4975 while (*p != ':' && *p != '}' && *p != '|' && *p != '&')
4976 p++;
4978 if (*p == '|' && (pipe_p || ordered))
4979 abort ();
4981 if (!body)
4983 if (*p != '}' && *p != '&')
4985 register int count = 1;
4986 register const char *q = p;
4988 while (*q++ != ':')
4989 continue;
4990 body = q;
4992 while (count > 0)
4994 if (*q == '{')
4995 count++;
4996 else if (*q == '}')
4997 count--;
4998 else if (*q == 0)
4999 abort ();
5000 q++;
5002 endbody = q;
5004 else
5005 body = p, endbody = p + 1;
5008 if (suffix)
5010 int found = (input_suffix != 0
5011 && (long) strlen (input_suffix) == (long) (p - filter)
5012 && strncmp (input_suffix, filter, p - filter) == 0);
5014 if (body[0] == '}')
5015 abort ();
5017 if (negate != found
5018 && do_spec_1 (save_string (body, endbody-body-1), 0, NULL) < 0)
5019 return 0;
5021 else if (p[-1] == '*' && (p[0] == '}' || p[0] == '&'))
5023 /* Substitute all matching switches as separate args. */
5024 register int i;
5026 for (i = 0; i < n_switches; i++)
5027 if (!strncmp (switches[i].part1, filter, p - 1 - filter)
5028 && check_live_switch (i, p - 1 - filter))
5030 if (elide_switch)
5032 switches[i].live_cond = SWITCH_IGNORE;
5033 switches[i].validated = 1;
5035 else
5036 ordered = 1, switches[i].ordering = 1;
5039 else
5041 /* Test for presence of the specified switch. */
5042 register int i;
5043 int present = 0;
5045 /* If name specified ends in *, as in {x*:...},
5046 check for %* and handle that case. */
5047 if (p[-1] == '*' && !negate)
5049 int substitution;
5050 const char *r = body;
5052 /* First see whether we have %*. */
5053 substitution = 0;
5054 while (r < endbody)
5056 if (*r == '%' && r[1] == '*')
5057 substitution = 1;
5058 r++;
5060 /* If we do, handle that case. */
5061 if (substitution)
5063 /* Substitute all matching switches as separate args.
5064 But do this by substituting for %*
5065 in the text that follows the colon. */
5067 unsigned hard_match_len = p - filter - 1;
5068 char *string = save_string (body, endbody - body - 1);
5070 for (i = 0; i < n_switches; i++)
5071 if (!strncmp (switches[i].part1, filter, hard_match_len)
5072 && check_live_switch (i, -1))
5074 do_spec_1 (string, 0, &switches[i].part1[hard_match_len]);
5075 /* Pass any arguments this switch has. */
5076 give_switch (i, 1, 1);
5077 suffix_subst = NULL;
5080 /* We didn't match. Try again. */
5081 if (*p++ == '|')
5082 goto next_member;
5083 return endbody;
5087 /* If name specified ends in *, as in {x*:...},
5088 check for presence of any switch name starting with x. */
5089 if (p[-1] == '*')
5091 for (i = 0; i < n_switches; i++)
5093 unsigned hard_match_len = p - filter - 1;
5095 if (!strncmp (switches[i].part1, filter, hard_match_len)
5096 && check_live_switch (i, hard_match_len))
5098 present = 1;
5099 break;
5103 /* Otherwise, check for presence of exact name specified. */
5104 else
5106 for (i = 0; i < n_switches; i++)
5108 if (!strncmp (switches[i].part1, filter, p - filter)
5109 && switches[i].part1[p - filter] == 0
5110 && check_live_switch (i, -1))
5112 present = 1;
5113 break;
5118 /* If it is as desired (present for %{s...}, absent for %{!s...})
5119 then substitute either the switch or the specified
5120 conditional text. */
5121 if (present != negate)
5123 if (elide_switch)
5125 switches[i].live_cond = SWITCH_IGNORE;
5126 switches[i].validated = 1;
5128 else if (ordered || *p == '&')
5129 ordered = 1, switches[i].ordering = 1;
5130 else if (*p == '}')
5131 give_switch (i, 0, include_blanks);
5132 else
5133 /* Even if many alternatives are matched, only output once. */
5134 true_once = 1;
5136 else if (pipe_p)
5138 /* Here if a %{|...} conditional fails: output a minus sign,
5139 which means "standard output" or "standard input". */
5140 do_spec_1 ("-", 0, NULL);
5141 return endbody;
5145 /* We didn't match; try again. */
5146 if (*p++ == '|')
5147 goto next_member;
5149 if (p[-1] == '&')
5151 body = 0;
5152 goto next_ampersand;
5155 if (ordered)
5157 int i;
5158 /* Doing this set of switches later preserves their command-line
5159 ordering. This is needed for e.g. -U, -D and -A. */
5160 for (i = 0; i < n_switches; i++)
5161 if (switches[i].ordering == 1)
5163 switches[i].ordering = 0;
5164 give_switch (i, 0, include_blanks);
5167 /* Process the spec just once, regardless of match count. */
5168 else if (true_once)
5170 if (do_spec_1 (save_string (body, endbody - body - 1),
5171 0, NULL) < 0)
5172 return 0;
5175 return endbody;
5178 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5179 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5180 spec, or -1 if either exact match or %* is used.
5182 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5183 whose value does not begin with "no-" is obsoleted by the same value
5184 with the "no-", similarly for a switch with the "no-" prefix. */
5186 static int
5187 check_live_switch (switchnum, prefix_length)
5188 int switchnum;
5189 int prefix_length;
5191 const char *name = switches[switchnum].part1;
5192 int i;
5194 /* In the common case of {<at-most-one-letter>*}, a negating
5195 switch would always match, so ignore that case. We will just
5196 send the conflicting switches to the compiler phase. */
5197 if (prefix_length >= 0 && prefix_length <= 1)
5198 return 1;
5200 /* If we already processed this switch and determined if it was
5201 live or not, return our past determination. */
5202 if (switches[switchnum].live_cond != 0)
5203 return switches[switchnum].live_cond > 0;
5205 /* Now search for duplicate in a manner that depends on the name. */
5206 switch (*name)
5208 case 'O':
5209 for (i = switchnum + 1; i < n_switches; i++)
5210 if (switches[i].part1[0] == 'O')
5212 switches[switchnum].validated = 1;
5213 switches[switchnum].live_cond = SWITCH_FALSE;
5214 return 0;
5216 break;
5218 case 'W': case 'f': case 'm':
5219 if (! strncmp (name + 1, "no-", 3))
5221 /* We have Xno-YYY, search for XYYY. */
5222 for (i = switchnum + 1; i < n_switches; i++)
5223 if (switches[i].part1[0] == name[0]
5224 && ! strcmp (&switches[i].part1[1], &name[4]))
5226 switches[switchnum].validated = 1;
5227 switches[switchnum].live_cond = SWITCH_FALSE;
5228 return 0;
5231 else
5233 /* We have XYYY, search for Xno-YYY. */
5234 for (i = switchnum + 1; i < n_switches; i++)
5235 if (switches[i].part1[0] == name[0]
5236 && switches[i].part1[1] == 'n'
5237 && switches[i].part1[2] == 'o'
5238 && switches[i].part1[3] == '-'
5239 && !strcmp (&switches[i].part1[4], &name[1]))
5241 switches[switchnum].validated = 1;
5242 switches[switchnum].live_cond = SWITCH_FALSE;
5243 return 0;
5246 break;
5249 /* Otherwise the switch is live. */
5250 switches[switchnum].live_cond = SWITCH_LIVE;
5251 return 1;
5254 /* Pass a switch to the current accumulating command
5255 in the same form that we received it.
5256 SWITCHNUM identifies the switch; it is an index into
5257 the vector of switches gcc received, which is `switches'.
5258 This cannot fail since it never finishes a command line.
5260 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument.
5262 If INCLUDE_BLANKS is nonzero, then we include blanks before each argument
5263 of the switch. */
5265 static void
5266 give_switch (switchnum, omit_first_word, include_blanks)
5267 int switchnum;
5268 int omit_first_word;
5269 int include_blanks;
5271 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5272 return;
5274 if (!omit_first_word)
5276 do_spec_1 ("-", 0, NULL);
5277 do_spec_1 (switches[switchnum].part1, 1, NULL);
5280 if (switches[switchnum].args != 0)
5282 const char **p;
5283 for (p = switches[switchnum].args; *p; p++)
5285 const char *arg = *p;
5287 if (include_blanks)
5288 do_spec_1 (" ", 0, NULL);
5289 if (suffix_subst)
5291 unsigned length = strlen (arg);
5292 int dot = 0;
5294 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5295 if (arg[length] == '.')
5297 ((char *)arg)[length] = 0;
5298 dot = 1;
5299 break;
5301 do_spec_1 (arg, 1, NULL);
5302 if (dot)
5303 ((char *)arg)[length] = '.';
5304 do_spec_1 (suffix_subst, 1, NULL);
5306 else
5307 do_spec_1 (arg, 1, NULL);
5311 do_spec_1 (" ", 0, NULL);
5312 switches[switchnum].validated = 1;
5315 /* Search for a file named NAME trying various prefixes including the
5316 user's -B prefix and some standard ones.
5317 Return the absolute file name found. If nothing is found, return NAME. */
5319 static const char *
5320 find_file (name)
5321 const char *name;
5323 char *newname;
5325 /* Try multilib_dir if it is defined. */
5326 if (multilib_dir != NULL)
5328 char *try;
5330 try = (char *) alloca (strlen (multilib_dir) + strlen (name) + 2);
5331 strcpy (try, multilib_dir);
5332 strcat (try, dir_separator_str);
5333 strcat (try, name);
5335 newname = find_a_file (&startfile_prefixes, try, R_OK);
5337 /* If we don't find it in the multi library dir, then fall
5338 through and look for it in the normal places. */
5339 if (newname != NULL)
5340 return newname;
5343 newname = find_a_file (&startfile_prefixes, name, R_OK);
5344 return newname ? newname : name;
5347 /* Determine whether a directory exists. If LINKER, return 0 for
5348 certain fixed names not needed by the linker. If not LINKER, it is
5349 only important to return 0 if the host machine has a small ARG_MAX
5350 limit. */
5352 static int
5353 is_directory (path1, path2, linker)
5354 const char *path1;
5355 const char *path2;
5356 int linker;
5358 int len1 = strlen (path1);
5359 int len2 = strlen (path2);
5360 char *path = (char *) alloca (3 + len1 + len2);
5361 char *cp;
5362 struct stat st;
5364 #ifndef SMALL_ARG_MAX
5365 if (! linker)
5366 return 1;
5367 #endif
5369 /* Construct the path from the two parts. Ensure the string ends with "/.".
5370 The resulting path will be a directory even if the given path is a
5371 symbolic link. */
5372 memcpy (path, path1, len1);
5373 memcpy (path + len1, path2, len2);
5374 cp = path + len1 + len2;
5375 if (!IS_DIR_SEPARATOR (cp[-1]))
5376 *cp++ = DIR_SEPARATOR;
5377 *cp++ = '.';
5378 *cp = '\0';
5380 /* Exclude directories that the linker is known to search. */
5381 if (linker
5382 && ((cp - path == 6
5383 && strcmp (path, concat (dir_separator_str, "lib",
5384 dir_separator_str, ".", NULL)) == 0)
5385 || (cp - path == 10
5386 && strcmp (path, concat (dir_separator_str, "usr",
5387 dir_separator_str, "lib",
5388 dir_separator_str, ".", NULL)) == 0)))
5389 return 0;
5391 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5394 /* Set up the various global variables to indicate that we're processing
5395 the input file named FILENAME. */
5397 static void
5398 set_input (filename)
5399 const char *filename;
5401 register const char *p;
5403 input_filename = filename;
5404 input_filename_length = strlen (input_filename);
5406 input_basename = input_filename;
5407 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5408 /* Skip drive name so 'x:foo' is handled properly. */
5409 if (input_basename[1] == ':')
5410 input_basename += 2;
5411 #endif
5412 for (p = input_basename; *p; p++)
5413 if (IS_DIR_SEPARATOR (*p))
5414 input_basename = p + 1;
5416 /* Find a suffix starting with the last period,
5417 and set basename_length to exclude that suffix. */
5418 basename_length = strlen (input_basename);
5419 suffixed_basename_length = basename_length;
5420 p = input_basename + basename_length;
5421 while (p != input_basename && *p != '.')
5422 --p;
5423 if (*p == '.' && p != input_basename)
5425 basename_length = p - input_basename;
5426 input_suffix = p + 1;
5428 else
5429 input_suffix = "";
5432 /* On fatal signals, delete all the temporary files. */
5434 static void
5435 fatal_error (signum)
5436 int signum;
5438 signal (signum, SIG_DFL);
5439 delete_failure_queue ();
5440 delete_temp_files ();
5441 /* Get the same signal again, this time not handled,
5442 so its normal effect occurs. */
5443 kill (getpid (), signum);
5446 extern int main PARAMS ((int, const char *const *));
5449 main (argc, argv)
5450 int argc;
5451 const char *const *argv;
5453 size_t i;
5454 int value;
5455 int linker_was_run = 0;
5456 char *explicit_link_files;
5457 char *specs_file;
5458 const char *p;
5459 struct user_specs *uptr;
5461 p = argv[0] + strlen (argv[0]);
5462 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
5463 --p;
5464 programname = p;
5466 xmalloc_set_program_name (programname);
5468 #ifdef GCC_DRIVER_HOST_INITIALIZATION
5469 /* Perform host dependant initialization when needed. */
5470 GCC_DRIVER_HOST_INITIALIZATION;
5471 #endif
5473 /* LC_CTYPE determines the character set used by the terminal so it has be set
5474 to output messages correctly. */
5476 #ifdef HAVE_LC_MESSAGES
5477 setlocale (LC_CTYPE, "");
5478 setlocale (LC_MESSAGES, "");
5479 #else
5480 setlocale (LC_ALL, "");
5481 #endif
5483 (void) bindtextdomain (PACKAGE, localedir);
5484 (void) textdomain (PACKAGE);
5486 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
5487 signal (SIGINT, fatal_error);
5488 #ifdef SIGHUP
5489 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
5490 signal (SIGHUP, fatal_error);
5491 #endif
5492 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
5493 signal (SIGTERM, fatal_error);
5494 #ifdef SIGPIPE
5495 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
5496 signal (SIGPIPE, fatal_error);
5497 #endif
5498 #ifdef SIGCHLD
5499 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
5500 receive the signal. A different setting is inheritable */
5501 signal (SIGCHLD, SIG_DFL);
5502 #endif
5504 argbuf_length = 10;
5505 argbuf = (const char **) xmalloc (argbuf_length * sizeof (const char *));
5507 obstack_init (&obstack);
5509 /* Build multilib_select, et. al from the separate lines that make up each
5510 multilib selection. */
5512 const char *const *q = multilib_raw;
5513 int need_space;
5515 obstack_init (&multilib_obstack);
5516 while ((p = *q++) != (char *) 0)
5517 obstack_grow (&multilib_obstack, p, strlen (p));
5519 obstack_1grow (&multilib_obstack, 0);
5520 multilib_select = obstack_finish (&multilib_obstack);
5522 q = multilib_matches_raw;
5523 while ((p = *q++) != (char *) 0)
5524 obstack_grow (&multilib_obstack, p, strlen (p));
5526 obstack_1grow (&multilib_obstack, 0);
5527 multilib_matches = obstack_finish (&multilib_obstack);
5529 q = multilib_exclusions_raw;
5530 while ((p = *q++) != (char *) 0)
5531 obstack_grow (&multilib_obstack, p, strlen (p));
5533 obstack_1grow (&multilib_obstack, 0);
5534 multilib_exclusions = obstack_finish (&multilib_obstack);
5536 need_space = FALSE;
5537 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
5539 if (need_space)
5540 obstack_1grow (&multilib_obstack, ' ');
5541 obstack_grow (&multilib_obstack,
5542 multilib_defaults_raw[i],
5543 strlen (multilib_defaults_raw[i]));
5544 need_space = TRUE;
5547 obstack_1grow (&multilib_obstack, 0);
5548 multilib_defaults = obstack_finish (&multilib_obstack);
5551 /* Set up to remember the pathname of gcc and any options
5552 needed for collect. We use argv[0] instead of programname because
5553 we need the complete pathname. */
5554 obstack_init (&collect_obstack);
5555 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
5556 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
5557 putenv (obstack_finish (&collect_obstack));
5559 #ifdef INIT_ENVIRONMENT
5560 /* Set up any other necessary machine specific environment variables. */
5561 putenv (INIT_ENVIRONMENT);
5562 #endif
5564 /* Make a table of what switches there are (switches, n_switches).
5565 Make a table of specified input files (infiles, n_infiles).
5566 Decode switches that are handled locally. */
5568 process_command (argc, argv);
5571 int first_time;
5573 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
5574 the compiler. */
5575 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
5576 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
5578 first_time = TRUE;
5579 for (i = 0; (int) i < n_switches; i++)
5581 const char *const *args;
5582 const char *p, *q;
5583 if (!first_time)
5584 obstack_grow (&collect_obstack, " ", 1);
5586 first_time = FALSE;
5587 obstack_grow (&collect_obstack, "'-", 2);
5588 q = switches[i].part1;
5589 while ((p = strchr (q, '\'')))
5591 obstack_grow (&collect_obstack, q, p - q);
5592 obstack_grow (&collect_obstack, "'\\''", 4);
5593 q = ++p;
5595 obstack_grow (&collect_obstack, q, strlen (q));
5596 obstack_grow (&collect_obstack, "'", 1);
5598 for (args = switches[i].args; args && *args; args++)
5600 obstack_grow (&collect_obstack, " '", 2);
5601 q = *args;
5602 while ((p = strchr (q, '\'')))
5604 obstack_grow (&collect_obstack, q, p - q);
5605 obstack_grow (&collect_obstack, "'\\''", 4);
5606 q = ++p;
5608 obstack_grow (&collect_obstack, q, strlen (q));
5609 obstack_grow (&collect_obstack, "'", 1);
5612 obstack_grow (&collect_obstack, "\0", 1);
5613 putenv (obstack_finish (&collect_obstack));
5616 /* Initialize the vector of specs to just the default.
5617 This means one element containing 0s, as a terminator. */
5619 compilers = (struct compiler *) xmalloc (sizeof default_compilers);
5620 memcpy ((char *) compilers, (char *) default_compilers,
5621 sizeof default_compilers);
5622 n_compilers = n_default_compilers;
5624 /* Read specs from a file if there is one. */
5626 machine_suffix = concat (spec_machine, dir_separator_str,
5627 spec_version, dir_separator_str, NULL);
5628 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
5630 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK);
5631 /* Read the specs file unless it is a default one. */
5632 if (specs_file != 0 && strcmp (specs_file, "specs"))
5633 read_specs (specs_file, TRUE);
5634 else
5635 init_spec ();
5637 /* We need to check standard_exec_prefix/just_machine_suffix/specs
5638 for any override of as, ld and libraries. */
5639 specs_file = (char *) alloca (strlen (standard_exec_prefix)
5640 + strlen (just_machine_suffix)
5641 + sizeof ("specs"));
5643 strcpy (specs_file, standard_exec_prefix);
5644 strcat (specs_file, just_machine_suffix);
5645 strcat (specs_file, "specs");
5646 if (access (specs_file, R_OK) == 0)
5647 read_specs (specs_file, TRUE);
5649 /* If not cross-compiling, look for startfiles in the standard places. */
5650 if (*cross_compile == '0')
5652 if (*md_exec_prefix)
5654 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
5655 PREFIX_PRIORITY_LAST, 0, NULL);
5656 add_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
5657 PREFIX_PRIORITY_LAST, 0, NULL);
5660 if (*md_startfile_prefix)
5661 add_prefix (&startfile_prefixes, md_startfile_prefix, "GCC",
5662 PREFIX_PRIORITY_LAST, 0, NULL);
5664 if (*md_startfile_prefix_1)
5665 add_prefix (&startfile_prefixes, md_startfile_prefix_1, "GCC",
5666 PREFIX_PRIORITY_LAST, 0, NULL);
5668 /* If standard_startfile_prefix is relative, base it on
5669 standard_exec_prefix. This lets us move the installed tree
5670 as a unit. If GCC_EXEC_PREFIX is defined, base
5671 standard_startfile_prefix on that as well. */
5672 if (IS_ABSOLUTE_PATHNAME (standard_startfile_prefix))
5673 add_prefix (&startfile_prefixes, standard_startfile_prefix, "BINUTILS",
5674 PREFIX_PRIORITY_LAST, 0, NULL);
5675 else
5677 if (gcc_exec_prefix)
5678 add_prefix (&startfile_prefixes,
5679 concat (gcc_exec_prefix, machine_suffix,
5680 standard_startfile_prefix, NULL),
5681 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
5682 add_prefix (&startfile_prefixes,
5683 concat (standard_exec_prefix,
5684 machine_suffix,
5685 standard_startfile_prefix, NULL),
5686 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
5689 add_prefix (&startfile_prefixes, standard_startfile_prefix_1,
5690 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5691 add_prefix (&startfile_prefixes, standard_startfile_prefix_2,
5692 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5693 #if 0 /* Can cause surprises, and one can use -B./ instead. */
5694 add_prefix (&startfile_prefixes, "./", NULL,
5695 PREFIX_PRIORITY_LAST, 1, NULL);
5696 #endif
5698 else
5700 if (!IS_ABSOLUTE_PATHNAME (standard_startfile_prefix)
5701 && gcc_exec_prefix)
5702 add_prefix (&startfile_prefixes,
5703 concat (gcc_exec_prefix, machine_suffix,
5704 standard_startfile_prefix, NULL),
5705 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5708 /* Process any user specified specs in the order given on the command
5709 line. */
5710 for (uptr = user_specs_head; uptr; uptr = uptr->next)
5712 char *filename = find_a_file (&startfile_prefixes, uptr->filename, R_OK);
5713 read_specs (filename ? filename : uptr->filename, FALSE);
5716 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
5717 if (gcc_exec_prefix)
5719 char *temp = (char *) xmalloc (strlen (gcc_exec_prefix)
5720 + strlen (spec_version)
5721 + strlen (spec_machine) + 3);
5722 strcpy (temp, gcc_exec_prefix);
5723 strcat (temp, spec_machine);
5724 strcat (temp, dir_separator_str);
5725 strcat (temp, spec_version);
5726 strcat (temp, dir_separator_str);
5727 gcc_exec_prefix = temp;
5730 /* Now we have the specs.
5731 Set the `valid' bits for switches that match anything in any spec. */
5733 validate_all_switches ();
5735 /* Now that we have the switches and the specs, set
5736 the subdirectory based on the options. */
5737 set_multilib_dir ();
5739 /* Warn about any switches that no pass was interested in. */
5741 for (i = 0; (int) i < n_switches; i++)
5742 if (! switches[i].validated)
5743 error ("unrecognized option `-%s'", switches[i].part1);
5745 /* Obey some of the options. */
5747 if (print_search_dirs)
5749 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
5750 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
5751 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
5752 return (0);
5755 if (print_file_name)
5757 printf ("%s\n", find_file (print_file_name));
5758 return (0);
5761 if (print_prog_name)
5763 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK);
5764 printf ("%s\n", (newname ? newname : print_prog_name));
5765 return (0);
5768 if (print_multi_lib)
5770 print_multilib_info ();
5771 return (0);
5774 if (print_multi_directory)
5776 if (multilib_dir == NULL)
5777 printf (".\n");
5778 else
5779 printf ("%s\n", multilib_dir);
5780 return (0);
5783 if (target_help_flag)
5785 /* Print if any target specific options.*/
5787 /* We do not exit here. Instead we have created a fake input file
5788 called 'target-dummy' which needs to be compiled, and we pass this
5789 on to the various sub-processes, along with the --target-help
5790 switch. */
5793 if (print_help_list)
5795 display_help ();
5797 if (! verbose_flag)
5799 printf (_("\nFor bug reporting instructions, please see:\n"));
5800 printf ("%s.\n", GCCBUGURL);
5802 return (0);
5805 /* We do not exit here. Instead we have created a fake input file
5806 called 'help-dummy' which needs to be compiled, and we pass this
5807 on the the various sub-processes, along with the --help switch. */
5810 if (verbose_flag)
5812 int n;
5813 const char *thrmod;
5815 notice ("Configured with: %s\n", configuration_arguments);
5817 #ifdef THREAD_MODEL_SPEC
5818 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
5819 but there's no point in doing all this processing just to get
5820 thread_model back. */
5821 obstack_init (&obstack);
5822 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
5823 obstack_1grow (&obstack, '\0');
5824 thrmod = obstack_finish (&obstack);
5825 #else
5826 thrmod = thread_model;
5827 #endif
5829 notice ("Thread model: %s\n", thrmod);
5831 /* compiler_version is truncated at the first space when initialized
5832 from version string, so truncate version_string at the first space
5833 before comparing. */
5834 for (n = 0; version_string[n]; n++)
5835 if (version_string[n] == ' ')
5836 break;
5838 if (! strncmp (version_string, compiler_version, n)
5839 && compiler_version[n] == 0)
5840 notice ("gcc version %s\n", version_string);
5841 else
5842 notice ("gcc driver version %s executing gcc version %s\n",
5843 version_string, compiler_version);
5845 if (n_infiles == 0)
5846 return (0);
5849 if (n_infiles == added_libraries)
5850 fatal ("No input files");
5852 /* Make a place to record the compiler output file names
5853 that correspond to the input files. */
5855 i = n_infiles;
5856 i += lang_specific_extra_outfiles;
5857 outfiles = (const char **) xcalloc (i, sizeof (char *));
5859 /* Record which files were specified explicitly as link input. */
5861 explicit_link_files = xcalloc (1, n_infiles);
5863 for (i = 0; (int) i < n_infiles; i++)
5865 int this_file_error = 0;
5867 /* Tell do_spec what to substitute for %i. */
5869 input_file_number = i;
5870 set_input (infiles[i].name);
5872 /* Use the same thing in %o, unless cp->spec says otherwise. */
5874 outfiles[i] = input_filename;
5876 /* Figure out which compiler from the file's suffix. */
5878 input_file_compiler
5879 = lookup_compiler (infiles[i].name, input_filename_length,
5880 infiles[i].language);
5882 if (input_file_compiler)
5884 /* Ok, we found an applicable compiler. Run its spec. */
5886 if (input_file_compiler->spec[0] == '#')
5887 error ("%s: %s compiler not installed on this system",
5888 input_filename, &input_file_compiler->spec[1]);
5889 value = do_spec (input_file_compiler->spec);
5890 if (value < 0)
5891 this_file_error = 1;
5894 /* If this file's name does not contain a recognized suffix,
5895 record it as explicit linker input. */
5897 else
5898 explicit_link_files[i] = 1;
5900 /* Clear the delete-on-failure queue, deleting the files in it
5901 if this compilation failed. */
5903 if (this_file_error)
5905 delete_failure_queue ();
5906 error_count++;
5908 /* If this compilation succeeded, don't delete those files later. */
5909 clear_failure_queue ();
5912 /* Reset the output file name to the first input file name, for use
5913 with %b in LINK_SPEC on a target that prefers not to emit a.out
5914 by default. */
5915 if (n_infiles > 0)
5916 set_input (infiles[0].name);
5918 if (error_count == 0)
5920 /* Make sure INPUT_FILE_NUMBER points to first available open
5921 slot. */
5922 input_file_number = n_infiles;
5923 if (lang_specific_pre_link ())
5924 error_count++;
5927 /* Run ld to link all the compiler output files. */
5929 if (error_count == 0)
5931 int tmp = execution_count;
5933 /* We'll use ld if we can't find collect2. */
5934 if (! strcmp (linker_name_spec, "collect2"))
5936 char *s = find_a_file (&exec_prefixes, "collect2", X_OK);
5937 if (s == NULL)
5938 linker_name_spec = "ld";
5940 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
5941 for collect. */
5942 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
5943 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
5945 value = do_spec (link_command_spec);
5946 if (value < 0)
5947 error_count = 1;
5948 linker_was_run = (tmp != execution_count);
5951 /* If options said don't run linker,
5952 complain about input files to be given to the linker. */
5954 if (! linker_was_run && error_count == 0)
5955 for (i = 0; (int) i < n_infiles; i++)
5956 if (explicit_link_files[i])
5957 error ("%s: linker input file unused because linking not done",
5958 outfiles[i]);
5960 /* Delete some or all of the temporary files we made. */
5962 if (error_count)
5963 delete_failure_queue ();
5964 delete_temp_files ();
5966 if (print_help_list)
5968 printf (("\nFor bug reporting instructions, please see:\n"));
5969 printf ("%s\n", GCCBUGURL);
5972 return (signal_count != 0 ? 2
5973 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
5974 : 0);
5977 /* Find the proper compilation spec for the file name NAME,
5978 whose length is LENGTH. LANGUAGE is the specified language,
5979 or 0 if this file is to be passed to the linker. */
5981 static struct compiler *
5982 lookup_compiler (name, length, language)
5983 const char *name;
5984 size_t length;
5985 const char *language;
5987 struct compiler *cp;
5989 /* If this was specified by the user to be a linker input, indicate that. */
5990 if (language != 0 && language[0] == '*')
5991 return 0;
5993 /* Otherwise, look for the language, if one is spec'd. */
5994 if (language != 0)
5996 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
5997 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
5998 return cp;
6000 error ("language %s not recognized", language);
6001 return 0;
6004 /* Look for a suffix. */
6005 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6007 if (/* The suffix `-' matches only the file name `-'. */
6008 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6009 || (strlen (cp->suffix) < length
6010 /* See if the suffix matches the end of NAME. */
6011 && !strcmp (cp->suffix,
6012 name + length - strlen (cp->suffix))
6014 break;
6017 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6018 /* look again, but case-insensitively this time. */
6019 if (cp < compilers)
6020 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6022 if (/* The suffix `-' matches only the file name `-'. */
6023 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6024 || (strlen (cp->suffix) < length
6025 /* See if the suffix matches the end of NAME. */
6026 && ((!strcmp (cp->suffix,
6027 name + length - strlen (cp->suffix))
6028 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6029 && !strcasecmp (cp->suffix,
6030 name + length - strlen (cp->suffix)))
6032 break;
6034 #endif
6036 if (cp >= compilers)
6038 if (cp->spec[0] != '@')
6039 /* A non-alias entry: return it. */
6040 return cp;
6042 /* An alias entry maps a suffix to a language.
6043 Search for the language; pass 0 for NAME and LENGTH
6044 to avoid infinite recursion if language not found. */
6045 return lookup_compiler (NULL, 0, cp->spec + 1);
6047 return 0;
6050 static char *
6051 save_string (s, len)
6052 const char *s;
6053 int len;
6055 register char *result = xmalloc (len + 1);
6057 memcpy (result, s, len);
6058 result[len] = 0;
6059 return result;
6062 void
6063 pfatal_with_name (name)
6064 const char *name;
6066 perror_with_name (name);
6067 delete_temp_files ();
6068 exit (1);
6071 static void
6072 perror_with_name (name)
6073 const char *name;
6075 error ("%s: %s", name, xstrerror (errno));
6078 static void
6079 pfatal_pexecute (errmsg_fmt, errmsg_arg)
6080 const char *errmsg_fmt;
6081 const char *errmsg_arg;
6083 if (errmsg_arg)
6085 int save_errno = errno;
6087 /* Space for trailing '\0' is in %s. */
6088 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6089 sprintf (msg, errmsg_fmt, errmsg_arg);
6090 errmsg_fmt = msg;
6092 errno = save_errno;
6095 pfatal_with_name (errmsg_fmt);
6098 /* Output an error message and exit */
6100 void
6101 fancy_abort ()
6103 fatal ("Internal gcc abort.");
6106 /* Output an error message and exit */
6108 void
6109 fatal VPARAMS ((const char *msgid, ...))
6111 #ifndef ANSI_PROTOTYPES
6112 const char *msgid;
6113 #endif
6114 va_list ap;
6116 VA_START (ap, msgid);
6118 #ifndef ANSI_PROTOTYPES
6119 msgid = va_arg (ap, const char *);
6120 #endif
6122 fprintf (stderr, "%s: ", programname);
6123 vfprintf (stderr, _(msgid), ap);
6124 va_end (ap);
6125 fprintf (stderr, "\n");
6126 delete_temp_files ();
6127 exit (1);
6130 void
6131 error VPARAMS ((const char *msgid, ...))
6133 #ifndef ANSI_PROTOTYPES
6134 const char *msgid;
6135 #endif
6136 va_list ap;
6138 VA_START (ap, msgid);
6140 #ifndef ANSI_PROTOTYPES
6141 msgid = va_arg (ap, const char *);
6142 #endif
6144 fprintf (stderr, "%s: ", programname);
6145 vfprintf (stderr, _(msgid), ap);
6146 va_end (ap);
6148 fprintf (stderr, "\n");
6151 static void
6152 notice VPARAMS ((const char *msgid, ...))
6154 #ifndef ANSI_PROTOTYPES
6155 const char *msgid;
6156 #endif
6157 va_list ap;
6159 VA_START (ap, msgid);
6161 #ifndef ANSI_PROTOTYPES
6162 msgid = va_arg (ap, const char *);
6163 #endif
6165 vfprintf (stderr, _(msgid), ap);
6166 va_end (ap);
6169 static void
6170 validate_all_switches ()
6172 struct compiler *comp;
6173 register const char *p;
6174 register char c;
6175 struct spec_list *spec;
6177 for (comp = compilers; comp->spec; comp++)
6179 p = comp->spec;
6180 while ((c = *p++))
6181 if (c == '%' && *p == '{')
6182 /* We have a switch spec. */
6183 validate_switches (p + 1);
6186 /* Look through the linked list of specs read from the specs file. */
6187 for (spec = specs; spec; spec = spec->next)
6189 p = *(spec->ptr_spec);
6190 while ((c = *p++))
6191 if (c == '%' && *p == '{')
6192 /* We have a switch spec. */
6193 validate_switches (p + 1);
6196 p = link_command_spec;
6197 while ((c = *p++))
6198 if (c == '%' && *p == '{')
6199 /* We have a switch spec. */
6200 validate_switches (p + 1);
6203 /* Look at the switch-name that comes after START
6204 and mark as valid all supplied switches that match it. */
6206 static void
6207 validate_switches (start)
6208 const char *start;
6210 register const char *p = start;
6211 const char *filter;
6212 register int i;
6213 int suffix;
6215 if (*p == '|')
6216 ++p;
6218 next_member:
6219 if (*p == '!')
6220 ++p;
6222 suffix = 0;
6223 if (*p == '.')
6224 suffix = 1, ++p;
6226 filter = p;
6227 while (*p != ':' && *p != '}' && *p != '|' && *p != '&')
6228 p++;
6230 if (suffix)
6232 else if (p[-1] == '*')
6234 /* Mark all matching switches as valid. */
6235 for (i = 0; i < n_switches; i++)
6236 if (!strncmp (switches[i].part1, filter, p - filter - 1))
6237 switches[i].validated = 1;
6239 else
6241 /* Mark an exact matching switch as valid. */
6242 for (i = 0; i < n_switches; i++)
6244 if (!strncmp (switches[i].part1, filter, p - filter)
6245 && switches[i].part1[p - filter] == 0)
6246 switches[i].validated = 1;
6250 if (*p++ == '|' || p[-1] == '&')
6251 goto next_member;
6254 /* Check whether a particular argument was used. The first time we
6255 canonicalize the switches to keep only the ones we care about. */
6257 static int
6258 used_arg (p, len)
6259 const char *p;
6260 int len;
6262 struct mswitchstr
6264 const char *str;
6265 const char *replace;
6266 int len;
6267 int rep_len;
6270 static struct mswitchstr *mswitches;
6271 static int n_mswitches;
6272 int i, j;
6274 if (!mswitches)
6276 struct mswitchstr *matches;
6277 const char *q;
6278 int cnt = 0;
6280 /* Break multilib_matches into the component strings of string
6281 and replacement string. */
6282 for (q = multilib_matches; *q != '\0'; q++)
6283 if (*q == ';')
6284 cnt++;
6286 matches =
6287 (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
6288 i = 0;
6289 q = multilib_matches;
6290 while (*q != '\0')
6292 matches[i].str = q;
6293 while (*q != ' ')
6295 if (*q == '\0')
6296 abort ();
6297 q++;
6299 matches[i].len = q - matches[i].str;
6301 matches[i].replace = ++q;
6302 while (*q != ';' && *q != '\0')
6304 if (*q == ' ')
6305 abort ();
6306 q++;
6308 matches[i].rep_len = q - matches[i].replace;
6309 i++;
6310 if (*q == ';')
6311 q++;
6314 /* Now build a list of the replacement string for switches that we care
6315 about. Make sure we allocate at least one entry. This prevents
6316 xmalloc from calling fatal, and prevents us from re-executing this
6317 block of code. */
6318 mswitches
6319 = (struct mswitchstr *) xmalloc ((sizeof (struct mswitchstr))
6320 * (n_switches ? n_switches : 1));
6321 for (i = 0; i < n_switches; i++)
6323 int xlen = strlen (switches[i].part1);
6324 for (j = 0; j < cnt; j++)
6325 if (xlen == matches[j].len
6326 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6328 mswitches[n_mswitches].str = matches[j].replace;
6329 mswitches[n_mswitches].len = matches[j].rep_len;
6330 mswitches[n_mswitches].replace = (char *) 0;
6331 mswitches[n_mswitches].rep_len = 0;
6332 n_mswitches++;
6333 break;
6338 for (i = 0; i < n_mswitches; i++)
6339 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
6340 return 1;
6342 return 0;
6345 static int
6346 default_arg (p, len)
6347 const char *p;
6348 int len;
6350 const char *start, *end;
6352 for (start = multilib_defaults; *start != '\0'; start = end + 1)
6354 while (*start == ' ' || *start == '\t')
6355 start++;
6357 if (*start == '\0')
6358 break;
6360 for (end = start + 1; *end != ' ' && *end != '\t' && *end != '\0'; end++)
6363 if ((end - start) == len && strncmp (p, start, len) == 0)
6364 return 1;
6366 if (*end == '\0')
6367 break;
6370 return 0;
6373 /* Work out the subdirectory to use based on the options. The format of
6374 multilib_select is a list of elements. Each element is a subdirectory
6375 name followed by a list of options followed by a semicolon. The format
6376 of multilib_exclusions is the same, but without the preceding
6377 directory. First gcc will check the exclusions, if none of the options
6378 beginning with an exclamation point are present, and all of the other
6379 options are present, then we will ignore this completely. Passing
6380 that, gcc will consider each multilib_select in turn using the same
6381 rules for matching the options. If a match is found, that subdirectory
6382 will be used. */
6384 static void
6385 set_multilib_dir ()
6387 const char *p;
6388 unsigned int this_path_len;
6389 const char *this_path, *this_arg;
6390 int not_arg;
6391 int ok;
6393 p = multilib_exclusions;
6394 while (*p != '\0')
6396 /* Ignore newlines. */
6397 if (*p == '\n')
6399 ++p;
6400 continue;
6403 /* Check the arguments. */
6404 ok = 1;
6405 while (*p != ';')
6407 if (*p == '\0')
6408 abort ();
6410 if (! ok)
6412 ++p;
6413 continue;
6416 this_arg = p;
6417 while (*p != ' ' && *p != ';')
6419 if (*p == '\0')
6420 abort ();
6421 ++p;
6424 if (*this_arg != '!')
6425 not_arg = 0;
6426 else
6428 not_arg = 1;
6429 ++this_arg;
6432 ok = used_arg (this_arg, p - this_arg);
6433 if (not_arg)
6434 ok = ! ok;
6436 if (*p == ' ')
6437 ++p;
6440 if (ok)
6441 return;
6443 ++p;
6446 p = multilib_select;
6447 while (*p != '\0')
6449 /* Ignore newlines. */
6450 if (*p == '\n')
6452 ++p;
6453 continue;
6456 /* Get the initial path. */
6457 this_path = p;
6458 while (*p != ' ')
6460 if (*p == '\0')
6461 abort ();
6462 ++p;
6464 this_path_len = p - this_path;
6466 /* Check the arguments. */
6467 ok = 1;
6468 ++p;
6469 while (*p != ';')
6471 if (*p == '\0')
6472 abort ();
6474 if (! ok)
6476 ++p;
6477 continue;
6480 this_arg = p;
6481 while (*p != ' ' && *p != ';')
6483 if (*p == '\0')
6484 abort ();
6485 ++p;
6488 if (*this_arg != '!')
6489 not_arg = 0;
6490 else
6492 not_arg = 1;
6493 ++this_arg;
6496 /* If this is a default argument, we can just ignore it.
6497 This is true even if this_arg begins with '!'. Beginning
6498 with '!' does not mean that this argument is necessarily
6499 inappropriate for this library: it merely means that
6500 there is a more specific library which uses this
6501 argument. If this argument is a default, we need not
6502 consider that more specific library. */
6503 if (! default_arg (this_arg, p - this_arg))
6505 ok = used_arg (this_arg, p - this_arg);
6506 if (not_arg)
6507 ok = ! ok;
6510 if (*p == ' ')
6511 ++p;
6514 if (ok)
6516 if (this_path_len != 1
6517 || this_path[0] != '.')
6519 char *new_multilib_dir = xmalloc (this_path_len + 1);
6520 strncpy (new_multilib_dir, this_path, this_path_len);
6521 new_multilib_dir[this_path_len] = '\0';
6522 multilib_dir = new_multilib_dir;
6524 break;
6527 ++p;
6531 /* Print out the multiple library subdirectory selection
6532 information. This prints out a series of lines. Each line looks
6533 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
6534 required. Only the desired options are printed out, the negative
6535 matches. The options are print without a leading dash. There are
6536 no spaces to make it easy to use the information in the shell.
6537 Each subdirectory is printed only once. This assumes the ordering
6538 generated by the genmultilib script. Also, we leave out ones that match
6539 the exclusions. */
6541 static void
6542 print_multilib_info ()
6544 const char *p = multilib_select;
6545 const char *last_path = 0, *this_path;
6546 int skip;
6547 unsigned int last_path_len = 0;
6549 while (*p != '\0')
6551 skip = 0;
6552 /* Ignore newlines. */
6553 if (*p == '\n')
6555 ++p;
6556 continue;
6559 /* Get the initial path. */
6560 this_path = p;
6561 while (*p != ' ')
6563 if (*p == '\0')
6564 abort ();
6565 ++p;
6568 /* Check for matches with the multilib_exclusions. We don't bother
6569 with the '!' in either list. If any of the exclusion rules match
6570 all of its options with the select rule, we skip it. */
6572 const char *e = multilib_exclusions;
6573 const char *this_arg;
6575 while (*e != '\0')
6577 int m = 1;
6578 /* Ignore newlines. */
6579 if (*e == '\n')
6581 ++e;
6582 continue;
6585 /* Check the arguments. */
6586 while (*e != ';')
6588 const char *q;
6589 int mp = 0;
6591 if (*e == '\0')
6592 abort ();
6594 if (! m)
6596 ++e;
6597 continue;
6600 this_arg = e;
6602 while (*e != ' ' && *e != ';')
6604 if (*e == '\0')
6605 abort ();
6606 ++e;
6609 q = p + 1;
6610 while (*q != ';')
6612 const char *arg;
6613 int len = e - this_arg;
6615 if (*q == '\0')
6616 abort ();
6618 arg = q;
6620 while (*q != ' ' && *q != ';')
6622 if (*q == '\0')
6623 abort ();
6624 ++q;
6627 if (! strncmp (arg, this_arg, (len < q - arg) ? q - arg : len) ||
6628 default_arg (this_arg, e - this_arg))
6630 mp = 1;
6631 break;
6634 if (*q == ' ')
6635 ++q;
6638 if (! mp)
6639 m = 0;
6641 if (*e == ' ')
6642 ++e;
6645 if (m)
6647 skip = 1;
6648 break;
6651 if (*e != '\0')
6652 ++e;
6656 if (! skip)
6658 /* If this is a duplicate, skip it. */
6659 skip = (last_path != 0 && (unsigned int) (p - this_path) == last_path_len
6660 && ! strncmp (last_path, this_path, last_path_len));
6662 last_path = this_path;
6663 last_path_len = p - this_path;
6666 /* If this directory requires any default arguments, we can skip
6667 it. We will already have printed a directory identical to
6668 this one which does not require that default argument. */
6669 if (! skip)
6671 const char *q;
6673 q = p + 1;
6674 while (*q != ';')
6676 const char *arg;
6678 if (*q == '\0')
6679 abort ();
6681 if (*q == '!')
6682 arg = NULL;
6683 else
6684 arg = q;
6686 while (*q != ' ' && *q != ';')
6688 if (*q == '\0')
6689 abort ();
6690 ++q;
6693 if (arg != NULL
6694 && default_arg (arg, q - arg))
6696 skip = 1;
6697 break;
6700 if (*q == ' ')
6701 ++q;
6705 if (! skip)
6707 const char *p1;
6709 for (p1 = last_path; p1 < p; p1++)
6710 putchar (*p1);
6711 putchar (';');
6714 ++p;
6715 while (*p != ';')
6717 int use_arg;
6719 if (*p == '\0')
6720 abort ();
6722 if (skip)
6724 ++p;
6725 continue;
6728 use_arg = *p != '!';
6730 if (use_arg)
6731 putchar ('@');
6733 while (*p != ' ' && *p != ';')
6735 if (*p == '\0')
6736 abort ();
6737 if (use_arg)
6738 putchar (*p);
6739 ++p;
6742 if (*p == ' ')
6743 ++p;
6746 if (! skip)
6748 /* If there are extra options, print them now. */
6749 if (multilib_extra && *multilib_extra)
6751 int print_at = TRUE;
6752 const char *q;
6754 for (q = multilib_extra; *q != '\0'; q++)
6756 if (*q == ' ')
6757 print_at = TRUE;
6758 else
6760 if (print_at)
6761 putchar ('@');
6762 putchar (*q);
6763 print_at = FALSE;
6768 putchar ('\n');
6771 ++p;