2002-02-19 Philip Blundell <philb@gnu.org>
[official-gcc.git] / gcc / gcc.c
blobae4bc6379be2f63d88f33cc0583fbb5dbcdd42b6
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA.
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!! */
25 /* This program is the user interface to the C compiler and possibly to
26 other compilers. It is used because compilation is a complicated procedure
27 which involves running several programs and passing temporary files between
28 them, forwarding the users switches to those programs selectively,
29 and deleting the temporary files at the end.
31 CC recognizes how to compile each input file by suffixes in the file names.
32 Once it knows which kind of compilation to perform, the procedure for
33 compilation is specified by a string called a "spec". */
35 /* A Short Introduction to Adding a Command-Line Option.
37 Before adding a command-line option, consider if it is really
38 necessary. Each additional command-line option adds complexity and
39 is difficult to remove in subsequent versions.
41 In the following, consider adding the command-line argument
42 `--bar'.
44 1. Each command-line option is specified in the specs file. The
45 notation is described below in the comment entitled "The Specs
46 Language". Read it.
48 2. In this file, add an entry to "option_map" equating the long
49 `--' argument version and any shorter, single letter version. Read
50 the comments in the declaration of "struct option_map" for an
51 explanation. Do not omit the first `-'.
53 3. Look in the "specs" file to determine which program or option
54 list should be given the argument, e.g., "cc1_options". Add the
55 appropriate syntax for the shorter option version to the
56 corresponding "const char *" entry in this file. Omit the first
57 `-' from the option. For example, use `-bar', rather than `--bar'.
59 4. If the argument takes an argument, e.g., `--baz argument1',
60 modify either DEFAULT_SWITCH_TAKES_ARG or
61 DEFAULT_WORD_SWITCH_TAKES_ARG in this file. Omit the first `-'
62 from `--baz'.
64 5. Document the option in this file's display_help(). If the
65 option is passed to a subprogram, modify its corresponding
66 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
67 instead.
69 6. Compile and test. Make sure that your new specs file is being
70 read. For example, use a debugger to investigate the value of
71 "specs_file" in main(). */
73 #include "config.h"
74 #include "system.h"
75 #include <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"
83 #include "flags.h"
85 #ifdef HAVE_SYS_RESOURCE_H
86 #include <sys/resource.h>
87 #endif
88 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
89 extern int getrusage PARAMS ((int, struct rusage *));
90 #endif
92 /* By default there is no special suffix for target executables. */
93 /* FIXME: when autoconf is fixed, remove the host check - dj */
94 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
95 #define HAVE_TARGET_EXECUTABLE_SUFFIX
96 #else
97 #undef TARGET_EXECUTABLE_SUFFIX
98 #define TARGET_EXECUTABLE_SUFFIX ""
99 #endif
101 /* By default there is no special suffix for host executables. */
102 #ifdef HOST_EXECUTABLE_SUFFIX
103 #define HAVE_HOST_EXECUTABLE_SUFFIX
104 #else
105 #define HOST_EXECUTABLE_SUFFIX ""
106 #endif
108 /* By default, the suffix for target object files is ".o". */
109 #ifdef TARGET_OBJECT_SUFFIX
110 #define HAVE_TARGET_OBJECT_SUFFIX
111 #else
112 #define TARGET_OBJECT_SUFFIX ".o"
113 #endif
115 #ifndef VMS
116 /* FIXME: the location independence code for VMS is hairier than this,
117 and hasn't been written. */
118 #ifndef DIR_UP
119 #define DIR_UP ".."
120 #endif /* DIR_UP */
121 #endif /* VMS */
123 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
125 #define obstack_chunk_alloc xmalloc
126 #define obstack_chunk_free free
128 #ifndef GET_ENV_PATH_LIST
129 #define GET_ENV_PATH_LIST(VAR,NAME) do { (VAR) = getenv (NAME); } while (0)
130 #endif
132 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
133 #ifndef LIBRARY_PATH_ENV
134 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
135 #endif
137 #ifndef HAVE_KILL
138 #define kill(p,s) raise(s)
139 #endif
141 /* If a stage of compilation returns an exit status >= 1,
142 compilation of that file ceases. */
144 #define MIN_FATAL_STATUS 1
146 /* Flag set by cppspec.c to 1. */
147 int is_cpp_driver;
149 /* Flag saying to pass the greatest exit code returned by a sub-process
150 to the calling program. */
151 static int pass_exit_codes;
153 /* Definition of string containing the arguments given to configure. */
154 #include "configargs.h"
156 /* Flag saying to print the directories gcc will search through looking for
157 programs, libraries, etc. */
159 static int print_search_dirs;
161 /* Flag saying to print the full filename of this file
162 as found through our usual search mechanism. */
164 static const char *print_file_name = NULL;
166 /* As print_file_name, but search for executable file. */
168 static const char *print_prog_name = NULL;
170 /* Flag saying to print the relative path we'd use to
171 find libgcc.a given the current compiler flags. */
173 static int print_multi_directory;
175 /* Flag saying to print the list of subdirectories and
176 compiler flags used to select them in a standard form. */
178 static int print_multi_lib;
180 /* Flag saying to print the command line options understood by gcc and its
181 sub-processes. */
183 static int print_help_list;
185 /* Flag indicating whether we should print the command and arguments */
187 static int verbose_flag;
189 /* Flag indicating whether we should ONLY print the command and
190 arguments (like verbose_flag) without executing the command.
191 Displayed arguments are quoted so that the generated command
192 line is suitable for execution. This is intended for use in
193 shell scripts to capture the driver-generated command line. */
194 static int verbose_only_flag;
196 /* Flag indicating to print target specific command line options. */
198 static int target_help_flag;
200 /* Flag indicating whether we should report subprocess execution times
201 (if this is supported by the system - see pexecute.c). */
203 static int report_times;
205 /* Nonzero means write "temp" files in source directory
206 and use the source file's name in them, and don't delete them. */
208 static int save_temps_flag;
210 /* The compiler version. */
212 static const char *compiler_version;
214 /* The target version specified with -V */
216 static const char *spec_version = DEFAULT_TARGET_VERSION;
218 /* The target machine specified with -b. */
220 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
222 /* Nonzero if cross-compiling.
223 When -b is used, the value comes from the `specs' file. */
225 #ifdef CROSS_COMPILE
226 static const char *cross_compile = "1";
227 #else
228 static const char *cross_compile = "0";
229 #endif
231 #ifdef MODIFY_TARGET_NAME
233 /* Information on how to alter the target name based on a command-line
234 switch. The only case we support now is simply appending or deleting a
235 string to or from the end of the first part of the configuration name. */
237 static const struct modify_target
239 const char *const sw;
240 const enum add_del {ADD, DELETE} add_del;
241 const char *const str;
243 modify_target[] = MODIFY_TARGET_NAME;
244 #endif
246 /* The number of errors that have occurred; the link phase will not be
247 run if this is non-zero. */
248 static int error_count = 0;
250 /* Greatest exit code of sub-processes that has been encountered up to
251 now. */
252 static int greatest_status = 1;
254 /* This is the obstack which we use to allocate many strings. */
256 static struct obstack obstack;
258 /* This is the obstack to build an environment variable to pass to
259 collect2 that describes all of the relevant switches of what to
260 pass the compiler in building the list of pointers to constructors
261 and destructors. */
263 static struct obstack collect_obstack;
265 /* These structs are used to collect resource usage information for
266 subprocesses. */
267 #ifdef HAVE_GETRUSAGE
268 static struct rusage rus, prus;
269 #endif
271 /* Forward declaration for prototypes. */
272 struct path_prefix;
274 static void init_spec PARAMS ((void));
275 #ifndef VMS
276 static char **split_directories PARAMS ((const char *, int *));
277 static void free_split_directories PARAMS ((char **));
278 static char *make_relative_prefix PARAMS ((const char *, const char *, const char *));
279 #endif /* VMS */
280 static void store_arg PARAMS ((const char *, int, int));
281 static char *load_specs PARAMS ((const char *));
282 static void read_specs PARAMS ((const char *, int));
283 static void set_spec PARAMS ((const char *, const char *));
284 static struct compiler *lookup_compiler PARAMS ((const char *, size_t, const char *));
285 static char *build_search_list PARAMS ((struct path_prefix *, const char *, int));
286 static void putenv_from_prefixes PARAMS ((struct path_prefix *, const char *));
287 static int access_check PARAMS ((const char *, int));
288 static char *find_a_file PARAMS ((struct path_prefix *, const char *, int));
289 static void add_prefix PARAMS ((struct path_prefix *, const char *,
290 const char *, int, int, int *));
291 static void translate_options PARAMS ((int *, const char *const **));
292 static char *skip_whitespace PARAMS ((char *));
293 static void delete_if_ordinary PARAMS ((const char *));
294 static void delete_temp_files PARAMS ((void));
295 static void delete_failure_queue PARAMS ((void));
296 static void clear_failure_queue PARAMS ((void));
297 static int check_live_switch PARAMS ((int, int));
298 static const char *handle_braces PARAMS ((const char *));
299 static char *save_string PARAMS ((const char *, int));
300 static void set_collect_gcc_options PARAMS ((void));
301 static int do_spec_1 PARAMS ((const char *, int, const char *));
302 static const char *find_file PARAMS ((const char *));
303 static int is_directory PARAMS ((const char *, const char *, int));
304 static void validate_switches PARAMS ((const char *));
305 static void validate_all_switches PARAMS ((void));
306 static void give_switch PARAMS ((int, int, int));
307 static int used_arg PARAMS ((const char *, int));
308 static int default_arg PARAMS ((const char *, int));
309 static void set_multilib_dir PARAMS ((void));
310 static void print_multilib_info PARAMS ((void));
311 static void perror_with_name PARAMS ((const char *));
312 static void pfatal_pexecute PARAMS ((const char *, const char *))
313 ATTRIBUTE_NORETURN;
314 static void notice PARAMS ((const char *, ...))
315 ATTRIBUTE_PRINTF_1;
316 static void display_help PARAMS ((void));
317 static void add_preprocessor_option PARAMS ((const char *, int));
318 static void add_assembler_option PARAMS ((const char *, int));
319 static void add_linker_option PARAMS ((const char *, int));
320 static void process_command PARAMS ((int, const char *const *));
321 static int execute PARAMS ((void));
322 static void clear_args PARAMS ((void));
323 static void fatal_error PARAMS ((int));
324 #ifdef ENABLE_SHARED_LIBGCC
325 static void init_gcc_specs PARAMS ((struct obstack *,
326 const char *, const char *,
327 const char *));
328 #endif
329 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
330 static const char *convert_filename PARAMS ((const char *, int, int));
331 #endif
333 /* The Specs Language
335 Specs are strings containing lines, each of which (if not blank)
336 is made up of a program name, and arguments separated by spaces.
337 The program name must be exact and start from root, since no path
338 is searched and it is unreliable to depend on the current working directory.
339 Redirection of input or output is not supported; the subprograms must
340 accept filenames saying what files to read and write.
342 In addition, the specs can contain %-sequences to substitute variable text
343 or for conditional text. Here is a table of all defined %-sequences.
344 Note that spaces are not generated automatically around the results of
345 expanding these sequences; therefore, you can concatenate them together
346 or with constant text in a single argument.
348 %% substitute one % into the program name or argument.
349 %i substitute the name of the input file being processed.
350 %b substitute the basename of the input file being processed.
351 This is the substring up to (and not including) the last period
352 and not including the directory.
353 %B same as %b, but include the file suffix (text after the last period).
354 %gSUFFIX
355 substitute a file name that has suffix SUFFIX and is chosen
356 once per compilation, and mark the argument a la %d. To reduce
357 exposure to denial-of-service attacks, the file name is now
358 chosen in a way that is hard to predict even when previously
359 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
360 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
361 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
362 had been pre-processed. Previously, %g was simply substituted
363 with a file name chosen once per compilation, without regard
364 to any appended suffix (which was therefore treated just like
365 ordinary text), making such attacks more likely to succeed.
366 %uSUFFIX
367 like %g, but generates a new temporary file name even if %uSUFFIX
368 was already seen.
369 %USUFFIX
370 substitutes the last file name generated with %uSUFFIX, generating a
371 new one if there is no such last file name. In the absence of any
372 %uSUFFIX, this is just like %gSUFFIX, except they don't share
373 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
374 would involve the generation of two distinct file names, one
375 for each `%g.s' and another for each `%U.s'. Previously, %U was
376 simply substituted with a file name chosen for the previous %u,
377 without regard to any appended suffix.
378 %jSUFFIX
379 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
380 writable, and if save-temps is off; otherwise, substitute the name
381 of a temporary file, just like %u. This temporary file is not
382 meant for communication between processes, but rather as a junk
383 disposal mechanism.
384 %.SUFFIX
385 substitutes .SUFFIX for the suffixes of a matched switch's args when
386 it is subsequently output with %*. SUFFIX is terminated by the next
387 space or %.
388 %d marks the argument containing or following the %d as a
389 temporary file name, so that that file will be deleted if CC exits
390 successfully. Unlike %g, this contributes no text to the argument.
391 %w marks the argument containing or following the %w as the
392 "output file" of this compilation. This puts the argument
393 into the sequence of arguments that %o will substitute later.
394 %W{...}
395 like %{...} but mark last argument supplied within
396 as a file to be deleted on failure.
397 %o substitutes the names of all the output files, with spaces
398 automatically placed around them. You should write spaces
399 around the %o as well or the results are undefined.
400 %o is for use in the specs for running the linker.
401 Input files whose names have no recognized suffix are not compiled
402 at all, but they are included among the output files, so they will
403 be linked.
404 %O substitutes the suffix for object files. Note that this is
405 handled specially when it immediately follows %g, %u, or %U
406 (with or without a suffix argument) because of the need for
407 those to form complete file names. The handling is such that
408 %O is treated exactly as if it had already been substituted,
409 except that %g, %u, and %U do not currently support additional
410 SUFFIX characters following %O as they would following, for
411 example, `.o'.
412 %p substitutes the standard macro predefinitions for the
413 current target machine. Use this when running cpp.
414 %P like %p, but puts `__' before and after the name of each macro.
415 (Except macros that already have __.)
416 This is for ANSI C.
417 %I Substitute a -iprefix option made from GCC_EXEC_PREFIX.
418 %s current argument is the name of a library or startup file of some sort.
419 Search for that file in a standard list of directories
420 and substitute the full name found.
421 %eSTR Print STR as an error message. STR is terminated by a newline.
422 Use this when inconsistent options are detected.
423 %nSTR Print STR as an notice. STR is terminated by a newline.
424 %x{OPTION} Accumulate an option for %X.
425 %X Output the accumulated linker options specified by compilations.
426 %Y Output the accumulated assembler options specified by compilations.
427 %Z Output the accumulated preprocessor options specified by compilations.
428 %v1 Substitute the major version number of GCC.
429 (For version 2.5.3, this is 2.)
430 %v2 Substitute the minor version number of GCC.
431 (For version 2.5.3, this is 5.)
432 %v3 Substitute the patch level number of GCC.
433 (For version 2.5.3, this is 3.)
434 %a process ASM_SPEC as a spec.
435 This allows config.h to specify part of the spec for running as.
436 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
437 used here. This can be used to run a post-processor after the
438 assembler has done its job.
439 %D Dump out a -L option for each directory in startfile_prefixes.
440 If multilib_dir is set, extra entries are generated with it affixed.
441 %l process LINK_SPEC as a spec.
442 %L process LIB_SPEC as a spec.
443 %G process LIBGCC_SPEC as a spec.
444 %M output multilib_dir with directory separators replaced with "_";
445 if multilib_dir is not set or is ".", output "".
446 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
447 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
448 %C process CPP_SPEC as a spec.
449 %1 process CC1_SPEC as a spec.
450 %2 process CC1PLUS_SPEC as a spec.
451 %| output "-" if the input for the current command is coming from a pipe.
452 %* substitute the variable part of a matched option. (See below.)
453 Note that each comma in the substituted string is replaced by
454 a single space.
455 %{S} substitutes the -S switch, if that switch was given to CC.
456 If that switch was not specified, this substitutes nothing.
457 Here S is a metasyntactic variable.
458 %{S*} substitutes all the switches specified to CC whose names start
459 with -S. This is used for -o, -I, etc; switches that take
460 arguments. CC considers `-o foo' as being one switch whose
461 name starts with `o'. %{o*} would substitute this text,
462 including the space; thus, two arguments would be generated.
463 %{^S*} likewise, but don't put a blank between a switch and any args.
464 %{S*&T*} likewise, but preserve order of S and T options (the order
465 of S and T in the spec is not significant). Can be any number
466 of ampersand-separated variables; for each the wild card is
467 optional. Useful for CPP as %{D*&U*&A*}.
468 %{S*:X} substitutes X if one or more switches whose names start with -S are
469 specified to CC. Note that the tail part of the -S option
470 (i.e. the part matched by the `*') will be substituted for each
471 occurrence of %* within X.
472 %{<S} remove all occurrences of -S from the command line.
473 Note - this option is position dependent. % commands in the
474 spec string before this option will see -S, % commands in the
475 spec string after this option will not.
476 %{S:X} substitutes X, but only if the -S switch was given to CC.
477 %{!S:X} substitutes X, but only if the -S switch was NOT given to CC.
478 %{|S:X} like %{S:X}, but if no S switch, substitute `-'.
479 %{|!S:X} like %{!S:X}, but if there is an S switch, substitute `-'.
480 %{.S:X} substitutes X, but only if processing a file with suffix S.
481 %{!.S:X} substitutes X, but only if NOT processing a file with suffix S.
482 %{S|P:X} substitutes X if either -S or -P was given to CC. This may be
483 combined with ! and . as above binding stronger than the OR.
484 %(Spec) processes a specification defined in a specs file as *Spec:
485 %[Spec] as above, but put __ around -D arguments
487 The conditional text X in a %{S:X} or %{!S:X} construct may contain
488 other nested % constructs or spaces, or even newlines. They are
489 processed as usual, as described above.
491 The -O, -f, -m, and -W switches are handled specifically in these
492 constructs. If another value of -O or the negated form of a -f, -m, or
493 -W switch is found later in the command line, the earlier switch
494 value is ignored, except with {S*} where S is just one letter; this
495 passes all matching options.
497 The character | at the beginning of the predicate text is used to indicate
498 that a command should be piped to the following command, but only if -pipe
499 is specified.
501 Note that it is built into CC which switches take arguments and which
502 do not. You might think it would be useful to generalize this to
503 allow each compiler's spec to say which switches take arguments. But
504 this cannot be done in a consistent fashion. CC cannot even decide
505 which input files have been specified without knowing which switches
506 take arguments, and it must know which input files to compile in order
507 to tell which compilers to run.
509 CC also knows implicitly that arguments starting in `-l' are to be
510 treated as compiler output files, and passed to the linker in their
511 proper position among the other output files. */
513 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
515 /* config.h can define ASM_SPEC to provide extra args to the assembler
516 or extra switch-translations. */
517 #ifndef ASM_SPEC
518 #define ASM_SPEC ""
519 #endif
521 /* config.h can define ASM_FINAL_SPEC to run a post processor after
522 the assembler has run. */
523 #ifndef ASM_FINAL_SPEC
524 #define ASM_FINAL_SPEC ""
525 #endif
527 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
528 or extra switch-translations. */
529 #ifndef CPP_SPEC
530 #define CPP_SPEC ""
531 #endif
533 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
534 or extra switch-translations. */
535 #ifndef CC1_SPEC
536 #define CC1_SPEC ""
537 #endif
539 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
540 or extra switch-translations. */
541 #ifndef CC1PLUS_SPEC
542 #define CC1PLUS_SPEC ""
543 #endif
545 /* config.h can define LINK_SPEC to provide extra args to the linker
546 or extra switch-translations. */
547 #ifndef LINK_SPEC
548 #define LINK_SPEC ""
549 #endif
551 /* config.h can define LIB_SPEC to override the default libraries. */
552 #ifndef LIB_SPEC
553 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
554 #endif
556 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
557 included. */
558 #ifndef LIBGCC_SPEC
559 #if defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
560 /* Have gcc do the search for libgcc.a. */
561 #define LIBGCC_SPEC "libgcc.a%s"
562 #else
563 #define LIBGCC_SPEC "-lgcc"
564 #endif
565 #endif
567 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
568 #ifndef STARTFILE_SPEC
569 #define STARTFILE_SPEC \
570 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
571 #endif
573 /* config.h can define SWITCHES_NEED_SPACES to control which options
574 require spaces between the option and the argument. */
575 #ifndef SWITCHES_NEED_SPACES
576 #define SWITCHES_NEED_SPACES ""
577 #endif
579 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
580 #ifndef ENDFILE_SPEC
581 #define ENDFILE_SPEC ""
582 #endif
584 #ifndef LINKER_NAME
585 #define LINKER_NAME "collect2"
586 #endif
588 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
589 to the assembler. */
590 #ifndef ASM_DEBUG_SPEC
591 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
592 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
593 # define ASM_DEBUG_SPEC \
594 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
595 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
596 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
597 # else
598 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
599 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
600 # endif
601 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
602 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
603 # endif
604 # endif
605 #endif
606 #ifndef ASM_DEBUG_SPEC
607 # define ASM_DEBUG_SPEC ""
608 #endif
610 /* Here is the spec for running the linker, after compiling all files. */
612 /* -u* was put back because both BSD and SysV seem to support it. */
613 /* %{static:} simply prevents an error message if the target machine
614 doesn't handle -static. */
615 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
616 scripts which exist in user specified directories, or in standard
617 directories. */
618 #ifndef LINK_COMMAND_SPEC
619 #define LINK_COMMAND_SPEC "\
620 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
621 %(linker) %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r} %{s} %{t}\
622 %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
623 %{static:} %{L*} %(link_libgcc) %o %{!nostdlib:%{!nodefaultlibs:%G %L %G}}\
624 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
625 #endif
627 #ifndef LINK_LIBGCC_SPEC
628 # ifdef LINK_LIBGCC_SPECIAL
629 /* Don't generate -L options for startfile prefix list. */
630 # define LINK_LIBGCC_SPEC ""
631 # else
632 /* Do generate them. */
633 # define LINK_LIBGCC_SPEC "%D"
634 # endif
635 #endif
637 static const char *asm_debug = ASM_DEBUG_SPEC;
638 static const char *cpp_spec = CPP_SPEC;
639 static const char *cpp_predefines = CPP_PREDEFINES;
640 static const char *cc1_spec = CC1_SPEC;
641 static const char *cc1plus_spec = CC1PLUS_SPEC;
642 static const char *asm_spec = ASM_SPEC;
643 static const char *asm_final_spec = ASM_FINAL_SPEC;
644 static const char *link_spec = LINK_SPEC;
645 static const char *lib_spec = LIB_SPEC;
646 static const char *libgcc_spec = LIBGCC_SPEC;
647 static const char *endfile_spec = ENDFILE_SPEC;
648 static const char *startfile_spec = STARTFILE_SPEC;
649 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
650 static const char *linker_name_spec = LINKER_NAME;
651 static const char *link_command_spec = LINK_COMMAND_SPEC;
652 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
654 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
655 There should be no need to override these in target dependent files,
656 but we need to copy them to the specs file so that newer versions
657 of the GCC driver can correctly drive older tool chains with the
658 appropriate -B options. */
660 static const char *trad_capable_cpp =
661 "%{traditional|ftraditional|traditional-cpp:trad}cpp0";
663 static const char *cpp_unique_options =
664 "%{C:%{!E:%eGNU C does not support -C without using -E}}\
665 %{nostdinc*} %{C} %{v} %{I*} %{P} %{$} %I\
666 %{MD:-M -MF %W{!o: %b.d}%W{o*:%.d%*}}\
667 %{MMD:-MM -MF %W{!o: %b.d}%W{o*:%.d%*}}\
668 %{M} %{MM} %W{MF*} %{MG} %{MP} %{MQ*} %{MT*} %{!E:%{M|MD|MM|MMD:%{o*:-MQ %*}}}\
669 %{!no-gcc:-D__GNUC__=%v1 -D__GNUC_MINOR__=%v2 -D__GNUC_PATCHLEVEL__=%v3}\
670 %{!undef:%{!ansi:%{!std=*:%p}%{std=gnu*:%p}} %P} %{trigraphs}\
671 %{Os:-D__OPTIMIZE_SIZE__} %{O*:%{!O0:-D__OPTIMIZE__}}\
672 %{fno-inline|O0|!O*:-D__NO_INLINE__} %{ffast-math:-D__FAST_MATH__}\
673 %{fshort-wchar:-U__WCHAR_TYPE__ -D__WCHAR_TYPE__=short\\ unsigned\\ int}\
674 %{ffreestanding:-D__STDC_HOSTED__=0} %{fno-hosted:-D__STDC_HOSTED__=0}\
675 %{!ffreestanding:%{!fno-hosted:-D__STDC_HOSTED__=1}} %{remap}\
676 %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
677 %{E:%W{o*}}";
679 /* This contains cpp options which are common with cc1_options and are passed
680 only when preprocessing only to avoid duplication. */
681 static const char *cpp_options =
682 "%(cpp_unique_options) %{std*} %{d*} %{W*} %{w} %{pedantic*}\
683 %{fshow-column} %{fno-show-column}\
684 %{fsigned-char&funsigned-char}\
685 %{fleading-underscore} %{fno-leading-underscore}\
686 %{fno-operator-names} %{ftabstop=*}";
688 /* NB: This is shared amongst all front-ends. */
689 static const char *cc1_options =
690 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
691 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
692 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{std*} %{ansi}\
693 %{traditional} %{v:-version} %{pg:-p} %{p} %{f*}\
694 %{Qn:-fno-ident} %{--help:--help}\
695 %{--target-help:--target-help}\
696 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
697 %{fsyntax-only:-o %j} %{-param*}";
699 static const char *asm_options =
700 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
702 static const char *invoke_as =
703 "%{!S:-o %{|!pipe:%g.s} |\n as %(asm_options) %{!pipe:%g.s} %A }";
705 /* Some compilers have limits on line lengths, and the multilib_select
706 and/or multilib_matches strings can be very long, so we build them at
707 run time. */
708 static struct obstack multilib_obstack;
709 static const char *multilib_select;
710 static const char *multilib_matches;
711 static const char *multilib_defaults;
712 static const char *multilib_exclusions;
713 #include "multilib.h"
715 /* Check whether a particular argument is a default argument. */
717 #ifndef MULTILIB_DEFAULTS
718 #define MULTILIB_DEFAULTS { "" }
719 #endif
721 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
723 struct user_specs
725 struct user_specs *next;
726 const char *filename;
729 static struct user_specs *user_specs_head, *user_specs_tail;
731 /* This defines which switch letters take arguments. */
733 #define DEFAULT_SWITCH_TAKES_ARG(CHAR) \
734 ((CHAR) == 'D' || (CHAR) == 'U' || (CHAR) == 'o' \
735 || (CHAR) == 'e' || (CHAR) == 'T' || (CHAR) == 'u' \
736 || (CHAR) == 'I' || (CHAR) == 'm' || (CHAR) == 'x' \
737 || (CHAR) == 'L' || (CHAR) == 'A' || (CHAR) == 'V' \
738 || (CHAR) == 'B' || (CHAR) == 'b')
740 #ifndef SWITCH_TAKES_ARG
741 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
742 #endif
744 /* This defines which multi-letter switches take arguments. */
746 #define DEFAULT_WORD_SWITCH_TAKES_ARG(STR) \
747 (!strcmp (STR, "Tdata") || !strcmp (STR, "Ttext") \
748 || !strcmp (STR, "Tbss") || !strcmp (STR, "include") \
749 || !strcmp (STR, "imacros") || !strcmp (STR, "aux-info") \
750 || !strcmp (STR, "idirafter") || !strcmp (STR, "iprefix") \
751 || !strcmp (STR, "iwithprefix") || !strcmp (STR, "iwithprefixbefore") \
752 || !strcmp (STR, "isystem") || !strcmp (STR, "-param") \
753 || !strcmp (STR, "specs") \
754 || !strcmp (STR, "MF") || !strcmp (STR, "MT") || !strcmp (STR, "MQ"))
756 #ifndef WORD_SWITCH_TAKES_ARG
757 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
758 #endif
760 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
761 /* This defines which switches stop a full compilation. */
762 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
763 ((CHAR) == 'c' || (CHAR) == 'S')
765 #ifndef SWITCH_CURTAILS_COMPILATION
766 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
767 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
768 #endif
769 #endif
771 /* Record the mapping from file suffixes for compilation specs. */
773 struct compiler
775 const char *suffix; /* Use this compiler for input files
776 whose names end in this suffix. */
778 const char *spec; /* To use this compiler, run this spec. */
780 const char *cpp_spec; /* If non-NULL, substitute this spec
781 for `%C', rather than the usual
782 cpp_spec. */
785 /* Pointer to a vector of `struct compiler' that gives the spec for
786 compiling a file, based on its suffix.
787 A file that does not end in any of these suffixes will be passed
788 unchanged to the loader and nothing else will be done to it.
790 An entry containing two 0s is used to terminate the vector.
792 If multiple entries match a file, the last matching one is used. */
794 static struct compiler *compilers;
796 /* Number of entries in `compilers', not counting the null terminator. */
798 static int n_compilers;
800 /* The default list of file name suffixes and their compilation specs. */
802 static const struct compiler default_compilers[] =
804 /* Add lists of suffixes of known languages here. If those languages
805 were not present when we built the driver, we will hit these copies
806 and be given a more meaningful error than "file not used since
807 linking is not done". */
808 {".m", "#Objective-C", 0}, {".mi", "#Objective-C", 0},
809 {".cc", "#C++", 0}, {".cxx", "#C++", 0}, {".cpp", "#C++", 0},
810 {".cp", "#C++", 0}, {".c++", "#C++", 0}, {".C", "#C++", 0},
811 {".ii", "#C++", 0},
812 {".ads", "#Ada", 0}, {".adb", "#Ada", 0},
813 {".f", "#Fortran", 0}, {".for", "#Fortran", 0}, {".fpp", "#Fortran", 0},
814 {".F", "#Fortran", 0}, {".FOR", "#Fortran", 0}, {".FPP", "#Fortran", 0},
815 {".r", "#Ratfor", 0},
816 {".p", "#Pascal", 0}, {".pas", "#Pascal", 0},
817 {".ch", "#Chill", 0}, {".chi", "#Chill", 0},
818 {".java", "#Java", 0}, {".class", "#Java", 0},
819 {".zip", "#Java", 0}, {".jar", "#Java", 0},
820 /* Next come the entries for C. */
821 {".c", "@c", 0},
822 {"@c",
823 /* cc1 has an integrated ISO C preprocessor. We should invoke the
824 external preprocessor if -save-temps or -traditional is given. */
825 "%{E|M|MM:%(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)}\
826 %{!E:%{!M:%{!MM:\
827 %{save-temps:%(trad_capable_cpp) -lang-c %{ansi:-std=c89}\
828 %(cpp_options) %b.i \n\
829 cc1 -fpreprocessed %b.i %(cc1_options)}\
830 %{!save-temps:\
831 %{traditional|ftraditional|traditional-cpp:\
832 tradcpp0 -lang-c %{ansi:-std=c89} %(cpp_options) %{!pipe:%g.i} |\n\
833 cc1 -fpreprocessed %{!pipe:%g.i} %(cc1_options)}\
834 %{!traditional:%{!ftraditional:%{!traditional-cpp:\
835 cc1 -lang-c %{ansi:-std=c89} %(cpp_unique_options) %(cc1_options)}}}}\
836 %{!fsyntax-only:%(invoke_as)}}}}", 0},
837 {"-",
838 "%{!E:%e-E required when input is from standard input}\
839 %(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)", 0},
840 {".h", "@c-header", 0},
841 {"@c-header",
842 "%{!E:%ecompilation of header file requested} \
843 %(trad_capable_cpp) -lang-c %{ansi:-std=c89} %(cpp_options)", 0},
844 {".i", "@cpp-output", 0},
845 {"@cpp-output",
846 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0},
847 {".s", "@assembler", 0},
848 {"@assembler",
849 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0},
850 {".S", "@assembler-with-cpp", 0},
851 {"@assembler-with-cpp",
852 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
853 %{!M:%{!MM:%{!E:%{!S:-o %{|!pipe:%g.s} |\n\
854 as %(asm_debug) %(asm_options) %{!pipe:%g.s} %A }}}}", 0},
855 #include "specs.h"
856 /* Mark end of table */
857 {0, 0, 0}
860 /* Number of elements in default_compilers, not counting the terminator. */
862 static int n_default_compilers
863 = (sizeof default_compilers / sizeof (struct compiler)) - 1;
865 /* A vector of options to give to the linker.
866 These options are accumulated by %x,
867 and substituted into the linker command with %X. */
868 static int n_linker_options;
869 static char **linker_options;
871 /* A vector of options to give to the assembler.
872 These options are accumulated by -Wa,
873 and substituted into the assembler command with %Y. */
874 static int n_assembler_options;
875 static char **assembler_options;
877 /* A vector of options to give to the preprocessor.
878 These options are accumulated by -Wp,
879 and substituted into the preprocessor command with %Z. */
880 static int n_preprocessor_options;
881 static char **preprocessor_options;
883 /* Define how to map long options into short ones. */
885 /* This structure describes one mapping. */
886 struct option_map
888 /* The long option's name. */
889 const char *const name;
890 /* The equivalent short option. */
891 const char *const equivalent;
892 /* Argument info. A string of flag chars; NULL equals no options.
893 a => argument required.
894 o => argument optional.
895 j => join argument to equivalent, making one word.
896 * => require other text after NAME as an argument. */
897 const char *const arg_info;
900 /* This is the table of mappings. Mappings are tried sequentially
901 for each option encountered; the first one that matches, wins. */
903 static const struct option_map option_map[] =
905 {"--all-warnings", "-Wall", 0},
906 {"--ansi", "-ansi", 0},
907 {"--assemble", "-S", 0},
908 {"--assert", "-A", "a"},
909 {"--classpath", "-fclasspath=", "aj"},
910 {"--CLASSPATH", "-fCLASSPATH=", "aj"},
911 {"--comments", "-C", 0},
912 {"--compile", "-c", 0},
913 {"--debug", "-g", "oj"},
914 {"--define-macro", "-D", "aj"},
915 {"--dependencies", "-M", 0},
916 {"--dump", "-d", "a"},
917 {"--dumpbase", "-dumpbase", "a"},
918 {"--entry", "-e", 0},
919 {"--extra-warnings", "-W", 0},
920 {"--for-assembler", "-Wa", "a"},
921 {"--for-linker", "-Xlinker", "a"},
922 {"--force-link", "-u", "a"},
923 {"--imacros", "-imacros", "a"},
924 {"--include", "-include", "a"},
925 {"--include-barrier", "-I-", 0},
926 {"--include-directory", "-I", "aj"},
927 {"--include-directory-after", "-idirafter", "a"},
928 {"--include-prefix", "-iprefix", "a"},
929 {"--include-with-prefix", "-iwithprefix", "a"},
930 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
931 {"--include-with-prefix-after", "-iwithprefix", "a"},
932 {"--language", "-x", "a"},
933 {"--library-directory", "-L", "a"},
934 {"--machine", "-m", "aj"},
935 {"--machine-", "-m", "*j"},
936 {"--no-line-commands", "-P", 0},
937 {"--no-precompiled-includes", "-noprecomp", 0},
938 {"--no-standard-includes", "-nostdinc", 0},
939 {"--no-standard-libraries", "-nostdlib", 0},
940 {"--no-warnings", "-w", 0},
941 {"--optimize", "-O", "oj"},
942 {"--output", "-o", "a"},
943 {"--output-class-directory", "-foutput-class-dir=", "ja"},
944 {"--param", "--param", "a"},
945 {"--pedantic", "-pedantic", 0},
946 {"--pedantic-errors", "-pedantic-errors", 0},
947 {"--pipe", "-pipe", 0},
948 {"--prefix", "-B", "a"},
949 {"--preprocess", "-E", 0},
950 {"--print-search-dirs", "-print-search-dirs", 0},
951 {"--print-file-name", "-print-file-name=", "aj"},
952 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
953 {"--print-missing-file-dependencies", "-MG", 0},
954 {"--print-multi-lib", "-print-multi-lib", 0},
955 {"--print-multi-directory", "-print-multi-directory", 0},
956 {"--print-prog-name", "-print-prog-name=", "aj"},
957 {"--profile", "-p", 0},
958 {"--profile-blocks", "-a", 0},
959 {"--quiet", "-q", 0},
960 {"--save-temps", "-save-temps", 0},
961 {"--shared", "-shared", 0},
962 {"--silent", "-q", 0},
963 {"--specs", "-specs=", "aj"},
964 {"--static", "-static", 0},
965 {"--std", "-std=", "aj"},
966 {"--symbolic", "-symbolic", 0},
967 {"--target", "-b", "a"},
968 {"--time", "-time", 0},
969 {"--trace-includes", "-H", 0},
970 {"--traditional", "-traditional", 0},
971 {"--traditional-cpp", "-traditional-cpp", 0},
972 {"--trigraphs", "-trigraphs", 0},
973 {"--undefine-macro", "-U", "aj"},
974 {"--use-version", "-V", "a"},
975 {"--user-dependencies", "-MM", 0},
976 {"--verbose", "-v", 0},
977 {"--warn-", "-W", "*j"},
978 {"--write-dependencies", "-MD", 0},
979 {"--write-user-dependencies", "-MMD", 0},
980 {"--", "-f", "*j"}
984 #ifdef TARGET_OPTION_TRANSLATE_TABLE
985 static const struct {
986 const char *const option_found;
987 const char *const replacements;
988 } target_option_translations[] =
990 TARGET_OPTION_TRANSLATE_TABLE,
991 { 0, 0 }
993 #endif
995 /* Translate the options described by *ARGCP and *ARGVP.
996 Make a new vector and store it back in *ARGVP,
997 and store its length in *ARGVC. */
999 static void
1000 translate_options (argcp, argvp)
1001 int *argcp;
1002 const char *const **argvp;
1004 int i;
1005 int argc = *argcp;
1006 const char *const *argv = *argvp;
1007 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1008 const char **newv =
1009 (const char **) xmalloc (newvsize);
1010 int newindex = 0;
1012 i = 0;
1013 newv[newindex++] = argv[i++];
1015 while (i < argc)
1017 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1018 int tott_idx;
1020 for (tott_idx = 0;
1021 target_option_translations[tott_idx].option_found;
1022 tott_idx++)
1024 if (strcmp (target_option_translations[tott_idx].option_found,
1025 argv[i]) == 0)
1027 int spaces = 1;
1028 const char *sp;
1029 char *np;
1031 for (sp = target_option_translations[tott_idx].replacements;
1032 *sp; sp++)
1034 if (*sp == ' ')
1035 spaces ++;
1038 newvsize += spaces * sizeof (const char *);
1039 newv = (const char **) xrealloc (newv, newvsize);
1041 sp = target_option_translations[tott_idx].replacements;
1042 np = xstrdup (sp);
1044 while (1)
1046 while (*np == ' ')
1047 np++;
1048 if (*np == 0)
1049 break;
1050 newv[newindex++] = np;
1051 while (*np != ' ' && *np)
1052 np++;
1053 if (*np == 0)
1054 break;
1055 *np++ = 0;
1058 i ++;
1059 break;
1062 if (target_option_translations[tott_idx].option_found)
1063 continue;
1064 #endif
1066 /* Translate -- options. */
1067 if (argv[i][0] == '-' && argv[i][1] == '-')
1069 size_t j;
1070 /* Find a mapping that applies to this option. */
1071 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1073 size_t optlen = strlen (option_map[j].name);
1074 size_t arglen = strlen (argv[i]);
1075 size_t complen = arglen > optlen ? optlen : arglen;
1076 const char *arginfo = option_map[j].arg_info;
1078 if (arginfo == 0)
1079 arginfo = "";
1081 if (!strncmp (argv[i], option_map[j].name, complen))
1083 const char *arg = 0;
1085 if (arglen < optlen)
1087 size_t k;
1088 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1089 if (strlen (option_map[k].name) >= arglen
1090 && !strncmp (argv[i], option_map[k].name, arglen))
1092 error ("ambiguous abbreviation %s", argv[i]);
1093 break;
1096 if (k != ARRAY_SIZE (option_map))
1097 break;
1100 if (arglen > optlen)
1102 /* If the option has an argument, accept that. */
1103 if (argv[i][optlen] == '=')
1104 arg = argv[i] + optlen + 1;
1106 /* If this mapping requires extra text at end of name,
1107 accept that as "argument". */
1108 else if (strchr (arginfo, '*') != 0)
1109 arg = argv[i] + optlen;
1111 /* Otherwise, extra text at end means mismatch.
1112 Try other mappings. */
1113 else
1114 continue;
1117 else if (strchr (arginfo, '*') != 0)
1119 error ("incomplete `%s' option", option_map[j].name);
1120 break;
1123 /* Handle arguments. */
1124 if (strchr (arginfo, 'a') != 0)
1126 if (arg == 0)
1128 if (i + 1 == argc)
1130 error ("missing argument to `%s' option",
1131 option_map[j].name);
1132 break;
1135 arg = argv[++i];
1138 else if (strchr (arginfo, '*') != 0)
1140 else if (strchr (arginfo, 'o') == 0)
1142 if (arg != 0)
1143 error ("extraneous argument to `%s' option",
1144 option_map[j].name);
1145 arg = 0;
1148 /* Store the translation as one argv elt or as two. */
1149 if (arg != 0 && strchr (arginfo, 'j') != 0)
1150 newv[newindex++] = concat (option_map[j].equivalent, arg,
1151 NULL);
1152 else if (arg != 0)
1154 newv[newindex++] = option_map[j].equivalent;
1155 newv[newindex++] = arg;
1157 else
1158 newv[newindex++] = option_map[j].equivalent;
1160 break;
1163 i++;
1166 /* Handle old-fashioned options--just copy them through,
1167 with their arguments. */
1168 else if (argv[i][0] == '-')
1170 const char *p = argv[i] + 1;
1171 int c = *p;
1172 int nskip = 1;
1174 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1175 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1176 else if (WORD_SWITCH_TAKES_ARG (p))
1177 nskip += WORD_SWITCH_TAKES_ARG (p);
1178 else if ((c == 'B' || c == 'b' || c == 'V' || c == 'x')
1179 && p[1] == 0)
1180 nskip += 1;
1181 else if (! strcmp (p, "Xlinker"))
1182 nskip += 1;
1184 /* Watch out for an option at the end of the command line that
1185 is missing arguments, and avoid skipping past the end of the
1186 command line. */
1187 if (nskip + i > argc)
1188 nskip = argc - i;
1190 while (nskip > 0)
1192 newv[newindex++] = argv[i++];
1193 nskip--;
1196 else
1197 /* Ordinary operands, or +e options. */
1198 newv[newindex++] = argv[i++];
1201 newv[newindex] = 0;
1203 *argvp = newv;
1204 *argcp = newindex;
1207 static char *
1208 skip_whitespace (p)
1209 char *p;
1211 while (1)
1213 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1214 be considered whitespace. */
1215 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1216 return p + 1;
1217 else if (*p == '\n' || *p == ' ' || *p == '\t')
1218 p++;
1219 else if (*p == '#')
1221 while (*p != '\n')
1222 p++;
1223 p++;
1225 else
1226 break;
1229 return p;
1231 /* Structures to keep track of prefixes to try when looking for files. */
1233 struct prefix_list
1235 const char *prefix; /* String to prepend to the path. */
1236 struct prefix_list *next; /* Next in linked list. */
1237 int require_machine_suffix; /* Don't use without machine_suffix. */
1238 /* 2 means try both machine_suffix and just_machine_suffix. */
1239 int *used_flag_ptr; /* 1 if a file was found with this prefix. */
1240 int priority; /* Sort key - priority within list */
1243 struct path_prefix
1245 struct prefix_list *plist; /* List of prefixes to try */
1246 int max_len; /* Max length of a prefix in PLIST */
1247 const char *name; /* Name of this list (used in config stuff) */
1250 /* List of prefixes to try when looking for executables. */
1252 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1254 /* List of prefixes to try when looking for startup (crt0) files. */
1256 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1258 /* List of prefixes to try when looking for include files. */
1260 static struct path_prefix include_prefixes = { 0, 0, "include" };
1262 /* Suffix to attach to directories searched for commands.
1263 This looks like `MACHINE/VERSION/'. */
1265 static const char *machine_suffix = 0;
1267 /* Suffix to attach to directories searched for commands.
1268 This is just `MACHINE/'. */
1270 static const char *just_machine_suffix = 0;
1272 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1274 static const char *gcc_exec_prefix;
1276 /* Default prefixes to attach to command names. */
1278 #ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1279 #undef MD_EXEC_PREFIX
1280 #undef MD_STARTFILE_PREFIX
1281 #undef MD_STARTFILE_PREFIX_1
1282 #endif
1284 /* If no prefixes defined, use the null string, which will disable them. */
1285 #ifndef MD_EXEC_PREFIX
1286 #define MD_EXEC_PREFIX ""
1287 #endif
1288 #ifndef MD_STARTFILE_PREFIX
1289 #define MD_STARTFILE_PREFIX ""
1290 #endif
1291 #ifndef MD_STARTFILE_PREFIX_1
1292 #define MD_STARTFILE_PREFIX_1 ""
1293 #endif
1295 /* Supply defaults for the standard prefixes. */
1297 #ifndef STANDARD_EXEC_PREFIX
1298 #define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
1299 #endif
1300 #ifndef STANDARD_STARTFILE_PREFIX
1301 #define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
1302 #endif
1303 #ifndef TOOLDIR_BASE_PREFIX
1304 #define TOOLDIR_BASE_PREFIX "/usr/local/"
1305 #endif
1306 #ifndef STANDARD_BINDIR_PREFIX
1307 #define STANDARD_BINDIR_PREFIX "/usr/local/bin"
1308 #endif
1310 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1311 static const char *const standard_exec_prefix_1 = "/usr/lib/gcc/";
1312 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1314 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1315 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1316 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1317 static const char *const standard_startfile_prefix_1 = "/lib/";
1318 static const char *const standard_startfile_prefix_2 = "/usr/lib/";
1320 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1321 static const char *tooldir_prefix;
1323 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1325 /* Subdirectory to use for locating libraries. Set by
1326 set_multilib_dir based on the compilation options. */
1328 static const char *multilib_dir;
1330 /* Structure to keep track of the specs that have been defined so far.
1331 These are accessed using %(specname) or %[specname] in a compiler
1332 or link spec. */
1334 struct spec_list
1336 /* The following 2 fields must be first */
1337 /* to allow EXTRA_SPECS to be initialized */
1338 const char *name; /* name of the spec. */
1339 const char *ptr; /* available ptr if no static pointer */
1341 /* The following fields are not initialized */
1342 /* by EXTRA_SPECS */
1343 const char **ptr_spec; /* pointer to the spec itself. */
1344 struct spec_list *next; /* Next spec in linked list. */
1345 int name_len; /* length of the name */
1346 int alloc_p; /* whether string was allocated */
1349 #define INIT_STATIC_SPEC(NAME,PTR) \
1350 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1352 /* List of statically defined specs. */
1353 static struct spec_list static_specs[] =
1355 INIT_STATIC_SPEC ("asm", &asm_spec),
1356 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1357 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1358 INIT_STATIC_SPEC ("asm_options", &asm_options),
1359 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1360 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1361 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1362 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1363 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1364 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1365 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1366 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1367 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1368 INIT_STATIC_SPEC ("link", &link_spec),
1369 INIT_STATIC_SPEC ("lib", &lib_spec),
1370 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1371 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1372 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1373 INIT_STATIC_SPEC ("predefines", &cpp_predefines),
1374 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1375 INIT_STATIC_SPEC ("version", &compiler_version),
1376 INIT_STATIC_SPEC ("multilib", &multilib_select),
1377 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1378 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1379 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1380 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1381 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1382 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1383 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1384 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1385 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1388 #ifdef EXTRA_SPECS /* additional specs needed */
1389 /* Structure to keep track of just the first two args of a spec_list.
1390 That is all that the EXTRA_SPECS macro gives us. */
1391 struct spec_list_1
1393 const char *const name;
1394 const char *const ptr;
1397 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1398 static struct spec_list *extra_specs = (struct spec_list *) 0;
1399 #endif
1401 /* List of dynamically allocates specs that have been defined so far. */
1403 static struct spec_list *specs = (struct spec_list *) 0;
1405 /* Add appropriate libgcc specs to OBSTACK, taking into account
1406 various permutations of -shared-libgcc, -shared, and such. */
1408 #ifdef ENABLE_SHARED_LIBGCC
1409 static void
1410 init_gcc_specs (obstack, shared_name, static_name, eh_name)
1411 struct obstack *obstack;
1412 const char *shared_name;
1413 const char *static_name;
1414 const char *eh_name;
1416 char buffer[128];
1417 const char *p;
1419 /* If we see -shared-libgcc, then use the shared version. */
1420 sprintf (buffer, "%%{shared-libgcc:%s %s}", shared_name, static_name);
1421 obstack_grow (obstack, buffer, strlen (buffer));
1422 /* If we see -static-libgcc, then use the static version. */
1423 sprintf (buffer, "%%{static-libgcc:%s %s}", static_name, eh_name);
1424 obstack_grow (obstack, buffer, strlen (buffer));
1425 /* Otherwise, if we see -shared, then use the shared version
1426 if using EH registration routines or static version without
1427 exception handling routines otherwise. */
1428 p = "%{!shared-libgcc:%{!static-libgcc:%{shared:";
1429 obstack_grow (obstack, p, strlen (p));
1430 #ifdef LINK_EH_SPEC
1431 sprintf (buffer, "%s}}}", static_name);
1432 #else
1433 sprintf (buffer, "%s}}}", shared_name);
1434 #endif
1435 obstack_grow (obstack, buffer, strlen (buffer));
1436 /* Otherwise, use the static version. */
1437 sprintf (buffer,
1438 "%%{!shared-libgcc:%%{!static-libgcc:%%{!shared:%s %s}}}",
1439 static_name, eh_name);
1440 obstack_grow (obstack, buffer, strlen (buffer));
1442 #endif /* ENABLE_SHARED_LIBGCC */
1444 /* Initialize the specs lookup routines. */
1446 static void
1447 init_spec ()
1449 struct spec_list *next = (struct spec_list *) 0;
1450 struct spec_list *sl = (struct spec_list *) 0;
1451 int i;
1453 if (specs)
1454 return; /* Already initialized. */
1456 if (verbose_flag)
1457 notice ("Using built-in specs.\n");
1459 #ifdef EXTRA_SPECS
1460 extra_specs = (struct spec_list *)
1461 xcalloc (sizeof (struct spec_list), ARRAY_SIZE (extra_specs_1));
1463 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1465 sl = &extra_specs[i];
1466 sl->name = extra_specs_1[i].name;
1467 sl->ptr = extra_specs_1[i].ptr;
1468 sl->next = next;
1469 sl->name_len = strlen (sl->name);
1470 sl->ptr_spec = &sl->ptr;
1471 next = sl;
1473 #endif
1475 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1477 sl = &static_specs[i];
1478 sl->next = next;
1479 next = sl;
1482 #ifdef ENABLE_SHARED_LIBGCC
1483 /* ??? If neither -shared-libgcc nor --static-libgcc was
1484 seen, then we should be making an educated guess. Some proposed
1485 heuristics for ELF include:
1487 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1488 program will be doing dynamic loading, which will likely
1489 need the shared libgcc.
1491 (2) If "-ldl", then it's also a fair bet that we're doing
1492 dynamic loading.
1494 (3) For each ET_DYN we're linking against (either through -lfoo
1495 or /some/path/foo.so), check to see whether it or one of
1496 its dependencies depends on a shared libgcc.
1498 (4) If "-shared"
1500 If the runtime is fixed to look for program headers instead
1501 of calling __register_frame_info at all, for each object,
1502 use the shared libgcc if any EH symbol referenced.
1504 If crtstuff is fixed to not invoke __register_frame_info
1505 automatically, for each object, use the shared libgcc if
1506 any non-empty unwind section found.
1508 Doing any of this probably requires invoking an external program to
1509 do the actual object file scanning. */
1511 const char *p = libgcc_spec;
1512 int in_sep = 1;
1514 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1515 when given the proper command line arguments. */
1516 while (*p)
1518 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1520 init_gcc_specs (&obstack,
1521 #ifdef NO_SHARED_LIBGCC_MULTILIB
1522 "-lgcc_s"
1523 #else
1524 "-lgcc_s%M"
1525 #endif
1527 "-lgcc",
1528 "-lgcc_eh");
1529 p += 5;
1530 in_sep = 0;
1532 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1534 /* Ug. We don't know shared library extensions. Hope that
1535 systems that use this form don't do shared libraries. */
1536 init_gcc_specs (&obstack,
1537 #ifdef NO_SHARED_LIBGCC_MULTILIB
1538 "-lgcc_s"
1539 #else
1540 "-lgcc_s%M"
1541 #endif
1543 "libgcc.a%s",
1544 "libgcc_eh.a%s");
1545 p += 10;
1546 in_sep = 0;
1548 else
1550 obstack_1grow (&obstack, *p);
1551 in_sep = (*p == ' ');
1552 p += 1;
1556 obstack_1grow (&obstack, '\0');
1557 libgcc_spec = obstack_finish (&obstack);
1559 #endif
1560 #ifdef USE_AS_TRADITIONAL_FORMAT
1561 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1563 static const char tf[] = "--traditional-format ";
1564 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1565 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1566 asm_spec = obstack_finish (&obstack);
1568 #endif
1569 #ifdef LINK_EH_SPEC
1570 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1571 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1572 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1573 link_spec = obstack_finish (&obstack);
1574 #endif
1576 specs = sl;
1579 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1580 removed; If the spec starts with a + then SPEC is added to the end of the
1581 current spec. */
1583 static void
1584 set_spec (name, spec)
1585 const char *name;
1586 const char *spec;
1588 struct spec_list *sl;
1589 const char *old_spec;
1590 int name_len = strlen (name);
1591 int i;
1593 /* If this is the first call, initialize the statically allocated specs. */
1594 if (!specs)
1596 struct spec_list *next = (struct spec_list *) 0;
1597 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1599 sl = &static_specs[i];
1600 sl->next = next;
1601 next = sl;
1603 specs = sl;
1606 /* See if the spec already exists. */
1607 for (sl = specs; sl; sl = sl->next)
1608 if (name_len == sl->name_len && !strcmp (sl->name, name))
1609 break;
1611 if (!sl)
1613 /* Not found - make it. */
1614 sl = (struct spec_list *) xmalloc (sizeof (struct spec_list));
1615 sl->name = xstrdup (name);
1616 sl->name_len = name_len;
1617 sl->ptr_spec = &sl->ptr;
1618 sl->alloc_p = 0;
1619 *(sl->ptr_spec) = "";
1620 sl->next = specs;
1621 specs = sl;
1624 old_spec = *(sl->ptr_spec);
1625 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1626 ? concat (old_spec, spec + 1, NULL)
1627 : xstrdup (spec));
1629 #ifdef DEBUG_SPECS
1630 if (verbose_flag)
1631 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1632 #endif
1634 /* Free the old spec. */
1635 if (old_spec && sl->alloc_p)
1636 free ((PTR) old_spec);
1638 sl->alloc_p = 1;
1641 /* Accumulate a command (program name and args), and run it. */
1643 /* Vector of pointers to arguments in the current line of specifications. */
1645 static const char **argbuf;
1647 /* Number of elements allocated in argbuf. */
1649 static int argbuf_length;
1651 /* Number of elements in argbuf currently in use (containing args). */
1653 static int argbuf_index;
1655 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1656 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1657 it here. */
1659 static struct temp_name {
1660 const char *suffix; /* suffix associated with the code. */
1661 int length; /* strlen (suffix). */
1662 int unique; /* Indicates whether %g or %u/%U was used. */
1663 const char *filename; /* associated filename. */
1664 int filename_length; /* strlen (filename). */
1665 struct temp_name *next;
1666 } *temp_names;
1668 /* Number of commands executed so far. */
1670 static int execution_count;
1672 /* Number of commands that exited with a signal. */
1674 static int signal_count;
1676 /* Name with which this program was invoked. */
1678 static const char *programname;
1680 /* Clear out the vector of arguments (after a command is executed). */
1682 static void
1683 clear_args ()
1685 argbuf_index = 0;
1688 /* Add one argument to the vector at the end.
1689 This is done when a space is seen or at the end of the line.
1690 If DELETE_ALWAYS is nonzero, the arg is a filename
1691 and the file should be deleted eventually.
1692 If DELETE_FAILURE is nonzero, the arg is a filename
1693 and the file should be deleted if this compilation fails. */
1695 static void
1696 store_arg (arg, delete_always, delete_failure)
1697 const char *arg;
1698 int delete_always, delete_failure;
1700 if (argbuf_index + 1 == argbuf_length)
1701 argbuf
1702 = (const char **) xrealloc (argbuf,
1703 (argbuf_length *= 2) * sizeof (const char *));
1705 argbuf[argbuf_index++] = arg;
1706 argbuf[argbuf_index] = 0;
1708 if (delete_always || delete_failure)
1709 record_temp_file (arg, delete_always, delete_failure);
1712 /* Load specs from a file name named FILENAME, replacing occurrences of
1713 various different types of line-endings, \r\n, \n\r and just \r, with
1714 a single \n. */
1716 static char *
1717 load_specs (filename)
1718 const char *filename;
1720 int desc;
1721 int readlen;
1722 struct stat statbuf;
1723 char *buffer;
1724 char *buffer_p;
1725 char *specs;
1726 char *specs_p;
1728 if (verbose_flag)
1729 notice ("Reading specs from %s\n", filename);
1731 /* Open and stat the file. */
1732 desc = open (filename, O_RDONLY, 0);
1733 if (desc < 0)
1734 pfatal_with_name (filename);
1735 if (stat (filename, &statbuf) < 0)
1736 pfatal_with_name (filename);
1738 /* Read contents of file into BUFFER. */
1739 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1740 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1741 if (readlen < 0)
1742 pfatal_with_name (filename);
1743 buffer[readlen] = 0;
1744 close (desc);
1746 specs = xmalloc (readlen + 1);
1747 specs_p = specs;
1748 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1750 int skip = 0;
1751 char c = *buffer_p;
1752 if (c == '\r')
1754 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1755 skip = 1;
1756 else if (*(buffer_p + 1) == '\n') /* \r\n */
1757 skip = 1;
1758 else /* \r */
1759 c = '\n';
1761 if (! skip)
1762 *specs_p++ = c;
1764 *specs_p = '\0';
1766 free (buffer);
1767 return (specs);
1770 /* Read compilation specs from a file named FILENAME,
1771 replacing the default ones.
1773 A suffix which starts with `*' is a definition for
1774 one of the machine-specific sub-specs. The "suffix" should be
1775 *asm, *cc1, *cpp, *link, *startfile, etc.
1776 The corresponding spec is stored in asm_spec, etc.,
1777 rather than in the `compilers' vector.
1779 Anything invalid in the file is a fatal error. */
1781 static void
1782 read_specs (filename, main_p)
1783 const char *filename;
1784 int main_p;
1786 char *buffer;
1787 char *p;
1789 buffer = load_specs (filename);
1791 /* Scan BUFFER for specs, putting them in the vector. */
1792 p = buffer;
1793 while (1)
1795 char *suffix;
1796 char *spec;
1797 char *in, *out, *p1, *p2, *p3;
1799 /* Advance P in BUFFER to the next nonblank nocomment line. */
1800 p = skip_whitespace (p);
1801 if (*p == 0)
1802 break;
1804 /* Is this a special command that starts with '%'? */
1805 /* Don't allow this for the main specs file, since it would
1806 encourage people to overwrite it. */
1807 if (*p == '%' && !main_p)
1809 p1 = p;
1810 while (*p && *p != '\n')
1811 p++;
1813 /* Skip '\n'. */
1814 p++;
1816 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1817 && (p1[sizeof "%include" - 1] == ' '
1818 || p1[sizeof "%include" - 1] == '\t'))
1820 char *new_filename;
1822 p1 += sizeof ("%include");
1823 while (*p1 == ' ' || *p1 == '\t')
1824 p1++;
1826 if (*p1++ != '<' || p[-2] != '>')
1827 fatal ("specs %%include syntax malformed after %ld characters",
1828 (long) (p1 - buffer + 1));
1830 p[-2] = '\0';
1831 new_filename = find_a_file (&startfile_prefixes, p1, R_OK);
1832 read_specs (new_filename ? new_filename : p1, FALSE);
1833 continue;
1835 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1836 && (p1[sizeof "%include_noerr" - 1] == ' '
1837 || p1[sizeof "%include_noerr" - 1] == '\t'))
1839 char *new_filename;
1841 p1 += sizeof "%include_noerr";
1842 while (*p1 == ' ' || *p1 == '\t')
1843 p1++;
1845 if (*p1++ != '<' || p[-2] != '>')
1846 fatal ("specs %%include syntax malformed after %ld characters",
1847 (long) (p1 - buffer + 1));
1849 p[-2] = '\0';
1850 new_filename = find_a_file (&startfile_prefixes, p1, R_OK);
1851 if (new_filename)
1852 read_specs (new_filename, FALSE);
1853 else if (verbose_flag)
1854 notice ("could not find specs file %s\n", p1);
1855 continue;
1857 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1858 && (p1[sizeof "%rename" - 1] == ' '
1859 || p1[sizeof "%rename" - 1] == '\t'))
1861 int name_len;
1862 struct spec_list *sl;
1864 /* Get original name */
1865 p1 += sizeof "%rename";
1866 while (*p1 == ' ' || *p1 == '\t')
1867 p1++;
1869 if (! ISALPHA ((unsigned char) *p1))
1870 fatal ("specs %%rename syntax malformed after %ld characters",
1871 (long) (p1 - buffer));
1873 p2 = p1;
1874 while (*p2 && !ISSPACE ((unsigned char) *p2))
1875 p2++;
1877 if (*p2 != ' ' && *p2 != '\t')
1878 fatal ("specs %%rename syntax malformed after %ld characters",
1879 (long) (p2 - buffer));
1881 name_len = p2 - p1;
1882 *p2++ = '\0';
1883 while (*p2 == ' ' || *p2 == '\t')
1884 p2++;
1886 if (! ISALPHA ((unsigned char) *p2))
1887 fatal ("specs %%rename syntax malformed after %ld characters",
1888 (long) (p2 - buffer));
1890 /* Get new spec name. */
1891 p3 = p2;
1892 while (*p3 && !ISSPACE ((unsigned char) *p3))
1893 p3++;
1895 if (p3 != p - 1)
1896 fatal ("specs %%rename syntax malformed after %ld characters",
1897 (long) (p3 - buffer));
1898 *p3 = '\0';
1900 for (sl = specs; sl; sl = sl->next)
1901 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1902 break;
1904 if (!sl)
1905 fatal ("specs %s spec was not found to be renamed", p1);
1907 if (strcmp (p1, p2) == 0)
1908 continue;
1910 if (verbose_flag)
1912 notice ("rename spec %s to %s\n", p1, p2);
1913 #ifdef DEBUG_SPECS
1914 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
1915 #endif
1918 set_spec (p2, *(sl->ptr_spec));
1919 if (sl->alloc_p)
1920 free ((PTR) *(sl->ptr_spec));
1922 *(sl->ptr_spec) = "";
1923 sl->alloc_p = 0;
1924 continue;
1926 else
1927 fatal ("specs unknown %% command after %ld characters",
1928 (long) (p1 - buffer));
1931 /* Find the colon that should end the suffix. */
1932 p1 = p;
1933 while (*p1 && *p1 != ':' && *p1 != '\n')
1934 p1++;
1936 /* The colon shouldn't be missing. */
1937 if (*p1 != ':')
1938 fatal ("specs file malformed after %ld characters",
1939 (long) (p1 - buffer));
1941 /* Skip back over trailing whitespace. */
1942 p2 = p1;
1943 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1944 p2--;
1946 /* Copy the suffix to a string. */
1947 suffix = save_string (p, p2 - p);
1948 /* Find the next line. */
1949 p = skip_whitespace (p1 + 1);
1950 if (p[1] == 0)
1951 fatal ("specs file malformed after %ld characters",
1952 (long) (p - buffer));
1954 p1 = p;
1955 /* Find next blank line or end of string. */
1956 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1957 p1++;
1959 /* Specs end at the blank line and do not include the newline. */
1960 spec = save_string (p, p1 - p);
1961 p = p1;
1963 /* Delete backslash-newline sequences from the spec. */
1964 in = spec;
1965 out = spec;
1966 while (*in != 0)
1968 if (in[0] == '\\' && in[1] == '\n')
1969 in += 2;
1970 else if (in[0] == '#')
1971 while (*in && *in != '\n')
1972 in++;
1974 else
1975 *out++ = *in++;
1977 *out = 0;
1979 if (suffix[0] == '*')
1981 if (! strcmp (suffix, "*link_command"))
1982 link_command_spec = spec;
1983 else
1984 set_spec (suffix + 1, spec);
1986 else
1988 /* Add this pair to the vector. */
1989 compilers
1990 = ((struct compiler *)
1991 xrealloc (compilers,
1992 (n_compilers + 2) * sizeof (struct compiler)));
1994 compilers[n_compilers].suffix = suffix;
1995 compilers[n_compilers].spec = spec;
1996 n_compilers++;
1997 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2000 if (*suffix == 0)
2001 link_command_spec = spec;
2004 if (link_command_spec == 0)
2005 fatal ("spec file has no spec for linking");
2008 /* Record the names of temporary files we tell compilers to write,
2009 and delete them at the end of the run. */
2011 /* This is the common prefix we use to make temp file names.
2012 It is chosen once for each run of this program.
2013 It is substituted into a spec by %g or %j.
2014 Thus, all temp file names contain this prefix.
2015 In practice, all temp file names start with this prefix.
2017 This prefix comes from the envvar TMPDIR if it is defined;
2018 otherwise, from the P_tmpdir macro if that is defined;
2019 otherwise, in /usr/tmp or /tmp;
2020 or finally the current directory if all else fails. */
2022 static const char *temp_filename;
2024 /* Length of the prefix. */
2026 static int temp_filename_length;
2028 /* Define the list of temporary files to delete. */
2030 struct temp_file
2032 const char *name;
2033 struct temp_file *next;
2036 /* Queue of files to delete on success or failure of compilation. */
2037 static struct temp_file *always_delete_queue;
2038 /* Queue of files to delete on failure of compilation. */
2039 static struct temp_file *failure_delete_queue;
2041 /* Record FILENAME as a file to be deleted automatically.
2042 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2043 otherwise delete it in any case.
2044 FAIL_DELETE nonzero means delete it if a compilation step fails;
2045 otherwise delete it in any case. */
2047 void
2048 record_temp_file (filename, always_delete, fail_delete)
2049 const char *filename;
2050 int always_delete;
2051 int fail_delete;
2053 char *const name = xstrdup (filename);
2055 if (always_delete)
2057 struct temp_file *temp;
2058 for (temp = always_delete_queue; temp; temp = temp->next)
2059 if (! strcmp (name, temp->name))
2060 goto already1;
2062 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2063 temp->next = always_delete_queue;
2064 temp->name = name;
2065 always_delete_queue = temp;
2067 already1:;
2070 if (fail_delete)
2072 struct temp_file *temp;
2073 for (temp = failure_delete_queue; temp; temp = temp->next)
2074 if (! strcmp (name, temp->name))
2075 goto already2;
2077 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
2078 temp->next = failure_delete_queue;
2079 temp->name = name;
2080 failure_delete_queue = temp;
2082 already2:;
2086 /* Delete all the temporary files whose names we previously recorded. */
2088 static void
2089 delete_if_ordinary (name)
2090 const char *name;
2092 struct stat st;
2093 #ifdef DEBUG
2094 int i, c;
2096 printf ("Delete %s? (y or n) ", name);
2097 fflush (stdout);
2098 i = getchar ();
2099 if (i != '\n')
2100 while ((c = getchar ()) != '\n' && c != EOF)
2103 if (i == 'y' || i == 'Y')
2104 #endif /* DEBUG */
2105 if (stat (name, &st) >= 0 && S_ISREG (st.st_mode))
2106 if (unlink (name) < 0)
2107 if (verbose_flag)
2108 perror_with_name (name);
2111 static void
2112 delete_temp_files ()
2114 struct temp_file *temp;
2116 for (temp = always_delete_queue; temp; temp = temp->next)
2117 delete_if_ordinary (temp->name);
2118 always_delete_queue = 0;
2121 /* Delete all the files to be deleted on error. */
2123 static void
2124 delete_failure_queue ()
2126 struct temp_file *temp;
2128 for (temp = failure_delete_queue; temp; temp = temp->next)
2129 delete_if_ordinary (temp->name);
2132 static void
2133 clear_failure_queue ()
2135 failure_delete_queue = 0;
2138 /* Build a list of search directories from PATHS.
2139 PREFIX is a string to prepend to the list.
2140 If CHECK_DIR_P is non-zero we ensure the directory exists.
2141 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2142 It is also used by the --print-search-dirs flag. */
2144 static char *
2145 build_search_list (paths, prefix, check_dir_p)
2146 struct path_prefix *paths;
2147 const char *prefix;
2148 int check_dir_p;
2150 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2151 int just_suffix_len
2152 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2153 int first_time = TRUE;
2154 struct prefix_list *pprefix;
2156 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2157 obstack_1grow (&collect_obstack, '=');
2159 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2161 int len = strlen (pprefix->prefix);
2163 if (machine_suffix
2164 && (! check_dir_p
2165 || is_directory (pprefix->prefix, machine_suffix, 0)))
2167 if (!first_time)
2168 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2170 first_time = FALSE;
2171 obstack_grow (&collect_obstack, pprefix->prefix, len);
2172 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2175 if (just_machine_suffix
2176 && pprefix->require_machine_suffix == 2
2177 && (! check_dir_p
2178 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2180 if (! first_time)
2181 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2183 first_time = FALSE;
2184 obstack_grow (&collect_obstack, pprefix->prefix, len);
2185 obstack_grow (&collect_obstack, just_machine_suffix,
2186 just_suffix_len);
2189 if (! pprefix->require_machine_suffix)
2191 if (! first_time)
2192 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2194 first_time = FALSE;
2195 obstack_grow (&collect_obstack, pprefix->prefix, len);
2199 obstack_1grow (&collect_obstack, '\0');
2200 return obstack_finish (&collect_obstack);
2203 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2204 for collect. */
2206 static void
2207 putenv_from_prefixes (paths, env_var)
2208 struct path_prefix *paths;
2209 const char *env_var;
2211 putenv (build_search_list (paths, env_var, 1));
2214 #ifndef VMS
2216 /* FIXME: the location independence code for VMS is hairier than this,
2217 and hasn't been written. */
2219 /* Split a filename into component directories. */
2221 static char **
2222 split_directories (name, ptr_num_dirs)
2223 const char *name;
2224 int *ptr_num_dirs;
2226 int num_dirs = 0;
2227 char **dirs;
2228 const char *p, *q;
2229 int ch;
2231 /* Count the number of directories. Special case MSDOS disk names as part
2232 of the initial directory. */
2233 p = name;
2234 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2235 if (name[1] == ':' && IS_DIR_SEPARATOR (name[2]))
2237 p += 3;
2238 num_dirs++;
2240 #endif /* HAVE_DOS_BASED_FILE_SYSTEM */
2242 while ((ch = *p++) != '\0')
2244 if (IS_DIR_SEPARATOR (ch))
2246 num_dirs++;
2247 while (IS_DIR_SEPARATOR (*p))
2248 p++;
2252 dirs = (char **) xmalloc (sizeof (char *) * (num_dirs + 2));
2254 /* Now copy the directory parts. */
2255 num_dirs = 0;
2256 p = name;
2257 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2258 if (name[1] == ':' && IS_DIR_SEPARATOR (name[2]))
2260 dirs[num_dirs++] = save_string (p, 3);
2261 p += 3;
2263 #endif /* HAVE_DOS_BASED_FILE_SYSTEM */
2265 q = p;
2266 while ((ch = *p++) != '\0')
2268 if (IS_DIR_SEPARATOR (ch))
2270 while (IS_DIR_SEPARATOR (*p))
2271 p++;
2273 dirs[num_dirs++] = save_string (q, p - q);
2274 q = p;
2278 if (p - 1 - q > 0)
2279 dirs[num_dirs++] = save_string (q, p - 1 - q);
2281 dirs[num_dirs] = NULL;
2282 if (ptr_num_dirs)
2283 *ptr_num_dirs = num_dirs;
2285 return dirs;
2288 /* Release storage held by split directories. */
2290 static void
2291 free_split_directories (dirs)
2292 char **dirs;
2294 int i = 0;
2296 while (dirs[i] != NULL)
2297 free (dirs[i++]);
2299 free ((char *) dirs);
2302 /* Given three strings PROGNAME, BIN_PREFIX, PREFIX, return a string that gets
2303 to PREFIX starting with the directory portion of PROGNAME and a relative
2304 pathname of the difference between BIN_PREFIX and PREFIX.
2306 For example, if BIN_PREFIX is /alpha/beta/gamma/gcc/delta, PREFIX is
2307 /alpha/beta/gamma/omega/, and PROGNAME is /red/green/blue/gcc, then this
2308 function will return /red/green/blue/../omega.
2310 If no relative prefix can be found, return NULL. */
2312 static char *
2313 make_relative_prefix (progname, bin_prefix, prefix)
2314 const char *progname;
2315 const char *bin_prefix;
2316 const char *prefix;
2318 char **prog_dirs, **bin_dirs, **prefix_dirs;
2319 int prog_num, bin_num, prefix_num, std_loc_p;
2320 int i, n, common;
2322 prog_dirs = split_directories (progname, &prog_num);
2323 bin_dirs = split_directories (bin_prefix, &bin_num);
2325 /* If there is no full pathname, try to find the program by checking in each
2326 of the directories specified in the PATH environment variable. */
2327 if (prog_num == 1)
2329 char *temp;
2331 GET_ENV_PATH_LIST (temp, "PATH");
2332 if (temp)
2334 char *startp, *endp, *nstore;
2335 size_t prefixlen = strlen (temp) + 1;
2336 if (prefixlen < 2)
2337 prefixlen = 2;
2339 nstore = (char *) alloca (prefixlen + strlen (progname) + 1);
2341 startp = endp = temp;
2342 while (1)
2344 if (*endp == PATH_SEPARATOR || *endp == 0)
2346 if (endp == startp)
2348 nstore[0] = '.';
2349 nstore[1] = DIR_SEPARATOR;
2350 nstore[2] = '\0';
2352 else
2354 strncpy (nstore, startp, endp - startp);
2355 if (! IS_DIR_SEPARATOR (endp[-1]))
2357 nstore[endp - startp] = DIR_SEPARATOR;
2358 nstore[endp - startp + 1] = 0;
2360 else
2361 nstore[endp - startp] = 0;
2363 strcat (nstore, progname);
2364 if (! access (nstore, X_OK)
2365 #ifdef HAVE_HOST_EXECUTABLE_SUFFIX
2366 || ! access (strcat (nstore, HOST_EXECUTABLE_SUFFIX), X_OK)
2367 #endif
2370 free_split_directories (prog_dirs);
2371 progname = nstore;
2372 prog_dirs = split_directories (progname, &prog_num);
2373 break;
2376 if (*endp == 0)
2377 break;
2378 endp = startp = endp + 1;
2380 else
2381 endp++;
2386 /* Remove the program name from comparison of directory names. */
2387 prog_num--;
2389 /* Determine if the compiler is installed in the standard location, and if
2390 so, we don't need to specify relative directories. Also, if argv[0]
2391 doesn't contain any directory specifiers, there is not much we can do. */
2392 std_loc_p = 0;
2393 if (prog_num == bin_num)
2395 for (i = 0; i < bin_num; i++)
2397 if (strcmp (prog_dirs[i], bin_dirs[i]) != 0)
2398 break;
2401 if (prog_num <= 0 || i == bin_num)
2403 std_loc_p = 1;
2404 free_split_directories (prog_dirs);
2405 free_split_directories (bin_dirs);
2406 prog_dirs = bin_dirs = (char **) 0;
2407 return NULL;
2411 prefix_dirs = split_directories (prefix, &prefix_num);
2413 /* Find how many directories are in common between bin_prefix & prefix. */
2414 n = (prefix_num < bin_num) ? prefix_num : bin_num;
2415 for (common = 0; common < n; common++)
2417 if (strcmp (bin_dirs[common], prefix_dirs[common]) != 0)
2418 break;
2421 /* If there are no common directories, there can be no relative prefix. */
2422 if (common == 0)
2424 free_split_directories (prog_dirs);
2425 free_split_directories (bin_dirs);
2426 free_split_directories (prefix_dirs);
2427 return NULL;
2430 /* Build up the pathnames in argv[0]. */
2431 for (i = 0; i < prog_num; i++)
2432 obstack_grow (&obstack, prog_dirs[i], strlen (prog_dirs[i]));
2434 /* Now build up the ..'s. */
2435 for (i = common; i < n; i++)
2437 obstack_grow (&obstack, DIR_UP, sizeof (DIR_UP) - 1);
2438 obstack_1grow (&obstack, DIR_SEPARATOR);
2441 /* Put in directories to move over to prefix. */
2442 for (i = common; i < prefix_num; i++)
2443 obstack_grow (&obstack, prefix_dirs[i], strlen (prefix_dirs[i]));
2445 free_split_directories (prog_dirs);
2446 free_split_directories (bin_dirs);
2447 free_split_directories (prefix_dirs);
2449 obstack_1grow (&obstack, '\0');
2450 return obstack_finish (&obstack);
2452 #endif /* VMS */
2454 /* Check whether NAME can be accessed in MODE. This is like access,
2455 except that it never considers directories to be executable. */
2457 static int
2458 access_check (name, mode)
2459 const char *name;
2460 int mode;
2462 if (mode == X_OK)
2464 struct stat st;
2466 if (stat (name, &st) < 0
2467 || S_ISDIR (st.st_mode))
2468 return -1;
2471 return access (name, mode);
2474 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2475 access to check permissions.
2476 Return 0 if not found, otherwise return its name, allocated with malloc. */
2478 static char *
2479 find_a_file (pprefix, name, mode)
2480 struct path_prefix *pprefix;
2481 const char *name;
2482 int mode;
2484 char *temp;
2485 const char *const file_suffix =
2486 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2487 struct prefix_list *pl;
2488 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2490 #ifdef DEFAULT_ASSEMBLER
2491 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2492 return xstrdup (DEFAULT_ASSEMBLER);
2493 #endif
2495 #ifdef DEFAULT_LINKER
2496 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2497 return xstrdup (DEFAULT_LINKER);
2498 #endif
2500 if (machine_suffix)
2501 len += strlen (machine_suffix);
2503 temp = xmalloc (len);
2505 /* Determine the filename to execute (special case for absolute paths). */
2507 if (IS_ABSOLUTE_PATHNAME (name))
2509 if (access (name, mode) == 0)
2511 strcpy (temp, name);
2512 return temp;
2515 else
2516 for (pl = pprefix->plist; pl; pl = pl->next)
2518 if (machine_suffix)
2520 /* Some systems have a suffix for executable files.
2521 So try appending that first. */
2522 if (file_suffix[0] != 0)
2524 strcpy (temp, pl->prefix);
2525 strcat (temp, machine_suffix);
2526 strcat (temp, name);
2527 strcat (temp, file_suffix);
2528 if (access_check (temp, mode) == 0)
2530 if (pl->used_flag_ptr != 0)
2531 *pl->used_flag_ptr = 1;
2532 return temp;
2536 /* Now try just the name. */
2537 strcpy (temp, pl->prefix);
2538 strcat (temp, machine_suffix);
2539 strcat (temp, name);
2540 if (access_check (temp, mode) == 0)
2542 if (pl->used_flag_ptr != 0)
2543 *pl->used_flag_ptr = 1;
2544 return temp;
2548 /* Certain prefixes are tried with just the machine type,
2549 not the version. This is used for finding as, ld, etc. */
2550 if (just_machine_suffix && pl->require_machine_suffix == 2)
2552 /* Some systems have a suffix for executable files.
2553 So try appending that first. */
2554 if (file_suffix[0] != 0)
2556 strcpy (temp, pl->prefix);
2557 strcat (temp, just_machine_suffix);
2558 strcat (temp, name);
2559 strcat (temp, file_suffix);
2560 if (access_check (temp, mode) == 0)
2562 if (pl->used_flag_ptr != 0)
2563 *pl->used_flag_ptr = 1;
2564 return temp;
2568 strcpy (temp, pl->prefix);
2569 strcat (temp, just_machine_suffix);
2570 strcat (temp, name);
2571 if (access_check (temp, mode) == 0)
2573 if (pl->used_flag_ptr != 0)
2574 *pl->used_flag_ptr = 1;
2575 return temp;
2579 /* Certain prefixes can't be used without the machine suffix
2580 when the machine or version is explicitly specified. */
2581 if (! pl->require_machine_suffix)
2583 /* Some systems have a suffix for executable files.
2584 So try appending that first. */
2585 if (file_suffix[0] != 0)
2587 strcpy (temp, pl->prefix);
2588 strcat (temp, name);
2589 strcat (temp, file_suffix);
2590 if (access_check (temp, mode) == 0)
2592 if (pl->used_flag_ptr != 0)
2593 *pl->used_flag_ptr = 1;
2594 return temp;
2598 strcpy (temp, pl->prefix);
2599 strcat (temp, name);
2600 if (access_check (temp, mode) == 0)
2602 if (pl->used_flag_ptr != 0)
2603 *pl->used_flag_ptr = 1;
2604 return temp;
2609 free (temp);
2610 return 0;
2613 /* Ranking of prefixes in the sort list. -B prefixes are put before
2614 all others. */
2616 enum path_prefix_priority
2618 PREFIX_PRIORITY_B_OPT,
2619 PREFIX_PRIORITY_LAST
2622 /* Add an entry for PREFIX in PLIST. The PLIST is kept in assending
2623 order according to PRIORITY. Within each PRIORITY, new entries are
2624 appended.
2626 If WARN is nonzero, we will warn if no file is found
2627 through this prefix. WARN should point to an int
2628 which will be set to 1 if this entry is used.
2630 COMPONENT is the value to be passed to update_path.
2632 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2633 the complete value of machine_suffix.
2634 2 means try both machine_suffix and just_machine_suffix. */
2636 static void
2637 add_prefix (pprefix, prefix, component, priority, require_machine_suffix, warn)
2638 struct path_prefix *pprefix;
2639 const char *prefix;
2640 const char *component;
2641 /* enum prefix_priority */ int priority;
2642 int require_machine_suffix;
2643 int *warn;
2645 struct prefix_list *pl, **prev;
2646 int len;
2648 for (prev = &pprefix->plist;
2649 (*prev) != NULL && (*prev)->priority <= priority;
2650 prev = &(*prev)->next)
2653 /* Keep track of the longest prefix */
2655 prefix = update_path (prefix, component);
2656 len = strlen (prefix);
2657 if (len > pprefix->max_len)
2658 pprefix->max_len = len;
2660 pl = (struct prefix_list *) xmalloc (sizeof (struct prefix_list));
2661 pl->prefix = prefix;
2662 pl->require_machine_suffix = require_machine_suffix;
2663 pl->used_flag_ptr = warn;
2664 pl->priority = priority;
2665 if (warn)
2666 *warn = 0;
2668 /* Insert after PREV */
2669 pl->next = (*prev);
2670 (*prev) = pl;
2673 /* Execute the command specified by the arguments on the current line of spec.
2674 When using pipes, this includes several piped-together commands
2675 with `|' between them.
2677 Return 0 if successful, -1 if failed. */
2679 static int
2680 execute ()
2682 int i;
2683 int n_commands; /* # of command. */
2684 char *string;
2685 struct command
2687 const char *prog; /* program name. */
2688 const char **argv; /* vector of args. */
2689 int pid; /* pid of process for this command. */
2692 struct command *commands; /* each command buffer with above info. */
2694 /* Count # of piped commands. */
2695 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2696 if (strcmp (argbuf[i], "|") == 0)
2697 n_commands++;
2699 /* Get storage for each command. */
2700 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2702 /* Split argbuf into its separate piped processes,
2703 and record info about each one.
2704 Also search for the programs that are to be run. */
2706 commands[0].prog = argbuf[0]; /* first command. */
2707 commands[0].argv = &argbuf[0];
2708 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK);
2710 if (string)
2711 commands[0].argv[0] = string;
2713 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2714 if (strcmp (argbuf[i], "|") == 0)
2715 { /* each command. */
2716 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2717 fatal ("-pipe not supported");
2718 #endif
2719 argbuf[i] = 0; /* termination of command args. */
2720 commands[n_commands].prog = argbuf[i + 1];
2721 commands[n_commands].argv = &argbuf[i + 1];
2722 string = find_a_file (&exec_prefixes, commands[n_commands].prog, X_OK);
2723 if (string)
2724 commands[n_commands].argv[0] = string;
2725 n_commands++;
2728 argbuf[argbuf_index] = 0;
2730 /* If -v, print what we are about to do, and maybe query. */
2732 if (verbose_flag)
2734 /* For help listings, put a blank line between sub-processes. */
2735 if (print_help_list)
2736 fputc ('\n', stderr);
2738 /* Print each piped command as a separate line. */
2739 for (i = 0; i < n_commands; i++)
2741 const char *const *j;
2743 if (verbose_only_flag)
2745 for (j = commands[i].argv; *j; j++)
2747 const char *p;
2748 fprintf (stderr, " \"");
2749 for (p = *j; *p; ++p)
2751 if (*p == '"' || *p == '\\' || *p == '$')
2752 fputc ('\\', stderr);
2753 fputc (*p, stderr);
2755 fputc ('"', stderr);
2758 else
2759 for (j = commands[i].argv; *j; j++)
2760 fprintf (stderr, " %s", *j);
2762 /* Print a pipe symbol after all but the last command. */
2763 if (i + 1 != n_commands)
2764 fprintf (stderr, " |");
2765 fprintf (stderr, "\n");
2767 fflush (stderr);
2768 if (verbose_only_flag != 0)
2769 return 0;
2770 #ifdef DEBUG
2771 notice ("\nGo ahead? (y or n) ");
2772 fflush (stderr);
2773 i = getchar ();
2774 if (i != '\n')
2775 while (getchar () != '\n')
2778 if (i != 'y' && i != 'Y')
2779 return 0;
2780 #endif /* DEBUG */
2783 /* Run each piped subprocess. */
2785 for (i = 0; i < n_commands; i++)
2787 char *errmsg_fmt, *errmsg_arg;
2788 const char *string = commands[i].argv[0];
2790 /* For some bizarre reason, the second argument of execvp() is
2791 char *const *, not const char *const *. */
2792 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2793 programname, temp_filename,
2794 &errmsg_fmt, &errmsg_arg,
2795 ((i == 0 ? PEXECUTE_FIRST : 0)
2796 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2797 | (string == commands[i].prog
2798 ? PEXECUTE_SEARCH : 0)
2799 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2801 if (commands[i].pid == -1)
2802 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2804 if (string != commands[i].prog)
2805 free ((PTR) string);
2808 execution_count++;
2810 /* Wait for all the subprocesses to finish.
2811 We don't care what order they finish in;
2812 we know that N_COMMANDS waits will get them all.
2813 Ignore subprocesses that we don't know about,
2814 since they can be spawned by the process that exec'ed us. */
2817 int ret_code = 0;
2818 #ifdef HAVE_GETRUSAGE
2819 struct timeval d;
2820 double ut = 0.0, st = 0.0;
2821 #endif
2823 for (i = 0; i < n_commands;)
2825 int j;
2826 int status;
2827 int pid;
2829 pid = pwait (commands[i].pid, &status, 0);
2830 if (pid < 0)
2831 abort ();
2833 #ifdef HAVE_GETRUSAGE
2834 if (report_times)
2836 /* getrusage returns the total resource usage of all children
2837 up to now. Copy the previous values into prus, get the
2838 current statistics, then take the difference. */
2840 prus = rus;
2841 getrusage (RUSAGE_CHILDREN, &rus);
2842 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2843 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2844 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2846 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2847 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2848 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2850 #endif
2852 for (j = 0; j < n_commands; j++)
2853 if (commands[j].pid == pid)
2855 i++;
2856 if (WIFSIGNALED (status))
2858 #ifdef SIGPIPE
2859 /* SIGPIPE is a special case. It happens in -pipe mode
2860 when the compiler dies before the preprocessor is
2861 done, or the assembler dies before the compiler is
2862 done. There's generally been an error already, and
2863 this is just fallout. So don't generate another error
2864 unless we would otherwise have succeeded. */
2865 if (WTERMSIG (status) == SIGPIPE
2866 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2868 else
2869 #endif
2870 fatal ("\
2871 Internal error: %s (program %s)\n\
2872 Please submit a full bug report.\n\
2873 See %s for instructions.",
2874 strsignal (WTERMSIG (status)), commands[j].prog,
2875 GCCBUGURL);
2876 signal_count++;
2877 ret_code = -1;
2879 else if (WIFEXITED (status)
2880 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2882 if (WEXITSTATUS (status) > greatest_status)
2883 greatest_status = WEXITSTATUS (status);
2884 ret_code = -1;
2886 #ifdef HAVE_GETRUSAGE
2887 if (report_times && ut + st != 0)
2888 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2889 #endif
2890 break;
2893 return ret_code;
2897 /* Find all the switches given to us
2898 and make a vector describing them.
2899 The elements of the vector are strings, one per switch given.
2900 If a switch uses following arguments, then the `part1' field
2901 is the switch itself and the `args' field
2902 is a null-terminated vector containing the following arguments.
2903 The `live_cond' field is:
2904 0 when initialized
2905 1 if the switch is true in a conditional spec,
2906 -1 if false (overridden by a later switch)
2907 -2 if this switch should be ignored (used in %{<S})
2908 The `validated' field is nonzero if any spec has looked at this switch;
2909 if it remains zero at the end of the run, it must be meaningless. */
2911 #define SWITCH_OK 0
2912 #define SWITCH_FALSE -1
2913 #define SWITCH_IGNORE -2
2914 #define SWITCH_LIVE 1
2916 struct switchstr
2918 const char *part1;
2919 const char **args;
2920 int live_cond;
2921 unsigned char validated;
2922 unsigned char ordering;
2925 static struct switchstr *switches;
2927 static int n_switches;
2929 struct infile
2931 const char *name;
2932 const char *language;
2935 /* Also a vector of input files specified. */
2937 static struct infile *infiles;
2939 int n_infiles;
2941 /* This counts the number of libraries added by lang_specific_driver, so that
2942 we can tell if there were any user supplied any files or libraries. */
2944 static int added_libraries;
2946 /* And a vector of corresponding output files is made up later. */
2948 const char **outfiles;
2950 /* Used to track if none of the -B paths are used. */
2951 static int warn_B;
2953 /* Used to track if standard path isn't used and -b or -V is specified. */
2954 static int warn_std;
2956 /* Gives value to pass as "warn" to add_prefix for standard prefixes. */
2957 static int *warn_std_ptr = 0;
2959 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2961 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2962 is true if we should look for an executable suffix. DO_OBJ
2963 is true if we should look for an object suffix. */
2965 static const char *
2966 convert_filename (name, do_exe, do_obj)
2967 const char *name;
2968 int do_exe ATTRIBUTE_UNUSED;
2969 int do_obj ATTRIBUTE_UNUSED;
2971 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2972 int i;
2973 #endif
2974 int len;
2976 if (name == NULL)
2977 return NULL;
2979 len = strlen (name);
2981 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2982 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2983 if (do_obj && len > 2
2984 && name[len - 2] == '.'
2985 && name[len - 1] == 'o')
2987 obstack_grow (&obstack, name, len - 2);
2988 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2989 name = obstack_finish (&obstack);
2991 #endif
2993 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2994 /* If there is no filetype, make it the executable suffix (which includes
2995 the "."). But don't get confused if we have just "-o". */
2996 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2997 return name;
2999 for (i = len - 1; i >= 0; i--)
3000 if (IS_DIR_SEPARATOR (name[i]))
3001 break;
3003 for (i++; i < len; i++)
3004 if (name[i] == '.')
3005 return name;
3007 obstack_grow (&obstack, name, len);
3008 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3009 strlen (TARGET_EXECUTABLE_SUFFIX));
3010 name = obstack_finish (&obstack);
3011 #endif
3013 return name;
3015 #endif
3017 /* Display the command line switches accepted by gcc. */
3018 static void
3019 display_help ()
3021 printf (_("Usage: %s [options] file...\n"), programname);
3022 fputs (_("Options:\n"), stdout);
3024 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3025 fputs (_(" --help Display this information\n"), stdout);
3026 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3027 if (! verbose_flag)
3028 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3029 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3030 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3031 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3032 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3033 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3034 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3035 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3036 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3037 fputs (_("\
3038 -print-multi-lib Display the mapping between command line options and\n\
3039 multiple library search directories\n"), stdout);
3040 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3041 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3042 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3043 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3044 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3045 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3046 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3047 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3048 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3049 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3050 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3051 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3052 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3053 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3054 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3055 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3056 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3057 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3058 fputs (_("\
3059 -x <language> Specify the language of the following input files\n\
3060 Permissable languages include: c c++ assembler none\n\
3061 'none' means revert to the default behavior of\n\
3062 guessing the language based on the file's extension\n\
3063 "), stdout);
3065 printf (_("\
3066 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3067 passed on to the various sub-processes invoked by %s. In order to pass\n\
3068 other options on to these processes the -W<letter> options must be used.\n\
3069 "), programname);
3071 /* The rest of the options are displayed by invocations of the various
3072 sub-processes. */
3075 static void
3076 add_preprocessor_option (option, len)
3077 const char *option;
3078 int len;
3080 n_preprocessor_options++;
3082 if (! preprocessor_options)
3083 preprocessor_options
3084 = (char **) xmalloc (n_preprocessor_options * sizeof (char *));
3085 else
3086 preprocessor_options
3087 = (char **) xrealloc (preprocessor_options,
3088 n_preprocessor_options * sizeof (char *));
3090 preprocessor_options [n_preprocessor_options - 1] =
3091 save_string (option, len);
3094 static void
3095 add_assembler_option (option, len)
3096 const char *option;
3097 int len;
3099 n_assembler_options++;
3101 if (! assembler_options)
3102 assembler_options
3103 = (char **) xmalloc (n_assembler_options * sizeof (char *));
3104 else
3105 assembler_options
3106 = (char **) xrealloc (assembler_options,
3107 n_assembler_options * sizeof (char *));
3109 assembler_options [n_assembler_options - 1] = save_string (option, len);
3112 static void
3113 add_linker_option (option, len)
3114 const char *option;
3115 int len;
3117 n_linker_options++;
3119 if (! linker_options)
3120 linker_options
3121 = (char **) xmalloc (n_linker_options * sizeof (char *));
3122 else
3123 linker_options
3124 = (char **) xrealloc (linker_options,
3125 n_linker_options * sizeof (char *));
3127 linker_options [n_linker_options - 1] = save_string (option, len);
3130 /* Create the vector `switches' and its contents.
3131 Store its length in `n_switches'. */
3133 static void
3134 process_command (argc, argv)
3135 int argc;
3136 const char *const *argv;
3138 int i;
3139 const char *temp;
3140 char *temp1;
3141 const char *spec_lang = 0;
3142 int last_language_n_infiles;
3143 int have_c = 0;
3144 int have_o = 0;
3145 int lang_n_infiles = 0;
3146 #ifdef MODIFY_TARGET_NAME
3147 int is_modify_target_name;
3148 int j;
3149 #endif
3151 GET_ENV_PATH_LIST (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3153 n_switches = 0;
3154 n_infiles = 0;
3155 added_libraries = 0;
3157 /* Figure compiler version from version string. */
3159 compiler_version = temp1 = xstrdup (version_string);
3161 for (; *temp1; ++temp1)
3163 if (*temp1 == ' ')
3165 *temp1 = '\0';
3166 break;
3170 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3171 see if we can create it from the pathname specified in argv[0]. */
3173 #ifndef VMS
3174 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3175 if (!gcc_exec_prefix)
3177 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3178 standard_exec_prefix);
3179 if (gcc_exec_prefix)
3180 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3182 #endif
3184 if (gcc_exec_prefix)
3186 int len = strlen (gcc_exec_prefix);
3188 if (len > (int) sizeof ("/lib/gcc-lib/") - 1
3189 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3191 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc-lib/") + 1;
3192 if (IS_DIR_SEPARATOR (*temp)
3193 && strncmp (temp + 1, "lib", 3) == 0
3194 && IS_DIR_SEPARATOR (temp[4])
3195 && strncmp (temp + 5, "gcc-lib", 7) == 0)
3196 len -= sizeof ("/lib/gcc-lib/") - 1;
3199 set_std_prefix (gcc_exec_prefix, len);
3200 add_prefix (&exec_prefixes, gcc_exec_prefix, "GCC",
3201 PREFIX_PRIORITY_LAST, 0, NULL);
3202 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3203 PREFIX_PRIORITY_LAST, 0, NULL);
3206 /* COMPILER_PATH and LIBRARY_PATH have values
3207 that are lists of directory names with colons. */
3209 GET_ENV_PATH_LIST (temp, "COMPILER_PATH");
3210 if (temp)
3212 const char *startp, *endp;
3213 char *nstore = (char *) alloca (strlen (temp) + 3);
3215 startp = endp = temp;
3216 while (1)
3218 if (*endp == PATH_SEPARATOR || *endp == 0)
3220 strncpy (nstore, startp, endp - startp);
3221 if (endp == startp)
3222 strcpy (nstore, concat (".", dir_separator_str, NULL));
3223 else if (!IS_DIR_SEPARATOR (endp[-1]))
3225 nstore[endp - startp] = DIR_SEPARATOR;
3226 nstore[endp - startp + 1] = 0;
3228 else
3229 nstore[endp - startp] = 0;
3230 add_prefix (&exec_prefixes, nstore, 0,
3231 PREFIX_PRIORITY_LAST, 0, NULL);
3232 add_prefix (&include_prefixes,
3233 concat (nstore, "include", NULL),
3234 0, PREFIX_PRIORITY_LAST, 0, NULL);
3235 if (*endp == 0)
3236 break;
3237 endp = startp = endp + 1;
3239 else
3240 endp++;
3244 GET_ENV_PATH_LIST (temp, LIBRARY_PATH_ENV);
3245 if (temp && *cross_compile == '0')
3247 const char *startp, *endp;
3248 char *nstore = (char *) alloca (strlen (temp) + 3);
3250 startp = endp = temp;
3251 while (1)
3253 if (*endp == PATH_SEPARATOR || *endp == 0)
3255 strncpy (nstore, startp, endp - startp);
3256 if (endp == startp)
3257 strcpy (nstore, concat (".", dir_separator_str, NULL));
3258 else if (!IS_DIR_SEPARATOR (endp[-1]))
3260 nstore[endp - startp] = DIR_SEPARATOR;
3261 nstore[endp - startp + 1] = 0;
3263 else
3264 nstore[endp - startp] = 0;
3265 add_prefix (&startfile_prefixes, nstore, NULL,
3266 PREFIX_PRIORITY_LAST, 0, NULL);
3267 if (*endp == 0)
3268 break;
3269 endp = startp = endp + 1;
3271 else
3272 endp++;
3276 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3277 GET_ENV_PATH_LIST (temp, "LPATH");
3278 if (temp && *cross_compile == '0')
3280 const char *startp, *endp;
3281 char *nstore = (char *) alloca (strlen (temp) + 3);
3283 startp = endp = temp;
3284 while (1)
3286 if (*endp == PATH_SEPARATOR || *endp == 0)
3288 strncpy (nstore, startp, endp - startp);
3289 if (endp == startp)
3290 strcpy (nstore, concat (".", dir_separator_str, NULL));
3291 else if (!IS_DIR_SEPARATOR (endp[-1]))
3293 nstore[endp - startp] = DIR_SEPARATOR;
3294 nstore[endp - startp + 1] = 0;
3296 else
3297 nstore[endp - startp] = 0;
3298 add_prefix (&startfile_prefixes, nstore, NULL,
3299 PREFIX_PRIORITY_LAST, 0, NULL);
3300 if (*endp == 0)
3301 break;
3302 endp = startp = endp + 1;
3304 else
3305 endp++;
3309 /* Convert new-style -- options to old-style. */
3310 translate_options (&argc, &argv);
3312 /* Do language-specific adjustment/addition of flags. */
3313 lang_specific_driver (&argc, &argv, &added_libraries);
3315 /* Scan argv twice. Here, the first time, just count how many switches
3316 there will be in their vector, and how many input files in theirs.
3317 Also parse any switches that determine the configuration name, such as -b.
3318 Here we also parse the switches that cc itself uses (e.g. -v). */
3320 for (i = 1; i < argc; i++)
3322 if (! strcmp (argv[i], "-dumpspecs"))
3324 struct spec_list *sl;
3325 init_spec ();
3326 for (sl = specs; sl; sl = sl->next)
3327 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3328 if (link_command_spec)
3329 printf ("*link_command:\n%s\n\n", link_command_spec);
3330 exit (0);
3332 else if (! strcmp (argv[i], "-dumpversion"))
3334 printf ("%s\n", spec_version);
3335 exit (0);
3337 else if (! strcmp (argv[i], "-dumpmachine"))
3339 printf ("%s\n", spec_machine);
3340 exit (0);
3342 else if (strcmp (argv[i], "-fversion") == 0)
3344 /* translate_options () has turned --version into -fversion. */
3345 printf (_("%s (GCC) %s\n"), programname, version_string);
3346 fputs (_("Copyright (C) 2002 Free Software Foundation, Inc.\n"),
3347 stdout);
3348 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3349 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3350 stdout);
3351 exit (0);
3353 else if (strcmp (argv[i], "-fhelp") == 0)
3355 /* translate_options () has turned --help into -fhelp. */
3356 print_help_list = 1;
3358 /* We will be passing a dummy file on to the sub-processes. */
3359 n_infiles++;
3360 n_switches++;
3362 /* CPP driver cannot obtain switch from cc1_options. */
3363 if (is_cpp_driver)
3364 add_preprocessor_option ("--help", 6);
3365 add_assembler_option ("--help", 6);
3366 add_linker_option ("--help", 6);
3368 else if (strcmp (argv[i], "-ftarget-help") == 0)
3370 /* translate_options() has turned --target-help into -ftarget-help. */
3371 target_help_flag = 1;
3373 /* We will be passing a dummy file on to the sub-processes. */
3374 n_infiles++;
3375 n_switches++;
3377 /* CPP driver cannot obtain switch from cc1_options. */
3378 if (is_cpp_driver)
3379 add_preprocessor_option ("--target-help", 13);
3380 add_assembler_option ("--target-help", 13);
3381 add_linker_option ("--target-help", 13);
3383 else if (! strcmp (argv[i], "-pass-exit-codes"))
3385 pass_exit_codes = 1;
3386 n_switches++;
3388 else if (! strcmp (argv[i], "-print-search-dirs"))
3389 print_search_dirs = 1;
3390 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3391 print_file_name = "libgcc.a";
3392 else if (! strncmp (argv[i], "-print-file-name=", 17))
3393 print_file_name = argv[i] + 17;
3394 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3395 print_prog_name = argv[i] + 17;
3396 else if (! strcmp (argv[i], "-print-multi-lib"))
3397 print_multi_lib = 1;
3398 else if (! strcmp (argv[i], "-print-multi-directory"))
3399 print_multi_directory = 1;
3400 else if (! strncmp (argv[i], "-Wa,", 4))
3402 int prev, j;
3403 /* Pass the rest of this option to the assembler. */
3405 /* Split the argument at commas. */
3406 prev = 4;
3407 for (j = 4; argv[i][j]; j++)
3408 if (argv[i][j] == ',')
3410 add_assembler_option (argv[i] + prev, j - prev);
3411 prev = j + 1;
3414 /* Record the part after the last comma. */
3415 add_assembler_option (argv[i] + prev, j - prev);
3417 else if (! strncmp (argv[i], "-Wp,", 4))
3419 int prev, j;
3420 /* Pass the rest of this option to the preprocessor. */
3422 /* Split the argument at commas. */
3423 prev = 4;
3424 for (j = 4; argv[i][j]; j++)
3425 if (argv[i][j] == ',')
3427 add_preprocessor_option (argv[i] + prev, j - prev);
3428 prev = j + 1;
3431 /* Record the part after the last comma. */
3432 add_preprocessor_option (argv[i] + prev, j - prev);
3434 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3435 /* The +e options to the C++ front-end. */
3436 n_switches++;
3437 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3439 int j;
3440 /* Split the argument at commas. */
3441 for (j = 3; argv[i][j]; j++)
3442 n_infiles += (argv[i][j] == ',');
3444 else if (strcmp (argv[i], "-Xlinker") == 0)
3446 if (i + 1 == argc)
3447 fatal ("argument to `-Xlinker' is missing");
3449 n_infiles++;
3450 i++;
3452 else if (strcmp (argv[i], "-l") == 0)
3454 if (i + 1 == argc)
3455 fatal ("argument to `-l' is missing");
3457 n_infiles++;
3458 i++;
3460 else if (strncmp (argv[i], "-l", 2) == 0)
3461 n_infiles++;
3462 else if (strcmp (argv[i], "-save-temps") == 0)
3464 save_temps_flag = 1;
3465 n_switches++;
3467 else if (strcmp (argv[i], "-specs") == 0)
3469 struct user_specs *user = (struct user_specs *)
3470 xmalloc (sizeof (struct user_specs));
3471 if (++i >= argc)
3472 fatal ("argument to `-specs' is missing");
3474 user->next = (struct user_specs *) 0;
3475 user->filename = argv[i];
3476 if (user_specs_tail)
3477 user_specs_tail->next = user;
3478 else
3479 user_specs_head = user;
3480 user_specs_tail = user;
3482 else if (strncmp (argv[i], "-specs=", 7) == 0)
3484 struct user_specs *user = (struct user_specs *)
3485 xmalloc (sizeof (struct user_specs));
3486 if (strlen (argv[i]) == 7)
3487 fatal ("argument to `-specs=' is missing");
3489 user->next = (struct user_specs *) 0;
3490 user->filename = argv[i] + 7;
3491 if (user_specs_tail)
3492 user_specs_tail->next = user;
3493 else
3494 user_specs_head = user;
3495 user_specs_tail = user;
3497 else if (strcmp (argv[i], "-time") == 0)
3498 report_times = 1;
3499 else if (strcmp (argv[i], "-###") == 0)
3501 /* This is similar to -v except that there is no execution
3502 of the commands and the echoed arguments are quoted. It
3503 is intended for use in shell scripts to capture the
3504 driver-generated command line. */
3505 verbose_only_flag++;
3506 verbose_flag++;
3508 else if (argv[i][0] == '-' && argv[i][1] != 0)
3510 const char *p = &argv[i][1];
3511 int c = *p;
3513 switch (c)
3515 case 'b':
3516 n_switches++;
3517 if (p[1] == 0 && i + 1 == argc)
3518 fatal ("argument to `-b' is missing");
3519 if (p[1] == 0)
3520 spec_machine = argv[++i];
3521 else
3522 spec_machine = p + 1;
3524 warn_std_ptr = &warn_std;
3525 break;
3527 case 'B':
3529 const char *value;
3530 int len;
3532 if (p[1] == 0 && i + 1 == argc)
3533 fatal ("argument to `-B' is missing");
3534 if (p[1] == 0)
3535 value = argv[++i];
3536 else
3537 value = p + 1;
3539 len = strlen (value);
3541 /* Catch the case where the user has forgotten to append a
3542 directory separator to the path. Note, they may be using
3543 -B to add an executable name prefix, eg "i386-elf-", in
3544 order to distinguish between multiple installations of
3545 GCC in the same directory. Hence we must check to see
3546 if appending a directory separator actually makes a
3547 valid directory name. */
3548 if (! IS_DIR_SEPARATOR (value [len - 1])
3549 && is_directory (value, "", 0))
3551 char *tmp = xmalloc (len + 2);
3552 strcpy (tmp, value);
3553 tmp[len] = DIR_SEPARATOR;
3554 tmp[++ len] = 0;
3555 value = tmp;
3558 /* As a kludge, if the arg is "[foo/]stageN/", just
3559 add "[foo/]include" to the include prefix. */
3560 if ((len == 7
3561 || (len > 7
3562 && (IS_DIR_SEPARATOR (value[len - 8]))))
3563 && strncmp (value + len - 7, "stage", 5) == 0
3564 && ISDIGIT (value[len - 2])
3565 && (IS_DIR_SEPARATOR (value[len - 1])))
3567 if (len == 7)
3568 add_prefix (&include_prefixes, "include", NULL,
3569 PREFIX_PRIORITY_B_OPT, 0, NULL);
3570 else
3572 char * string = xmalloc (len + 1);
3574 strncpy (string, value, len - 7);
3575 strcpy (string + len - 7, "include");
3576 add_prefix (&include_prefixes, string, NULL,
3577 PREFIX_PRIORITY_B_OPT, 0, NULL);
3581 add_prefix (&exec_prefixes, value, NULL,
3582 PREFIX_PRIORITY_B_OPT, 0, &warn_B);
3583 add_prefix (&startfile_prefixes, value, NULL,
3584 PREFIX_PRIORITY_B_OPT, 0, &warn_B);
3585 add_prefix (&include_prefixes, concat (value, "include", NULL),
3586 NULL, PREFIX_PRIORITY_B_OPT, 0, NULL);
3587 n_switches++;
3589 break;
3591 case 'v': /* Print our subcommands and print versions. */
3592 n_switches++;
3593 /* If they do anything other than exactly `-v', don't set
3594 verbose_flag; rather, continue on to give the error. */
3595 if (p[1] != 0)
3596 break;
3597 verbose_flag++;
3598 break;
3600 case 'V':
3601 n_switches++;
3602 if (p[1] == 0 && i + 1 == argc)
3603 fatal ("argument to `-V' is missing");
3604 if (p[1] == 0)
3605 spec_version = argv[++i];
3606 else
3607 spec_version = p + 1;
3608 compiler_version = spec_version;
3609 warn_std_ptr = &warn_std;
3611 /* Validate the version number. Use the same checks
3612 done when inserting it into a spec.
3614 The format of the version string is
3615 ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)? */
3617 const char *v = compiler_version;
3619 /* Ignore leading non-digits. i.e. "foo-" in "foo-2.7.2". */
3620 while (! ISDIGIT (*v))
3621 v++;
3623 if (v > compiler_version && v[-1] != '-')
3624 fatal ("invalid version number format");
3626 /* Set V after the first period. */
3627 while (ISDIGIT (*v))
3628 v++;
3630 if (*v != '.')
3631 fatal ("invalid version number format");
3633 v++;
3634 while (ISDIGIT (*v))
3635 v++;
3637 if (*v != 0 && *v != ' ' && *v != '.' && *v != '-')
3638 fatal ("invalid version number format");
3640 break;
3642 case 'S':
3643 case 'c':
3644 if (p[1] == 0)
3646 have_c = 1;
3647 n_switches++;
3648 break;
3650 goto normal_switch;
3652 case 'o':
3653 have_o = 1;
3654 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3655 if (! have_c)
3657 int skip;
3659 /* Forward scan, just in case -S or -c is specified
3660 after -o. */
3661 int j = i + 1;
3662 if (p[1] == 0)
3663 ++j;
3664 while (j < argc)
3666 if (argv[j][0] == '-')
3668 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3669 && argv[j][2] == 0)
3671 have_c = 1;
3672 break;
3674 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3675 j += skip - (argv[j][2] != 0);
3676 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3677 j += skip;
3679 j++;
3682 #endif
3683 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3684 if (p[1] == 0)
3685 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3686 else
3687 argv[i] = convert_filename (argv[i], ! have_c, 0);
3688 #endif
3689 goto normal_switch;
3691 default:
3692 normal_switch:
3694 #ifdef MODIFY_TARGET_NAME
3695 is_modify_target_name = 0;
3697 for (j = 0;
3698 j < sizeof modify_target / sizeof modify_target[0]; j++)
3699 if (! strcmp (argv[i], modify_target[j].sw))
3701 char *new_name
3702 = (char *) xmalloc (strlen (modify_target[j].str)
3703 + strlen (spec_machine));
3704 const char *p, *r;
3705 char *q;
3706 int made_addition = 0;
3708 is_modify_target_name = 1;
3709 for (p = spec_machine, q = new_name; *p != 0; )
3711 if (modify_target[j].add_del == DELETE
3712 && (! strncmp (q, modify_target[j].str,
3713 strlen (modify_target[j].str))))
3714 p += strlen (modify_target[j].str);
3715 else if (modify_target[j].add_del == ADD
3716 && ! made_addition && *p == '-')
3718 for (r = modify_target[j].str; *r != 0; )
3719 *q++ = *r++;
3720 made_addition = 1;
3723 *q++ = *p++;
3726 spec_machine = new_name;
3729 if (is_modify_target_name)
3730 break;
3731 #endif
3733 n_switches++;
3735 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3736 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3737 else if (WORD_SWITCH_TAKES_ARG (p))
3738 i += WORD_SWITCH_TAKES_ARG (p);
3741 else
3743 n_infiles++;
3744 lang_n_infiles++;
3748 if (have_c && have_o && lang_n_infiles > 1)
3749 fatal ("cannot specify -o with -c or -S and multiple compilations");
3751 /* Set up the search paths before we go looking for config files. */
3753 /* These come before the md prefixes so that we will find gcc's subcommands
3754 (such as cpp) rather than those of the host system. */
3755 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3756 as well as trying the machine and the version. */
3757 #ifndef OS2
3758 add_prefix (&exec_prefixes, standard_exec_prefix, "GCC",
3759 PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3760 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3761 PREFIX_PRIORITY_LAST, 2, warn_std_ptr);
3762 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3763 PREFIX_PRIORITY_LAST, 2, warn_std_ptr);
3764 #endif
3766 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3767 PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3768 add_prefix (&startfile_prefixes, standard_exec_prefix_1, "BINUTILS",
3769 PREFIX_PRIORITY_LAST, 1, warn_std_ptr);
3771 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3772 dir_separator_str, NULL);
3774 /* If tooldir is relative, base it on exec_prefixes. A relative
3775 tooldir lets us move the installed tree as a unit.
3777 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3778 directories, so that we can search both the user specified directory
3779 and the standard place. */
3781 if (!IS_ABSOLUTE_PATHNAME (tooldir_prefix))
3783 if (gcc_exec_prefix)
3785 char *gcc_exec_tooldir_prefix
3786 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3787 spec_version, dir_separator_str, tooldir_prefix, NULL);
3789 add_prefix (&exec_prefixes,
3790 concat (gcc_exec_tooldir_prefix, "bin",
3791 dir_separator_str, NULL),
3792 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
3793 add_prefix (&startfile_prefixes,
3794 concat (gcc_exec_tooldir_prefix, "lib",
3795 dir_separator_str, NULL),
3796 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
3799 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3800 dir_separator_str, spec_version,
3801 dir_separator_str, tooldir_prefix, NULL);
3804 add_prefix (&exec_prefixes,
3805 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3806 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
3807 add_prefix (&startfile_prefixes,
3808 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3809 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
3811 /* More prefixes are enabled in main, after we read the specs file
3812 and determine whether this is cross-compilation or not. */
3814 /* Then create the space for the vectors and scan again. */
3816 switches = ((struct switchstr *)
3817 xmalloc ((n_switches + 1) * sizeof (struct switchstr)));
3818 infiles = (struct infile *) xmalloc ((n_infiles + 1) * sizeof (struct infile));
3819 n_switches = 0;
3820 n_infiles = 0;
3821 last_language_n_infiles = -1;
3823 /* This, time, copy the text of each switch and store a pointer
3824 to the copy in the vector of switches.
3825 Store all the infiles in their vector. */
3827 for (i = 1; i < argc; i++)
3829 /* Just skip the switches that were handled by the preceding loop. */
3830 #ifdef MODIFY_TARGET_NAME
3831 is_modify_target_name = 0;
3833 for (j = 0; j < sizeof modify_target / sizeof modify_target[0]; j++)
3834 if (! strcmp (argv[i], modify_target[j].sw))
3835 is_modify_target_name = 1;
3837 if (is_modify_target_name)
3839 else
3840 #endif
3841 if (! strncmp (argv[i], "-Wa,", 4))
3843 else if (! strncmp (argv[i], "-Wp,", 4))
3845 else if (! strcmp (argv[i], "-pass-exit-codes"))
3847 else if (! strcmp (argv[i], "-print-search-dirs"))
3849 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3851 else if (! strncmp (argv[i], "-print-file-name=", 17))
3853 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3855 else if (! strcmp (argv[i], "-print-multi-lib"))
3857 else if (! strcmp (argv[i], "-print-multi-directory"))
3859 else if (! strcmp (argv[i], "-ftarget-help"))
3861 else if (! strcmp (argv[i], "-fhelp"))
3863 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3865 /* Compensate for the +e options to the C++ front-end;
3866 they're there simply for cfront call-compatibility. We do
3867 some magic in default_compilers to pass them down properly.
3868 Note we deliberately start at the `+' here, to avoid passing
3869 -e0 or -e1 down into the linker. */
3870 switches[n_switches].part1 = &argv[i][0];
3871 switches[n_switches].args = 0;
3872 switches[n_switches].live_cond = SWITCH_OK;
3873 switches[n_switches].validated = 0;
3874 n_switches++;
3876 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3878 int prev, j;
3879 /* Split the argument at commas. */
3880 prev = 4;
3881 for (j = 4; argv[i][j]; j++)
3882 if (argv[i][j] == ',')
3884 infiles[n_infiles].language = "*";
3885 infiles[n_infiles++].name
3886 = save_string (argv[i] + prev, j - prev);
3887 prev = j + 1;
3889 /* Record the part after the last comma. */
3890 infiles[n_infiles].language = "*";
3891 infiles[n_infiles++].name = argv[i] + prev;
3893 else if (strcmp (argv[i], "-Xlinker") == 0)
3895 infiles[n_infiles].language = "*";
3896 infiles[n_infiles++].name = argv[++i];
3898 else if (strcmp (argv[i], "-l") == 0)
3899 { /* POSIX allows separation of -l and the lib arg;
3900 canonicalize by concatenating -l with its arg */
3901 infiles[n_infiles].language = "*";
3902 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3904 else if (strncmp (argv[i], "-l", 2) == 0)
3906 infiles[n_infiles].language = "*";
3907 infiles[n_infiles++].name = argv[i];
3909 else if (strcmp (argv[i], "-specs") == 0)
3910 i++;
3911 else if (strncmp (argv[i], "-specs=", 7) == 0)
3913 else if (strcmp (argv[i], "-time") == 0)
3915 else if ((save_temps_flag || report_times)
3916 && strcmp (argv[i], "-pipe") == 0)
3918 /* -save-temps overrides -pipe, so that temp files are produced */
3919 if (save_temps_flag)
3920 error ("warning: -pipe ignored because -save-temps specified");
3921 /* -time overrides -pipe because we can't get correct stats when
3922 multiple children are running at once. */
3923 else if (report_times)
3924 error ("warning: -pipe ignored because -time specified");
3926 else if (strcmp (argv[i], "-###") == 0)
3928 else if (argv[i][0] == '-' && argv[i][1] != 0)
3930 const char *p = &argv[i][1];
3931 int c = *p;
3933 if (c == 'x')
3935 if (p[1] == 0 && i + 1 == argc)
3936 fatal ("argument to `-x' is missing");
3937 if (p[1] == 0)
3938 spec_lang = argv[++i];
3939 else
3940 spec_lang = p + 1;
3941 if (! strcmp (spec_lang, "none"))
3942 /* Suppress the warning if -xnone comes after the last input
3943 file, because alternate command interfaces like g++ might
3944 find it useful to place -xnone after each input file. */
3945 spec_lang = 0;
3946 else
3947 last_language_n_infiles = n_infiles;
3948 continue;
3950 switches[n_switches].part1 = p;
3951 /* Deal with option arguments in separate argv elements. */
3952 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
3953 || WORD_SWITCH_TAKES_ARG (p))
3955 int j = 0;
3956 int n_args = WORD_SWITCH_TAKES_ARG (p);
3958 if (n_args == 0)
3960 /* Count only the option arguments in separate argv elements. */
3961 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
3963 if (i + n_args >= argc)
3964 fatal ("argument to `-%s' is missing", p);
3965 switches[n_switches].args
3966 = (const char **) xmalloc ((n_args + 1) * sizeof(const char *));
3967 while (j < n_args)
3968 switches[n_switches].args[j++] = argv[++i];
3969 /* Null-terminate the vector. */
3970 switches[n_switches].args[j] = 0;
3972 else if (strchr (switches_need_spaces, c))
3974 /* On some systems, ld cannot handle some options without
3975 a space. So split the option from its argument. */
3976 char *part1 = (char *) xmalloc (2);
3977 part1[0] = c;
3978 part1[1] = '\0';
3980 switches[n_switches].part1 = part1;
3981 switches[n_switches].args
3982 = (const char **) xmalloc (2 * sizeof (const char *));
3983 switches[n_switches].args[0] = xstrdup (p+1);
3984 switches[n_switches].args[1] = 0;
3986 else
3987 switches[n_switches].args = 0;
3989 switches[n_switches].live_cond = SWITCH_OK;
3990 switches[n_switches].validated = 0;
3991 switches[n_switches].ordering = 0;
3992 /* These are always valid, since gcc.c itself understands it. */
3993 if (!strcmp (p, "save-temps")
3994 || !strcmp (p, "static-libgcc")
3995 || !strcmp (p, "shared-libgcc"))
3996 switches[n_switches].validated = 1;
3997 else
3999 char ch = switches[n_switches].part1[0];
4000 if (ch == 'V' || ch == 'b' || ch == 'B')
4001 switches[n_switches].validated = 1;
4003 n_switches++;
4005 else
4007 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4008 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4009 #endif
4011 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4013 perror_with_name (argv[i]);
4014 error_count++;
4016 else
4018 infiles[n_infiles].language = spec_lang;
4019 infiles[n_infiles++].name = argv[i];
4024 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4025 error ("warning: `-x %s' after last input file has no effect", spec_lang);
4027 /* Ensure we only invoke each subprocess once. */
4028 if (target_help_flag || print_help_list)
4030 n_infiles = 1;
4032 /* Create a dummy input file, so that we can pass --target-help on to
4033 the various sub-processes. */
4034 infiles[0].language = "c";
4035 infiles[0].name = "help-dummy";
4037 if (target_help_flag)
4039 switches[n_switches].part1 = "--target-help";
4040 switches[n_switches].args = 0;
4041 switches[n_switches].live_cond = SWITCH_OK;
4042 switches[n_switches].validated = 0;
4044 n_switches++;
4047 if (print_help_list)
4049 switches[n_switches].part1 = "--help";
4050 switches[n_switches].args = 0;
4051 switches[n_switches].live_cond = SWITCH_OK;
4052 switches[n_switches].validated = 0;
4054 n_switches++;
4058 switches[n_switches].part1 = 0;
4059 infiles[n_infiles].name = 0;
4062 /* Store switches not filtered out by %{<S} in spec in COLLECT_GCC_OPTIONS
4063 and place that in the environment. */
4065 static void
4066 set_collect_gcc_options ()
4068 int i;
4069 int first_time;
4071 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4072 the compiler. */
4073 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4074 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4076 first_time = TRUE;
4077 for (i = 0; (int) i < n_switches; i++)
4079 const char *const *args;
4080 const char *p, *q;
4081 if (!first_time)
4082 obstack_grow (&collect_obstack, " ", 1);
4084 first_time = FALSE;
4086 /* Ignore elided switches. */
4087 if (switches[i].live_cond == SWITCH_IGNORE)
4088 continue;
4090 obstack_grow (&collect_obstack, "'-", 2);
4091 q = switches[i].part1;
4092 while ((p = strchr (q, '\'')))
4094 obstack_grow (&collect_obstack, q, p - q);
4095 obstack_grow (&collect_obstack, "'\\''", 4);
4096 q = ++p;
4098 obstack_grow (&collect_obstack, q, strlen (q));
4099 obstack_grow (&collect_obstack, "'", 1);
4101 for (args = switches[i].args; args && *args; args++)
4103 obstack_grow (&collect_obstack, " '", 2);
4104 q = *args;
4105 while ((p = strchr (q, '\'')))
4107 obstack_grow (&collect_obstack, q, p - q);
4108 obstack_grow (&collect_obstack, "'\\''", 4);
4109 q = ++p;
4111 obstack_grow (&collect_obstack, q, strlen (q));
4112 obstack_grow (&collect_obstack, "'", 1);
4115 obstack_grow (&collect_obstack, "\0", 1);
4116 putenv (obstack_finish (&collect_obstack));
4119 /* Process a spec string, accumulating and running commands. */
4121 /* These variables describe the input file name.
4122 input_file_number is the index on outfiles of this file,
4123 so that the output file name can be stored for later use by %o.
4124 input_basename is the start of the part of the input file
4125 sans all directory names, and basename_length is the number
4126 of characters starting there excluding the suffix .c or whatever. */
4128 const char *input_filename;
4129 static int input_file_number;
4130 size_t input_filename_length;
4131 static int basename_length;
4132 static int suffixed_basename_length;
4133 static const char *input_basename;
4134 static const char *input_suffix;
4135 static struct stat input_stat;
4136 static int input_stat_set;
4138 /* The compiler used to process the current input file. */
4139 static struct compiler *input_file_compiler;
4141 /* These are variables used within do_spec and do_spec_1. */
4143 /* Nonzero if an arg has been started and not yet terminated
4144 (with space, tab or newline). */
4145 static int arg_going;
4147 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4148 is a temporary file name. */
4149 static int delete_this_arg;
4151 /* Nonzero means %w has been seen; the next arg to be terminated
4152 is the output file name of this compilation. */
4153 static int this_is_output_file;
4155 /* Nonzero means %s has been seen; the next arg to be terminated
4156 is the name of a library file and we should try the standard
4157 search dirs for it. */
4158 static int this_is_library_file;
4160 /* Nonzero means that the input of this command is coming from a pipe. */
4161 static int input_from_pipe;
4163 /* Nonnull means substitute this for any suffix when outputting a switches
4164 arguments. */
4165 static const char *suffix_subst;
4167 /* Process the spec SPEC and run the commands specified therein.
4168 Returns 0 if the spec is successfully processed; -1 if failed. */
4171 do_spec (spec)
4172 const char *spec;
4174 int value;
4176 clear_args ();
4177 arg_going = 0;
4178 delete_this_arg = 0;
4179 this_is_output_file = 0;
4180 this_is_library_file = 0;
4181 input_from_pipe = 0;
4182 suffix_subst = NULL;
4184 value = do_spec_1 (spec, 0, NULL);
4186 /* Force out any unfinished command.
4187 If -pipe, this forces out the last command if it ended in `|'. */
4188 if (value == 0)
4190 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4191 argbuf_index--;
4193 set_collect_gcc_options ();
4195 if (argbuf_index > 0)
4196 value = execute ();
4199 return value;
4202 /* Process the sub-spec SPEC as a portion of a larger spec.
4203 This is like processing a whole spec except that we do
4204 not initialize at the beginning and we do not supply a
4205 newline by default at the end.
4206 INSWITCH nonzero means don't process %-sequences in SPEC;
4207 in this case, % is treated as an ordinary character.
4208 This is used while substituting switches.
4209 INSWITCH nonzero also causes SPC not to terminate an argument.
4211 Value is zero unless a line was finished
4212 and the command on that line reported an error. */
4214 static int
4215 do_spec_1 (spec, inswitch, soft_matched_part)
4216 const char *spec;
4217 int inswitch;
4218 const char *soft_matched_part;
4220 const char *p = spec;
4221 int c;
4222 int i;
4223 const char *string;
4224 int value;
4226 while ((c = *p++))
4227 /* If substituting a switch, treat all chars like letters.
4228 Otherwise, NL, SPC, TAB and % are special. */
4229 switch (inswitch ? 'a' : c)
4231 case '\n':
4232 /* End of line: finish any pending argument,
4233 then run the pending command if one has been started. */
4234 if (arg_going)
4236 obstack_1grow (&obstack, 0);
4237 string = obstack_finish (&obstack);
4238 if (this_is_library_file)
4239 string = find_file (string);
4240 store_arg (string, delete_this_arg, this_is_output_file);
4241 if (this_is_output_file)
4242 outfiles[input_file_number] = string;
4244 arg_going = 0;
4246 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4248 for (i = 0; i < n_switches; i++)
4249 if (!strcmp (switches[i].part1, "pipe"))
4250 break;
4252 /* A `|' before the newline means use a pipe here,
4253 but only if -pipe was specified.
4254 Otherwise, execute now and don't pass the `|' as an arg. */
4255 if (i < n_switches)
4257 input_from_pipe = 1;
4258 switches[i].validated = 1;
4259 break;
4261 else
4262 argbuf_index--;
4265 set_collect_gcc_options ();
4267 if (argbuf_index > 0)
4269 value = execute ();
4270 if (value)
4271 return value;
4273 /* Reinitialize for a new command, and for a new argument. */
4274 clear_args ();
4275 arg_going = 0;
4276 delete_this_arg = 0;
4277 this_is_output_file = 0;
4278 this_is_library_file = 0;
4279 input_from_pipe = 0;
4280 break;
4282 case '|':
4283 /* End any pending argument. */
4284 if (arg_going)
4286 obstack_1grow (&obstack, 0);
4287 string = obstack_finish (&obstack);
4288 if (this_is_library_file)
4289 string = find_file (string);
4290 store_arg (string, delete_this_arg, this_is_output_file);
4291 if (this_is_output_file)
4292 outfiles[input_file_number] = string;
4295 /* Use pipe */
4296 obstack_1grow (&obstack, c);
4297 arg_going = 1;
4298 break;
4300 case '\t':
4301 case ' ':
4302 /* Space or tab ends an argument if one is pending. */
4303 if (arg_going)
4305 obstack_1grow (&obstack, 0);
4306 string = obstack_finish (&obstack);
4307 if (this_is_library_file)
4308 string = find_file (string);
4309 store_arg (string, delete_this_arg, this_is_output_file);
4310 if (this_is_output_file)
4311 outfiles[input_file_number] = string;
4313 /* Reinitialize for a new argument. */
4314 arg_going = 0;
4315 delete_this_arg = 0;
4316 this_is_output_file = 0;
4317 this_is_library_file = 0;
4318 break;
4320 case '%':
4321 switch (c = *p++)
4323 case 0:
4324 fatal ("invalid specification! Bug in cc");
4326 case 'b':
4327 obstack_grow (&obstack, input_basename, basename_length);
4328 arg_going = 1;
4329 break;
4331 case 'B':
4332 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4333 arg_going = 1;
4334 break;
4336 case 'd':
4337 delete_this_arg = 2;
4338 break;
4340 /* Dump out the directories specified with LIBRARY_PATH,
4341 followed by the absolute directories
4342 that we search for startfiles. */
4343 case 'D':
4345 struct prefix_list *pl = startfile_prefixes.plist;
4346 size_t bufsize = 100;
4347 char *buffer = (char *) xmalloc (bufsize);
4348 int idx;
4350 for (; pl; pl = pl->next)
4352 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4353 /* Used on systems which record the specified -L dirs
4354 and use them to search for dynamic linking. */
4355 /* Relative directories always come from -B,
4356 and it is better not to use them for searching
4357 at run time. In particular, stage1 loses. */
4358 if (!IS_ABSOLUTE_PATHNAME (pl->prefix))
4359 continue;
4360 #endif
4361 /* Try subdirectory if there is one. */
4362 if (multilib_dir != NULL)
4364 if (machine_suffix)
4366 if (strlen (pl->prefix) + strlen (machine_suffix)
4367 >= bufsize)
4368 bufsize = (strlen (pl->prefix)
4369 + strlen (machine_suffix)) * 2 + 1;
4370 buffer = (char *) xrealloc (buffer, bufsize);
4371 strcpy (buffer, pl->prefix);
4372 strcat (buffer, machine_suffix);
4373 if (is_directory (buffer, multilib_dir, 1))
4375 do_spec_1 ("-L", 0, NULL);
4376 #ifdef SPACE_AFTER_L_OPTION
4377 do_spec_1 (" ", 0, NULL);
4378 #endif
4379 do_spec_1 (buffer, 1, NULL);
4380 do_spec_1 (multilib_dir, 1, NULL);
4381 /* Make this a separate argument. */
4382 do_spec_1 (" ", 0, NULL);
4385 if (!pl->require_machine_suffix)
4387 if (is_directory (pl->prefix, multilib_dir, 1))
4389 do_spec_1 ("-L", 0, NULL);
4390 #ifdef SPACE_AFTER_L_OPTION
4391 do_spec_1 (" ", 0, NULL);
4392 #endif
4393 do_spec_1 (pl->prefix, 1, NULL);
4394 do_spec_1 (multilib_dir, 1, NULL);
4395 /* Make this a separate argument. */
4396 do_spec_1 (" ", 0, NULL);
4400 if (machine_suffix)
4402 if (is_directory (pl->prefix, machine_suffix, 1))
4404 do_spec_1 ("-L", 0, NULL);
4405 #ifdef SPACE_AFTER_L_OPTION
4406 do_spec_1 (" ", 0, NULL);
4407 #endif
4408 do_spec_1 (pl->prefix, 1, NULL);
4409 /* Remove slash from machine_suffix. */
4410 if (strlen (machine_suffix) >= bufsize)
4411 bufsize = strlen (machine_suffix) * 2 + 1;
4412 buffer = (char *) xrealloc (buffer, bufsize);
4413 strcpy (buffer, machine_suffix);
4414 idx = strlen (buffer);
4415 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4416 buffer[idx - 1] = 0;
4417 do_spec_1 (buffer, 1, NULL);
4418 /* Make this a separate argument. */
4419 do_spec_1 (" ", 0, NULL);
4422 if (!pl->require_machine_suffix)
4424 if (is_directory (pl->prefix, "", 1))
4426 do_spec_1 ("-L", 0, NULL);
4427 #ifdef SPACE_AFTER_L_OPTION
4428 do_spec_1 (" ", 0, NULL);
4429 #endif
4430 /* Remove slash from pl->prefix. */
4431 if (strlen (pl->prefix) >= bufsize)
4432 bufsize = strlen (pl->prefix) * 2 + 1;
4433 buffer = (char *) xrealloc (buffer, bufsize);
4434 strcpy (buffer, pl->prefix);
4435 idx = strlen (buffer);
4436 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4437 buffer[idx - 1] = 0;
4438 do_spec_1 (buffer, 1, NULL);
4439 /* Make this a separate argument. */
4440 do_spec_1 (" ", 0, NULL);
4444 free (buffer);
4446 break;
4448 case 'e':
4449 /* %efoo means report an error with `foo' as error message
4450 and don't execute any more commands for this file. */
4452 const char *q = p;
4453 char *buf;
4454 while (*p != 0 && *p != '\n')
4455 p++;
4456 buf = (char *) alloca (p - q + 1);
4457 strncpy (buf, q, p - q);
4458 buf[p - q] = 0;
4459 error ("%s", buf);
4460 return -1;
4462 break;
4463 case 'n':
4464 /* %nfoo means report an notice with `foo' on stderr. */
4466 const char *q = p;
4467 char *buf;
4468 while (*p != 0 && *p != '\n')
4469 p++;
4470 buf = (char *) alloca (p - q + 1);
4471 strncpy (buf, q, p - q);
4472 buf[p - q] = 0;
4473 notice ("%s\n", buf);
4474 if (*p)
4475 p++;
4477 break;
4479 case 'j':
4481 struct stat st;
4483 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is defined,
4484 and it is not a directory, and it is writable, use it.
4485 Otherwise, fall through and treat this like any other
4486 temporary file. */
4488 if ((!save_temps_flag)
4489 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4490 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4492 obstack_grow (&obstack, HOST_BIT_BUCKET,
4493 strlen (HOST_BIT_BUCKET));
4494 delete_this_arg = 0;
4495 arg_going = 1;
4496 break;
4499 case 'g':
4500 case 'u':
4501 case 'U':
4503 struct temp_name *t;
4504 int suffix_length;
4505 const char *suffix = p;
4506 char *saved_suffix = NULL;
4508 while (*p == '.' || ISALPHA ((unsigned char) *p))
4509 p++;
4510 suffix_length = p - suffix;
4511 if (p[0] == '%' && p[1] == 'O')
4513 p += 2;
4514 /* We don't support extra suffix characters after %O. */
4515 if (*p == '.' || ISALPHA ((unsigned char) *p))
4516 abort ();
4517 if (suffix_length == 0)
4518 suffix = TARGET_OBJECT_SUFFIX;
4519 else
4521 saved_suffix
4522 = (char *) xmalloc (suffix_length
4523 + strlen (TARGET_OBJECT_SUFFIX));
4524 strncpy (saved_suffix, suffix, suffix_length);
4525 strcpy (saved_suffix + suffix_length,
4526 TARGET_OBJECT_SUFFIX);
4528 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4531 /* If the input_filename has the same suffix specified
4532 for the %g, %u, or %U, and -save-temps is specified,
4533 we could end up using that file as an intermediate
4534 thus clobbering the user's source file (.e.g.,
4535 gcc -save-temps foo.s would clobber foo.s with the
4536 output of cpp0). So check for this condition and
4537 generate a temp file as the intermediate. */
4539 if (save_temps_flag)
4541 temp_filename_length = basename_length + suffix_length;
4542 temp_filename = alloca (temp_filename_length + 1);
4543 strncpy ((char *) temp_filename, input_basename, basename_length);
4544 strncpy ((char *) temp_filename + basename_length, suffix,
4545 suffix_length);
4546 *((char *) temp_filename + temp_filename_length) = '\0';
4547 if (strcmp (temp_filename, input_filename) != 0)
4549 struct stat st_temp;
4551 /* Note, set_input() resets input_stat_set to 0. */
4552 if (input_stat_set == 0)
4554 input_stat_set = stat (input_filename, &input_stat);
4555 if (input_stat_set >= 0)
4556 input_stat_set = 1;
4559 /* If we have the stat for the input_filename
4560 and we can do the stat for the temp_filename
4561 then the they could still refer to the same
4562 file if st_dev/st_ino's are the same. */
4564 if (input_stat_set != 1
4565 || stat (temp_filename, &st_temp) < 0
4566 || input_stat.st_dev != st_temp.st_dev
4567 || input_stat.st_ino != st_temp.st_ino)
4569 temp_filename = save_string (temp_filename,
4570 temp_filename_length + 1);
4571 obstack_grow (&obstack, temp_filename,
4572 temp_filename_length);
4573 arg_going = 1;
4574 break;
4579 /* See if we already have an association of %g/%u/%U and
4580 suffix. */
4581 for (t = temp_names; t; t = t->next)
4582 if (t->length == suffix_length
4583 && strncmp (t->suffix, suffix, suffix_length) == 0
4584 && t->unique == (c != 'g'))
4585 break;
4587 /* Make a new association if needed. %u and %j
4588 require one. */
4589 if (t == 0 || c == 'u' || c == 'j')
4591 if (t == 0)
4593 t = (struct temp_name *) xmalloc (sizeof (struct temp_name));
4594 t->next = temp_names;
4595 temp_names = t;
4597 t->length = suffix_length;
4598 if (saved_suffix)
4600 t->suffix = saved_suffix;
4601 saved_suffix = NULL;
4603 else
4604 t->suffix = save_string (suffix, suffix_length);
4605 t->unique = (c != 'g');
4606 temp_filename = make_temp_file (t->suffix);
4607 temp_filename_length = strlen (temp_filename);
4608 t->filename = temp_filename;
4609 t->filename_length = temp_filename_length;
4612 if (saved_suffix)
4613 free (saved_suffix);
4615 obstack_grow (&obstack, t->filename, t->filename_length);
4616 delete_this_arg = 1;
4618 arg_going = 1;
4619 break;
4621 case 'i':
4622 obstack_grow (&obstack, input_filename, input_filename_length);
4623 arg_going = 1;
4624 break;
4626 case 'I':
4628 struct prefix_list *pl = include_prefixes.plist;
4630 if (gcc_exec_prefix)
4632 do_spec_1 ("-iprefix", 1, NULL);
4633 /* Make this a separate argument. */
4634 do_spec_1 (" ", 0, NULL);
4635 do_spec_1 (gcc_exec_prefix, 1, NULL);
4636 do_spec_1 (" ", 0, NULL);
4639 for (; pl; pl = pl->next)
4641 do_spec_1 ("-isystem", 1, NULL);
4642 /* Make this a separate argument. */
4643 do_spec_1 (" ", 0, NULL);
4644 do_spec_1 (pl->prefix, 1, NULL);
4645 do_spec_1 (" ", 0, NULL);
4648 break;
4650 case 'o':
4652 int max = n_infiles;
4653 max += lang_specific_extra_outfiles;
4655 for (i = 0; i < max; i++)
4656 if (outfiles[i])
4657 store_arg (outfiles[i], 0, 0);
4658 break;
4661 case 'O':
4662 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4663 arg_going = 1;
4664 break;
4666 case 's':
4667 this_is_library_file = 1;
4668 break;
4670 case 'w':
4671 this_is_output_file = 1;
4672 break;
4674 case 'W':
4676 int cur_index = argbuf_index;
4677 /* Handle the {...} following the %W. */
4678 if (*p != '{')
4679 abort ();
4680 p = handle_braces (p + 1);
4681 if (p == 0)
4682 return -1;
4683 /* If any args were output, mark the last one for deletion
4684 on failure. */
4685 if (argbuf_index != cur_index)
4686 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4687 break;
4690 /* %x{OPTION} records OPTION for %X to output. */
4691 case 'x':
4693 const char *p1 = p;
4694 char *string;
4696 /* Skip past the option value and make a copy. */
4697 if (*p != '{')
4698 abort ();
4699 while (*p++ != '}')
4701 string = save_string (p1 + 1, p - p1 - 2);
4703 /* See if we already recorded this option. */
4704 for (i = 0; i < n_linker_options; i++)
4705 if (! strcmp (string, linker_options[i]))
4707 free (string);
4708 return 0;
4711 /* This option is new; add it. */
4712 add_linker_option (string, strlen (string));
4714 break;
4716 /* Dump out the options accumulated previously using %x. */
4717 case 'X':
4718 for (i = 0; i < n_linker_options; i++)
4720 do_spec_1 (linker_options[i], 1, NULL);
4721 /* Make each accumulated option a separate argument. */
4722 do_spec_1 (" ", 0, NULL);
4724 break;
4726 /* Dump out the options accumulated previously using -Wa,. */
4727 case 'Y':
4728 for (i = 0; i < n_assembler_options; i++)
4730 do_spec_1 (assembler_options[i], 1, NULL);
4731 /* Make each accumulated option a separate argument. */
4732 do_spec_1 (" ", 0, NULL);
4734 break;
4736 /* Dump out the options accumulated previously using -Wp,. */
4737 case 'Z':
4738 for (i = 0; i < n_preprocessor_options; i++)
4740 do_spec_1 (preprocessor_options[i], 1, NULL);
4741 /* Make each accumulated option a separate argument. */
4742 do_spec_1 (" ", 0, NULL);
4744 break;
4746 /* Here are digits and numbers that just process
4747 a certain constant string as a spec. */
4749 case '1':
4750 value = do_spec_1 (cc1_spec, 0, NULL);
4751 if (value != 0)
4752 return value;
4753 break;
4755 case '2':
4756 value = do_spec_1 (cc1plus_spec, 0, NULL);
4757 if (value != 0)
4758 return value;
4759 break;
4761 case 'a':
4762 value = do_spec_1 (asm_spec, 0, NULL);
4763 if (value != 0)
4764 return value;
4765 break;
4767 case 'A':
4768 value = do_spec_1 (asm_final_spec, 0, NULL);
4769 if (value != 0)
4770 return value;
4771 break;
4773 case 'C':
4775 const char *const spec
4776 = (input_file_compiler->cpp_spec
4777 ? input_file_compiler->cpp_spec
4778 : cpp_spec);
4779 value = do_spec_1 (spec, 0, NULL);
4780 if (value != 0)
4781 return value;
4783 break;
4785 case 'E':
4786 value = do_spec_1 (endfile_spec, 0, NULL);
4787 if (value != 0)
4788 return value;
4789 break;
4791 case 'l':
4792 value = do_spec_1 (link_spec, 0, NULL);
4793 if (value != 0)
4794 return value;
4795 break;
4797 case 'L':
4798 value = do_spec_1 (lib_spec, 0, NULL);
4799 if (value != 0)
4800 return value;
4801 break;
4803 case 'G':
4804 value = do_spec_1 (libgcc_spec, 0, NULL);
4805 if (value != 0)
4806 return value;
4807 break;
4809 case 'M':
4810 if (multilib_dir && strcmp (multilib_dir, ".") != 0)
4812 char *p;
4813 const char *q;
4814 size_t len;
4816 len = strlen (multilib_dir);
4817 obstack_blank (&obstack, len + 1);
4818 p = obstack_next_free (&obstack) - (len + 1);
4820 *p++ = '_';
4821 for (q = multilib_dir; *q ; ++q, ++p)
4822 *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
4824 break;
4826 case 'p':
4828 char *x = (char *) alloca (strlen (cpp_predefines) + 1);
4829 char *buf = x;
4830 const char *y;
4832 /* Copy all of the -D options in CPP_PREDEFINES into BUF. */
4833 y = cpp_predefines;
4834 while (*y != 0)
4836 if (! strncmp (y, "-D", 2))
4837 /* Copy the whole option. */
4838 while (*y && *y != ' ' && *y != '\t')
4839 *x++ = *y++;
4840 else if (*y == ' ' || *y == '\t')
4841 /* Copy whitespace to the result. */
4842 *x++ = *y++;
4843 /* Don't copy other options. */
4844 else
4845 y++;
4848 *x = 0;
4850 value = do_spec_1 (buf, 0, NULL);
4851 if (value != 0)
4852 return value;
4854 break;
4856 case 'P':
4858 char *x = (char *) alloca (strlen (cpp_predefines) * 4 + 1);
4859 char *buf = x;
4860 const char *y;
4862 /* Copy all of CPP_PREDEFINES into BUF,
4863 but force them all into the reserved name space if they
4864 aren't already there. The reserved name space is all
4865 identifiers beginning with two underscores or with one
4866 underscore and a capital letter. We do the forcing by
4867 adding up to two underscores to the beginning and end
4868 of each symbol. e.g. mips, _mips, mips_, and _mips_ all
4869 become __mips__. */
4870 y = cpp_predefines;
4871 while (*y != 0)
4873 if (! strncmp (y, "-D", 2))
4875 int flag = 0;
4877 *x++ = *y++;
4878 *x++ = *y++;
4880 if (*y != '_'
4881 || (*(y + 1) != '_'
4882 && ! ISUPPER ((unsigned char) *(y + 1))))
4884 /* Stick __ at front of macro name. */
4885 if (*y != '_')
4886 *x++ = '_';
4887 *x++ = '_';
4888 /* Arrange to stick __ at the end as well. */
4889 flag = 1;
4892 /* Copy the macro name. */
4893 while (*y && *y != '=' && *y != ' ' && *y != '\t')
4894 *x++ = *y++;
4896 if (flag)
4898 if (x[-1] != '_')
4900 if (x[-2] != '_')
4901 *x++ = '_';
4902 *x++ = '_';
4906 /* Copy the value given, if any. */
4907 while (*y && *y != ' ' && *y != '\t')
4908 *x++ = *y++;
4910 else if (*y == ' ' || *y == '\t')
4911 /* Copy whitespace to the result. */
4912 *x++ = *y++;
4913 /* Don't copy -A options */
4914 else
4915 y++;
4917 *x++ = ' ';
4919 /* Copy all of CPP_PREDEFINES into BUF,
4920 but put __ after every -D. */
4921 y = cpp_predefines;
4922 while (*y != 0)
4924 if (! strncmp (y, "-D", 2))
4926 y += 2;
4928 if (*y != '_'
4929 || (*(y + 1) != '_'
4930 && ! ISUPPER ((unsigned char) *(y + 1))))
4932 /* Stick -D__ at front of macro name. */
4933 *x++ = '-';
4934 *x++ = 'D';
4935 if (*y != '_')
4936 *x++ = '_';
4937 *x++ = '_';
4939 /* Copy the macro name. */
4940 while (*y && *y != '=' && *y != ' ' && *y != '\t')
4941 *x++ = *y++;
4943 /* Copy the value given, if any. */
4944 while (*y && *y != ' ' && *y != '\t')
4945 *x++ = *y++;
4947 else
4949 /* Do not copy this macro - we have just done it before */
4950 while (*y && *y != ' ' && *y != '\t')
4951 y++;
4954 else if (*y == ' ' || *y == '\t')
4955 /* Copy whitespace to the result. */
4956 *x++ = *y++;
4957 /* Don't copy -A options. */
4958 else
4959 y++;
4961 *x++ = ' ';
4963 /* Copy all of the -A options in CPP_PREDEFINES into BUF. */
4964 y = cpp_predefines;
4965 while (*y != 0)
4967 if (! strncmp (y, "-A", 2))
4968 /* Copy the whole option. */
4969 while (*y && *y != ' ' && *y != '\t')
4970 *x++ = *y++;
4971 else if (*y == ' ' || *y == '\t')
4972 /* Copy whitespace to the result. */
4973 *x++ = *y++;
4974 /* Don't copy other options. */
4975 else
4976 y++;
4979 *x = 0;
4981 value = do_spec_1 (buf, 0, NULL);
4982 if (value != 0)
4983 return value;
4985 break;
4987 case 'S':
4988 value = do_spec_1 (startfile_spec, 0, NULL);
4989 if (value != 0)
4990 return value;
4991 break;
4993 /* Here we define characters other than letters and digits. */
4995 case '{':
4996 p = handle_braces (p);
4997 if (p == 0)
4998 return -1;
4999 break;
5001 case '%':
5002 obstack_1grow (&obstack, '%');
5003 break;
5005 case '.':
5007 unsigned len = 0;
5009 while (p[len] && p[len] != ' ' && p[len] != '%')
5010 len++;
5011 suffix_subst = save_string (p - 1, len + 1);
5012 p += len;
5014 break;
5016 case '*':
5017 if (soft_matched_part)
5019 do_spec_1 (soft_matched_part, 1, NULL);
5020 do_spec_1 (" ", 0, NULL);
5022 else
5023 /* Catch the case where a spec string contains something like
5024 '%{foo:%*}'. ie there is no * in the pattern on the left
5025 hand side of the :. */
5026 error ("spec failure: '%%*' has not been initialized by pattern match");
5027 break;
5029 /* Process a string found as the value of a spec given by name.
5030 This feature allows individual machine descriptions
5031 to add and use their own specs.
5032 %[...] modifies -D options the way %P does;
5033 %(...) uses the spec unmodified. */
5034 case '[':
5035 error ("warning: use of obsolete %%[ operator in specs");
5036 case '(':
5038 const char *name = p;
5039 struct spec_list *sl;
5040 int len;
5042 /* The string after the S/P is the name of a spec that is to be
5043 processed. */
5044 while (*p && *p != ')' && *p != ']')
5045 p++;
5047 /* See if it's in the list. */
5048 for (len = p - name, sl = specs; sl; sl = sl->next)
5049 if (sl->name_len == len && !strncmp (sl->name, name, len))
5051 name = *(sl->ptr_spec);
5052 #ifdef DEBUG_SPECS
5053 notice ("Processing spec %c%s%c, which is '%s'\n",
5054 c, sl->name, (c == '(') ? ')' : ']', name);
5055 #endif
5056 break;
5059 if (sl)
5061 if (c == '(')
5063 value = do_spec_1 (name, 0, NULL);
5064 if (value != 0)
5065 return value;
5067 else
5069 char *x = (char *) alloca (strlen (name) * 2 + 1);
5070 char *buf = x;
5071 const char *y = name;
5072 int flag = 0;
5074 /* Copy all of NAME into BUF, but put __ after
5075 every -D and at the end of each arg. */
5076 while (1)
5078 if (! strncmp (y, "-D", 2))
5080 *x++ = '-';
5081 *x++ = 'D';
5082 *x++ = '_';
5083 *x++ = '_';
5084 y += 2;
5085 flag = 1;
5086 continue;
5088 else if (flag
5089 && (*y == ' ' || *y == '\t' || *y == '='
5090 || *y == '}' || *y == 0))
5092 *x++ = '_';
5093 *x++ = '_';
5094 flag = 0;
5096 if (*y == 0)
5097 break;
5098 else
5099 *x++ = *y++;
5101 *x = 0;
5103 value = do_spec_1 (buf, 0, NULL);
5104 if (value != 0)
5105 return value;
5109 /* Discard the closing paren or bracket. */
5110 if (*p)
5111 p++;
5113 break;
5115 case 'v':
5117 int c1 = *p++; /* Select first or second version number. */
5118 const char *v = compiler_version;
5119 const char *q;
5120 static const char zeroc = '0';
5122 /* The format of the version string is
5123 ([^0-9]*-)?[0-9]+[.][0-9]+([.][0-9]+)?([- ].*)? */
5125 /* Ignore leading non-digits. i.e. "foo-" in "foo-2.7.2". */
5126 while (! ISDIGIT (*v))
5127 v++;
5128 if (v > compiler_version && v[-1] != '-')
5129 abort ();
5131 /* If desired, advance to second version number. */
5132 if (c1 >= '2')
5134 /* Set V after the first period. */
5135 while (ISDIGIT (*v))
5136 v++;
5137 if (*v != '.')
5138 abort ();
5139 v++;
5142 /* If desired, advance to third version number.
5143 But don't complain if it's not present */
5144 if (c1 == '3')
5146 /* Set V after the second period. */
5147 while (ISDIGIT (*v))
5148 v++;
5149 if ((*v != 0) && (*v != ' ') && (*v != '.') && (*v != '-'))
5150 abort ();
5151 if (*v != 0)
5152 v++;
5155 /* Set Q at the next period or at the end. */
5156 q = v;
5157 while (ISDIGIT (*q))
5158 q++;
5159 if (*q != 0 && q > v && *q != ' ' && *q != '.' && *q != '-')
5160 abort ();
5162 if (q > v)
5163 /* Put that part into the command. */
5164 obstack_grow (&obstack, v, q - v);
5165 else
5166 /* Default to "0" */
5167 obstack_grow (&obstack, &zeroc, 1);
5168 arg_going = 1;
5170 break;
5172 case '|':
5173 if (input_from_pipe)
5174 do_spec_1 ("-", 0, NULL);
5175 break;
5177 default:
5178 error ("spec failure: unrecognized spec option '%c'", c);
5179 break;
5181 break;
5183 case '\\':
5184 /* Backslash: treat next character as ordinary. */
5185 c = *p++;
5187 /* fall through */
5188 default:
5189 /* Ordinary character: put it into the current argument. */
5190 obstack_1grow (&obstack, c);
5191 arg_going = 1;
5194 /* End of string. */
5195 return 0;
5198 /* Return 0 if we call do_spec_1 and that returns -1. */
5200 static const char *
5201 handle_braces (p)
5202 const char *p;
5204 const char *filter, *body = NULL, *endbody = NULL;
5205 int pipe_p = 0;
5206 int true_once = 0; /* If, in %{a|b:d}, at least one of a,b was seen. */
5207 int negate;
5208 int suffix;
5209 int include_blanks = 1;
5210 int elide_switch = 0;
5211 int ordered = 0;
5213 if (*p == '^')
5215 /* A '^' after the open-brace means to not give blanks before args. */
5216 include_blanks = 0;
5217 ++p;
5220 if (*p == '|')
5222 /* A `|' after the open-brace means,
5223 if the test fails, output a single minus sign rather than nothing.
5224 This is used in %{|!pipe:...}. */
5225 pipe_p = 1;
5226 ++p;
5229 if (*p == '<')
5231 /* A `<' after the open-brace means that the switch should be
5232 removed from the command-line. */
5233 elide_switch = 1;
5234 ++p;
5237 next_member:
5238 negate = suffix = 0;
5240 if (*p == '!')
5241 /* A `!' after the open-brace negates the condition:
5242 succeed if the specified switch is not present. */
5243 negate = 1, ++p;
5245 if (*p == '.')
5246 /* A `.' after the open-brace means test against the current suffix. */
5248 if (pipe_p)
5249 abort ();
5251 suffix = 1;
5252 ++p;
5255 if (elide_switch && (negate || pipe_p || suffix))
5257 /* It doesn't make sense to mix elision with other flags. We
5258 could fatal() here, but the standard seems to be to abort. */
5259 abort ();
5262 next_ampersand:
5263 filter = p;
5264 while (*p != ':' && *p != '}' && *p != '|' && *p != '&')
5265 p++;
5267 if (*p == '|' && (pipe_p || ordered))
5268 abort ();
5270 if (!body)
5272 if (*p != '}' && *p != '&')
5274 int count = 1;
5275 const char *q = p;
5277 while (*q++ != ':')
5278 continue;
5279 body = q;
5281 while (count > 0)
5283 if (*q == '{')
5284 count++;
5285 else if (*q == '}')
5286 count--;
5287 else if (*q == 0)
5288 fatal ("mismatched braces in specs");
5289 q++;
5291 endbody = q;
5293 else
5294 body = p, endbody = p + 1;
5297 if (suffix)
5299 int found = (input_suffix != 0
5300 && (long) strlen (input_suffix) == (long) (p - filter)
5301 && strncmp (input_suffix, filter, p - filter) == 0);
5303 if (body[0] == '}')
5304 abort ();
5306 if (negate != found
5307 && do_spec_1 (save_string (body, endbody-body-1), 0, NULL) < 0)
5308 return 0;
5310 else if (p[-1] == '*' && (p[0] == '}' || p[0] == '&'))
5312 /* Substitute all matching switches as separate args. */
5313 int i;
5315 for (i = 0; i < n_switches; i++)
5316 if (!strncmp (switches[i].part1, filter, p - 1 - filter)
5317 && check_live_switch (i, p - 1 - filter))
5319 if (elide_switch)
5321 switches[i].live_cond = SWITCH_IGNORE;
5322 switches[i].validated = 1;
5324 else
5325 ordered = 1, switches[i].ordering = 1;
5328 else
5330 /* Test for presence of the specified switch. */
5331 int i;
5332 int present = 0;
5334 /* If name specified ends in *, as in {x*:...},
5335 check for %* and handle that case. */
5336 if (p[-1] == '*' && !negate)
5338 int substitution;
5339 const char *r = body;
5341 /* First see whether we have %*. */
5342 substitution = 0;
5343 while (r < endbody)
5345 if (*r == '%' && r[1] == '*')
5346 substitution = 1;
5347 r++;
5349 /* If we do, handle that case. */
5350 if (substitution)
5352 /* Substitute all matching switches as separate args.
5353 But do this by substituting for %*
5354 in the text that follows the colon. */
5356 unsigned hard_match_len = p - filter - 1;
5357 char *string = save_string (body, endbody - body - 1);
5359 for (i = 0; i < n_switches; i++)
5360 if (!strncmp (switches[i].part1, filter, hard_match_len)
5361 && check_live_switch (i, -1))
5363 do_spec_1 (string, 0, &switches[i].part1[hard_match_len]);
5364 /* Pass any arguments this switch has. */
5365 give_switch (i, 1, 1);
5366 suffix_subst = NULL;
5369 /* We didn't match. Try again. */
5370 if (*p++ == '|')
5371 goto next_member;
5372 return endbody;
5376 /* If name specified ends in *, as in {x*:...},
5377 check for presence of any switch name starting with x. */
5378 if (p[-1] == '*')
5380 for (i = 0; i < n_switches; i++)
5382 unsigned hard_match_len = p - filter - 1;
5384 if (!strncmp (switches[i].part1, filter, hard_match_len)
5385 && check_live_switch (i, hard_match_len))
5387 present = 1;
5388 break;
5392 /* Otherwise, check for presence of exact name specified. */
5393 else
5395 for (i = 0; i < n_switches; i++)
5397 if (!strncmp (switches[i].part1, filter, p - filter)
5398 && switches[i].part1[p - filter] == 0
5399 && check_live_switch (i, -1))
5401 present = 1;
5402 break;
5407 /* If it is as desired (present for %{s...}, absent for %{!s...})
5408 then substitute either the switch or the specified
5409 conditional text. */
5410 if (present != negate)
5412 if (elide_switch)
5414 switches[i].live_cond = SWITCH_IGNORE;
5415 switches[i].validated = 1;
5417 else if (ordered || *p == '&')
5418 ordered = 1, switches[i].ordering = 1;
5419 else if (*p == '}')
5420 give_switch (i, 0, include_blanks);
5421 else
5422 /* Even if many alternatives are matched, only output once. */
5423 true_once = 1;
5425 else if (pipe_p)
5427 /* Here if a %{|...} conditional fails: output a minus sign,
5428 which means "standard output" or "standard input". */
5429 do_spec_1 ("-", 0, NULL);
5430 return endbody;
5434 /* We didn't match; try again. */
5435 if (*p++ == '|')
5436 goto next_member;
5438 if (p[-1] == '&')
5440 body = 0;
5441 goto next_ampersand;
5444 if (ordered)
5446 int i;
5447 /* Doing this set of switches later preserves their command-line
5448 ordering. This is needed for e.g. -U, -D and -A. */
5449 for (i = 0; i < n_switches; i++)
5450 if (switches[i].ordering == 1)
5452 switches[i].ordering = 0;
5453 give_switch (i, 0, include_blanks);
5456 /* Process the spec just once, regardless of match count. */
5457 else if (true_once)
5459 if (do_spec_1 (save_string (body, endbody - body - 1),
5460 0, NULL) < 0)
5461 return 0;
5464 return endbody;
5467 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5468 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5469 spec, or -1 if either exact match or %* is used.
5471 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5472 whose value does not begin with "no-" is obsoleted by the same value
5473 with the "no-", similarly for a switch with the "no-" prefix. */
5475 static int
5476 check_live_switch (switchnum, prefix_length)
5477 int switchnum;
5478 int prefix_length;
5480 const char *name = switches[switchnum].part1;
5481 int i;
5483 /* In the common case of {<at-most-one-letter>*}, a negating
5484 switch would always match, so ignore that case. We will just
5485 send the conflicting switches to the compiler phase. */
5486 if (prefix_length >= 0 && prefix_length <= 1)
5487 return 1;
5489 /* If we already processed this switch and determined if it was
5490 live or not, return our past determination. */
5491 if (switches[switchnum].live_cond != 0)
5492 return switches[switchnum].live_cond > 0;
5494 /* Now search for duplicate in a manner that depends on the name. */
5495 switch (*name)
5497 case 'O':
5498 for (i = switchnum + 1; i < n_switches; i++)
5499 if (switches[i].part1[0] == 'O')
5501 switches[switchnum].validated = 1;
5502 switches[switchnum].live_cond = SWITCH_FALSE;
5503 return 0;
5505 break;
5507 case 'W': case 'f': case 'm':
5508 if (! strncmp (name + 1, "no-", 3))
5510 /* We have Xno-YYY, search for XYYY. */
5511 for (i = switchnum + 1; i < n_switches; i++)
5512 if (switches[i].part1[0] == name[0]
5513 && ! strcmp (&switches[i].part1[1], &name[4]))
5515 switches[switchnum].validated = 1;
5516 switches[switchnum].live_cond = SWITCH_FALSE;
5517 return 0;
5520 else
5522 /* We have XYYY, search for Xno-YYY. */
5523 for (i = switchnum + 1; i < n_switches; i++)
5524 if (switches[i].part1[0] == name[0]
5525 && switches[i].part1[1] == 'n'
5526 && switches[i].part1[2] == 'o'
5527 && switches[i].part1[3] == '-'
5528 && !strcmp (&switches[i].part1[4], &name[1]))
5530 switches[switchnum].validated = 1;
5531 switches[switchnum].live_cond = SWITCH_FALSE;
5532 return 0;
5535 break;
5538 /* Otherwise the switch is live. */
5539 switches[switchnum].live_cond = SWITCH_LIVE;
5540 return 1;
5543 /* Pass a switch to the current accumulating command
5544 in the same form that we received it.
5545 SWITCHNUM identifies the switch; it is an index into
5546 the vector of switches gcc received, which is `switches'.
5547 This cannot fail since it never finishes a command line.
5549 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument.
5551 If INCLUDE_BLANKS is nonzero, then we include blanks before each argument
5552 of the switch. */
5554 static void
5555 give_switch (switchnum, omit_first_word, include_blanks)
5556 int switchnum;
5557 int omit_first_word;
5558 int include_blanks;
5560 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5561 return;
5563 if (!omit_first_word)
5565 do_spec_1 ("-", 0, NULL);
5566 do_spec_1 (switches[switchnum].part1, 1, NULL);
5569 if (switches[switchnum].args != 0)
5571 const char **p;
5572 for (p = switches[switchnum].args; *p; p++)
5574 const char *arg = *p;
5576 if (include_blanks)
5577 do_spec_1 (" ", 0, NULL);
5578 if (suffix_subst)
5580 unsigned length = strlen (arg);
5581 int dot = 0;
5583 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5584 if (arg[length] == '.')
5586 ((char *)arg)[length] = 0;
5587 dot = 1;
5588 break;
5590 do_spec_1 (arg, 1, NULL);
5591 if (dot)
5592 ((char *)arg)[length] = '.';
5593 do_spec_1 (suffix_subst, 1, NULL);
5595 else
5596 do_spec_1 (arg, 1, NULL);
5600 do_spec_1 (" ", 0, NULL);
5601 switches[switchnum].validated = 1;
5604 /* Search for a file named NAME trying various prefixes including the
5605 user's -B prefix and some standard ones.
5606 Return the absolute file name found. If nothing is found, return NAME. */
5608 static const char *
5609 find_file (name)
5610 const char *name;
5612 char *newname;
5614 /* Try multilib_dir if it is defined. */
5615 if (multilib_dir != NULL)
5617 const char *const try = ACONCAT ((multilib_dir, dir_separator_str, name, NULL));
5619 newname = find_a_file (&startfile_prefixes, try, R_OK);
5621 /* If we don't find it in the multi library dir, then fall
5622 through and look for it in the normal places. */
5623 if (newname != NULL)
5624 return newname;
5627 newname = find_a_file (&startfile_prefixes, name, R_OK);
5628 return newname ? newname : name;
5631 /* Determine whether a directory exists. If LINKER, return 0 for
5632 certain fixed names not needed by the linker. If not LINKER, it is
5633 only important to return 0 if the host machine has a small ARG_MAX
5634 limit. */
5636 static int
5637 is_directory (path1, path2, linker)
5638 const char *path1;
5639 const char *path2;
5640 int linker;
5642 int len1 = strlen (path1);
5643 int len2 = strlen (path2);
5644 char *path = (char *) alloca (3 + len1 + len2);
5645 char *cp;
5646 struct stat st;
5648 #ifndef SMALL_ARG_MAX
5649 if (! linker)
5650 return 1;
5651 #endif
5653 /* Construct the path from the two parts. Ensure the string ends with "/.".
5654 The resulting path will be a directory even if the given path is a
5655 symbolic link. */
5656 memcpy (path, path1, len1);
5657 memcpy (path + len1, path2, len2);
5658 cp = path + len1 + len2;
5659 if (!IS_DIR_SEPARATOR (cp[-1]))
5660 *cp++ = DIR_SEPARATOR;
5661 *cp++ = '.';
5662 *cp = '\0';
5664 /* Exclude directories that the linker is known to search. */
5665 if (linker
5666 && ((cp - path == 6
5667 && strcmp (path, concat (dir_separator_str, "lib",
5668 dir_separator_str, ".", NULL)) == 0)
5669 || (cp - path == 10
5670 && strcmp (path, concat (dir_separator_str, "usr",
5671 dir_separator_str, "lib",
5672 dir_separator_str, ".", NULL)) == 0)))
5673 return 0;
5675 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5678 /* Set up the various global variables to indicate that we're processing
5679 the input file named FILENAME. */
5681 void
5682 set_input (filename)
5683 const char *filename;
5685 const char *p;
5687 input_filename = filename;
5688 input_filename_length = strlen (input_filename);
5690 input_basename = input_filename;
5691 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5692 /* Skip drive name so 'x:foo' is handled properly. */
5693 if (input_basename[1] == ':')
5694 input_basename += 2;
5695 #endif
5696 for (p = input_basename; *p; p++)
5697 if (IS_DIR_SEPARATOR (*p))
5698 input_basename = p + 1;
5700 /* Find a suffix starting with the last period,
5701 and set basename_length to exclude that suffix. */
5702 basename_length = strlen (input_basename);
5703 suffixed_basename_length = basename_length;
5704 p = input_basename + basename_length;
5705 while (p != input_basename && *p != '.')
5706 --p;
5707 if (*p == '.' && p != input_basename)
5709 basename_length = p - input_basename;
5710 input_suffix = p + 1;
5712 else
5713 input_suffix = "";
5715 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5716 we will need to do a stat on the input_filename. The
5717 INPUT_STAT_SET signals that the stat is needed. */
5718 input_stat_set = 0;
5721 /* On fatal signals, delete all the temporary files. */
5723 static void
5724 fatal_error (signum)
5725 int signum;
5727 signal (signum, SIG_DFL);
5728 delete_failure_queue ();
5729 delete_temp_files ();
5730 /* Get the same signal again, this time not handled,
5731 so its normal effect occurs. */
5732 kill (getpid (), signum);
5735 extern int main PARAMS ((int, const char *const *));
5738 main (argc, argv)
5739 int argc;
5740 const char *const *argv;
5742 size_t i;
5743 int value;
5744 int linker_was_run = 0;
5745 char *explicit_link_files;
5746 char *specs_file;
5747 const char *p;
5748 struct user_specs *uptr;
5750 p = argv[0] + strlen (argv[0]);
5751 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
5752 --p;
5753 programname = p;
5755 xmalloc_set_program_name (programname);
5757 #ifdef GCC_DRIVER_HOST_INITIALIZATION
5758 /* Perform host dependent initialization when needed. */
5759 GCC_DRIVER_HOST_INITIALIZATION;
5760 #endif
5762 gcc_init_libintl ();
5764 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
5765 signal (SIGINT, fatal_error);
5766 #ifdef SIGHUP
5767 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
5768 signal (SIGHUP, fatal_error);
5769 #endif
5770 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
5771 signal (SIGTERM, fatal_error);
5772 #ifdef SIGPIPE
5773 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
5774 signal (SIGPIPE, fatal_error);
5775 #endif
5776 #ifdef SIGCHLD
5777 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
5778 receive the signal. A different setting is inheritable */
5779 signal (SIGCHLD, SIG_DFL);
5780 #endif
5782 argbuf_length = 10;
5783 argbuf = (const char **) xmalloc (argbuf_length * sizeof (const char *));
5785 obstack_init (&obstack);
5787 /* Build multilib_select, et. al from the separate lines that make up each
5788 multilib selection. */
5790 const char *const *q = multilib_raw;
5791 int need_space;
5793 obstack_init (&multilib_obstack);
5794 while ((p = *q++) != (char *) 0)
5795 obstack_grow (&multilib_obstack, p, strlen (p));
5797 obstack_1grow (&multilib_obstack, 0);
5798 multilib_select = obstack_finish (&multilib_obstack);
5800 q = multilib_matches_raw;
5801 while ((p = *q++) != (char *) 0)
5802 obstack_grow (&multilib_obstack, p, strlen (p));
5804 obstack_1grow (&multilib_obstack, 0);
5805 multilib_matches = obstack_finish (&multilib_obstack);
5807 q = multilib_exclusions_raw;
5808 while ((p = *q++) != (char *) 0)
5809 obstack_grow (&multilib_obstack, p, strlen (p));
5811 obstack_1grow (&multilib_obstack, 0);
5812 multilib_exclusions = obstack_finish (&multilib_obstack);
5814 need_space = FALSE;
5815 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
5817 if (need_space)
5818 obstack_1grow (&multilib_obstack, ' ');
5819 obstack_grow (&multilib_obstack,
5820 multilib_defaults_raw[i],
5821 strlen (multilib_defaults_raw[i]));
5822 need_space = TRUE;
5825 obstack_1grow (&multilib_obstack, 0);
5826 multilib_defaults = obstack_finish (&multilib_obstack);
5829 /* Set up to remember the pathname of gcc and any options
5830 needed for collect. We use argv[0] instead of programname because
5831 we need the complete pathname. */
5832 obstack_init (&collect_obstack);
5833 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
5834 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
5835 putenv (obstack_finish (&collect_obstack));
5837 #ifdef INIT_ENVIRONMENT
5838 /* Set up any other necessary machine specific environment variables. */
5839 putenv (INIT_ENVIRONMENT);
5840 #endif
5842 /* Make a table of what switches there are (switches, n_switches).
5843 Make a table of specified input files (infiles, n_infiles).
5844 Decode switches that are handled locally. */
5846 process_command (argc, argv);
5848 /* Initialize the vector of specs to just the default.
5849 This means one element containing 0s, as a terminator. */
5851 compilers = (struct compiler *) xmalloc (sizeof default_compilers);
5852 memcpy ((char *) compilers, (char *) default_compilers,
5853 sizeof default_compilers);
5854 n_compilers = n_default_compilers;
5856 /* Read specs from a file if there is one. */
5858 machine_suffix = concat (spec_machine, dir_separator_str,
5859 spec_version, dir_separator_str, NULL);
5860 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
5862 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK);
5863 /* Read the specs file unless it is a default one. */
5864 if (specs_file != 0 && strcmp (specs_file, "specs"))
5865 read_specs (specs_file, TRUE);
5866 else
5867 init_spec ();
5869 /* We need to check standard_exec_prefix/just_machine_suffix/specs
5870 for any override of as, ld and libraries. */
5871 specs_file = (char *) alloca (strlen (standard_exec_prefix)
5872 + strlen (just_machine_suffix)
5873 + sizeof ("specs"));
5875 strcpy (specs_file, standard_exec_prefix);
5876 strcat (specs_file, just_machine_suffix);
5877 strcat (specs_file, "specs");
5878 if (access (specs_file, R_OK) == 0)
5879 read_specs (specs_file, TRUE);
5881 /* If not cross-compiling, look for startfiles in the standard places. */
5882 if (*cross_compile == '0')
5884 if (*md_exec_prefix)
5886 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
5887 PREFIX_PRIORITY_LAST, 0, NULL);
5888 add_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
5889 PREFIX_PRIORITY_LAST, 0, NULL);
5892 if (*md_startfile_prefix)
5893 add_prefix (&startfile_prefixes, md_startfile_prefix, "GCC",
5894 PREFIX_PRIORITY_LAST, 0, NULL);
5896 if (*md_startfile_prefix_1)
5897 add_prefix (&startfile_prefixes, md_startfile_prefix_1, "GCC",
5898 PREFIX_PRIORITY_LAST, 0, NULL);
5900 /* If standard_startfile_prefix is relative, base it on
5901 standard_exec_prefix. This lets us move the installed tree
5902 as a unit. If GCC_EXEC_PREFIX is defined, base
5903 standard_startfile_prefix on that as well. */
5904 if (IS_ABSOLUTE_PATHNAME (standard_startfile_prefix))
5905 add_prefix (&startfile_prefixes, standard_startfile_prefix, "BINUTILS",
5906 PREFIX_PRIORITY_LAST, 0, NULL);
5907 else
5909 if (gcc_exec_prefix)
5910 add_prefix (&startfile_prefixes,
5911 concat (gcc_exec_prefix, machine_suffix,
5912 standard_startfile_prefix, NULL),
5913 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
5914 add_prefix (&startfile_prefixes,
5915 concat (standard_exec_prefix,
5916 machine_suffix,
5917 standard_startfile_prefix, NULL),
5918 NULL, PREFIX_PRIORITY_LAST, 0, NULL);
5921 add_prefix (&startfile_prefixes, standard_startfile_prefix_1,
5922 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5923 add_prefix (&startfile_prefixes, standard_startfile_prefix_2,
5924 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5925 #if 0 /* Can cause surprises, and one can use -B./ instead. */
5926 add_prefix (&startfile_prefixes, "./", NULL,
5927 PREFIX_PRIORITY_LAST, 1, NULL);
5928 #endif
5930 else
5932 if (!IS_ABSOLUTE_PATHNAME (standard_startfile_prefix)
5933 && gcc_exec_prefix)
5934 add_prefix (&startfile_prefixes,
5935 concat (gcc_exec_prefix, machine_suffix,
5936 standard_startfile_prefix, NULL),
5937 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL);
5940 /* Process any user specified specs in the order given on the command
5941 line. */
5942 for (uptr = user_specs_head; uptr; uptr = uptr->next)
5944 char *filename = find_a_file (&startfile_prefixes, uptr->filename, R_OK);
5945 read_specs (filename ? filename : uptr->filename, FALSE);
5948 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
5949 if (gcc_exec_prefix)
5950 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
5951 spec_version, dir_separator_str, NULL);
5953 /* Now we have the specs.
5954 Set the `valid' bits for switches that match anything in any spec. */
5956 validate_all_switches ();
5958 /* Now that we have the switches and the specs, set
5959 the subdirectory based on the options. */
5960 set_multilib_dir ();
5962 /* Warn about any switches that no pass was interested in. */
5964 for (i = 0; (int) i < n_switches; i++)
5965 if (! switches[i].validated)
5966 error ("unrecognized option `-%s'", switches[i].part1);
5968 /* Obey some of the options. */
5970 if (print_search_dirs)
5972 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
5973 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
5974 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
5975 return (0);
5978 if (print_file_name)
5980 printf ("%s\n", find_file (print_file_name));
5981 return (0);
5984 if (print_prog_name)
5986 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK);
5987 printf ("%s\n", (newname ? newname : print_prog_name));
5988 return (0);
5991 if (print_multi_lib)
5993 print_multilib_info ();
5994 return (0);
5997 if (print_multi_directory)
5999 if (multilib_dir == NULL)
6000 printf (".\n");
6001 else
6002 printf ("%s\n", multilib_dir);
6003 return (0);
6006 if (target_help_flag)
6008 /* Print if any target specific options. */
6010 /* We do not exit here. Instead we have created a fake input file
6011 called 'target-dummy' which needs to be compiled, and we pass this
6012 on to the various sub-processes, along with the --target-help
6013 switch. */
6016 if (print_help_list)
6018 display_help ();
6020 if (! verbose_flag)
6022 printf (_("\nFor bug reporting instructions, please see:\n"));
6023 printf ("%s.\n", GCCBUGURL);
6025 return (0);
6028 /* We do not exit here. Instead we have created a fake input file
6029 called 'help-dummy' which needs to be compiled, and we pass this
6030 on the various sub-processes, along with the --help switch. */
6033 if (verbose_flag)
6035 int n;
6036 const char *thrmod;
6038 notice ("Configured with: %s\n", configuration_arguments);
6040 #ifdef THREAD_MODEL_SPEC
6041 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6042 but there's no point in doing all this processing just to get
6043 thread_model back. */
6044 obstack_init (&obstack);
6045 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6046 obstack_1grow (&obstack, '\0');
6047 thrmod = obstack_finish (&obstack);
6048 #else
6049 thrmod = thread_model;
6050 #endif
6052 notice ("Thread model: %s\n", thrmod);
6054 /* compiler_version is truncated at the first space when initialized
6055 from version string, so truncate version_string at the first space
6056 before comparing. */
6057 for (n = 0; version_string[n]; n++)
6058 if (version_string[n] == ' ')
6059 break;
6061 if (! strncmp (version_string, compiler_version, n)
6062 && compiler_version[n] == 0)
6063 notice ("gcc version %s\n", version_string);
6064 else
6065 notice ("gcc driver version %s executing gcc version %s\n",
6066 version_string, compiler_version);
6068 if (n_infiles == 0)
6069 return (0);
6072 if (n_infiles == added_libraries)
6073 fatal ("no input files");
6075 /* Make a place to record the compiler output file names
6076 that correspond to the input files. */
6078 i = n_infiles;
6079 i += lang_specific_extra_outfiles;
6080 outfiles = (const char **) xcalloc (i, sizeof (char *));
6082 /* Record which files were specified explicitly as link input. */
6084 explicit_link_files = xcalloc (1, n_infiles);
6086 for (i = 0; (int) i < n_infiles; i++)
6088 int this_file_error = 0;
6090 /* Tell do_spec what to substitute for %i. */
6092 input_file_number = i;
6093 set_input (infiles[i].name);
6095 /* Use the same thing in %o, unless cp->spec says otherwise. */
6097 outfiles[i] = input_filename;
6099 /* Figure out which compiler from the file's suffix. */
6101 input_file_compiler
6102 = lookup_compiler (infiles[i].name, input_filename_length,
6103 infiles[i].language);
6105 if (input_file_compiler)
6107 /* Ok, we found an applicable compiler. Run its spec. */
6109 if (input_file_compiler->spec[0] == '#')
6111 error ("%s: %s compiler not installed on this system",
6112 input_filename, &input_file_compiler->spec[1]);
6113 this_file_error = 1;
6115 else
6117 value = do_spec (input_file_compiler->spec);
6118 if (value < 0)
6119 this_file_error = 1;
6123 /* If this file's name does not contain a recognized suffix,
6124 record it as explicit linker input. */
6126 else
6127 explicit_link_files[i] = 1;
6129 /* Clear the delete-on-failure queue, deleting the files in it
6130 if this compilation failed. */
6132 if (this_file_error)
6134 delete_failure_queue ();
6135 error_count++;
6137 /* If this compilation succeeded, don't delete those files later. */
6138 clear_failure_queue ();
6141 /* Reset the output file name to the first input file name, for use
6142 with %b in LINK_SPEC on a target that prefers not to emit a.out
6143 by default. */
6144 if (n_infiles > 0)
6145 set_input (infiles[0].name);
6147 if (error_count == 0)
6149 /* Make sure INPUT_FILE_NUMBER points to first available open
6150 slot. */
6151 input_file_number = n_infiles;
6152 if (lang_specific_pre_link ())
6153 error_count++;
6156 /* Run ld to link all the compiler output files. */
6158 if (error_count == 0)
6160 int tmp = execution_count;
6162 /* We'll use ld if we can't find collect2. */
6163 if (! strcmp (linker_name_spec, "collect2"))
6165 char *s = find_a_file (&exec_prefixes, "collect2", X_OK);
6166 if (s == NULL)
6167 linker_name_spec = "ld";
6169 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6170 for collect. */
6171 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6172 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6174 value = do_spec (link_command_spec);
6175 if (value < 0)
6176 error_count = 1;
6177 linker_was_run = (tmp != execution_count);
6180 /* If options said don't run linker,
6181 complain about input files to be given to the linker. */
6183 if (! linker_was_run && error_count == 0)
6184 for (i = 0; (int) i < n_infiles; i++)
6185 if (explicit_link_files[i])
6186 error ("%s: linker input file unused because linking not done",
6187 outfiles[i]);
6189 /* Delete some or all of the temporary files we made. */
6191 if (error_count)
6192 delete_failure_queue ();
6193 delete_temp_files ();
6195 if (print_help_list)
6197 printf (("\nFor bug reporting instructions, please see:\n"));
6198 printf ("%s\n", GCCBUGURL);
6201 return (signal_count != 0 ? 2
6202 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6203 : 0);
6206 /* Find the proper compilation spec for the file name NAME,
6207 whose length is LENGTH. LANGUAGE is the specified language,
6208 or 0 if this file is to be passed to the linker. */
6210 static struct compiler *
6211 lookup_compiler (name, length, language)
6212 const char *name;
6213 size_t length;
6214 const char *language;
6216 struct compiler *cp;
6218 /* If this was specified by the user to be a linker input, indicate that. */
6219 if (language != 0 && language[0] == '*')
6220 return 0;
6222 /* Otherwise, look for the language, if one is spec'd. */
6223 if (language != 0)
6225 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6226 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6227 return cp;
6229 error ("language %s not recognized", language);
6230 return 0;
6233 /* Look for a suffix. */
6234 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6236 if (/* The suffix `-' matches only the file name `-'. */
6237 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6238 || (strlen (cp->suffix) < length
6239 /* See if the suffix matches the end of NAME. */
6240 && !strcmp (cp->suffix,
6241 name + length - strlen (cp->suffix))
6243 break;
6246 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6247 /* look again, but case-insensitively this time. */
6248 if (cp < compilers)
6249 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6251 if (/* The suffix `-' matches only the file name `-'. */
6252 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6253 || (strlen (cp->suffix) < length
6254 /* See if the suffix matches the end of NAME. */
6255 && ((!strcmp (cp->suffix,
6256 name + length - strlen (cp->suffix))
6257 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6258 && !strcasecmp (cp->suffix,
6259 name + length - strlen (cp->suffix)))
6261 break;
6263 #endif
6265 if (cp >= compilers)
6267 if (cp->spec[0] != '@')
6268 /* A non-alias entry: return it. */
6269 return cp;
6271 /* An alias entry maps a suffix to a language.
6272 Search for the language; pass 0 for NAME and LENGTH
6273 to avoid infinite recursion if language not found. */
6274 return lookup_compiler (NULL, 0, cp->spec + 1);
6276 return 0;
6279 static char *
6280 save_string (s, len)
6281 const char *s;
6282 int len;
6284 char *result = xmalloc (len + 1);
6286 memcpy (result, s, len);
6287 result[len] = 0;
6288 return result;
6291 void
6292 pfatal_with_name (name)
6293 const char *name;
6295 perror_with_name (name);
6296 delete_temp_files ();
6297 exit (1);
6300 static void
6301 perror_with_name (name)
6302 const char *name;
6304 error ("%s: %s", name, xstrerror (errno));
6307 static void
6308 pfatal_pexecute (errmsg_fmt, errmsg_arg)
6309 const char *errmsg_fmt;
6310 const char *errmsg_arg;
6312 if (errmsg_arg)
6314 int save_errno = errno;
6316 /* Space for trailing '\0' is in %s. */
6317 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6318 sprintf (msg, errmsg_fmt, errmsg_arg);
6319 errmsg_fmt = msg;
6321 errno = save_errno;
6324 pfatal_with_name (errmsg_fmt);
6327 /* Output an error message and exit */
6329 void
6330 fancy_abort ()
6332 fatal ("internal gcc abort");
6335 /* Output an error message and exit */
6337 void
6338 fatal VPARAMS ((const char *msgid, ...))
6340 VA_OPEN (ap, msgid);
6341 VA_FIXEDARG (ap, const char *, msgid);
6343 fprintf (stderr, "%s: ", programname);
6344 vfprintf (stderr, _(msgid), ap);
6345 VA_CLOSE (ap);
6346 fprintf (stderr, "\n");
6347 delete_temp_files ();
6348 exit (1);
6351 void
6352 error VPARAMS ((const char *msgid, ...))
6354 VA_OPEN (ap, msgid);
6355 VA_FIXEDARG (ap, const char *, msgid);
6357 fprintf (stderr, "%s: ", programname);
6358 vfprintf (stderr, _(msgid), ap);
6359 VA_CLOSE (ap);
6361 fprintf (stderr, "\n");
6364 static void
6365 notice VPARAMS ((const char *msgid, ...))
6367 VA_OPEN (ap, msgid);
6368 VA_FIXEDARG (ap, const char *, msgid);
6370 vfprintf (stderr, _(msgid), ap);
6371 VA_CLOSE (ap);
6374 static void
6375 validate_all_switches ()
6377 struct compiler *comp;
6378 const char *p;
6379 char c;
6380 struct spec_list *spec;
6382 for (comp = compilers; comp->spec; comp++)
6384 p = comp->spec;
6385 while ((c = *p++))
6386 if (c == '%' && *p == '{')
6387 /* We have a switch spec. */
6388 validate_switches (p + 1);
6391 /* Look through the linked list of specs read from the specs file. */
6392 for (spec = specs; spec; spec = spec->next)
6394 p = *(spec->ptr_spec);
6395 while ((c = *p++))
6396 if (c == '%' && *p == '{')
6397 /* We have a switch spec. */
6398 validate_switches (p + 1);
6401 p = link_command_spec;
6402 while ((c = *p++))
6403 if (c == '%' && *p == '{')
6404 /* We have a switch spec. */
6405 validate_switches (p + 1);
6408 /* Look at the switch-name that comes after START
6409 and mark as valid all supplied switches that match it. */
6411 static void
6412 validate_switches (start)
6413 const char *start;
6415 const char *p = start;
6416 const char *filter;
6417 int i;
6418 int suffix;
6420 if (*p == '|')
6421 ++p;
6423 next_member:
6424 if (*p == '!')
6425 ++p;
6427 suffix = 0;
6428 if (*p == '.')
6429 suffix = 1, ++p;
6431 filter = p;
6432 while (*p != ':' && *p != '}' && *p != '|' && *p != '&')
6433 p++;
6435 if (suffix)
6437 else if (p[-1] == '*')
6439 /* Mark all matching switches as valid. */
6440 for (i = 0; i < n_switches; i++)
6441 if (!strncmp (switches[i].part1, filter, p - filter - 1))
6442 switches[i].validated = 1;
6444 else
6446 /* Mark an exact matching switch as valid. */
6447 for (i = 0; i < n_switches; i++)
6449 if (!strncmp (switches[i].part1, filter, p - filter)
6450 && switches[i].part1[p - filter] == 0)
6451 switches[i].validated = 1;
6455 if (*p++ == '|' || p[-1] == '&')
6456 goto next_member;
6459 /* Check whether a particular argument was used. The first time we
6460 canonicalize the switches to keep only the ones we care about. */
6462 static int
6463 used_arg (p, len)
6464 const char *p;
6465 int len;
6467 struct mswitchstr
6469 const char *str;
6470 const char *replace;
6471 int len;
6472 int rep_len;
6475 static struct mswitchstr *mswitches;
6476 static int n_mswitches;
6477 int i, j;
6479 if (!mswitches)
6481 struct mswitchstr *matches;
6482 const char *q;
6483 int cnt = 0;
6485 /* Break multilib_matches into the component strings of string
6486 and replacement string. */
6487 for (q = multilib_matches; *q != '\0'; q++)
6488 if (*q == ';')
6489 cnt++;
6491 matches =
6492 (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
6493 i = 0;
6494 q = multilib_matches;
6495 while (*q != '\0')
6497 matches[i].str = q;
6498 while (*q != ' ')
6500 if (*q == '\0')
6501 abort ();
6502 q++;
6504 matches[i].len = q - matches[i].str;
6506 matches[i].replace = ++q;
6507 while (*q != ';' && *q != '\0')
6509 if (*q == ' ')
6510 abort ();
6511 q++;
6513 matches[i].rep_len = q - matches[i].replace;
6514 i++;
6515 if (*q == ';')
6516 q++;
6519 /* Now build a list of the replacement string for switches that we care
6520 about. Make sure we allocate at least one entry. This prevents
6521 xmalloc from calling fatal, and prevents us from re-executing this
6522 block of code. */
6523 mswitches
6524 = (struct mswitchstr *) xmalloc ((sizeof (struct mswitchstr))
6525 * (n_switches ? n_switches : 1));
6526 for (i = 0; i < n_switches; i++)
6528 int xlen = strlen (switches[i].part1);
6529 for (j = 0; j < cnt; j++)
6530 if (xlen == matches[j].len
6531 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6533 mswitches[n_mswitches].str = matches[j].replace;
6534 mswitches[n_mswitches].len = matches[j].rep_len;
6535 mswitches[n_mswitches].replace = (char *) 0;
6536 mswitches[n_mswitches].rep_len = 0;
6537 n_mswitches++;
6538 break;
6543 for (i = 0; i < n_mswitches; i++)
6544 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
6545 return 1;
6547 return 0;
6550 static int
6551 default_arg (p, len)
6552 const char *p;
6553 int len;
6555 const char *start, *end;
6557 for (start = multilib_defaults; *start != '\0'; start = end + 1)
6559 while (*start == ' ' || *start == '\t')
6560 start++;
6562 if (*start == '\0')
6563 break;
6565 for (end = start + 1; *end != ' ' && *end != '\t' && *end != '\0'; end++)
6568 if ((end - start) == len && strncmp (p, start, len) == 0)
6569 return 1;
6571 if (*end == '\0')
6572 break;
6575 return 0;
6578 /* Work out the subdirectory to use based on the options. The format of
6579 multilib_select is a list of elements. Each element is a subdirectory
6580 name followed by a list of options followed by a semicolon. The format
6581 of multilib_exclusions is the same, but without the preceding
6582 directory. First gcc will check the exclusions, if none of the options
6583 beginning with an exclamation point are present, and all of the other
6584 options are present, then we will ignore this completely. Passing
6585 that, gcc will consider each multilib_select in turn using the same
6586 rules for matching the options. If a match is found, that subdirectory
6587 will be used. */
6589 static void
6590 set_multilib_dir ()
6592 const char *p;
6593 unsigned int this_path_len;
6594 const char *this_path, *this_arg;
6595 int not_arg;
6596 int ok;
6598 p = multilib_exclusions;
6599 while (*p != '\0')
6601 /* Ignore newlines. */
6602 if (*p == '\n')
6604 ++p;
6605 continue;
6608 /* Check the arguments. */
6609 ok = 1;
6610 while (*p != ';')
6612 if (*p == '\0')
6613 abort ();
6615 if (! ok)
6617 ++p;
6618 continue;
6621 this_arg = p;
6622 while (*p != ' ' && *p != ';')
6624 if (*p == '\0')
6625 abort ();
6626 ++p;
6629 if (*this_arg != '!')
6630 not_arg = 0;
6631 else
6633 not_arg = 1;
6634 ++this_arg;
6637 ok = used_arg (this_arg, p - this_arg);
6638 if (not_arg)
6639 ok = ! ok;
6641 if (*p == ' ')
6642 ++p;
6645 if (ok)
6646 return;
6648 ++p;
6651 p = multilib_select;
6652 while (*p != '\0')
6654 /* Ignore newlines. */
6655 if (*p == '\n')
6657 ++p;
6658 continue;
6661 /* Get the initial path. */
6662 this_path = p;
6663 while (*p != ' ')
6665 if (*p == '\0')
6666 abort ();
6667 ++p;
6669 this_path_len = p - this_path;
6671 /* Check the arguments. */
6672 ok = 1;
6673 ++p;
6674 while (*p != ';')
6676 if (*p == '\0')
6677 abort ();
6679 if (! ok)
6681 ++p;
6682 continue;
6685 this_arg = p;
6686 while (*p != ' ' && *p != ';')
6688 if (*p == '\0')
6689 abort ();
6690 ++p;
6693 if (*this_arg != '!')
6694 not_arg = 0;
6695 else
6697 not_arg = 1;
6698 ++this_arg;
6701 /* If this is a default argument, we can just ignore it.
6702 This is true even if this_arg begins with '!'. Beginning
6703 with '!' does not mean that this argument is necessarily
6704 inappropriate for this library: it merely means that
6705 there is a more specific library which uses this
6706 argument. If this argument is a default, we need not
6707 consider that more specific library. */
6708 if (! default_arg (this_arg, p - this_arg))
6710 ok = used_arg (this_arg, p - this_arg);
6711 if (not_arg)
6712 ok = ! ok;
6715 if (*p == ' ')
6716 ++p;
6719 if (ok)
6721 if (this_path_len != 1
6722 || this_path[0] != '.')
6724 char *new_multilib_dir = xmalloc (this_path_len + 1);
6725 strncpy (new_multilib_dir, this_path, this_path_len);
6726 new_multilib_dir[this_path_len] = '\0';
6727 multilib_dir = new_multilib_dir;
6729 break;
6732 ++p;
6736 /* Print out the multiple library subdirectory selection
6737 information. This prints out a series of lines. Each line looks
6738 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
6739 required. Only the desired options are printed out, the negative
6740 matches. The options are print without a leading dash. There are
6741 no spaces to make it easy to use the information in the shell.
6742 Each subdirectory is printed only once. This assumes the ordering
6743 generated by the genmultilib script. Also, we leave out ones that match
6744 the exclusions. */
6746 static void
6747 print_multilib_info ()
6749 const char *p = multilib_select;
6750 const char *last_path = 0, *this_path;
6751 int skip;
6752 unsigned int last_path_len = 0;
6754 while (*p != '\0')
6756 skip = 0;
6757 /* Ignore newlines. */
6758 if (*p == '\n')
6760 ++p;
6761 continue;
6764 /* Get the initial path. */
6765 this_path = p;
6766 while (*p != ' ')
6768 if (*p == '\0')
6769 abort ();
6770 ++p;
6773 /* Check for matches with the multilib_exclusions. We don't bother
6774 with the '!' in either list. If any of the exclusion rules match
6775 all of its options with the select rule, we skip it. */
6777 const char *e = multilib_exclusions;
6778 const char *this_arg;
6780 while (*e != '\0')
6782 int m = 1;
6783 /* Ignore newlines. */
6784 if (*e == '\n')
6786 ++e;
6787 continue;
6790 /* Check the arguments. */
6791 while (*e != ';')
6793 const char *q;
6794 int mp = 0;
6796 if (*e == '\0')
6797 abort ();
6799 if (! m)
6801 ++e;
6802 continue;
6805 this_arg = e;
6807 while (*e != ' ' && *e != ';')
6809 if (*e == '\0')
6810 abort ();
6811 ++e;
6814 q = p + 1;
6815 while (*q != ';')
6817 const char *arg;
6818 int len = e - this_arg;
6820 if (*q == '\0')
6821 abort ();
6823 arg = q;
6825 while (*q != ' ' && *q != ';')
6827 if (*q == '\0')
6828 abort ();
6829 ++q;
6832 if (! strncmp (arg, this_arg, (len < q - arg) ? q - arg : len) ||
6833 default_arg (this_arg, e - this_arg))
6835 mp = 1;
6836 break;
6839 if (*q == ' ')
6840 ++q;
6843 if (! mp)
6844 m = 0;
6846 if (*e == ' ')
6847 ++e;
6850 if (m)
6852 skip = 1;
6853 break;
6856 if (*e != '\0')
6857 ++e;
6861 if (! skip)
6863 /* If this is a duplicate, skip it. */
6864 skip = (last_path != 0 && (unsigned int) (p - this_path) == last_path_len
6865 && ! strncmp (last_path, this_path, last_path_len));
6867 last_path = this_path;
6868 last_path_len = p - this_path;
6871 /* If this directory requires any default arguments, we can skip
6872 it. We will already have printed a directory identical to
6873 this one which does not require that default argument. */
6874 if (! skip)
6876 const char *q;
6878 q = p + 1;
6879 while (*q != ';')
6881 const char *arg;
6883 if (*q == '\0')
6884 abort ();
6886 if (*q == '!')
6887 arg = NULL;
6888 else
6889 arg = q;
6891 while (*q != ' ' && *q != ';')
6893 if (*q == '\0')
6894 abort ();
6895 ++q;
6898 if (arg != NULL
6899 && default_arg (arg, q - arg))
6901 skip = 1;
6902 break;
6905 if (*q == ' ')
6906 ++q;
6910 if (! skip)
6912 const char *p1;
6914 for (p1 = last_path; p1 < p; p1++)
6915 putchar (*p1);
6916 putchar (';');
6919 ++p;
6920 while (*p != ';')
6922 int use_arg;
6924 if (*p == '\0')
6925 abort ();
6927 if (skip)
6929 ++p;
6930 continue;
6933 use_arg = *p != '!';
6935 if (use_arg)
6936 putchar ('@');
6938 while (*p != ' ' && *p != ';')
6940 if (*p == '\0')
6941 abort ();
6942 if (use_arg)
6943 putchar (*p);
6944 ++p;
6947 if (*p == ' ')
6948 ++p;
6951 if (! skip)
6953 /* If there are extra options, print them now. */
6954 if (multilib_extra && *multilib_extra)
6956 int print_at = TRUE;
6957 const char *q;
6959 for (q = multilib_extra; *q != '\0'; q++)
6961 if (*q == ' ')
6962 print_at = TRUE;
6963 else
6965 if (print_at)
6966 putchar ('@');
6967 putchar (*q);
6968 print_at = FALSE;
6973 putchar ('\n');
6976 ++p;