]> gcc.gnu.org Git - gcc.git/blame - gcc/gcc.c
(struct switchstr): New field LIVE_COND.
[gcc.git] / gcc / gcc.c
CommitLineData
ed1f651b 1/* Compiler driver program that can handle many languages.
4aea22ca 2 Copyright (C) 1987, 1989, 1992, 1993, 1994 Free Software Foundation, Inc.
ed1f651b
RS
3
4This file is part of GNU CC.
5
6GNU CC is free software; you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
8the Free Software Foundation; either version 2, or (at your option)
9any later version.
10
11GNU CC is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU CC; see the file COPYING. If not, write to
18the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
19
20This paragraph is here to try to keep Sun CC from dying.
21The number of chars here seems crucial!!!! */
22
23/* This program is the user interface to the C compiler and possibly to
24other compilers. It is used because compilation is a complicated procedure
25which involves running several programs and passing temporary files between
26them, forwarding the users switches to those programs selectively,
27and deleting the temporary files at the end.
28
29CC recognizes how to compile each input file by suffixes in the file names.
30Once it knows which kind of compilation to perform, the procedure for
31compilation is specified by a string called a "spec". */
32\f
ed1f651b
RS
33#include <sys/types.h>
34#include <ctype.h>
35#include <signal.h>
ed1f651b 36#include <sys/stat.h>
4c64aaf6 37#include <sys/file.h> /* May get R_OK, etc. on some systems. */
ed1f651b
RS
38
39#include "config.h"
40#include "obstack.h"
4f90e4a0 41#ifdef __STDC__
f62a12d0 42#include <stdarg.h>
4f90e4a0 43#else
f62a12d0 44#include <varargs.h>
4f90e4a0 45#endif
f8d97cf4 46#include <stdio.h>
ed1f651b 47
ed1f651b
RS
48#ifndef R_OK
49#define R_OK 4
50#define W_OK 2
51#define X_OK 1
52#endif
53
99360286
DE
54/* Add prototype support. */
55#ifndef PROTO
56#if defined (USE_PROTOTYPES) ? USE_PROTOTYPES : defined (__STDC__)
57#define PROTO(ARGS) ARGS
58#else
59#define PROTO(ARGS) ()
60#endif
61#endif
62
b67b29cd
DE
63#ifndef VPROTO
64#ifdef __STDC__
d18225c4 65#define PVPROTO(ARGS) ARGS
b67b29cd
DE
66#define VPROTO(ARGS) ARGS
67#define VA_START(va_list,var) va_start(va_list,var)
68#else
d18225c4 69#define PVPROTO(ARGS) ()
b67b29cd
DE
70#define VPROTO(ARGS) (va_alist) va_dcl
71#define VA_START(va_list,var) va_start(va_list)
72#endif
73#endif
74
26ba9d26
TW
75/* Define a generic NULL if one hasn't already been defined. */
76
906c4e36
RK
77#ifndef NULL
78#define NULL 0
79#endif
80
26ba9d26
TW
81#ifndef GENERIC_PTR
82#if defined (USE_PROTOTYPES) ? USE_PROTOTYPES : defined (__STDC__)
83#define GENERIC_PTR void *
84#else
85#define GENERIC_PTR char *
86#endif
87#endif
88
906c4e36 89#ifndef NULL_PTR
26ba9d26 90#define NULL_PTR ((GENERIC_PTR)0)
906c4e36
RK
91#endif
92
2378088a 93#ifdef USG
ed1f651b
RS
94#define vfork fork
95#endif /* USG */
96
97/* On MSDOS, write temp files in current dir
98 because there's no place else we can expect to use. */
4b19dee8 99#ifdef __MSDOS__
ed1f651b 100#ifndef P_tmpdir
1e72f68f 101#define P_tmpdir "."
ed1f651b
RS
102#endif
103#endif
104
105/* Test if something is a normal file. */
106#ifndef S_ISREG
107#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)
108#endif
109
110/* Test if something is a directory. */
111#ifndef S_ISDIR
112#define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)
113#endif
114
115/* By default there is no special suffix for executables. */
116#ifndef EXECUTABLE_SUFFIX
ed1f651b
RS
117#define EXECUTABLE_SUFFIX ""
118#endif
f6ec7e54
RS
119
120/* By default, colon separates directories in a path. */
121#ifndef PATH_SEPARATOR
122#define PATH_SEPARATOR ':'
ed1f651b
RS
123#endif
124
125#define obstack_chunk_alloc xmalloc
126#define obstack_chunk_free free
127
128extern void free ();
129extern char *getenv ();
130
131extern int errno, sys_nerr;
5d672cd7
JW
132#if defined(bsd4_4)
133extern const char *const sys_errlist[];
134#else
ed1f651b 135extern char *sys_errlist[];
5d672cd7 136#endif
ed1f651b
RS
137
138extern int execv (), execvp ();
139
140/* If a stage of compilation returns an exit status >= 1,
141 compilation of that file ceases. */
142
143#define MIN_FATAL_STATUS 1
144
2dcb563f
RS
145/* Flag saying to print the full filename of libgcc.a
146 as found through our usual search mechanism. */
147
148static int print_libgcc_file_name;
149
ed1f651b
RS
150/* Flag indicating whether we should print the command and arguments */
151
152static int verbose_flag;
153
154/* Nonzero means write "temp" files in source directory
155 and use the source file's name in them, and don't delete them. */
156
157static int save_temps_flag;
158
53117a2f 159/* The compiler version. */
ed1f651b 160
53117a2f
RK
161static char *compiler_version;
162
163/* The target version specified with -V */
164
165static char *spec_version = DEFAULT_TARGET_VERSION;
ed1f651b
RS
166
167/* The target machine specified with -b. */
168
169static char *spec_machine = DEFAULT_TARGET_MACHINE;
170
004fd4d5
RS
171/* Nonzero if cross-compiling.
172 When -b is used, the value comes from the `specs' file. */
173
174#ifdef CROSS_COMPILE
175static int cross_compile = 1;
176#else
177static int cross_compile = 0;
178#endif
179
48fb792a
BK
180/* The number of errors that have occurred; the link phase will not be
181 run if this is non-zero. */
182static int error_count = 0;
183
ed1f651b
RS
184/* This is the obstack which we use to allocate many strings. */
185
186static struct obstack obstack;
187
b3865ca9 188/* This is the obstack to build an environment variable to pass to
6dc42e49 189 collect2 that describes all of the relevant switches of what to
b3865ca9
RS
190 pass the compiler in building the list of pointers to constructors
191 and destructors. */
192
193static struct obstack collect_obstack;
194
ed1f651b
RS
195extern char *version_string;
196
99360286
DE
197/* Forward declaration for prototypes. */
198struct path_prefix;
199
200static void set_spec PROTO((char *, char *));
201static struct compiler *lookup_compiler PROTO((char *, int, char *));
202static char *find_a_file PROTO((struct path_prefix *, char *, int));
203static void add_prefix PROTO((struct path_prefix *, char *, int, int, int *));
204static char *skip_whitespace PROTO((char *));
205static void record_temp_file PROTO((char *, int, int));
f5b0eb4e 206static int check_live_switch PROTO((int, int));
99360286
DE
207static char *handle_braces PROTO((char *));
208static char *save_string PROTO((char *, int));
209static char *concat PROTO((char *, char *, char *));
210static int do_spec PROTO((char *));
211static int do_spec_1 PROTO((char *, int, char *));
212static char *find_file PROTO((char *));
213static int is_directory PROTO((char *, char *, int));
214static void validate_switches PROTO((char *));
215static void validate_all_switches PROTO((void));
216static void give_switch PROTO((int, int));
217static void pfatal_with_name PROTO((char *));
218static void perror_with_name PROTO((char *));
219static void perror_exec PROTO((char *));
fd2c2b2b 220#ifdef HAVE_VPRINTF
d18225c4
RK
221static void fatal PVPROTO((char *, ...));
222static void error PVPROTO((char *, ...));
fd2c2b2b
DE
223#else
224/* We must not provide any prototype here, even if ANSI C. */
225static void fatal PROTO(());
226static void error PROTO(());
227#endif
99360286 228
ed1f651b
RS
229void fancy_abort ();
230char *xmalloc ();
231char *xrealloc ();
232\f
233/* Specs are strings containing lines, each of which (if not blank)
234is made up of a program name, and arguments separated by spaces.
235The program name must be exact and start from root, since no path
236is searched and it is unreliable to depend on the current working directory.
237Redirection of input or output is not supported; the subprograms must
238accept filenames saying what files to read and write.
239
240In addition, the specs can contain %-sequences to substitute variable text
241or for conditional text. Here is a table of all defined %-sequences.
242Note that spaces are not generated automatically around the results of
243expanding these sequences; therefore, you can concatenate them together
244or with constant text in a single argument.
245
246 %% substitute one % into the program name or argument.
247 %i substitute the name of the input file being processed.
248 %b substitute the basename of the input file being processed.
249 This is the substring up to (and not including) the last period
250 and not including the directory.
251 %g substitute the temporary-file-name-base. This is a string chosen
252 once per compilation. Different temporary file names are made by
253 concatenation of constant strings on the end, as in `%g.s'.
254 %g also has the same effect of %d.
d887e808 255 %u like %g, but make the temporary file name unique.
4401b31c 256 %U returns the last file name generated with %u.
ed1f651b
RS
257 %d marks the argument containing or following the %d as a
258 temporary file name, so that that file will be deleted if CC exits
259 successfully. Unlike %g, this contributes no text to the argument.
260 %w marks the argument containing or following the %w as the
261 "output file" of this compilation. This puts the argument
262 into the sequence of arguments that %o will substitute later.
263 %W{...}
264 like %{...} but mark last argument supplied within
265 as a file to be deleted on failure.
266 %o substitutes the names of all the output files, with spaces
267 automatically placed around them. You should write spaces
268 around the %o as well or the results are undefined.
269 %o is for use in the specs for running the linker.
270 Input files whose names have no recognized suffix are not compiled
271 at all, but they are included among the output files, so they will
272 be linked.
273 %p substitutes the standard macro predefinitions for the
274 current target machine. Use this when running cpp.
275 %P like %p, but puts `__' before and after the name of each macro.
276 (Except macros that already have __.)
277 This is for ANSI C.
8eebb258 278 %I Substitute a -iprefix option made from GCC_EXEC_PREFIX.
ed1f651b
RS
279 %s current argument is the name of a library or startup file of some sort.
280 Search for that file in a standard list of directories
281 and substitute the full name found.
282 %eSTR Print STR as an error message. STR is terminated by a newline.
283 Use this when inconsistent options are detected.
284 %x{OPTION} Accumulate an option for %X.
285 %X Output the accumulated linker options specified by compilations.
c9ebacb8 286 %Y Output the accumulated assembler options specified by compilations.
500c9e81
RS
287 %v1 Substitute the major version number of GCC.
288 (For version 2.5.n, this is 2.)
289 %v2 Substitute the minor version number of GCC.
829407e1 290 (For version 2.5.n, this is 5.)
ed1f651b
RS
291 %a process ASM_SPEC as a spec.
292 This allows config.h to specify part of the spec for running as.
293 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
294 used here. This can be used to run a post-processor after the
295 assembler has done it's job.
8cacec76 296 %D Dump out a -L option for each directory in startfile_prefix.
ed1f651b
RS
297 %l process LINK_SPEC as a spec.
298 %L process LIB_SPEC as a spec.
299 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
300 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
301 %c process SIGNED_CHAR_SPEC as a spec.
302 %C process CPP_SPEC as a spec. A capital C is actually used here.
303 %1 process CC1_SPEC as a spec.
304 %2 process CC1PLUS_SPEC as a spec.
a99bf70c 305 %| output "-" if the input for the current command is coming from a pipe.
ed1f651b
RS
306 %* substitute the variable part of a matched option. (See below.)
307 Note that each comma in the substituted string is replaced by
308 a single space.
309 %{S} substitutes the -S switch, if that switch was given to CC.
310 If that switch was not specified, this substitutes nothing.
311 Here S is a metasyntactic variable.
312 %{S*} substitutes all the switches specified to CC whose names start
313 with -S. This is used for -o, -D, -I, etc; switches that take
314 arguments. CC considers `-o foo' as being one switch whose
315 name starts with `o'. %{o*} would substitute this text,
316 including the space; thus, two arguments would be generated.
b9490a6e 317 %{S*:X} substitutes X if one or more switches whose names start with -S are
ed1f651b
RS
318 specified to CC. Note that the tail part of the -S option
319 (i.e. the part matched by the `*') will be substituted for each
6dc42e49 320 occurrence of %* within X.
ed1f651b
RS
321 %{S:X} substitutes X, but only if the -S switch was given to CC.
322 %{!S:X} substitutes X, but only if the -S switch was NOT given to CC.
323 %{|S:X} like %{S:X}, but if no S switch, substitute `-'.
324 %{|!S:X} like %{!S:X}, but if there is an S switch, substitute `-'.
325 %{.S:X} substitutes X, but only if processing a file with suffix S.
326 %{!.S:X} substitutes X, but only if NOT processing a file with suffix S.
b3865ca9
RS
327 %(Spec) processes a specification defined in a specs file as *Spec:
328 %[Spec] as above, but put __ around -D arguments
ed1f651b
RS
329
330The conditional text X in a %{S:X} or %{!S:X} construct may contain
331other nested % constructs or spaces, or even newlines. They are
332processed as usual, as described above.
333
f5b0eb4e
RK
334The -O, -f, -m, and -w switches are handled specifically in these
335constructs. If another value of -O or the negated form of a -f, -m, or
336-W switch is found later in the command line, the earlier switch
337value is ignored.
338
ed1f651b
RS
339The character | is used to indicate that a command should be piped to
340the following command, but only if -pipe is specified.
341
342Note that it is built into CC which switches take arguments and which
343do not. You might think it would be useful to generalize this to
344allow each compiler's spec to say which switches take arguments. But
345this cannot be done in a consistent fashion. CC cannot even decide
346which input files have been specified without knowing which switches
347take arguments, and it must know which input files to compile in order
348to tell which compilers to run.
349
350CC also knows implicitly that arguments starting in `-l' are to be
351treated as compiler output files, and passed to the linker in their
352proper position among the other output files. */
353\f
354/* Define the macros used for specs %a, %l, %L, %S, %c, %C, %1. */
355
356/* config.h can define ASM_SPEC to provide extra args to the assembler
357 or extra switch-translations. */
358#ifndef ASM_SPEC
359#define ASM_SPEC ""
360#endif
361
362/* config.h can define ASM_FINAL_SPEC to run a post processor after
363 the assembler has run. */
364#ifndef ASM_FINAL_SPEC
365#define ASM_FINAL_SPEC ""
366#endif
367
368/* config.h can define CPP_SPEC to provide extra args to the C preprocessor
369 or extra switch-translations. */
370#ifndef CPP_SPEC
371#define CPP_SPEC ""
372#endif
373
374/* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
375 or extra switch-translations. */
376#ifndef CC1_SPEC
377#define CC1_SPEC ""
378#endif
379
380/* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
381 or extra switch-translations. */
382#ifndef CC1PLUS_SPEC
383#define CC1PLUS_SPEC ""
384#endif
385
386/* config.h can define LINK_SPEC to provide extra args to the linker
387 or extra switch-translations. */
388#ifndef LINK_SPEC
389#define LINK_SPEC ""
390#endif
391
392/* config.h can define LIB_SPEC to override the default libraries. */
393#ifndef LIB_SPEC
394#define LIB_SPEC "%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}"
395#endif
396
397/* config.h can define STARTFILE_SPEC to override the default crt0 files. */
398#ifndef STARTFILE_SPEC
399#define STARTFILE_SPEC \
400 "%{pg:gcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}"
401#endif
402
403/* config.h can define SWITCHES_NEED_SPACES to control passing -o and -L.
404 Make the string nonempty to require spaces there. */
405#ifndef SWITCHES_NEED_SPACES
406#define SWITCHES_NEED_SPACES ""
407#endif
408
409/* config.h can define ENDFILE_SPEC to override the default crtn files. */
410#ifndef ENDFILE_SPEC
411#define ENDFILE_SPEC ""
412#endif
413
414/* This spec is used for telling cpp whether char is signed or not. */
415#ifndef SIGNED_CHAR_SPEC
0e14ddbc
RS
416/* Use #if rather than ?:
417 because MIPS C compiler rejects like ?: in initializers. */
f396d278
RS
418#if DEFAULT_SIGNED_CHAR
419#define SIGNED_CHAR_SPEC "%{funsigned-char:-D__CHAR_UNSIGNED__}"
420#else
421#define SIGNED_CHAR_SPEC "%{!fsigned-char:-D__CHAR_UNSIGNED__}"
422#endif
ed1f651b
RS
423#endif
424
425static char *cpp_spec = CPP_SPEC;
426static char *cpp_predefines = CPP_PREDEFINES;
427static char *cc1_spec = CC1_SPEC;
428static char *cc1plus_spec = CC1PLUS_SPEC;
429static char *signed_char_spec = SIGNED_CHAR_SPEC;
430static char *asm_spec = ASM_SPEC;
431static char *asm_final_spec = ASM_FINAL_SPEC;
432static char *link_spec = LINK_SPEC;
433static char *lib_spec = LIB_SPEC;
434static char *endfile_spec = ENDFILE_SPEC;
435static char *startfile_spec = STARTFILE_SPEC;
436static char *switches_need_spaces = SWITCHES_NEED_SPACES;
437
438/* This defines which switch letters take arguments. */
439
440#ifndef SWITCH_TAKES_ARG
441#define SWITCH_TAKES_ARG(CHAR) \
442 ((CHAR) == 'D' || (CHAR) == 'U' || (CHAR) == 'o' \
443 || (CHAR) == 'e' || (CHAR) == 'T' || (CHAR) == 'u' \
444 || (CHAR) == 'I' || (CHAR) == 'm' \
445 || (CHAR) == 'L' || (CHAR) == 'A')
446#endif
447
448/* This defines which multi-letter switches take arguments. */
449
3b39b94f 450#define DEFAULT_WORD_SWITCH_TAKES_ARG(STR) \
ebb8e0c6
JW
451 (!strcmp (STR, "Tdata") || !strcmp (STR, "Ttext") \
452 || !strcmp (STR, "Tbss") || !strcmp (STR, "include") \
3b39b94f
ILT
453 || !strcmp (STR, "imacros") || !strcmp (STR, "aux-info") \
454 || !strcmp (STR, "idirafter") || !strcmp (STR, "iprefix") \
8b3d0251 455 || !strcmp (STR, "iwithprefix") || !strcmp (STR, "iwithprefixbefore"))
3b39b94f
ILT
456
457#ifndef WORD_SWITCH_TAKES_ARG
458#define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
ed1f651b
RS
459#endif
460\f
461/* Record the mapping from file suffixes for compilation specs. */
462
463struct compiler
464{
465 char *suffix; /* Use this compiler for input files
466 whose names end in this suffix. */
ec32609a
RS
467
468 char *spec[4]; /* To use this compiler, concatenate these
469 specs and pass to do_spec. */
ed1f651b
RS
470};
471
472/* Pointer to a vector of `struct compiler' that gives the spec for
473 compiling a file, based on its suffix.
474 A file that does not end in any of these suffixes will be passed
475 unchanged to the loader and nothing else will be done to it.
476
477 An entry containing two 0s is used to terminate the vector.
478
479 If multiple entries match a file, the last matching one is used. */
480
481static struct compiler *compilers;
482
483/* Number of entries in `compilers', not counting the null terminator. */
484
485static int n_compilers;
486
487/* The default list of file name suffixes and their compilation specs. */
488
489static struct compiler default_compilers[] =
490{
491 {".c", "@c"},
492 {"@c",
b9490a6e 493 "cpp -lang-c %{nostdinc*} %{C} %{v} %{A*} %{I*} %{P} %I\
ed1f651b
RS
494 %{C:%{!E:%eGNU C does not support -C without using -E}}\
495 %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d}\
500c9e81 496 -undef -D__GNUC__=%v1 -D__GNUC_MINOR__=%v2\
829407e1 497 %{ansi:-trigraphs -$ -D__STRICT_ANSI__}\
b9490a6e 498 %{!undef:%{!ansi:%p} %P} %{trigraphs} \
4782d5b5 499 %c %{O*:%{!O0:-D__OPTIMIZE__}} %{traditional} %{ftraditional:-traditional}\
ed1f651b 500 %{traditional-cpp:-traditional}\
b9490a6e 501 %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*}\
ec32609a
RS
502 %i %{!M:%{!MM:%{!E:%{!pipe:%g.i}}}}%{E:%W{o*}}%{M:%W{o*}}%{MM:%W{o*}} |\n",
503 "%{!M:%{!MM:%{!E:cc1 %{!pipe:%g.i} %1 \
ed1f651b
RS
504 %{!Q:-quiet} -dumpbase %b.c %{d*} %{m*} %{a}\
505 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{ansi} \
506 %{traditional} %{v:-version} %{pg:-p} %{p} %{f*}\
b3865ca9 507 %{aux-info*}\
ed1f651b
RS
508 %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
509 %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
c9ebacb8 510 %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 511 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
ed1f651b
RS
512 %{!pipe:%g.s} %A\n }}}}"},
513 {"-",
b9490a6e 514 "%{E:cpp -lang-c %{nostdinc*} %{C} %{v} %{A*} %{I*} %{P} %I\
ed1f651b
RS
515 %{C:%{!E:%eGNU C does not support -C without using -E}}\
516 %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d}\
dc476ce2
RS
517 -undef -D__GNUC__=%v1 -D__GNUC_MINOR__=%v2\
518 %{ansi:-trigraphs -$ -D__STRICT_ANSI__}\
ed1f651b 519 %{!undef:%{!ansi:%p} %P} %{trigraphs}\
4782d5b5 520 %c %{O*:%{!O0:-D__OPTIMIZE__}} %{traditional} %{ftraditional:-traditional}\
ed1f651b 521 %{traditional-cpp:-traditional}\
b9490a6e 522 %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*}\
ed1f651b
RS
523 %i %W{o*}}\
524 %{!E:%e-E required when input is from standard input}"},
525 {".m", "@objective-c"},
526 {"@objective-c",
b9490a6e 527 "cpp -lang-objc %{nostdinc*} %{C} %{v} %{A*} %{I*} %{P} %I\
ed1f651b
RS
528 %{C:%{!E:%eGNU C does not support -C without using -E}}\
529 %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d}\
500c9e81 530 -undef -D__OBJC__ -D__GNUC__=%v1 -D__GNUC_MINOR__=%v2\
829407e1 531 %{ansi:-trigraphs -$ -D__STRICT_ANSI__}\
ed1f651b 532 %{!undef:%{!ansi:%p} %P} %{trigraphs}\
4782d5b5 533 %c %{O*:%{!O0:-D__OPTIMIZE__}} %{traditional} %{ftraditional:-traditional}\
ed1f651b 534 %{traditional-cpp:-traditional}\
b9490a6e 535 %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*}\
20eec2c2 536 %i %{!M:%{!MM:%{!E:%{!pipe:%g.i}}}}%{E:%W{o*}}%{M:%W{o*}}%{MM:%W{o*}} |\n",
ec32609a 537 "%{!M:%{!MM:%{!E:cc1obj %{!pipe:%g.i} %1 \
ed1f651b
RS
538 %{!Q:-quiet} -dumpbase %b.m %{d*} %{m*} %{a}\
539 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{ansi} \
540 %{traditional} %{v:-version} %{pg:-p} %{p} %{f*} \
541 -lang-objc %{gen-decls} \
b3865ca9 542 %{aux-info*}\
ed1f651b
RS
543 %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
544 %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
c9ebacb8 545 %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 546 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
ed1f651b
RS
547 %{!pipe:%g.s} %A\n }}}}"},
548 {".h", "@c-header"},
549 {"@c-header",
550 "%{!E:%eCompilation of header file requested} \
b9490a6e 551 cpp %{nostdinc*} %{C} %{v} %{A*} %{I*} %{P} %I\
ed1f651b
RS
552 %{C:%{!E:%eGNU C does not support -C without using -E}}\
553 %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d} \
500c9e81 554 -undef -D__GNUC__=%v1 -D__GNUC_MINOR__=%v2\
829407e1 555 %{ansi:-trigraphs -$ -D__STRICT_ANSI__}\
ed1f651b 556 %{!undef:%{!ansi:%p} %P} %{trigraphs}\
4782d5b5 557 %c %{O*:%{!O0:-D__OPTIMIZE__}} %{traditional} %{ftraditional:-traditional}\
ed1f651b 558 %{traditional-cpp:-traditional}\
b9490a6e 559 %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*}\
ed1f651b
RS
560 %i %W{o*}"},
561 {".cc", "@c++"},
562 {".cxx", "@c++"},
cc70323d 563 {".cpp", "@c++"},
ed1f651b
RS
564 {".C", "@c++"},
565 {"@c++",
b9490a6e 566 "cpp -lang-c++ %{nostdinc*} %{C} %{v} %{A*} %{I*} %{P} %I\
ed1f651b
RS
567 %{C:%{!E:%eGNU C++ does not support -C without using -E}}\
568 %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d} \
500c9e81 569 -undef -D__GNUC__=%v1 -D__GNUG__=%v1 -D__cplusplus -D__GNUC_MINOR__=%v2\
ed1f651b 570 %{ansi:-trigraphs -$ -D__STRICT_ANSI__} %{!undef:%{!ansi:%p} %P}\
4782d5b5 571 %c %{O*:%{!O0:-D__OPTIMIZE__}} %{traditional} %{ftraditional:-traditional}\
ed1f651b 572 %{traditional-cpp:-traditional} %{trigraphs}\
b9490a6e 573 %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*}\
7aaf8abb
RK
574 %i %{!M:%{!MM:%{!E:%{!pipe:%g.ii}}}}%{E:%W{o*}}%{M:%W{o*}}%{MM:%W{o*}} |\n",
575 "%{!M:%{!MM:%{!E:cc1plus %{!pipe:%g.ii} %1 %2\
ed1f651b
RS
576 %{!Q:-quiet} -dumpbase %b.cc %{d*} %{m*} %{a}\
577 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{ansi} %{traditional}\
301a5c0b 578 %{v:-version} %{pg:-p} %{p} %{f*} %{+e*}\
b3865ca9 579 %{aux-info*}\
ed1f651b
RS
580 %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
581 %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
c9ebacb8 582 %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 583 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
ed1f651b
RS
584 %{!pipe:%g.s} %A\n }}}}"},
585 {".i", "@cpp-output"},
586 {"@cpp-output",
587 "cc1 %i %1 %{!Q:-quiet} %{d*} %{m*} %{a}\
588 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{ansi} %{traditional}\
589 %{v:-version} %{pg:-p} %{p} %{f*}\
b3865ca9 590 %{aux-info*}\
ed1f651b
RS
591 %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
592 %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
c9ebacb8 593 %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 594 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o} %{!pipe:%g.s} %A\n }"},
ed1f651b
RS
595 {".ii", "@c++-cpp-output"},
596 {"@c++-cpp-output",
597 "cc1plus %i %1 %2 %{!Q:-quiet} %{d*} %{m*} %{a}\
598 %{g*} %{O*} %{W*} %{w} %{pedantic*} %{ansi} %{traditional}\
301a5c0b 599 %{v:-version} %{pg:-p} %{p} %{f*} %{+e*}\
b3865ca9 600 %{aux-info*}\
ed1f651b
RS
601 %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
602 %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
c9ebacb8 603 %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 604 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
004fd4d5 605 %{!pipe:%g.s} %A\n }"},
ed1f651b
RS
606 {".s", "@assembler"},
607 {"@assembler",
c9ebacb8 608 "%{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 609 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o} %i %A\n }"},
ed1f651b
RS
610 {".S", "@assembler-with-cpp"},
611 {"@assembler-with-cpp",
b9490a6e 612 "cpp -lang-asm %{nostdinc*} %{C} %{v} %{A*} %{I*} %{P} %I\
ed1f651b
RS
613 %{C:%{!E:%eGNU C does not support -C without using -E}}\
614 %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d} %{trigraphs} \
615 -undef -$ %{!undef:%p %P} -D__ASSEMBLER__ \
4782d5b5 616 %c %{O*:%{!O0:-D__OPTIMIZE__}} %{traditional} %{ftraditional:-traditional}\
ed1f651b 617 %{traditional-cpp:-traditional}\
b9490a6e 618 %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*}\
20eec2c2 619 %i %{!M:%{!MM:%{!E:%{!pipe:%g.s}}}}%{E:%W{o*}}%{M:%W{o*}}%{MM:%W{o*}} |\n",
ec32609a 620 "%{!M:%{!MM:%{!E:%{!S:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
d887e808 621 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
ed1f651b 622 %{!pipe:%g.s} %A\n }}}}"},
c1de946d
RK
623 {".ads", "@ada"},
624 {".adb", "@ada"},
625 {".ada", "@ada"},
626 {"@ada",
4aea22ca 627 "gnat1 %{k8:-gnatk8} %{w:-gnatws} %{!Q:-quiet} -dumpbase %b.ada\
c1de946d
RK
628 %{g*} %{O*} %{p} %{pg:-p} %{f*} %{d*}\
629 %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
630 %i %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} | \n",
631 "%{!S:%{!gnatc:%{!gnats:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
632 %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
633 %{!pipe:%g.s} %A\n}}} "},
ed1f651b
RS
634 /* Mark end of table */
635 {0, 0}
636};
637
638/* Number of elements in default_compilers, not counting the terminator. */
639
640static int n_default_compilers
641 = (sizeof default_compilers / sizeof (struct compiler)) - 1;
642
643/* Here is the spec for running the linker, after compiling all files. */
644
2378088a 645/* -u* was put back because both BSD and SysV seem to support it. */
7ede72fc
RS
646/* %{static:} simply prevents an error message if the target machine
647 doesn't handle -static. */
a2dfec99
JW
648/* We want %{T*} after %{L*} and %D so that it can be used to specify linker
649 scripts which exist in user specified directories, or in standard
650 directories. */
49003ff6
RS
651#ifdef LINK_LIBGCC_SPECIAL_1
652/* Have gcc do the search for libgcc.a, but generate -L options as usual. */
653static char *link_command_spec = "\
1763b229 654%{!fsyntax-only: \
4b3f0a5b 655 %{!c:%{!M:%{!MM:%{!E:%{!S:ld %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} \
a2dfec99 656 %{r} %{s} %{t} %{u*} %{x} %{z}\
ac509592 657 %{!A:%{!nostartfiles:%{!nostdlib:%S}}} %{static:}\
a2dfec99 658 %{L*} %D %{T*} %o %{!nostdlib:libgcc.a%s %L libgcc.a%s %{!A:%E}}\n }}}}}}";
49003ff6
RS
659#else
660#ifdef LINK_LIBGCC_SPECIAL
661/* Have gcc do the search for libgcc.a, and don't generate -L options. */
ed1f651b 662static char *link_command_spec = "\
1763b229 663%{!fsyntax-only: \
4b3f0a5b 664 %{!c:%{!M:%{!MM:%{!E:%{!S:ld %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} \
a2dfec99 665 %{r} %{s} %{t} %{u*} %{x} %{z}\
ac509592 666 %{!A:%{!nostartfiles:%{!nostdlib:%S}}} %{static:}\
a2dfec99 667 %{L*} %{T*} %o %{!nostdlib:libgcc.a%s %L libgcc.a%s %{!A:%E}}\n }}}}}}";
004fd4d5 668#else
efb19330 669/* Use -L and have the linker do the search for -lgcc. */
004fd4d5 670static char *link_command_spec = "\
1763b229 671%{!fsyntax-only: \
4b3f0a5b 672 %{!c:%{!M:%{!MM:%{!E:%{!S:ld %l %X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} \
a2dfec99 673 %{r} %{s} %{t} %{u*} %{x} %{z}\
ac509592 674 %{!A:%{!nostartfiles:%{!nostdlib:%S}}} %{static:}\
a2dfec99 675 %{L*} %D %{T*} %o %{!nostdlib:-lgcc %L -lgcc %{!A:%E}}\n }}}}}}";
004fd4d5 676#endif
49003ff6 677#endif
ed1f651b
RS
678
679/* A vector of options to give to the linker.
c9ebacb8 680 These options are accumulated by -Xlinker and -Wl,
ed1f651b
RS
681 and substituted into the linker command with %X. */
682static int n_linker_options;
683static char **linker_options;
c9ebacb8
RS
684
685/* A vector of options to give to the assembler.
686 These options are accumulated by -Wa,
687 and substituted into the assembler command with %X. */
688static int n_assembler_options;
689static char **assembler_options;
ed1f651b 690\f
f2faf549
RS
691/* Define how to map long options into short ones. */
692
693/* This structure describes one mapping. */
694struct option_map
695{
696 /* The long option's name. */
697 char *name;
698 /* The equivalent short option. */
699 char *equivalent;
700 /* Argument info. A string of flag chars; NULL equals no options.
701 a => argument required.
702 o => argument optional.
703 j => join argument to equivalent, making one word.
704 * => allow other text after NAME as an argument. */
705 char *arg_info;
706};
707
708/* This is the table of mappings. Mappings are tried sequentially
709 for each option encountered; the first one that matches, wins. */
710
711struct option_map option_map[] =
712 {
713 {"--profile-blocks", "-a", 0},
714 {"--target", "-b", "a"},
715 {"--compile", "-c", 0},
716 {"--dump", "-d", "a"},
717 {"--entry", "-e", 0},
718 {"--debug", "-g", "oj"},
719 {"--include", "-include", "a"},
720 {"--imacros", "-imacros", "a"},
721 {"--include-prefix", "-iprefix", "a"},
722 {"--include-directory-after", "-idirafter", "a"},
723 {"--include-with-prefix", "-iwithprefix", "a"},
8b3d0251
RS
724 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
725 {"--include-with-prefix-after", "-iwithprefix", "a"},
f2faf549
RS
726 {"--machine-", "-m", "*j"},
727 {"--machine", "-m", "aj"},
728 {"--no-standard-includes", "-nostdinc", 0},
729 {"--no-standard-libraries", "-nostdlib", 0},
730 {"--no-precompiled-includes", "-noprecomp", 0},
731 {"--output", "-o", "a"},
732 {"--profile", "-p", 0},
733 {"--quiet", "-q", 0},
734 {"--silent", "-q", 0},
735 {"--force-link", "-u", "a"},
736 {"--verbose", "-v", 0},
5e3f49d1 737 {"--version", "-dumpversion", 0},
f2faf549
RS
738 {"--no-warnings", "-w", 0},
739 {"--language", "-x", "a"},
740
741 {"--assert", "-A", "a"},
742 {"--prefix", "-B", "a"},
743 {"--comments", "-C", 0},
744 {"--define-macro", "-D", "a"},
745 {"--preprocess", "-E", 0},
746 {"--trace-includes", "-H", 0},
747 {"--include-directory", "-I", "a"},
748 {"--include-barrier", "-I-", 0},
749 {"--library-directory", "-L", "a"},
750 {"--dependencies", "-M", 0},
751 {"--user-dependencies", "-MM", 0},
752 {"--write-dependencies", "-MD", 0},
753 {"--write-user-dependencies", "-MMD", 0},
754 {"--optimize", "-O", "oj"},
755 {"--no-line-commands", "-P", 0},
756 {"--assemble", "-S", 0},
757 {"--undefine-macro", "-U", "a"},
8e063665 758 {"--use-version", "-V", "a"},
f2faf549
RS
759 {"--for-assembler", "-Wa", "a"},
760 {"--extra-warnings", "-W", 0},
761 {"--all-warnings", "-Wall", 0},
762 {"--warn-", "-W", "*j"},
763 {"--for-linker", "-Xlinker", "a"},
764
765 {"--ansi", "-ansi", 0},
766 {"--traditional", "-traditional", 0},
767 {"--traditional-cpp", "-traditional-cpp", 0},
768 {"--trigraphs", "-trigraphs", 0},
769 {"--pipe", "-pipe", 0},
770 {"--dumpbase", "-dumpbase", "a"},
771 {"--pedantic", "-pedantic", 0},
772 {"--pedantic-errors", "-pedantic-errors", 0},
773 {"--save-temps", "-save-temps", 0},
774 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
775 {"--static", "-static", 0},
776 {"--shared", "-shared", 0},
777 {"--symbolic", "-symbolic", 0},
778 {"--", "-f", "*j"}
779 };
780\f
781/* Translate the options described by *ARGCP and *ARGVP.
782 Make a new vector and store it back in *ARGVP,
783 and store its length in *ARGVC. */
784
785static void
786translate_options (argcp, argvp)
787 int *argcp;
788 char ***argvp;
789{
790 int i, j;
791 int argc = *argcp;
792 char **argv = *argvp;
793 char **newv = (char **) xmalloc ((argc + 2) * 2 * sizeof (char *));
794 int newindex = 0;
795
796 i = 0;
797 newv[newindex++] = argv[i++];
798
799 while (i < argc)
800 {
801 /* Translate -- options. */
802 if (argv[i][0] == '-' && argv[i][1] == '-')
803 {
804 /* Find a mapping that applies to this option. */
805 for (j = 0; j < sizeof (option_map) / sizeof (option_map[0]); j++)
806 {
807 int optlen = strlen (option_map[j].name);
808 int complen = strlen (argv[i]);
cc198f10
RS
809 char *arginfo = option_map[j].arg_info;
810
811 if (arginfo == 0)
812 arginfo = "";
f2faf549
RS
813 if (complen > optlen)
814 complen = optlen;
815 if (!strncmp (argv[i], option_map[j].name, complen))
816 {
817 int extra = strlen (argv[i]) > optlen;
818 char *arg = 0;
819
820 if (extra)
821 {
822 /* If the option has an argument, accept that. */
823 if (argv[i][optlen] == '=')
824 arg = argv[i] + optlen + 1;
825 /* If this mapping allows extra text at end of name,
826 accept that as "argument". */
cc198f10 827 else if (index (arginfo, '*') != 0)
f2faf549
RS
828 arg = argv[i] + optlen;
829 /* Otherwise, extra text at end means mismatch.
830 Try other mappings. */
831 else
832 continue;
833 }
cc198f10 834 else if (index (arginfo, '*') != 0)
f2faf549
RS
835 error ("Incomplete `%s' option", option_map[j].name);
836
837 /* Handle arguments. */
cc198f10 838 if (index (arginfo, 'o') != 0)
f2faf549
RS
839 {
840 if (arg == 0)
841 {
842 if (i + 1 == argc)
843 error ("Missing argument to `%s' option",
844 option_map[j].name);
845 arg = argv[++i];
846 }
847 }
fff26804
RS
848 else if (index (arginfo, '*') != 0)
849 ;
cc198f10 850 else if (index (arginfo, 'a') == 0)
f2faf549
RS
851 {
852 if (arg != 0)
853 error ("Extraneous argument to `%s' option",
854 option_map[j].name);
855 arg = 0;
856 }
857
858 /* Store the translation as one argv elt or as two. */
cc198f10 859 if (arg != 0 && index (arginfo, 'j') != 0)
f2faf549
RS
860 newv[newindex++] = concat (option_map[j].equivalent,
861 arg, "");
862 else if (arg != 0)
863 {
864 newv[newindex++] = option_map[j].equivalent;
865 newv[newindex++] = arg;
866 }
867 else
868 newv[newindex++] = option_map[j].equivalent;
869
870 break;
871 }
872 }
873 i++;
874 }
875 /* Handle old-fashioned options--just copy them through,
876 with their arguments. */
877 else if (argv[i][0] == '-')
878 {
879 char *p = argv[i] + 1;
880 int c = *p;
881 int nskip = 1;
882
883 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
884 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
885 else if (WORD_SWITCH_TAKES_ARG (p))
886 nskip += WORD_SWITCH_TAKES_ARG (p);
fb99c21c
JW
887 else if ((c == 'B' || c == 'b' || c == 'V' || c == 'x')
888 && p[1] == 0)
889 nskip += 1;
890 else if (! strcmp (p, "Xlinker"))
891 nskip += 1;
f2faf549
RS
892
893 while (nskip > 0)
894 {
895 newv[newindex++] = argv[i++];
896 nskip--;
897 }
898 }
899 else
900 /* Ordinary operands, or +e options. */
901 newv[newindex++] = argv[i++];
902 }
903
904 newv[newindex] = 0;
905
906 *argvp = newv;
907 *argcp = newindex;
908}
909\f
ed1f651b
RS
910/* Read compilation specs from a file named FILENAME,
911 replacing the default ones.
912
913 A suffix which starts with `*' is a definition for
914 one of the machine-specific sub-specs. The "suffix" should be
915 *asm, *cc1, *cpp, *link, *startfile, *signed_char, etc.
916 The corresponding spec is stored in asm_spec, etc.,
917 rather than in the `compilers' vector.
918
919 Anything invalid in the file is a fatal error. */
920
921static void
922read_specs (filename)
923 char *filename;
924{
925 int desc;
926 struct stat statbuf;
927 char *buffer;
928 register char *p;
929
930 if (verbose_flag)
931 fprintf (stderr, "Reading specs from %s\n", filename);
932
933 /* Open and stat the file. */
934 desc = open (filename, 0, 0);
935 if (desc < 0)
936 pfatal_with_name (filename);
937 if (stat (filename, &statbuf) < 0)
938 pfatal_with_name (filename);
939
940 /* Read contents of file into BUFFER. */
a6bf4347
RS
941 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
942 read (desc, buffer, (unsigned) statbuf.st_size);
ed1f651b
RS
943 buffer[statbuf.st_size] = 0;
944 close (desc);
945
946 /* Scan BUFFER for specs, putting them in the vector. */
947 p = buffer;
948 while (1)
949 {
950 char *suffix;
951 char *spec;
952 char *in, *out, *p1, *p2;
953
954 /* Advance P in BUFFER to the next nonblank nocomment line. */
955 p = skip_whitespace (p);
956 if (*p == 0)
957 break;
958
959 /* Find the colon that should end the suffix. */
960 p1 = p;
961 while (*p1 && *p1 != ':' && *p1 != '\n') p1++;
962 /* The colon shouldn't be missing. */
963 if (*p1 != ':')
964 fatal ("specs file malformed after %d characters", p1 - buffer);
965 /* Skip back over trailing whitespace. */
966 p2 = p1;
967 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t')) p2--;
968 /* Copy the suffix to a string. */
969 suffix = save_string (p, p2 - p);
970 /* Find the next line. */
971 p = skip_whitespace (p1 + 1);
972 if (p[1] == 0)
973 fatal ("specs file malformed after %d characters", p - buffer);
974 p1 = p;
975 /* Find next blank line. */
976 while (*p1 && !(*p1 == '\n' && p1[1] == '\n')) p1++;
977 /* Specs end at the blank line and do not include the newline. */
978 spec = save_string (p, p1 - p);
979 p = p1;
980
981 /* Delete backslash-newline sequences from the spec. */
982 in = spec;
983 out = spec;
984 while (*in != 0)
985 {
986 if (in[0] == '\\' && in[1] == '\n')
987 in += 2;
988 else if (in[0] == '#')
989 {
990 while (*in && *in != '\n') in++;
ed1f651b
RS
991 }
992 else
993 *out++ = *in++;
994 }
995 *out = 0;
996
997 if (suffix[0] == '*')
998 {
999 if (! strcmp (suffix, "*link_command"))
1000 link_command_spec = spec;
1001 else
1002 set_spec (suffix + 1, spec);
1003 }
1004 else
1005 {
1006 /* Add this pair to the vector. */
1007 compilers
1008 = ((struct compiler *)
1009 xrealloc (compilers, (n_compilers + 2) * sizeof (struct compiler)));
1010 compilers[n_compilers].suffix = suffix;
ec32609a
RS
1011 bzero (compilers[n_compilers].spec,
1012 sizeof compilers[n_compilers].spec);
1013 compilers[n_compilers].spec[0] = spec;
ed1f651b 1014 n_compilers++;
cbc580f0 1015 bzero (&compilers[n_compilers], sizeof compilers[n_compilers]);
ed1f651b
RS
1016 }
1017
1018 if (*suffix == 0)
1019 link_command_spec = spec;
1020 }
1021
1022 if (link_command_spec == 0)
1023 fatal ("spec file has no spec for linking");
1024}
1025
1026static char *
1027skip_whitespace (p)
1028 char *p;
1029{
1030 while (1)
1031 {
1032 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1033 be considered whitespace. */
1034 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1035 return p + 1;
1036 else if (*p == '\n' || *p == ' ' || *p == '\t')
1037 p++;
1038 else if (*p == '#')
1039 {
1040 while (*p != '\n') p++;
1041 p++;
1042 }
1043 else
1044 break;
1045 }
1046
1047 return p;
1048}
1049\f
1050/* Structure to keep track of the specs that have been defined so far. These
b3865ca9 1051 are accessed using %(specname) or %[specname] in a compiler or link spec. */
ed1f651b
RS
1052
1053struct spec_list
1054{
1055 char *name; /* Name of the spec. */
1056 char *spec; /* The spec itself. */
1057 struct spec_list *next; /* Next spec in linked list. */
1058};
1059
1060/* List of specs that have been defined so far. */
1061
1062static struct spec_list *specs = (struct spec_list *) 0;
1063\f
1064/* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1065 removed; If the spec starts with a + then SPEC is added to the end of the
1066 current spec. */
1067
1068static void
1069set_spec (name, spec)
1070 char *name;
1071 char *spec;
1072{
1073 struct spec_list *sl;
1074 char *old_spec;
1075
1076 /* See if the spec already exists */
1077 for (sl = specs; sl; sl = sl->next)
1078 if (strcmp (sl->name, name) == 0)
1079 break;
1080
1081 if (!sl)
1082 {
1083 /* Not found - make it */
1084 sl = (struct spec_list *) xmalloc (sizeof (struct spec_list));
1085 sl->name = save_string (name, strlen (name));
1086 sl->spec = save_string ("", 0);
1087 sl->next = specs;
1088 specs = sl;
1089 }
1090
1091 old_spec = sl->spec;
1092 if (name && spec[0] == '+' && isspace (spec[1]))
6196c528 1093 sl->spec = concat (old_spec, spec + 1, "");
ed1f651b
RS
1094 else
1095 sl->spec = save_string (spec, strlen (spec));
1096
1097 if (! strcmp (name, "asm"))
1098 asm_spec = sl->spec;
1099 else if (! strcmp (name, "asm_final"))
1100 asm_final_spec = sl->spec;
1101 else if (! strcmp (name, "cc1"))
1102 cc1_spec = sl->spec;
1103 else if (! strcmp (name, "cc1plus"))
1104 cc1plus_spec = sl->spec;
1105 else if (! strcmp (name, "cpp"))
1106 cpp_spec = sl->spec;
1107 else if (! strcmp (name, "endfile"))
1108 endfile_spec = sl->spec;
1109 else if (! strcmp (name, "lib"))
1110 lib_spec = sl->spec;
1111 else if (! strcmp (name, "link"))
1112 link_spec = sl->spec;
1113 else if (! strcmp (name, "predefines"))
1114 cpp_predefines = sl->spec;
1115 else if (! strcmp (name, "signed_char"))
1116 signed_char_spec = sl->spec;
1117 else if (! strcmp (name, "startfile"))
1118 startfile_spec = sl->spec;
1119 else if (! strcmp (name, "switches_need_spaces"))
1120 switches_need_spaces = sl->spec;
004fd4d5
RS
1121 else if (! strcmp (name, "cross_compile"))
1122 cross_compile = atoi (sl->spec);
ed1f651b
RS
1123 /* Free the old spec */
1124 if (old_spec)
1125 free (old_spec);
1126}
1127\f
1128/* Accumulate a command (program name and args), and run it. */
1129
1130/* Vector of pointers to arguments in the current line of specifications. */
1131
1132static char **argbuf;
1133
1134/* Number of elements allocated in argbuf. */
1135
1136static int argbuf_length;
1137
1138/* Number of elements in argbuf currently in use (containing args). */
1139
1140static int argbuf_index;
1141
fb266030
TW
1142/* This is the list of suffixes and codes (%g/%u/%U) and the associated
1143 temp file. Used only if MKTEMP_EACH_FILE. */
1144
1145static struct temp_name {
1146 char *suffix; /* suffix associated with the code. */
1147 int length; /* strlen (suffix). */
1148 int unique; /* Indicates whether %g or %u/%U was used. */
1149 char *filename; /* associated filename. */
1150 int filename_length; /* strlen (filename). */
1151 struct temp_name *next;
1152} *temp_names;
1153
ed1f651b
RS
1154/* Number of commands executed so far. */
1155
1156static int execution_count;
1157
3b9b4d3f
RS
1158/* Number of commands that exited with a signal. */
1159
1160static int signal_count;
1161
ed1f651b
RS
1162/* Name with which this program was invoked. */
1163
1164static char *programname;
1165\f
1166/* Structures to keep track of prefixes to try when looking for files. */
1167
1168struct prefix_list
1169{
1170 char *prefix; /* String to prepend to the path. */
1171 struct prefix_list *next; /* Next in linked list. */
1172 int require_machine_suffix; /* Don't use without machine_suffix. */
ae04227b 1173 /* 2 means try both machine_suffix and just_machine_suffix. */
ed1f651b
RS
1174 int *used_flag_ptr; /* 1 if a file was found with this prefix. */
1175};
1176
1177struct path_prefix
1178{
1179 struct prefix_list *plist; /* List of prefixes to try */
1180 int max_len; /* Max length of a prefix in PLIST */
1181 char *name; /* Name of this list (used in config stuff) */
1182};
1183
1184/* List of prefixes to try when looking for executables. */
1185
1186static struct path_prefix exec_prefix = { 0, 0, "exec" };
1187
1188/* List of prefixes to try when looking for startup (crt0) files. */
1189
1190static struct path_prefix startfile_prefix = { 0, 0, "startfile" };
1191
2d879387
JW
1192/* List of prefixes to try when looking for include files. */
1193
1194static struct path_prefix include_prefix = { 0, 0, "include" };
1195
ae04227b
CH
1196/* Suffix to attach to directories searched for commands.
1197 This looks like `MACHINE/VERSION/'. */
ed1f651b
RS
1198
1199static char *machine_suffix = 0;
1200
ae04227b
CH
1201/* Suffix to attach to directories searched for commands.
1202 This is just `MACHINE/'. */
1203
1204static char *just_machine_suffix = 0;
1205
8eebb258
RS
1206/* Adjusted value of GCC_EXEC_PREFIX envvar. */
1207
1208static char *gcc_exec_prefix;
1209
ed1f651b
RS
1210/* Default prefixes to attach to command names. */
1211
1212#ifdef CROSS_COMPILE /* Don't use these prefixes for a cross compiler. */
1213#undef MD_EXEC_PREFIX
1214#undef MD_STARTFILE_PREFIX
607a4f7d 1215#undef MD_STARTFILE_PREFIX_1
ed1f651b
RS
1216#endif
1217
1218#ifndef STANDARD_EXEC_PREFIX
004fd4d5 1219#define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
ed1f651b
RS
1220#endif /* !defined STANDARD_EXEC_PREFIX */
1221
1222static char *standard_exec_prefix = STANDARD_EXEC_PREFIX;
1223static char *standard_exec_prefix_1 = "/usr/lib/gcc/";
1224#ifdef MD_EXEC_PREFIX
1225static char *md_exec_prefix = MD_EXEC_PREFIX;
1226#endif
1227
1228#ifndef STANDARD_STARTFILE_PREFIX
1229#define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
1230#endif /* !defined STANDARD_STARTFILE_PREFIX */
1231
1232#ifdef MD_STARTFILE_PREFIX
1233static char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1234#endif
607a4f7d
RS
1235#ifdef MD_STARTFILE_PREFIX_1
1236static char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1237#endif
ed1f651b
RS
1238static char *standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1239static char *standard_startfile_prefix_1 = "/lib/";
1240static char *standard_startfile_prefix_2 = "/usr/lib/";
1241
53cc3d63
ILT
1242#ifndef TOOLDIR_BASE_PREFIX
1243#define TOOLDIR_BASE_PREFIX "/usr/local/"
f18fd956 1244#endif
53cc3d63 1245static char *tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
f18fd956
RS
1246static char *tooldir_prefix;
1247
ed1f651b
RS
1248/* Clear out the vector of arguments (after a command is executed). */
1249
1250static void
1251clear_args ()
1252{
1253 argbuf_index = 0;
1254}
1255
1256/* Add one argument to the vector at the end.
1257 This is done when a space is seen or at the end of the line.
1258 If DELETE_ALWAYS is nonzero, the arg is a filename
1259 and the file should be deleted eventually.
1260 If DELETE_FAILURE is nonzero, the arg is a filename
1261 and the file should be deleted if this compilation fails. */
1262
1263static void
1264store_arg (arg, delete_always, delete_failure)
1265 char *arg;
1266 int delete_always, delete_failure;
1267{
1268 if (argbuf_index + 1 == argbuf_length)
1269 {
1270 argbuf = (char **) xrealloc (argbuf, (argbuf_length *= 2) * sizeof (char *));
1271 }
1272
1273 argbuf[argbuf_index++] = arg;
1274 argbuf[argbuf_index] = 0;
1275
1276 if (delete_always || delete_failure)
1277 record_temp_file (arg, delete_always, delete_failure);
1278}
1279\f
1280/* Record the names of temporary files we tell compilers to write,
1281 and delete them at the end of the run. */
1282
1283/* This is the common prefix we use to make temp file names.
1284 It is chosen once for each run of this program.
1285 It is substituted into a spec by %g.
1286 Thus, all temp file names contain this prefix.
1287 In practice, all temp file names start with this prefix.
1288
1289 This prefix comes from the envvar TMPDIR if it is defined;
1290 otherwise, from the P_tmpdir macro if that is defined;
1291 otherwise, in /usr/tmp or /tmp. */
1292
1293static char *temp_filename;
1294
1295/* Length of the prefix. */
1296
1297static int temp_filename_length;
1298
1299/* Define the list of temporary files to delete. */
1300
1301struct temp_file
1302{
1303 char *name;
1304 struct temp_file *next;
1305};
1306
1307/* Queue of files to delete on success or failure of compilation. */
1308static struct temp_file *always_delete_queue;
1309/* Queue of files to delete on failure of compilation. */
1310static struct temp_file *failure_delete_queue;
1311
1312/* Record FILENAME as a file to be deleted automatically.
1313 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
1314 otherwise delete it in any case.
1315 FAIL_DELETE nonzero means delete it if a compilation step fails;
1316 otherwise delete it in any case. */
1317
1318static void
1319record_temp_file (filename, always_delete, fail_delete)
1320 char *filename;
1321 int always_delete;
1322 int fail_delete;
1323{
1324 register char *name;
1325 name = xmalloc (strlen (filename) + 1);
1326 strcpy (name, filename);
1327
1328 if (always_delete)
1329 {
1330 register struct temp_file *temp;
1331 for (temp = always_delete_queue; temp; temp = temp->next)
1332 if (! strcmp (name, temp->name))
1333 goto already1;
1334 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
1335 temp->next = always_delete_queue;
1336 temp->name = name;
1337 always_delete_queue = temp;
1338 already1:;
1339 }
1340
1341 if (fail_delete)
1342 {
1343 register struct temp_file *temp;
1344 for (temp = failure_delete_queue; temp; temp = temp->next)
1345 if (! strcmp (name, temp->name))
1346 goto already2;
1347 temp = (struct temp_file *) xmalloc (sizeof (struct temp_file));
1348 temp->next = failure_delete_queue;
1349 temp->name = name;
1350 failure_delete_queue = temp;
1351 already2:;
1352 }
1353}
1354
1355/* Delete all the temporary files whose names we previously recorded. */
1356
1357static void
1358delete_temp_files ()
1359{
1360 register struct temp_file *temp;
1361
1362 for (temp = always_delete_queue; temp; temp = temp->next)
1363 {
1364#ifdef DEBUG
1365 int i;
1366 printf ("Delete %s? (y or n) ", temp->name);
1367 fflush (stdout);
1368 i = getchar ();
1369 if (i != '\n')
1370 while (getchar () != '\n') ;
1371 if (i == 'y' || i == 'Y')
1372#endif /* DEBUG */
1373 {
1374 struct stat st;
1375 if (stat (temp->name, &st) >= 0)
1376 {
1377 /* Delete only ordinary files. */
1378 if (S_ISREG (st.st_mode))
1379 if (unlink (temp->name) < 0)
1380 if (verbose_flag)
1381 perror_with_name (temp->name);
1382 }
1383 }
1384 }
1385
1386 always_delete_queue = 0;
1387}
1388
1389/* Delete all the files to be deleted on error. */
1390
1391static void
1392delete_failure_queue ()
1393{
1394 register struct temp_file *temp;
1395
1396 for (temp = failure_delete_queue; temp; temp = temp->next)
1397 {
1398#ifdef DEBUG
1399 int i;
1400 printf ("Delete %s? (y or n) ", temp->name);
1401 fflush (stdout);
1402 i = getchar ();
1403 if (i != '\n')
1404 while (getchar () != '\n') ;
1405 if (i == 'y' || i == 'Y')
1406#endif /* DEBUG */
1407 {
1408 if (unlink (temp->name) < 0)
1409 if (verbose_flag)
1410 perror_with_name (temp->name);
1411 }
1412 }
1413}
1414
1415static void
1416clear_failure_queue ()
1417{
1418 failure_delete_queue = 0;
1419}
1420
1421/* Compute a string to use as the base of all temporary file names.
1422 It is substituted for %g. */
1423
1e72f68f
RS
1424static char *
1425choose_temp_base_try (try, base)
1426char *try;
1427char *base;
1428{
1429 char *rv;
1430 if (base)
1431 rv = base;
1432 else if (try == (char *)0)
1433 rv = 0;
1434 else if (access (try, R_OK | W_OK) != 0)
1435 rv = 0;
1436 else
1437 rv = try;
1438 return rv;
1439}
1440
ed1f651b
RS
1441static void
1442choose_temp_base ()
1443{
1e72f68f 1444 char *base = 0;
ed1f651b
RS
1445 int len;
1446
1e72f68f
RS
1447 base = choose_temp_base_try (getenv ("TMPDIR"), base);
1448 base = choose_temp_base_try (getenv ("TMP"), base);
1449 base = choose_temp_base_try (getenv ("TEMP"), base);
1450
ed1f651b 1451#ifdef P_tmpdir
1e72f68f 1452 base = choose_temp_base_try (P_tmpdir, base);
ed1f651b 1453#endif
1e72f68f
RS
1454
1455 base = choose_temp_base_try ("/usr/tmp", base);
1456 base = choose_temp_base_try ("/tmp", base);
1457
1458 /* If all else fails, use the current directory! */
1459 if (base == (char *)0)
1460 base = "./";
ed1f651b
RS
1461
1462 len = strlen (base);
da6d85c0 1463 temp_filename = xmalloc (len + sizeof("/ccXXXXXX") + 1);
ed1f651b
RS
1464 strcpy (temp_filename, base);
1465 if (len > 0 && temp_filename[len-1] != '/')
1466 temp_filename[len++] = '/';
1467 strcpy (temp_filename + len, "ccXXXXXX");
1468
1469 mktemp (temp_filename);
1470 temp_filename_length = strlen (temp_filename);
fb266030
TW
1471 if (temp_filename_length == 0)
1472 abort ();
ed1f651b 1473}
b3865ca9
RS
1474\f
1475
1476/* Routine to add variables to the environment. We do this to pass
1477 the pathname of the gcc driver, and the directories search to the
1478 collect2 program, which is being run as ld. This way, we can be
1479 sure of executing the right compiler when collect2 wants to build
1480 constructors and destructors. Since the environment variables we
1481 use come from an obstack, we don't have to worry about allocating
1482 space for them. */
1483
1484#ifndef HAVE_PUTENV
1485
2a353d3a 1486void
b3865ca9
RS
1487putenv (str)
1488 char *str;
1489{
b3865ca9
RS
1490#ifndef VMS /* nor about VMS */
1491
1492 extern char **environ;
1493 char **old_environ = environ;
1494 char **envp;
1495 int num_envs = 0;
1496 int name_len = 1;
1497 int str_len = strlen (str);
1498 char *p = str;
1499 int ch;
1500
1501 while ((ch = *p++) != '\0' && ch != '=')
1502 name_len++;
1503
1504 if (!ch)
1505 abort ();
1506
1507 /* Search for replacing an existing environment variable, and
1508 count the number of total environment variables. */
1509 for (envp = old_environ; *envp; envp++)
1510 {
1511 num_envs++;
1512 if (!strncmp (str, *envp, name_len))
1513 {
1514 *envp = str;
1515 return;
1516 }
1517 }
1518
1519 /* Add a new environment variable */
1520 environ = (char **) xmalloc (sizeof (char *) * (num_envs+2));
1521 *environ = str;
1522 bcopy (old_environ, environ+1, sizeof (char *) * (num_envs+1));
1523
1524#endif /* VMS */
b3865ca9
RS
1525}
1526
1527#endif /* HAVE_PUTENV */
1528
1529\f
1530/* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables for collect. */
1531
1532static void
1533putenv_from_prefixes (paths, env_var)
1534 struct path_prefix *paths;
1535 char *env_var;
1536{
1537 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
3ae7de4e
RK
1538 int just_suffix_len
1539 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
b3865ca9
RS
1540 int first_time = TRUE;
1541 struct prefix_list *pprefix;
1542
1543 obstack_grow (&collect_obstack, env_var, strlen (env_var));
1544
1545 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
1546 {
1547 int len = strlen (pprefix->prefix);
1548
0ad5835e
ILT
1549 if (machine_suffix
1550 && is_directory (pprefix->prefix, machine_suffix, 0))
b3865ca9
RS
1551 {
1552 if (!first_time)
3ae7de4e 1553 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
b3865ca9
RS
1554
1555 first_time = FALSE;
1556 obstack_grow (&collect_obstack, pprefix->prefix, len);
1557 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
1558 }
1559
0ad5835e
ILT
1560 if (just_machine_suffix
1561 && pprefix->require_machine_suffix == 2
1562 && is_directory (pprefix->prefix, just_machine_suffix, 0))
ae04227b
CH
1563 {
1564 if (!first_time)
3ae7de4e 1565 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
ae04227b
CH
1566
1567 first_time = FALSE;
1568 obstack_grow (&collect_obstack, pprefix->prefix, len);
3ae7de4e
RK
1569 obstack_grow (&collect_obstack, just_machine_suffix,
1570 just_suffix_len);
ae04227b
CH
1571 }
1572
b3865ca9
RS
1573 if (!pprefix->require_machine_suffix)
1574 {
1575 if (!first_time)
3ae7de4e 1576 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
b3865ca9
RS
1577
1578 first_time = FALSE;
1579 obstack_grow (&collect_obstack, pprefix->prefix, len);
1580 }
1581 }
3ae7de4e 1582 obstack_1grow (&collect_obstack, '\0');
b3865ca9
RS
1583 putenv (obstack_finish (&collect_obstack));
1584}
1585
ed1f651b
RS
1586\f
1587/* Search for NAME using the prefix list PREFIXES. MODE is passed to
1588 access to check permissions.
1589 Return 0 if not found, otherwise return its name, allocated with malloc. */
1590
1591static char *
1592find_a_file (pprefix, name, mode)
1593 struct path_prefix *pprefix;
1594 char *name;
1595 int mode;
1596{
1597 char *temp;
004fd4d5 1598 char *file_suffix = ((mode & X_OK) != 0 ? EXECUTABLE_SUFFIX : "");
ed1f651b
RS
1599 struct prefix_list *pl;
1600 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
1601
1602 if (machine_suffix)
1603 len += strlen (machine_suffix);
1604
1605 temp = xmalloc (len);
1606
1607 /* Determine the filename to execute (special case for absolute paths). */
1608
1609 if (*name == '/')
1610 {
1611 if (access (name, mode))
1612 {
1613 strcpy (temp, name);
1614 return temp;
1615 }
1616 }
1617 else
1618 for (pl = pprefix->plist; pl; pl = pl->next)
1619 {
1620 if (machine_suffix)
1621 {
1622 strcpy (temp, pl->prefix);
1623 strcat (temp, machine_suffix);
1624 strcat (temp, name);
1625 if (access (temp, mode) == 0)
1626 {
1627 if (pl->used_flag_ptr != 0)
1628 *pl->used_flag_ptr = 1;
1629 return temp;
1630 }
1631 /* Some systems have a suffix for executable files.
1632 So try appending that. */
1633 if (file_suffix[0] != 0)
1634 {
1635 strcat (temp, file_suffix);
1636 if (access (temp, mode) == 0)
1637 {
1638 if (pl->used_flag_ptr != 0)
1639 *pl->used_flag_ptr = 1;
1640 return temp;
1641 }
1642 }
1643 }
ae04227b
CH
1644 /* Certain prefixes are tried with just the machine type,
1645 not the version. This is used for finding as, ld, etc. */
1646 if (just_machine_suffix && pl->require_machine_suffix == 2)
1647 {
1648 strcpy (temp, pl->prefix);
1649 strcat (temp, just_machine_suffix);
1650 strcat (temp, name);
1651 if (access (temp, mode) == 0)
1652 {
1653 if (pl->used_flag_ptr != 0)
1654 *pl->used_flag_ptr = 1;
1655 return temp;
1656 }
1657 /* Some systems have a suffix for executable files.
1658 So try appending that. */
1659 if (file_suffix[0] != 0)
1660 {
1661 strcat (temp, file_suffix);
1662 if (access (temp, mode) == 0)
1663 {
1664 if (pl->used_flag_ptr != 0)
1665 *pl->used_flag_ptr = 1;
1666 return temp;
1667 }
1668 }
1669 }
ed1f651b
RS
1670 /* Certain prefixes can't be used without the machine suffix
1671 when the machine or version is explicitly specified. */
004fd4d5 1672 if (!pl->require_machine_suffix)
ed1f651b
RS
1673 {
1674 strcpy (temp, pl->prefix);
1675 strcat (temp, name);
1676 if (access (temp, mode) == 0)
1677 {
1678 if (pl->used_flag_ptr != 0)
1679 *pl->used_flag_ptr = 1;
1680 return temp;
1681 }
1682 /* Some systems have a suffix for executable files.
1683 So try appending that. */
1684 if (file_suffix[0] != 0)
1685 {
1686 strcat (temp, file_suffix);
1687 if (access (temp, mode) == 0)
1688 {
1689 if (pl->used_flag_ptr != 0)
1690 *pl->used_flag_ptr = 1;
1691 return temp;
1692 }
1693 }
1694 }
1695 }
1696
1697 free (temp);
1698 return 0;
1699}
1700
1701/* Add an entry for PREFIX in PLIST. If FIRST is set, it goes
1702 at the start of the list, otherwise it goes at the end.
1703
1704 If WARN is nonzero, we will warn if no file is found
1705 through this prefix. WARN should point to an int
ae04227b
CH
1706 which will be set to 1 if this entry is used.
1707
1708 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
1709 the complete value of machine_suffix.
1710 2 means try both machine_suffix and just_machine_suffix. */
ed1f651b
RS
1711
1712static void
1713add_prefix (pprefix, prefix, first, require_machine_suffix, warn)
1714 struct path_prefix *pprefix;
1715 char *prefix;
1716 int first;
1717 int require_machine_suffix;
1718 int *warn;
1719{
1720 struct prefix_list *pl, **prev;
1721 int len;
1722
1723 if (!first && pprefix->plist)
1724 {
1725 for (pl = pprefix->plist; pl->next; pl = pl->next)
1726 ;
1727 prev = &pl->next;
1728 }
1729 else
1730 prev = &pprefix->plist;
1731
1732 /* Keep track of the longest prefix */
1733
1734 len = strlen (prefix);
1735 if (len > pprefix->max_len)
1736 pprefix->max_len = len;
1737
1738 pl = (struct prefix_list *) xmalloc (sizeof (struct prefix_list));
1739 pl->prefix = save_string (prefix, len);
1740 pl->require_machine_suffix = require_machine_suffix;
1741 pl->used_flag_ptr = warn;
1742 if (warn)
1743 *warn = 0;
1744
1745 if (*prev)
1746 pl->next = *prev;
1747 else
1748 pl->next = (struct prefix_list *) 0;
1749 *prev = pl;
1750}
1751
1752/* Print warnings for any prefixes in the list PPREFIX that were not used. */
1753
1754static void
1755unused_prefix_warnings (pprefix)
1756 struct path_prefix *pprefix;
1757{
1758 struct prefix_list *pl = pprefix->plist;
1759
1760 while (pl)
1761 {
1762 if (pl->used_flag_ptr != 0 && !*pl->used_flag_ptr)
1763 {
1764 error ("file path prefix `%s' never used",
1765 pl->prefix);
1766 /* Prevent duplicate warnings. */
1767 *pl->used_flag_ptr = 1;
1768 }
1769 pl = pl->next;
1770 }
1771}
1772
1773/* Get rid of all prefixes built up so far in *PLISTP. */
1774
1775static void
1776free_path_prefix (pprefix)
1777 struct path_prefix *pprefix;
1778{
1779 struct prefix_list *pl = pprefix->plist;
1780 struct prefix_list *temp;
1781
1782 while (pl)
1783 {
1784 temp = pl;
1785 pl = pl->next;
1786 free (temp->prefix);
1787 free ((char *) temp);
1788 }
1789 pprefix->plist = (struct prefix_list *) 0;
1790}
1791\f
1792/* stdin file number. */
1793#define STDIN_FILE_NO 0
1794
1795/* stdout file number. */
1796#define STDOUT_FILE_NO 1
1797
1798/* value of `pipe': port index for reading. */
1799#define READ_PORT 0
1800
1801/* value of `pipe': port index for writing. */
1802#define WRITE_PORT 1
1803
1804/* Pipe waiting from last process, to be used as input for the next one.
1805 Value is STDIN_FILE_NO if no pipe is waiting
1806 (i.e. the next command is the first of a group). */
1807
1808static int last_pipe_input;
1809
1810/* Fork one piped subcommand. FUNC is the system call to use
1811 (either execv or execvp). ARGV is the arg vector to use.
1812 NOT_LAST is nonzero if this is not the last subcommand
1813 (i.e. its output should be piped to the next one.) */
1814
14be024e 1815#ifndef OS2
ed1f651b
RS
1816#ifdef __MSDOS__
1817
1818/* Declare these to avoid compilation error. They won't be called. */
1819int execv(const char *a, const char **b){}
1820int execvp(const char *a, const char **b){}
1821
1822static int
14be024e
RS
1823pexecute (search_flag, program, argv, not_last)
1824 int search_flag;
ed1f651b 1825 char *program;
ed1f651b
RS
1826 char *argv[];
1827 int not_last;
1828{
1e72f68f 1829 char *scmd, *rf;
ed1f651b 1830 FILE *argfile;
1e72f68f 1831 int i, el = search_flag ? 0 : 4;
ed1f651b 1832
1e72f68f
RS
1833 scmd = (char *)malloc (strlen (program) + strlen (temp_filename) + 6 + el);
1834 rf = scmd + strlen(program) + 2 + el;
1835 sprintf (scmd, "%s%s @%s.gp", program,
1836 (search_flag ? "" : ".exe"), temp_filename);
1837 argfile = fopen (rf, "w");
ed1f651b 1838 if (argfile == 0)
1e72f68f 1839 pfatal_with_name (rf);
ed1f651b
RS
1840
1841 for (i=1; argv[i]; i++)
1e72f68f
RS
1842 {
1843 char *cp;
1844 for (cp = argv[i]; *cp; cp++)
1845 {
1846 if (*cp == '"' || *cp == '\'' || *cp == '\\' || isspace (*cp))
1847 fputc ('\\', argfile);
1848 fputc (*cp, argfile);
1849 }
1850 fputc ('\n', argfile);
1851 }
59014d0a 1852 fclose (argfile);
ed1f651b 1853
59014d0a 1854 i = system (scmd);
ed1f651b 1855
1e72f68f
RS
1856 remove (rf);
1857
1858 if (i == -1)
1859 {
1860 perror_exec (program);
1861 return MIN_FATAL_STATUS << 8;
1862 }
1863
ed1f651b
RS
1864 return i << 8;
1865}
1866
1867#else /* not __MSDOS__ */
1868
1869static int
14be024e
RS
1870pexecute (search_flag, program, argv, not_last)
1871 int search_flag;
ed1f651b 1872 char *program;
ed1f651b
RS
1873 char *argv[];
1874 int not_last;
1875{
14be024e 1876 int (*func)() = (search_flag ? execv : execvp);
ed1f651b
RS
1877 int pid;
1878 int pdes[2];
1879 int input_desc = last_pipe_input;
1880 int output_desc = STDOUT_FILE_NO;
1881 int retries, sleep_interval;
1882
1883 /* If this isn't the last process, make a pipe for its output,
1884 and record it as waiting to be the input to the next process. */
1885
1886 if (not_last)
1887 {
1888 if (pipe (pdes) < 0)
1889 pfatal_with_name ("pipe");
1890 output_desc = pdes[WRITE_PORT];
1891 last_pipe_input = pdes[READ_PORT];
1892 }
1893 else
1894 last_pipe_input = STDIN_FILE_NO;
1895
1896 /* Fork a subprocess; wait and retry if it fails. */
1897 sleep_interval = 1;
1898 for (retries = 0; retries < 4; retries++)
1899 {
1900 pid = vfork ();
1901 if (pid >= 0)
1902 break;
1903 sleep (sleep_interval);
1904 sleep_interval *= 2;
1905 }
1906
1907 switch (pid)
1908 {
1909 case -1:
1910#ifdef vfork
1911 pfatal_with_name ("fork");
1912#else
1913 pfatal_with_name ("vfork");
1914#endif
1915 /* NOTREACHED */
1916 return 0;
1917
1918 case 0: /* child */
1919 /* Move the input and output pipes into place, if nec. */
1920 if (input_desc != STDIN_FILE_NO)
1921 {
1922 close (STDIN_FILE_NO);
1923 dup (input_desc);
1924 close (input_desc);
1925 }
1926 if (output_desc != STDOUT_FILE_NO)
1927 {
1928 close (STDOUT_FILE_NO);
1929 dup (output_desc);
1930 close (output_desc);
1931 }
1932
1933 /* Close the parent's descs that aren't wanted here. */
1934 if (last_pipe_input != STDIN_FILE_NO)
1935 close (last_pipe_input);
1936
1937 /* Exec the program. */
1938 (*func) (program, argv);
1939 perror_exec (program);
1940 exit (-1);
1941 /* NOTREACHED */
1942 return 0;
1943
1944 default:
1945 /* In the parent, after forking.
1946 Close the descriptors that we made for this child. */
1947 if (input_desc != STDIN_FILE_NO)
1948 close (input_desc);
1949 if (output_desc != STDOUT_FILE_NO)
1950 close (output_desc);
1951
1952 /* Return child's process number. */
1953 return pid;
1954 }
1955}
1956
1957#endif /* not __MSDOS__ */
14be024e
RS
1958#else /* not OS2 */
1959
1960static int
1961pexecute (search_flag, program, argv, not_last)
1962 int search_flag;
1963 char *program;
1964 char *argv[];
1965 int not_last;
1966{
1967 return (search_flag ? spawnv : spawnvp) (1, program, argv);
1968}
1969#endif /* not OS2 */
ed1f651b
RS
1970\f
1971/* Execute the command specified by the arguments on the current line of spec.
1972 When using pipes, this includes several piped-together commands
1973 with `|' between them.
1974
1975 Return 0 if successful, -1 if failed. */
1976
1977static int
1978execute ()
1979{
1980 int i;
1981 int n_commands; /* # of command. */
1982 char *string;
1983 struct command
1984 {
1985 char *prog; /* program name. */
1986 char **argv; /* vector of args. */
1987 int pid; /* pid of process for this command. */
1988 };
1989
1990 struct command *commands; /* each command buffer with above info. */
1991
1992 /* Count # of piped commands. */
1993 for (n_commands = 1, i = 0; i < argbuf_index; i++)
1994 if (strcmp (argbuf[i], "|") == 0)
1995 n_commands++;
1996
1997 /* Get storage for each command. */
1998 commands
1999 = (struct command *) alloca (n_commands * sizeof (struct command));
2000
2001 /* Split argbuf into its separate piped processes,
2002 and record info about each one.
2003 Also search for the programs that are to be run. */
2004
2005 commands[0].prog = argbuf[0]; /* first command. */
2006 commands[0].argv = &argbuf[0];
2007 string = find_a_file (&exec_prefix, commands[0].prog, X_OK);
2008 if (string)
2009 commands[0].argv[0] = string;
2010
2011 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2012 if (strcmp (argbuf[i], "|") == 0)
2013 { /* each command. */
2014#ifdef __MSDOS__
2015 fatal ("-pipe not supported under MS-DOS");
2016#endif
2017 argbuf[i] = 0; /* termination of command args. */
2018 commands[n_commands].prog = argbuf[i + 1];
2019 commands[n_commands].argv = &argbuf[i + 1];
2020 string = find_a_file (&exec_prefix, commands[n_commands].prog, X_OK);
2021 if (string)
2022 commands[n_commands].argv[0] = string;
2023 n_commands++;
2024 }
2025
2026 argbuf[argbuf_index] = 0;
2027
2028 /* If -v, print what we are about to do, and maybe query. */
2029
b3865ca9 2030 if (verbose_flag)
ed1f651b
RS
2031 {
2032 /* Print each piped command as a separate line. */
2033 for (i = 0; i < n_commands ; i++)
2034 {
2035 char **j;
2036
2037 for (j = commands[i].argv; *j; j++)
2038 fprintf (stderr, " %s", *j);
2039
2040 /* Print a pipe symbol after all but the last command. */
2041 if (i + 1 != n_commands)
2042 fprintf (stderr, " |");
2043 fprintf (stderr, "\n");
2044 }
2045 fflush (stderr);
2046#ifdef DEBUG
2047 fprintf (stderr, "\nGo ahead? (y or n) ");
2048 fflush (stderr);
2049 i = getchar ();
2050 if (i != '\n')
2051 while (getchar () != '\n') ;
2052 if (i != 'y' && i != 'Y')
2053 return 0;
2054#endif /* DEBUG */
2055 }
2056
2057 /* Run each piped subprocess. */
2058
2059 last_pipe_input = STDIN_FILE_NO;
2060 for (i = 0; i < n_commands; i++)
2061 {
2062 char *string = commands[i].argv[0];
2063
14be024e 2064 commands[i].pid = pexecute (string != commands[i].prog,
ed1f651b
RS
2065 string, commands[i].argv,
2066 i + 1 < n_commands);
2067
2068 if (string != commands[i].prog)
2069 free (string);
2070 }
2071
2072 execution_count++;
2073
2074 /* Wait for all the subprocesses to finish.
2075 We don't care what order they finish in;
2076 we know that N_COMMANDS waits will get them all. */
2077
2078 {
2079 int ret_code = 0;
2080
2081 for (i = 0; i < n_commands; i++)
2082 {
2083 int status;
2084 int pid;
870bc052 2085 char *prog = "unknown";
ed1f651b
RS
2086
2087#ifdef __MSDOS__
2088 status = pid = commands[i].pid;
2089#else
2090 pid = wait (&status);
2091#endif
2092 if (pid < 0)
2093 abort ();
2094
2095 if (status != 0)
2096 {
2097 int j;
2098 for (j = 0; j < n_commands; j++)
2099 if (commands[j].pid == pid)
2100 prog = commands[j].prog;
2101
2102 if ((status & 0x7F) != 0)
3b9b4d3f
RS
2103 {
2104 fatal ("Internal compiler error: program %s got fatal signal %d",
2105 prog, (status & 0x7F));
2106 signal_count++;
2107 }
ed1f651b
RS
2108 if (((status & 0xFF00) >> 8) >= MIN_FATAL_STATUS)
2109 ret_code = -1;
2110 }
2111 }
2112 return ret_code;
2113 }
2114}
2115\f
2116/* Find all the switches given to us
2117 and make a vector describing them.
2118 The elements of the vector are strings, one per switch given.
2119 If a switch uses following arguments, then the `part1' field
2120 is the switch itself and the `args' field
2121 is a null-terminated vector containing the following arguments.
f5b0eb4e
RK
2122 The `live_cond' field is 1 if the switch is true in a conditional spec,
2123 -1 if false (overridden by a later switch), and is initialized to zero.
ed1f651b
RS
2124 The `valid' field is nonzero if any spec has looked at this switch;
2125 if it remains zero at the end of the run, it must be meaningless. */
2126
2127struct switchstr
2128{
2129 char *part1;
2130 char **args;
f5b0eb4e 2131 int live_cond;
ed1f651b
RS
2132 int valid;
2133};
2134
2135static struct switchstr *switches;
2136
2137static int n_switches;
2138
2139struct infile
2140{
2141 char *name;
2142 char *language;
2143};
2144
2145/* Also a vector of input files specified. */
2146
2147static struct infile *infiles;
2148
2149static int n_infiles;
2150
2151/* And a vector of corresponding output files is made up later. */
2152
2153static char **outfiles;
2154
2155/* Create the vector `switches' and its contents.
2156 Store its length in `n_switches'. */
2157
2158static void
2159process_command (argc, argv)
2160 int argc;
2161 char **argv;
2162{
2163 register int i;
2164 char *temp;
2165 char *spec_lang = 0;
2166 int last_language_n_infiles;
2167
8eebb258
RS
2168 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
2169
ed1f651b
RS
2170 n_switches = 0;
2171 n_infiles = 0;
2484b6d2 2172
53117a2f
RK
2173 /* Figure compiler version from version string. */
2174
2175 compiler_version = save_string (version_string, strlen (version_string));
2176 for (temp = compiler_version; *temp; ++temp)
2177 {
2178 if (*temp == ' ')
2179 {
2180 *temp = '\0';
2181 break;
2182 }
2183 }
ed1f651b
RS
2184
2185 /* Set up the default search paths. */
2186
8eebb258 2187 if (gcc_exec_prefix)
ed1f651b 2188 {
906c4e36
RK
2189 add_prefix (&exec_prefix, gcc_exec_prefix, 0, 0, NULL_PTR);
2190 add_prefix (&startfile_prefix, gcc_exec_prefix, 0, 0, NULL_PTR);
ed1f651b
RS
2191 }
2192
2193 /* COMPILER_PATH and LIBRARY_PATH have values
2194 that are lists of directory names with colons. */
2195
2196 temp = getenv ("COMPILER_PATH");
2197 if (temp)
2198 {
2199 char *startp, *endp;
2200 char *nstore = (char *) alloca (strlen (temp) + 3);
2201
2202 startp = endp = temp;
2203 while (1)
2204 {
f6ec7e54 2205 if (*endp == PATH_SEPARATOR || *endp == 0)
ed1f651b
RS
2206 {
2207 strncpy (nstore, startp, endp-startp);
2208 if (endp == startp)
2209 {
2210 strcpy (nstore, "./");
2211 }
2212 else if (endp[-1] != '/')
2213 {
2214 nstore[endp-startp] = '/';
2215 nstore[endp-startp+1] = 0;
2216 }
2217 else
2218 nstore[endp-startp] = 0;
906c4e36 2219 add_prefix (&exec_prefix, nstore, 0, 0, NULL_PTR);
ed1f651b
RS
2220 if (*endp == 0)
2221 break;
2222 endp = startp = endp + 1;
2223 }
2224 else
2225 endp++;
2226 }
2227 }
2228
2229 temp = getenv ("LIBRARY_PATH");
2230 if (temp)
2231 {
2232 char *startp, *endp;
2233 char *nstore = (char *) alloca (strlen (temp) + 3);
2234
2235 startp = endp = temp;
2236 while (1)
2237 {
f6ec7e54 2238 if (*endp == PATH_SEPARATOR || *endp == 0)
ed1f651b
RS
2239 {
2240 strncpy (nstore, startp, endp-startp);
2241 if (endp == startp)
2242 {
2243 strcpy (nstore, "./");
2244 }
2245 else if (endp[-1] != '/')
2246 {
2247 nstore[endp-startp] = '/';
2248 nstore[endp-startp+1] = 0;
2249 }
2250 else
2251 nstore[endp-startp] = 0;
906c4e36 2252 add_prefix (&startfile_prefix, nstore, 0, 0, NULL_PTR);
ed1f651b
RS
2253 if (*endp == 0)
2254 break;
2255 endp = startp = endp + 1;
2256 }
2257 else
2258 endp++;
2259 }
2260 }
2261
2262 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
2263 temp = getenv ("LPATH");
2264 if (temp)
2265 {
2266 char *startp, *endp;
2267 char *nstore = (char *) alloca (strlen (temp) + 3);
2268
2269 startp = endp = temp;
2270 while (1)
2271 {
f6ec7e54 2272 if (*endp == PATH_SEPARATOR || *endp == 0)
ed1f651b
RS
2273 {
2274 strncpy (nstore, startp, endp-startp);
2275 if (endp == startp)
2276 {
2277 strcpy (nstore, "./");
2278 }
2279 else if (endp[-1] != '/')
2280 {
2281 nstore[endp-startp] = '/';
2282 nstore[endp-startp+1] = 0;
2283 }
2284 else
2285 nstore[endp-startp] = 0;
906c4e36 2286 add_prefix (&startfile_prefix, nstore, 0, 0, NULL_PTR);
ed1f651b
RS
2287 if (*endp == 0)
2288 break;
2289 endp = startp = endp + 1;
2290 }
2291 else
2292 endp++;
2293 }
2294 }
2295
f2faf549
RS
2296 /* Convert new-style -- options to old-style. */
2297 translate_options (&argc, &argv);
2298
ed1f651b
RS
2299 /* Scan argv twice. Here, the first time, just count how many switches
2300 there will be in their vector, and how many input files in theirs.
2301 Here we also parse the switches that cc itself uses (e.g. -v). */
2302
2303 for (i = 1; i < argc; i++)
2304 {
2305 if (! strcmp (argv[i], "-dumpspecs"))
2306 {
2307 printf ("*asm:\n%s\n\n", asm_spec);
2308 printf ("*asm_final:\n%s\n\n", asm_final_spec);
2309 printf ("*cpp:\n%s\n\n", cpp_spec);
2310 printf ("*cc1:\n%s\n\n", cc1_spec);
2311 printf ("*cc1plus:\n%s\n\n", cc1plus_spec);
2312 printf ("*endfile:\n%s\n\n", endfile_spec);
2313 printf ("*link:\n%s\n\n", link_spec);
2314 printf ("*lib:\n%s\n\n", lib_spec);
2315 printf ("*startfile:\n%s\n\n", startfile_spec);
2316 printf ("*switches_need_spaces:\n%s\n\n", switches_need_spaces);
2317 printf ("*signed_char:\n%s\n\n", signed_char_spec);
2318 printf ("*predefines:\n%s\n\n", cpp_predefines);
004fd4d5 2319 printf ("*cross_compile:\n%d\n\n", cross_compile);
ed1f651b
RS
2320
2321 exit (0);
2322 }
2323 else if (! strcmp (argv[i], "-dumpversion"))
2324 {
2325 printf ("%s\n", version_string);
2326 exit (0);
2327 }
2dcb563f
RS
2328 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
2329 {
2330 print_libgcc_file_name = 1;
2331 }
ed1f651b
RS
2332 else if (! strcmp (argv[i], "-Xlinker"))
2333 {
2334 /* Pass the argument of this option to the linker when we link. */
2335
2336 if (i + 1 == argc)
2337 fatal ("argument to `-Xlinker' is missing");
2338
2339 n_linker_options++;
2340 if (!linker_options)
2341 linker_options
2342 = (char **) xmalloc (n_linker_options * sizeof (char **));
2343 else
2344 linker_options
2345 = (char **) xrealloc (linker_options,
2346 n_linker_options * sizeof (char **));
2347
2348 linker_options[n_linker_options - 1] = argv[++i];
2349 }
c9ebacb8
RS
2350 else if (! strncmp (argv[i], "-Wl,", 4))
2351 {
2352 int prev, j;
2353 /* Pass the rest of this option to the linker when we link. */
2354
2355 n_linker_options++;
2356 if (!linker_options)
2357 linker_options
2358 = (char **) xmalloc (n_linker_options * sizeof (char **));
2359 else
2360 linker_options
2361 = (char **) xrealloc (linker_options,
2362 n_linker_options * sizeof (char **));
2363
2364 /* Split the argument at commas. */
2365 prev = 4;
2366 for (j = 4; argv[i][j]; j++)
2367 if (argv[i][j] == ',')
2368 {
2369 linker_options[n_linker_options - 1]
2370 = save_string (argv[i] + prev, j - prev);
2371 n_linker_options++;
2372 linker_options
2373 = (char **) xrealloc (linker_options,
2374 n_linker_options * sizeof (char **));
2375 prev = j + 1;
2376 }
2377 /* Record the part after the last comma. */
2378 linker_options[n_linker_options - 1] = argv[i] + prev;
2379 }
2380 else if (! strncmp (argv[i], "-Wa,", 4))
2381 {
2382 int prev, j;
2383 /* Pass the rest of this option to the assembler. */
2384
2385 n_assembler_options++;
2386 if (!assembler_options)
2387 assembler_options
2388 = (char **) xmalloc (n_assembler_options * sizeof (char **));
2389 else
2390 assembler_options
2391 = (char **) xrealloc (assembler_options,
2392 n_assembler_options * sizeof (char **));
2393
2394 /* Split the argument at commas. */
2395 prev = 4;
2396 for (j = 4; argv[i][j]; j++)
2397 if (argv[i][j] == ',')
2398 {
2399 assembler_options[n_assembler_options - 1]
2400 = save_string (argv[i] + prev, j - prev);
2401 n_assembler_options++;
2402 assembler_options
2403 = (char **) xrealloc (assembler_options,
2404 n_assembler_options * sizeof (char **));
2405 prev = j + 1;
2406 }
2407 /* Record the part after the last comma. */
2408 assembler_options[n_assembler_options - 1] = argv[i] + prev;
2409 }
301a5c0b 2410 else if (argv[i][0] == '+' && argv[i][1] == 'e')
f2faf549 2411 /* The +e options to the C++ front-end. */
301a5c0b 2412 n_switches++;
ed1f651b
RS
2413 else if (argv[i][0] == '-' && argv[i][1] != 0 && argv[i][1] != 'l')
2414 {
2415 register char *p = &argv[i][1];
2416 register int c = *p;
2417
2418 switch (c)
2419 {
2420 case 'b':
2421 if (p[1] == 0 && i + 1 == argc)
2422 fatal ("argument to `-b' is missing");
2423 if (p[1] == 0)
2424 spec_machine = argv[++i];
2425 else
2426 spec_machine = p + 1;
2427 break;
2428
2429 case 'B':
2430 {
2431 int *temp = (int *) xmalloc (sizeof (int));
2432 char *value;
2433 if (p[1] == 0 && i + 1 == argc)
2434 fatal ("argument to `-B' is missing");
2435 if (p[1] == 0)
2436 value = argv[++i];
2437 else
2438 value = p + 1;
2439 add_prefix (&exec_prefix, value, 1, 0, temp);
2440 add_prefix (&startfile_prefix, value, 1, 0, temp);
2d879387
JW
2441 add_prefix (&include_prefix, concat (value, "include", ""),
2442 1, 0, 0);
6b0639bc 2443
a78a8d58 2444 /* As a kludge, if the arg is "[foo/]stageN/", just add
6b0639bc 2445 "include" to the include prefix. */
ea694f2d
DE
2446 {
2447 int len = strlen (value);
a78a8d58
DE
2448 if ((len == 7 || (len > 7 && value[len - 8] == '/'))
2449 && strncmp (value + len - 7, "stage", 5) == 0
2450 && isdigit (value[len - 2])
2451 && value[len - 1] == '/')
ea694f2d
DE
2452 add_prefix (&include_prefix, "include", 1, 0, 0);
2453 }
ed1f651b
RS
2454 }
2455 break;
2456
2457 case 'v': /* Print our subcommands and print versions. */
ed1f651b 2458 n_switches++;
8436fe35
RS
2459 /* If they do anything other than exactly `-v', don't set
2460 verbose_flag; rather, continue on to give the error. */
2461 if (p[1] != 0)
2462 break;
2463 verbose_flag++;
ed1f651b
RS
2464 break;
2465
2466 case 'V':
2467 if (p[1] == 0 && i + 1 == argc)
2468 fatal ("argument to `-V' is missing");
2469 if (p[1] == 0)
2470 spec_version = argv[++i];
2471 else
2472 spec_version = p + 1;
53117a2f 2473 compiler_version = spec_version;
ed1f651b
RS
2474 break;
2475
2476 case 's':
2477 if (!strcmp (p, "save-temps"))
2478 {
2479 save_temps_flag = 1;
8eebb258 2480 n_switches++;
ed1f651b
RS
2481 break;
2482 }
2483 default:
2484 n_switches++;
2485
2486 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
2487 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
2488 else if (WORD_SWITCH_TAKES_ARG (p))
2489 i += WORD_SWITCH_TAKES_ARG (p);
2490 }
2491 }
2492 else
2493 n_infiles++;
2494 }
2495
2496 /* Set up the search paths before we go looking for config files. */
2497
2498 /* These come before the md prefixes so that we will find gcc's subcommands
2499 (such as cpp) rather than those of the host system. */
ae04227b
CH
2500 /* Use 2 as fourth arg meaning try just the machine as a suffix,
2501 as well as trying the machine and the version. */
2502 add_prefix (&exec_prefix, standard_exec_prefix, 0, 2, NULL_PTR);
2503 add_prefix (&exec_prefix, standard_exec_prefix_1, 0, 2, NULL_PTR);
ed1f651b 2504
906c4e36
RK
2505 add_prefix (&startfile_prefix, standard_exec_prefix, 0, 1, NULL_PTR);
2506 add_prefix (&startfile_prefix, standard_exec_prefix_1, 0, 1, NULL_PTR);
ed1f651b 2507
c648ab8a
RS
2508 tooldir_prefix = concat (tooldir_base_prefix, spec_machine, "/");
2509
2510 /* If tooldir is relative, base it on exec_prefix. A relative
2511 tooldir lets us move the installed tree as a unit.
2512
2513 If GCC_EXEC_PREFIX is defined, then we want to add two relative
2514 directories, so that we can search both the user specified directory
2515 and the standard place. */
2516
2517 if (*tooldir_prefix != '/')
2518 {
2519 if (gcc_exec_prefix)
2520 {
2521 char *gcc_exec_tooldir_prefix
2522 = concat (concat (gcc_exec_prefix, spec_machine, "/"),
2523 concat (spec_version, "/", tooldir_prefix),
2524 "");
2525
2526 add_prefix (&exec_prefix, concat (gcc_exec_tooldir_prefix, "bin", "/"),
2527 0, 0, NULL_PTR);
2528 add_prefix (&startfile_prefix, concat (gcc_exec_tooldir_prefix, "lib", "/"),
2529 0, 0, NULL_PTR);
2530 }
2531
2532 tooldir_prefix = concat (concat (standard_exec_prefix, spec_machine, "/"),
2533 concat (spec_version, "/", tooldir_prefix),
2534 "");
2535 }
2536
f18fd956
RS
2537 add_prefix (&exec_prefix, concat (tooldir_prefix, "bin", "/"),
2538 0, 0, NULL_PTR);
2539 add_prefix (&startfile_prefix, concat (tooldir_prefix, "lib", "/"),
2540 0, 0, NULL_PTR);
2541
004fd4d5
RS
2542 /* More prefixes are enabled in main, after we read the specs file
2543 and determine whether this is cross-compilation or not. */
ed1f651b 2544
ed1f651b
RS
2545
2546 /* Then create the space for the vectors and scan again. */
2547
2548 switches = ((struct switchstr *)
2549 xmalloc ((n_switches + 1) * sizeof (struct switchstr)));
2550 infiles = (struct infile *) xmalloc ((n_infiles + 1) * sizeof (struct infile));
2551 n_switches = 0;
2552 n_infiles = 0;
2553 last_language_n_infiles = -1;
2554
2555 /* This, time, copy the text of each switch and store a pointer
2556 to the copy in the vector of switches.
2557 Store all the infiles in their vector. */
2558
2559 for (i = 1; i < argc; i++)
2560 {
2ef32c88 2561 /* Just skip the switches that were handled by the preceding loop. */
ed1f651b
RS
2562 if (!strcmp (argv[i], "-Xlinker"))
2563 i++;
c9ebacb8 2564 else if (! strncmp (argv[i], "-Wl,", 4))
2ef32c88 2565 ;
c9ebacb8 2566 else if (! strncmp (argv[i], "-Wa,", 4))
2ef32c88 2567 ;
2dcb563f 2568 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
2ef32c88 2569 ;
cc6fc442
RS
2570 else if (argv[i][0] == '+' && argv[i][1] == 'e')
2571 {
2572 /* Compensate for the +e options to the C++ front-end;
a1c37766 2573 they're there simply for cfront call-compatibility. We do
cc6fc442
RS
2574 some magic in default_compilers to pass them down properly.
2575 Note we deliberately start at the `+' here, to avoid passing
2576 -e0 or -e1 down into the linker. */
2577 switches[n_switches].part1 = &argv[i][0];
2578 switches[n_switches].args = 0;
f5b0eb4e 2579 switches[n_switches].live_cond = 0;
cc6fc442
RS
2580 switches[n_switches].valid = 0;
2581 n_switches++;
2582 }
ed1f651b
RS
2583 else if (argv[i][0] == '-' && argv[i][1] != 0 && argv[i][1] != 'l')
2584 {
2585 register char *p = &argv[i][1];
2586 register int c = *p;
2587
2588 if (c == 'B' || c == 'b' || c == 'V')
2589 {
2590 /* Skip a separate arg, if any. */
2591 if (p[1] == 0)
2592 i++;
2593 continue;
2594 }
2595 if (c == 'x')
2596 {
2597 if (p[1] == 0 && i + 1 == argc)
2598 fatal ("argument to `-x' is missing");
2599 if (p[1] == 0)
2600 spec_lang = argv[++i];
2601 else
2602 spec_lang = p + 1;
2603 if (! strcmp (spec_lang, "none"))
2604 /* Suppress the warning if -xnone comes after the last input file,
2605 because alternate command interfaces like g++ might find it
2606 useful to place -xnone after each input file. */
2607 spec_lang = 0;
2608 else
2609 last_language_n_infiles = n_infiles;
2610 continue;
2611 }
2612 switches[n_switches].part1 = p;
2613 /* Deal with option arguments in separate argv elements. */
2614 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
14553b75
RS
2615 || WORD_SWITCH_TAKES_ARG (p))
2616 {
2617 int j = 0;
2618 int n_args = WORD_SWITCH_TAKES_ARG (p);
ed1f651b 2619
14553b75
RS
2620 if (n_args == 0)
2621 {
2622 /* Count only the option arguments in separate argv elements. */
2623 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
2624 }
2625 if (i + n_args >= argc)
2626 fatal ("argument to `-%s' is missing", p);
2627 switches[n_switches].args
2628 = (char **) xmalloc ((n_args + 1) * sizeof (char *));
2629 while (j < n_args)
2630 switches[n_switches].args[j++] = argv[++i];
2631 /* Null-terminate the vector. */
2632 switches[n_switches].args[j] = 0;
ed1f651b 2633 }
14553b75
RS
2634 else if (*switches_need_spaces != 0 && (c == 'o' || c == 'L'))
2635 {
2636 /* On some systems, ld cannot handle -o or -L without space.
2637 So split the -o or -L from its argument. */
2638 switches[n_switches].part1 = (c == 'o' ? "o" : "L");
2639 switches[n_switches].args = (char **) xmalloc (2 * sizeof (char *));
2640 switches[n_switches].args[0] = xmalloc (strlen (p));
2641 strcpy (switches[n_switches].args[0], &p[1]);
2642 switches[n_switches].args[1] = 0;
2643 }
2644 else
ed1f651b 2645 switches[n_switches].args = 0;
f5b0eb4e
RK
2646
2647 switches[n_switches].live_cond = 0;
ed1f651b
RS
2648 switches[n_switches].valid = 0;
2649 /* This is always valid, since gcc.c itself understands it. */
2650 if (!strcmp (p, "save-temps"))
2651 switches[n_switches].valid = 1;
2652 n_switches++;
2653 }
2654 else
2655 {
dd30a199 2656 if ((argv[i][0] != '-' || argv[i][1] != 'l')
14553b75 2657 && strcmp (argv[i], "-")
cb25ac92 2658 && access (argv[i], R_OK) < 0)
48fb792a
BK
2659 {
2660 perror_with_name (argv[i]);
2661 error_count++;
2662 }
2663 else
2664 {
2665 infiles[n_infiles].language = spec_lang;
2666 infiles[n_infiles++].name = argv[i];
2667 }
ed1f651b
RS
2668 }
2669 }
2670
fa0d5369 2671 if (n_infiles == last_language_n_infiles && spec_lang != 0)
ed1f651b
RS
2672 error ("Warning: `-x %s' after last input file has no effect", spec_lang);
2673
2674 switches[n_switches].part1 = 0;
2675 infiles[n_infiles].name = 0;
8eebb258
RS
2676
2677 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
2678 if (gcc_exec_prefix)
2679 {
2680 temp = (char *) xmalloc (strlen (gcc_exec_prefix) + strlen (spec_version)
2681 + strlen (spec_machine) + 3);
2682 strcpy (temp, gcc_exec_prefix);
8eebb258
RS
2683 strcat (temp, spec_machine);
2684 strcat (temp, "/");
00f7e603
RS
2685 strcat (temp, spec_version);
2686 strcat (temp, "/");
8eebb258
RS
2687 gcc_exec_prefix = temp;
2688 }
ed1f651b
RS
2689}
2690\f
2691/* Process a spec string, accumulating and running commands. */
2692
2693/* These variables describe the input file name.
2694 input_file_number is the index on outfiles of this file,
2695 so that the output file name can be stored for later use by %o.
2696 input_basename is the start of the part of the input file
2697 sans all directory names, and basename_length is the number
2698 of characters starting there excluding the suffix .c or whatever. */
2699
2700static char *input_filename;
2701static int input_file_number;
2702static int input_filename_length;
2703static int basename_length;
2704static char *input_basename;
2705static char *input_suffix;
2706
2707/* These are variables used within do_spec and do_spec_1. */
2708
2709/* Nonzero if an arg has been started and not yet terminated
2710 (with space, tab or newline). */
2711static int arg_going;
2712
2713/* Nonzero means %d or %g has been seen; the next arg to be terminated
2714 is a temporary file name. */
2715static int delete_this_arg;
2716
2717/* Nonzero means %w has been seen; the next arg to be terminated
2718 is the output file name of this compilation. */
2719static int this_is_output_file;
2720
2721/* Nonzero means %s has been seen; the next arg to be terminated
2722 is the name of a library file and we should try the standard
2723 search dirs for it. */
2724static int this_is_library_file;
2725
a99bf70c
JW
2726/* Nonzero means that the input of this command is coming from a pipe. */
2727static int input_from_pipe;
2728
ed1f651b
RS
2729/* Process the spec SPEC and run the commands specified therein.
2730 Returns 0 if the spec is successfully processed; -1 if failed. */
2731
2732static int
2733do_spec (spec)
2734 char *spec;
2735{
2736 int value;
2737
2738 clear_args ();
2739 arg_going = 0;
2740 delete_this_arg = 0;
2741 this_is_output_file = 0;
2742 this_is_library_file = 0;
a99bf70c 2743 input_from_pipe = 0;
ed1f651b 2744
906c4e36 2745 value = do_spec_1 (spec, 0, NULL_PTR);
ed1f651b
RS
2746
2747 /* Force out any unfinished command.
2748 If -pipe, this forces out the last command if it ended in `|'. */
2749 if (value == 0)
2750 {
2751 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
2752 argbuf_index--;
2753
2754 if (argbuf_index > 0)
2755 value = execute ();
2756 }
2757
2758 return value;
2759}
2760
2761/* Process the sub-spec SPEC as a portion of a larger spec.
2762 This is like processing a whole spec except that we do
2763 not initialize at the beginning and we do not supply a
2764 newline by default at the end.
2765 INSWITCH nonzero means don't process %-sequences in SPEC;
2766 in this case, % is treated as an ordinary character.
2767 This is used while substituting switches.
2768 INSWITCH nonzero also causes SPC not to terminate an argument.
2769
2770 Value is zero unless a line was finished
2771 and the command on that line reported an error. */
2772
2773static int
2774do_spec_1 (spec, inswitch, soft_matched_part)
2775 char *spec;
2776 int inswitch;
2777 char *soft_matched_part;
2778{
2779 register char *p = spec;
2780 register int c;
2781 int i;
2782 char *string;
3279bba6 2783 int value;
ed1f651b
RS
2784
2785 while (c = *p++)
2786 /* If substituting a switch, treat all chars like letters.
2787 Otherwise, NL, SPC, TAB and % are special. */
2788 switch (inswitch ? 'a' : c)
2789 {
2790 case '\n':
2791 /* End of line: finish any pending argument,
2792 then run the pending command if one has been started. */
2793 if (arg_going)
2794 {
2795 obstack_1grow (&obstack, 0);
2796 string = obstack_finish (&obstack);
2797 if (this_is_library_file)
2798 string = find_file (string);
2799 store_arg (string, delete_this_arg, this_is_output_file);
2800 if (this_is_output_file)
2801 outfiles[input_file_number] = string;
2802 }
2803 arg_going = 0;
2804
2805 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
2806 {
2807 int i;
2808 for (i = 0; i < n_switches; i++)
2809 if (!strcmp (switches[i].part1, "pipe"))
2810 break;
2811
2812 /* A `|' before the newline means use a pipe here,
2813 but only if -pipe was specified.
2814 Otherwise, execute now and don't pass the `|' as an arg. */
2815 if (i < n_switches)
2816 {
a99bf70c 2817 input_from_pipe = 1;
ed1f651b
RS
2818 switches[i].valid = 1;
2819 break;
2820 }
2821 else
2822 argbuf_index--;
2823 }
2824
2825 if (argbuf_index > 0)
2826 {
3279bba6 2827 value = execute ();
ed1f651b
RS
2828 if (value)
2829 return value;
2830 }
2831 /* Reinitialize for a new command, and for a new argument. */
2832 clear_args ();
2833 arg_going = 0;
2834 delete_this_arg = 0;
2835 this_is_output_file = 0;
2836 this_is_library_file = 0;
a99bf70c 2837 input_from_pipe = 0;
ed1f651b
RS
2838 break;
2839
2840 case '|':
2841 /* End any pending argument. */
2842 if (arg_going)
2843 {
2844 obstack_1grow (&obstack, 0);
2845 string = obstack_finish (&obstack);
2846 if (this_is_library_file)
2847 string = find_file (string);
2848 store_arg (string, delete_this_arg, this_is_output_file);
2849 if (this_is_output_file)
2850 outfiles[input_file_number] = string;
2851 }
2852
2853 /* Use pipe */
2854 obstack_1grow (&obstack, c);
2855 arg_going = 1;
2856 break;
2857
2858 case '\t':
2859 case ' ':
2860 /* Space or tab ends an argument if one is pending. */
2861 if (arg_going)
2862 {
2863 obstack_1grow (&obstack, 0);
2864 string = obstack_finish (&obstack);
2865 if (this_is_library_file)
2866 string = find_file (string);
2867 store_arg (string, delete_this_arg, this_is_output_file);
2868 if (this_is_output_file)
2869 outfiles[input_file_number] = string;
2870 }
2871 /* Reinitialize for a new argument. */
2872 arg_going = 0;
2873 delete_this_arg = 0;
2874 this_is_output_file = 0;
2875 this_is_library_file = 0;
2876 break;
2877
2878 case '%':
2879 switch (c = *p++)
2880 {
2881 case 0:
2882 fatal ("Invalid specification! Bug in cc.");
2883
2884 case 'b':
2885 obstack_grow (&obstack, input_basename, basename_length);
2886 arg_going = 1;
2887 break;
2888
2889 case 'd':
2890 delete_this_arg = 2;
2891 break;
2892
2893 /* Dump out the directories specified with LIBRARY_PATH,
004fd4d5
RS
2894 followed by the absolute directories
2895 that we search for startfiles. */
ed1f651b 2896 case 'D':
8cacec76
JW
2897 {
2898 struct prefix_list *pl = startfile_prefix.plist;
2899 int bufsize = 100;
2900 char *buffer = (char *) xmalloc (bufsize);
2901 int idx;
59014d0a 2902
8cacec76
JW
2903 for (; pl; pl = pl->next)
2904 {
004fd4d5 2905#ifdef RELATIVE_PREFIX_NOT_LINKDIR
8cacec76
JW
2906 /* Used on systems which record the specified -L dirs
2907 and use them to search for dynamic linking. */
2908 /* Relative directories always come from -B,
2909 and it is better not to use them for searching
2910 at run time. In particular, stage1 loses */
2911 if (pl->prefix[0] != '/')
2912 continue;
004fd4d5 2913#endif
8cacec76
JW
2914 if (machine_suffix)
2915 {
0ad5835e 2916 if (is_directory (pl->prefix, machine_suffix, 1))
8cacec76
JW
2917 {
2918 do_spec_1 ("-L", 0, NULL_PTR);
004fd4d5 2919#ifdef SPACE_AFTER_L_OPTION
8cacec76 2920 do_spec_1 (" ", 0, NULL_PTR);
004fd4d5 2921#endif
8cacec76
JW
2922 do_spec_1 (pl->prefix, 1, NULL_PTR);
2923 /* Remove slash from machine_suffix. */
2924 if (strlen (machine_suffix) >= bufsize)
2925 bufsize = strlen (machine_suffix) * 2 + 1;
2926 buffer = (char *) xrealloc (buffer, bufsize);
2927 strcpy (buffer, machine_suffix);
2928 idx = strlen (buffer);
2929 if (buffer[idx - 1] == '/')
2930 buffer[idx - 1] = 0;
2931 do_spec_1 (buffer, 1, NULL_PTR);
2932 /* Make this a separate argument. */
2933 do_spec_1 (" ", 0, NULL_PTR);
2934 }
2935 }
2936 if (!pl->require_machine_suffix)
2937 {
0ad5835e 2938 if (is_directory (pl->prefix, "", 1))
8cacec76
JW
2939 {
2940 do_spec_1 ("-L", 0, NULL_PTR);
004fd4d5 2941#ifdef SPACE_AFTER_L_OPTION
8cacec76 2942 do_spec_1 (" ", 0, NULL_PTR);
004fd4d5 2943#endif
8cacec76
JW
2944 /* Remove slash from pl->prefix. */
2945 if (strlen (pl->prefix) >= bufsize)
2946 bufsize = strlen (pl->prefix) * 2 + 1;
2947 buffer = (char *) xrealloc (buffer, bufsize);
2948 strcpy (buffer, pl->prefix);
2949 idx = strlen (buffer);
2950 if (buffer[idx - 1] == '/')
2951 buffer[idx - 1] = 0;
2952 do_spec_1 (buffer, 1, NULL_PTR);
2953 /* Make this a separate argument. */
2954 do_spec_1 (" ", 0, NULL_PTR);
2955 }
2956 }
2957 }
2958 free (buffer);
2959 }
ed1f651b
RS
2960 break;
2961
2962 case 'e':
2963 /* {...:%efoo} means report an error with `foo' as error message
2964 and don't execute any more commands for this file. */
2965 {
2966 char *q = p;
2967 char *buf;
2968 while (*p != 0 && *p != '\n') p++;
2969 buf = (char *) alloca (p - q + 1);
2970 strncpy (buf, q, p - q);
2971 buf[p - q] = 0;
2972 error ("%s", buf);
2973 return -1;
2974 }
2975 break;
2976
2977 case 'g':
d887e808 2978 case 'u':
4401b31c 2979 case 'U':
ed1f651b
RS
2980 if (save_temps_flag)
2981 obstack_grow (&obstack, input_basename, basename_length);
2982 else
2983 {
fb266030
TW
2984#ifdef MKTEMP_EACH_FILE
2985 /* ??? This has a problem: the total number of
2986 values mktemp can return is limited.
2987 That matters for the names of object files.
2988 In 2.4, do something about that. */
2989 struct temp_name *t;
2990 char *suffix = p;
b9490a6e
RS
2991 while (*p == '.' || isalpha (*p))
2992 p++;
fb266030
TW
2993
2994 /* See if we already have an association of %g/%u/%U and
2995 suffix. */
2996 for (t = temp_names; t; t = t->next)
2997 if (t->length == p - suffix
2998 && strncmp (t->suffix, suffix, p - suffix) == 0
2999 && t->unique == (c != 'g'))
3000 break;
3001
3002 /* Make a new association if needed. %u requires one. */
3003 if (t == 0 || c == 'u')
3004 {
3005 if (t == 0)
3006 {
3007 t = (struct temp_name *) xmalloc (sizeof (struct temp_name));
3008 t->next = temp_names;
3009 temp_names = t;
3010 }
3011 t->length = p - suffix;
3012 t->suffix = save_string (suffix, p - suffix);
3013 t->unique = (c != 'g');
3014 choose_temp_base ();
3015 t->filename = temp_filename;
3016 t->filename_length = temp_filename_length;
3017 }
3018
3019 obstack_grow (&obstack, t->filename, t->filename_length);
b9490a6e
RS
3020 delete_this_arg = 1;
3021#else
ed1f651b 3022 obstack_grow (&obstack, temp_filename, temp_filename_length);
4401b31c 3023 if (c == 'u' || c == 'U')
d887e808
TW
3024 {
3025 static int unique;
3026 char buff[9];
4401b31c
MM
3027 if (c == 'u')
3028 unique++;
3029 sprintf (buff, "%d", unique);
d887e808
TW
3030 obstack_grow (&obstack, buff, strlen (buff));
3031 }
b9490a6e 3032#endif
ed1f651b
RS
3033 delete_this_arg = 1;
3034 }
3035 arg_going = 1;
3036 break;
3037
3038 case 'i':
3039 obstack_grow (&obstack, input_filename, input_filename_length);
3040 arg_going = 1;
3041 break;
3042
8eebb258 3043 case 'I':
2d879387
JW
3044 {
3045 struct prefix_list *pl = include_prefix.plist;
3046
3047 if (gcc_exec_prefix)
3048 {
3049 do_spec_1 ("-iprefix", 1, NULL_PTR);
3050 /* Make this a separate argument. */
3051 do_spec_1 (" ", 0, NULL_PTR);
3052 do_spec_1 (gcc_exec_prefix, 1, NULL_PTR);
3053 do_spec_1 (" ", 0, NULL_PTR);
3054 }
3055
3056 for (; pl; pl = pl->next)
3057 {
3058 do_spec_1 ("-isystem", 1, NULL_PTR);
3059 /* Make this a separate argument. */
3060 do_spec_1 (" ", 0, NULL_PTR);
3061 do_spec_1 (pl->prefix, 1, NULL_PTR);
3062 do_spec_1 (" ", 0, NULL_PTR);
3063 }
3064 }
8eebb258
RS
3065 break;
3066
ed1f651b
RS
3067 case 'o':
3068 {
3069 register int f;
3070 for (f = 0; f < n_infiles; f++)
3071 store_arg (outfiles[f], 0, 0);
3072 }
3073 break;
3074
3075 case 's':
3076 this_is_library_file = 1;
3077 break;
3078
3079 case 'w':
3080 this_is_output_file = 1;
3081 break;
3082
3083 case 'W':
3084 {
3085 int index = argbuf_index;
3086 /* Handle the {...} following the %W. */
3087 if (*p != '{')
3088 abort ();
3089 p = handle_braces (p + 1);
3090 if (p == 0)
3091 return -1;
3092 /* If any args were output, mark the last one for deletion
3093 on failure. */
3094 if (argbuf_index != index)
3095 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
3096 break;
3097 }
3098
3099 /* %x{OPTION} records OPTION for %X to output. */
3100 case 'x':
3101 {
3102 char *p1 = p;
3103 char *string;
3104
3105 /* Skip past the option value and make a copy. */
3106 if (*p != '{')
3107 abort ();
3108 while (*p++ != '}')
3109 ;
3110 string = save_string (p1 + 1, p - p1 - 2);
3111
3112 /* See if we already recorded this option. */
3113 for (i = 0; i < n_linker_options; i++)
3114 if (! strcmp (string, linker_options[i]))
3115 {
3116 free (string);
3117 return 0;
3118 }
3119
3120 /* This option is new; add it. */
3121 n_linker_options++;
3122 if (!linker_options)
3123 linker_options
3124 = (char **) xmalloc (n_linker_options * sizeof (char **));
3125 else
3126 linker_options
3127 = (char **) xrealloc (linker_options,
3128 n_linker_options * sizeof (char **));
3129
3130 linker_options[n_linker_options - 1] = string;
3131 }
3132 break;
3133
c9ebacb8
RS
3134 /* Dump out the options accumulated previously using %x,
3135 -Xlinker and -Wl,. */
ed1f651b
RS
3136 case 'X':
3137 for (i = 0; i < n_linker_options; i++)
3138 {
906c4e36 3139 do_spec_1 (linker_options[i], 1, NULL_PTR);
ed1f651b 3140 /* Make each accumulated option a separate argument. */
906c4e36 3141 do_spec_1 (" ", 0, NULL_PTR);
ed1f651b
RS
3142 }
3143 break;
3144
c9ebacb8
RS
3145 /* Dump out the options accumulated previously using -Wa,. */
3146 case 'Y':
3147 for (i = 0; i < n_assembler_options; i++)
3148 {
3149 do_spec_1 (assembler_options[i], 1, NULL_PTR);
3150 /* Make each accumulated option a separate argument. */
3151 do_spec_1 (" ", 0, NULL_PTR);
3152 }
3153 break;
3154
ed1f651b
RS
3155 /* Here are digits and numbers that just process
3156 a certain constant string as a spec. */
3157
3158 case '1':
3279bba6
RS
3159 value = do_spec_1 (cc1_spec, 0, NULL_PTR);
3160 if (value != 0)
3161 return value;
ed1f651b
RS
3162 break;
3163
3164 case '2':
3279bba6
RS
3165 value = do_spec_1 (cc1plus_spec, 0, NULL_PTR);
3166 if (value != 0)
3167 return value;
ed1f651b
RS
3168 break;
3169
3170 case 'a':
3279bba6
RS
3171 value = do_spec_1 (asm_spec, 0, NULL_PTR);
3172 if (value != 0)
3173 return value;
ed1f651b
RS
3174 break;
3175
3176 case 'A':
3279bba6
RS
3177 value = do_spec_1 (asm_final_spec, 0, NULL_PTR);
3178 if (value != 0)
3179 return value;
ed1f651b
RS
3180 break;
3181
3182 case 'c':
3279bba6
RS
3183 value = do_spec_1 (signed_char_spec, 0, NULL_PTR);
3184 if (value != 0)
3185 return value;
ed1f651b
RS
3186 break;
3187
3188 case 'C':
3279bba6
RS
3189 value = do_spec_1 (cpp_spec, 0, NULL_PTR);
3190 if (value != 0)
3191 return value;
ed1f651b
RS
3192 break;
3193
3194 case 'E':
3279bba6
RS
3195 value = do_spec_1 (endfile_spec, 0, NULL_PTR);
3196 if (value != 0)
3197 return value;
ed1f651b
RS
3198 break;
3199
3200 case 'l':
3279bba6
RS
3201 value = do_spec_1 (link_spec, 0, NULL_PTR);
3202 if (value != 0)
3203 return value;
ed1f651b
RS
3204 break;
3205
3206 case 'L':
3279bba6
RS
3207 value = do_spec_1 (lib_spec, 0, NULL_PTR);
3208 if (value != 0)
3209 return value;
ed1f651b
RS
3210 break;
3211
3212 case 'p':
3213 {
3214 char *x = (char *) alloca (strlen (cpp_predefines) + 1);
3215 char *buf = x;
3216 char *y;
3217
3218 /* Copy all of the -D options in CPP_PREDEFINES into BUF. */
3219 y = cpp_predefines;
3220 while (*y != 0)
3221 {
3222 if (! strncmp (y, "-D", 2))
3223 /* Copy the whole option. */
3224 while (*y && *y != ' ' && *y != '\t')
3225 *x++ = *y++;
3226 else if (*y == ' ' || *y == '\t')
3227 /* Copy whitespace to the result. */
3228 *x++ = *y++;
3229 /* Don't copy other options. */
3230 else
3231 y++;
3232 }
3233
3234 *x = 0;
3235
3279bba6
RS
3236 value = do_spec_1 (buf, 0, NULL_PTR);
3237 if (value != 0)
3238 return value;
ed1f651b
RS
3239 }
3240 break;
3241
3242 case 'P':
3243 {
3244 char *x = (char *) alloca (strlen (cpp_predefines) * 4 + 1);
3245 char *buf = x;
3246 char *y;
3247
3248 /* Copy all of CPP_PREDEFINES into BUF,
3249 but put __ after every -D and at the end of each arg. */
3250 y = cpp_predefines;
3251 while (*y != 0)
3252 {
3253 if (! strncmp (y, "-D", 2))
3254 {
3255 int flag = 0;
3256
3257 *x++ = *y++;
3258 *x++ = *y++;
3259
3260 if (strncmp (y, "__", 2))
3261 {
3262 /* Stick __ at front of macro name. */
3263 *x++ = '_';
3264 *x++ = '_';
3265 /* Arrange to stick __ at the end as well. */
3266 flag = 1;
3267 }
3268
3269 /* Copy the macro name. */
3270 while (*y && *y != '=' && *y != ' ' && *y != '\t')
3271 *x++ = *y++;
3272
3273 if (flag)
3274 {
3275 *x++ = '_';
3276 *x++ = '_';
3277 }
3278
3279 /* Copy the value given, if any. */
3280 while (*y && *y != ' ' && *y != '\t')
3281 *x++ = *y++;
3282 }
3283 else if (*y == ' ' || *y == '\t')
3284 /* Copy whitespace to the result. */
3285 *x++ = *y++;
3286 /* Don't copy -A options */
3287 else
3288 y++;
3289 }
3290 *x++ = ' ';
3291
3292 /* Copy all of CPP_PREDEFINES into BUF,
3293 but put __ after every -D. */
3294 y = cpp_predefines;
3295 while (*y != 0)
3296 {
3297 if (! strncmp (y, "-D", 2))
3298 {
54a88f92 3299 y += 2;
ed1f651b
RS
3300
3301 if (strncmp (y, "__", 2))
3302 {
54a88f92
RK
3303 /* Stick -D__ at front of macro name. */
3304 *x++ = '-';
3305 *x++ = 'D';
ed1f651b
RS
3306 *x++ = '_';
3307 *x++ = '_';
ed1f651b 3308
54a88f92
RK
3309 /* Copy the macro name. */
3310 while (*y && *y != '=' && *y != ' ' && *y != '\t')
3311 *x++ = *y++;
ed1f651b 3312
54a88f92
RK
3313 /* Copy the value given, if any. */
3314 while (*y && *y != ' ' && *y != '\t')
3315 *x++ = *y++;
3316 }
3317 else
3318 {
3319 /* Do not copy this macro - we have just done it before */
3320 while (*y && *y != ' ' && *y != '\t')
3321 y++;
3322 }
ed1f651b
RS
3323 }
3324 else if (*y == ' ' || *y == '\t')
3325 /* Copy whitespace to the result. */
3326 *x++ = *y++;
3327 /* Don't copy -A options */
3328 else
3329 y++;
3330 }
3331 *x++ = ' ';
3332
3333 /* Copy all of the -A options in CPP_PREDEFINES into BUF. */
3334 y = cpp_predefines;
3335 while (*y != 0)
3336 {
3337 if (! strncmp (y, "-A", 2))
3338 /* Copy the whole option. */
3339 while (*y && *y != ' ' && *y != '\t')
3340 *x++ = *y++;
3341 else if (*y == ' ' || *y == '\t')
3342 /* Copy whitespace to the result. */
3343 *x++ = *y++;
3344 /* Don't copy other options. */
3345 else
3346 y++;
3347 }
3348
3349 *x = 0;
3350
3279bba6
RS
3351 value = do_spec_1 (buf, 0, NULL_PTR);
3352 if (value != 0)
3353 return value;
ed1f651b
RS
3354 }
3355 break;
3356
3357 case 'S':
3279bba6
RS
3358 value = do_spec_1 (startfile_spec, 0, NULL_PTR);
3359 if (value != 0)
3360 return value;
ed1f651b
RS
3361 break;
3362
3363 /* Here we define characters other than letters and digits. */
3364
3365 case '{':
3366 p = handle_braces (p);
3367 if (p == 0)
3368 return -1;
3369 break;
3370
3371 case '%':
3372 obstack_1grow (&obstack, '%');
3373 break;
3374
3375 case '*':
906c4e36
RK
3376 do_spec_1 (soft_matched_part, 1, NULL_PTR);
3377 do_spec_1 (" ", 0, NULL_PTR);
ed1f651b
RS
3378 break;
3379
3380 /* Process a string found as the value of a spec given by name.
3381 This feature allows individual machine descriptions
3382 to add and use their own specs.
3383 %[...] modifies -D options the way %P does;
3384 %(...) uses the spec unmodified. */
3385 case '(':
3386 case '[':
3387 {
3388 char *name = p;
3389 struct spec_list *sl;
3390 int len;
3391
3392 /* The string after the S/P is the name of a spec that is to be
3393 processed. */
3394 while (*p && *p != ')' && *p != ']')
3395 p++;
3396
3397 /* See if it's in the list */
3398 for (len = p - name, sl = specs; sl; sl = sl->next)
3399 if (strncmp (sl->name, name, len) == 0 && !sl->name[len])
3400 {
3401 name = sl->spec;
3402 break;
3403 }
3404
3405 if (sl)
3406 {
3407 if (c == '(')
3279bba6
RS
3408 {
3409 value = do_spec_1 (name, 0, NULL_PTR);
3410 if (value != 0)
3411 return value;
3412 }
ed1f651b
RS
3413 else
3414 {
3415 char *x = (char *) alloca (strlen (name) * 2 + 1);
3416 char *buf = x;
3417 char *y = name;
3418
3419 /* Copy all of NAME into BUF, but put __ after
3420 every -D and at the end of each arg, */
3421 while (1)
3422 {
3423 if (! strncmp (y, "-D", 2))
3424 {
3425 *x++ = '-';
3426 *x++ = 'D';
3427 *x++ = '_';
3428 *x++ = '_';
3429 y += 2;
3430 }
3431 else if (*y == ' ' || *y == 0)
3432 {
3433 *x++ = '_';
3434 *x++ = '_';
3435 if (*y == 0)
3436 break;
3437 else
3438 *x++ = *y++;
3439 }
3440 else
3441 *x++ = *y++;
3442 }
3443 *x = 0;
3444
3279bba6
RS
3445 value = do_spec_1 (buf, 0, NULL_PTR);
3446 if (value != 0)
3447 return value;
ed1f651b
RS
3448 }
3449 }
b3865ca9
RS
3450
3451 /* Discard the closing paren or bracket. */
3452 if (*p)
3453 p++;
ed1f651b
RS
3454 }
3455 break;
3456
829407e1
RS
3457 case 'v':
3458 {
500c9e81 3459 int c1 = *p++; /* Select first or second version number. */
53117a2f 3460 char *v = compiler_version;
829407e1 3461 char *q, *copy;
500c9e81
RS
3462 /* If desired, advance to second version number. */
3463 if (c1 == '2')
3464 {
3465 /* Set P after the first period. */
53117a2f
RK
3466 while (*v != 0 && *v != ' ' && *v != '.')
3467 v++;
3468 if (*v == '.')
3469 v++;
500c9e81
RS
3470 }
3471 /* Set Q at the next period or at the end. */
53117a2f
RK
3472 q = v;
3473 while (*q != 0 && *q != ' ' && *q != '.')
3474 q++;
3475 /* Empty string means zero. */
3476 if (p == q)
3477 {
3478 v = "0";
3479 q = v + 1;
3480 }
829407e1 3481 /* Put that part into the command. */
53117a2f 3482 obstack_grow (&obstack, v, q - v);
829407e1
RS
3483 arg_going = 1;
3484 }
3485 break;
3486
a99bf70c
JW
3487 case '|':
3488 if (input_from_pipe)
3489 do_spec_1 ("-", 0, NULL_PTR);
3490 break;
3491
ed1f651b
RS
3492 default:
3493 abort ();
3494 }
3495 break;
3496
3497 case '\\':
3498 /* Backslash: treat next character as ordinary. */
3499 c = *p++;
3500
3501 /* fall through */
3502 default:
3503 /* Ordinary character: put it into the current argument. */
3504 obstack_1grow (&obstack, c);
3505 arg_going = 1;
3506 }
3507
3508 return 0; /* End of string */
3509}
3510
3511/* Return 0 if we call do_spec_1 and that returns -1. */
3512
3513static char *
3514handle_braces (p)
3515 register char *p;
3516{
3517 register char *q;
3518 char *filter;
3519 int pipe = 0;
3520 int negate = 0;
3521 int suffix = 0;
3522
3523 if (*p == '|')
3524 /* A `|' after the open-brace means,
3525 if the test fails, output a single minus sign rather than nothing.
3526 This is used in %{|!pipe:...}. */
3527 pipe = 1, ++p;
3528
3529 if (*p == '!')
3530 /* A `!' after the open-brace negates the condition:
3531 succeed if the specified switch is not present. */
3532 negate = 1, ++p;
3533
3534 if (*p == '.')
3535 /* A `.' after the open-brace means test against the current suffix. */
3536 {
3537 if (pipe)
3538 abort ();
3539
3540 suffix = 1;
3541 ++p;
3542 }
3543
3544 filter = p;
3545 while (*p != ':' && *p != '}') p++;
3546 if (*p != '}')
3547 {
3548 register int count = 1;
3549 q = p + 1;
3550 while (count > 0)
3551 {
3552 if (*q == '{')
3553 count++;
3554 else if (*q == '}')
3555 count--;
3556 else if (*q == 0)
3557 abort ();
3558 q++;
3559 }
3560 }
3561 else
3562 q = p + 1;
3563
3564 if (suffix)
3565 {
3566 int found = (input_suffix != 0
004fd4d5 3567 && strlen (input_suffix) == p - filter
ed1f651b
RS
3568 && strncmp (input_suffix, filter, p - filter) == 0);
3569
3570 if (p[0] == '}')
3571 abort ();
3572
3573 if (negate != found
906c4e36 3574 && do_spec_1 (save_string (p + 1, q - p - 2), 0, NULL_PTR) < 0)
ed1f651b
RS
3575 return 0;
3576
3577 return q;
3578 }
3579 else if (p[-1] == '*' && p[0] == '}')
3580 {
3581 /* Substitute all matching switches as separate args. */
3582 register int i;
3583 --p;
3584 for (i = 0; i < n_switches; i++)
f5b0eb4e
RK
3585 if (!strncmp (switches[i].part1, filter, p - filter)
3586 && check_live_switch (i, p - filter))
ed1f651b
RS
3587 give_switch (i, 0);
3588 }
3589 else
3590 {
3591 /* Test for presence of the specified switch. */
3592 register int i;
3593 int present = 0;
3594
3595 /* If name specified ends in *, as in {x*:...},
3596 check for %* and handle that case. */
3597 if (p[-1] == '*' && !negate)
3598 {
3599 int substitution;
3600 char *r = p;
3601
3602 /* First see whether we have %*. */
3603 substitution = 0;
b3865ca9 3604 while (r < q)
ed1f651b
RS
3605 {
3606 if (*r == '%' && r[1] == '*')
3607 substitution = 1;
3608 r++;
3609 }
3610 /* If we do, handle that case. */
3611 if (substitution)
3612 {
3613 /* Substitute all matching switches as separate args.
3614 But do this by substituting for %*
3615 in the text that follows the colon. */
3616
3617 unsigned hard_match_len = p - filter - 1;
3618 char *string = save_string (p + 1, q - p - 2);
3619
3620 for (i = 0; i < n_switches; i++)
f5b0eb4e
RK
3621 if (!strncmp (switches[i].part1, filter, hard_match_len)
3622 && check_live_switch (i, hard_match_len))
ed1f651b
RS
3623 {
3624 do_spec_1 (string, 0, &switches[i].part1[hard_match_len]);
3625 /* Pass any arguments this switch has. */
3626 give_switch (i, 1);
3627 }
3628
3629 return q;
3630 }
3631 }
3632
3633 /* If name specified ends in *, as in {x*:...},
3634 check for presence of any switch name starting with x. */
3635 if (p[-1] == '*')
3636 {
3637 for (i = 0; i < n_switches; i++)
3638 {
3639 unsigned hard_match_len = p - filter - 1;
3640
f5b0eb4e
RK
3641 if (!strncmp (switches[i].part1, filter, hard_match_len)
3642 && check_live_switch (i, hard_match_len))
ed1f651b 3643 {
ed1f651b
RS
3644 present = 1;
3645 }
3646 }
3647 }
3648 /* Otherwise, check for presence of exact name specified. */
3649 else
3650 {
3651 for (i = 0; i < n_switches; i++)
3652 {
3653 if (!strncmp (switches[i].part1, filter, p - filter)
f5b0eb4e
RK
3654 && switches[i].part1[p - filter] == 0
3655 && check_live_switch (i, p - filter))
ed1f651b 3656 {
ed1f651b
RS
3657 present = 1;
3658 break;
3659 }
3660 }
3661 }
3662
3663 /* If it is as desired (present for %{s...}, absent for %{-s...})
3664 then substitute either the switch or the specified
3665 conditional text. */
3666 if (present != negate)
3667 {
3668 if (*p == '}')
3669 {
3670 give_switch (i, 0);
3671 }
3672 else
3673 {
906c4e36 3674 if (do_spec_1 (save_string (p + 1, q - p - 2), 0, NULL_PTR) < 0)
ed1f651b
RS
3675 return 0;
3676 }
3677 }
3678 else if (pipe)
3679 {
3680 /* Here if a %{|...} conditional fails: output a minus sign,
3681 which means "standard output" or "standard input". */
906c4e36 3682 do_spec_1 ("-", 0, NULL_PTR);
ed1f651b
RS
3683 }
3684 }
3685
3686 return q;
3687}
f5b0eb4e
RK
3688\f
3689/* Return 0 if switch number SWITCHNUM is obsoleted by a later switch
3690 on the command line. LENGTH is the length of the switch name we
3691 are to compare for. Otherwise return zero.
3692
3693 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
3694 whose value does not begin with "no-" is obsoleted by the same value
3695 with the "no-", similarly for a switch with the "no-" prefix. */
3696
3697static int
3698check_live_switch (switchnum, length)
3699 int switchnum;
3700 int length;
3701{
3702 char *name = switches[switchnum].part1;
3703 int i;
3704
3705 /* If we just have a single letter and it isn't "O", a negating
3706 switch would always match, so ignore that case. We will just
3707 send the conflicting switches to the compiler phase. */
3708 if (length == 1 && name[0] != 'O')
3709 return 1;
3710
3711 /* If we already processed this switch and determined if it was
3712 live or not, return our past determination. */
3713 if (switches[switchnum].live_cond != 0)
3714 return switches[switchnum].live_cond > 0;
3715
3716 /* Now search for duplicate in a manner that depends on the name. */
3717 switch (*name)
3718 {
3719 case 'O':
3720 if (length == 1)
3721 for (i = switchnum + 1; i < n_switches; i++)
3722 if (switches[i].part1[0] == 'O')
3723 {
3724 switches[switchnum].valid = 1;
3725 switches[switchnum].live_cond = -1;
3726 return 0;
3727 }
3728 break;
ed1f651b 3729
f5b0eb4e
RK
3730 case 'W': case 'f': case 'm':
3731 if (length > 4 && ! strncmp (name + 1, "no-", 3))
3732 {
3733 /* We have Xno-YYY, search for XYYY. */
3734 for (i = switchnum + 1; i < n_switches; i++)
3735 if (switches[i].part1[0] == name[0]
3736 && ! strcmp (&switches[i].part1[1], &name[4]))
3737 {
3738 switches[switchnum].valid = 1;
3739 switches[switchnum].live_cond = -1;
3740 return 0;
3741 }
3742 }
3743 else
3744 {
3745 /* We have XYYY, search for Xno-YYY. */
3746 for (i = switchnum + 1; i < n_switches; i++)
3747 if (switches[i].part1[0] == name[0]
3748 && switches[i].part1[1] == 'n'
3749 && switches[i].part1[2] == 'o'
3750 && switches[i].part1[3] == '-'
3751 && !strcmp (&switches[i].part1[4], &name[1]))
3752 {
3753 switches[switchnum].valid = 1;
3754 switches[switchnum].live_cond = -1;
3755 return 0;
3756 }
3757 }
3758 break;
3759 }
3760
3761 /* Otherwise the switch is live. */
3762 switches[switchnum].live_cond = 1;
3763 return 1;
3764}
3765\f
ed1f651b
RS
3766/* Pass a switch to the current accumulating command
3767 in the same form that we received it.
3768 SWITCHNUM identifies the switch; it is an index into
3769 the vector of switches gcc received, which is `switches'.
3770 This cannot fail since it never finishes a command line.
3771
3772 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
3773
3774static void
3775give_switch (switchnum, omit_first_word)
3776 int switchnum;
3777 int omit_first_word;
3778{
3779 if (!omit_first_word)
3780 {
906c4e36
RK
3781 do_spec_1 ("-", 0, NULL_PTR);
3782 do_spec_1 (switches[switchnum].part1, 1, NULL_PTR);
ed1f651b 3783 }
906c4e36 3784 do_spec_1 (" ", 0, NULL_PTR);
ed1f651b
RS
3785 if (switches[switchnum].args != 0)
3786 {
3787 char **p;
3788 for (p = switches[switchnum].args; *p; p++)
3789 {
906c4e36
RK
3790 do_spec_1 (*p, 1, NULL_PTR);
3791 do_spec_1 (" ", 0, NULL_PTR);
ed1f651b
RS
3792 }
3793 }
3794 switches[switchnum].valid = 1;
3795}
3796\f
3797/* Search for a file named NAME trying various prefixes including the
3798 user's -B prefix and some standard ones.
3799 Return the absolute file name found. If nothing is found, return NAME. */
3800
3801static char *
3802find_file (name)
3803 char *name;
3804{
3805 char *newname;
3806
3807 newname = find_a_file (&startfile_prefix, name, R_OK);
3808 return newname ? newname : name;
3809}
3810
0ad5835e
ILT
3811/* Determine whether a directory exists. If LINKER, return 0 for
3812 certain fixed names not needed by the linker. If not LINKER, it is
3813 only important to return 0 if the host machine has a small ARG_MAX
3814 limit. */
ed1f651b
RS
3815
3816static int
0ad5835e 3817is_directory (path1, path2, linker)
ed1f651b
RS
3818 char *path1;
3819 char *path2;
0ad5835e 3820 int linker;
ed1f651b
RS
3821{
3822 int len1 = strlen (path1);
3823 int len2 = strlen (path2);
3824 char *path = (char *) alloca (3 + len1 + len2);
3825 char *cp;
3826 struct stat st;
3827
0ad5835e
ILT
3828#ifndef SMALL_ARG_MAX
3829 if (! linker)
3830 return 1;
3831#endif
3832
ed1f651b
RS
3833 /* Construct the path from the two parts. Ensure the string ends with "/.".
3834 The resulting path will be a directory even if the given path is a
3835 symbolic link. */
3836 bcopy (path1, path, len1);
3837 bcopy (path2, path + len1, len2);
3838 cp = path + len1 + len2;
3839 if (cp[-1] != '/')
3840 *cp++ = '/';
3841 *cp++ = '.';
3842 *cp = '\0';
3843
3844 /* Exclude directories that the linker is known to search. */
0ad5835e
ILT
3845 if (linker
3846 && ((cp - path == 6 && strcmp (path, "/lib/.") == 0)
3847 || (cp - path == 10 && strcmp (path, "/usr/lib/.") == 0)))
ed1f651b
RS
3848 return 0;
3849
3850 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
3851}
ed1f651b
RS
3852\f
3853/* On fatal signals, delete all the temporary files. */
3854
3855static void
3856fatal_error (signum)
3857 int signum;
3858{
3859 signal (signum, SIG_DFL);
3860 delete_failure_queue ();
3861 delete_temp_files ();
3862 /* Get the same signal again, this time not handled,
3863 so its normal effect occurs. */
3864 kill (getpid (), signum);
3865}
3866
3867int
3868main (argc, argv)
3869 int argc;
3870 char **argv;
3871{
3872 register int i;
058d8521 3873 int j;
ed1f651b 3874 int value;
ed1f651b
RS
3875 int linker_was_run = 0;
3876 char *explicit_link_files;
3877 char *specs_file;
afcd8a02 3878 char *p;
ed1f651b 3879
afcd8a02
JW
3880 p = argv[0] + strlen (argv[0]);
3881 while (p != argv[0] && p[-1] != '/') --p;
3882 programname = p;
ed1f651b
RS
3883
3884 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
3885 signal (SIGINT, fatal_error);
2a353d3a 3886#ifdef SIGHUP
ed1f651b
RS
3887 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
3888 signal (SIGHUP, fatal_error);
2a353d3a 3889#endif
ed1f651b
RS
3890 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
3891 signal (SIGTERM, fatal_error);
3892#ifdef SIGPIPE
3893 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
3894 signal (SIGPIPE, fatal_error);
3895#endif
3896
3897 argbuf_length = 10;
3898 argbuf = (char **) xmalloc (argbuf_length * sizeof (char *));
3899
3900 obstack_init (&obstack);
3901
b3865ca9 3902 /* Set up to remember the pathname of gcc and any options
1d23c208
JW
3903 needed for collect. We use argv[0] instead of programname because
3904 we need the complete pathname. */
b3865ca9
RS
3905 obstack_init (&collect_obstack);
3906 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=")-1);
1d23c208 3907 obstack_grow (&collect_obstack, argv[0], strlen (argv[0])+1);
b3865ca9
RS
3908 putenv (obstack_finish (&collect_obstack));
3909
ed1f651b
RS
3910 /* Choose directory for temp files. */
3911
3912 choose_temp_base ();
3913
3914 /* Make a table of what switches there are (switches, n_switches).
3915 Make a table of specified input files (infiles, n_infiles).
3916 Decode switches that are handled locally. */
3917
3918 process_command (argc, argv);
3919
3920 /* Initialize the vector of specs to just the default.
3921 This means one element containing 0s, as a terminator. */
3922
3923 compilers = (struct compiler *) xmalloc (sizeof default_compilers);
3924 bcopy (default_compilers, compilers, sizeof default_compilers);
3925 n_compilers = n_default_compilers;
3926
3927 /* Read specs from a file if there is one. */
3928
3929 machine_suffix = concat (spec_machine, "/", concat (spec_version, "/", ""));
ae04227b 3930 just_machine_suffix = concat (spec_machine, "/", "");
ed1f651b
RS
3931
3932 specs_file = find_a_file (&startfile_prefix, "specs", R_OK);
3933 /* Read the specs file unless it is a default one. */
3934 if (specs_file != 0 && strcmp (specs_file, "specs"))
3935 read_specs (specs_file);
3936
004fd4d5
RS
3937 /* If not cross-compiling, look for startfiles in the standard places. */
3938 /* The fact that these are done here, after reading the specs file,
3939 means that it cannot be found in these directories.
3940 But that's okay. It should never be there anyway. */
3941 if (!cross_compile)
3942 {
3943#ifdef MD_EXEC_PREFIX
906c4e36
RK
3944 add_prefix (&exec_prefix, md_exec_prefix, 0, 0, NULL_PTR);
3945 add_prefix (&startfile_prefix, md_exec_prefix, 0, 0, NULL_PTR);
004fd4d5
RS
3946#endif
3947
3948#ifdef MD_STARTFILE_PREFIX
906c4e36 3949 add_prefix (&startfile_prefix, md_startfile_prefix, 0, 0, NULL_PTR);
004fd4d5
RS
3950#endif
3951
607a4f7d 3952#ifdef MD_STARTFILE_PREFIX_1
906c4e36 3953 add_prefix (&startfile_prefix, md_startfile_prefix_1, 0, 0, NULL_PTR);
607a4f7d
RS
3954#endif
3955
4dbc7773
ILT
3956 /* If standard_startfile_prefix is relative, base it on
3957 standard_exec_prefix. This lets us move the installed tree
3958 as a unit. If GCC_EXEC_PREFIX is defined, base
3959 standard_startfile_prefix on that as well. */
3960 if (*standard_startfile_prefix == '/')
3961 add_prefix (&startfile_prefix, standard_startfile_prefix, 0, 0,
3962 NULL_PTR);
3963 else
3964 {
3965 if (gcc_exec_prefix)
3966 add_prefix (&startfile_prefix,
3967 concat (gcc_exec_prefix,
7560d6cb
ILT
3968 standard_startfile_prefix,
3969 ""),
4dbc7773
ILT
3970 0, 0, NULL_PTR);
3971 add_prefix (&startfile_prefix,
3972 concat (standard_exec_prefix,
3973 machine_suffix,
3974 standard_startfile_prefix),
3975 0, 0, NULL_PTR);
3976 }
3977
906c4e36
RK
3978 add_prefix (&startfile_prefix, standard_startfile_prefix_1, 0, 0,
3979 NULL_PTR);
3980 add_prefix (&startfile_prefix, standard_startfile_prefix_2, 0, 0,
3981 NULL_PTR);
004fd4d5 3982#if 0 /* Can cause surprises, and one can use -B./ instead. */
906c4e36 3983 add_prefix (&startfile_prefix, "./", 0, 1, NULL_PTR);
004fd4d5
RS
3984#endif
3985 }
3986
ed1f651b
RS
3987 /* Now we have the specs.
3988 Set the `valid' bits for switches that match anything in any spec. */
3989
3990 validate_all_switches ();
3991
3992 /* Warn about any switches that no pass was interested in. */
3993
3994 for (i = 0; i < n_switches; i++)
3995 if (! switches[i].valid)
3996 error ("unrecognized option `-%s'", switches[i].part1);
3997
2dcb563f
RS
3998 if (print_libgcc_file_name)
3999 {
4000 printf ("%s\n", find_file ("libgcc.a"));
4001 exit (0);
4002 }
4003
ed1f651b
RS
4004 /* Obey some of the options. */
4005
4006 if (verbose_flag)
4007 {
4008 fprintf (stderr, "gcc version %s\n", version_string);
4009 if (n_infiles == 0)
4010 exit (0);
4011 }
4012
4013 if (n_infiles == 0)
1df80ae4 4014 fatal ("No input files");
ed1f651b
RS
4015
4016 /* Make a place to record the compiler output file names
4017 that correspond to the input files. */
4018
4019 outfiles = (char **) xmalloc (n_infiles * sizeof (char *));
4020 bzero (outfiles, n_infiles * sizeof (char *));
4021
4022 /* Record which files were specified explicitly as link input. */
4023
4024 explicit_link_files = xmalloc (n_infiles);
4025 bzero (explicit_link_files, n_infiles);
4026
4027 for (i = 0; i < n_infiles; i++)
4028 {
4029 register struct compiler *cp = 0;
4030 int this_file_error = 0;
4031
4032 /* Tell do_spec what to substitute for %i. */
4033
4034 input_filename = infiles[i].name;
4035 input_filename_length = strlen (input_filename);
4036 input_file_number = i;
4037
4038 /* Use the same thing in %o, unless cp->spec says otherwise. */
4039
4040 outfiles[i] = input_filename;
4041
4042 /* Figure out which compiler from the file's suffix. */
4043
4044 cp = lookup_compiler (infiles[i].name, input_filename_length,
4045 infiles[i].language);
4046
4047 if (cp)
4048 {
4049 /* Ok, we found an applicable compiler. Run its spec. */
4050 /* First say how much of input_filename to substitute for %b */
4051 register char *p;
ec32609a 4052 int len;
ed1f651b
RS
4053
4054 input_basename = input_filename;
4055 for (p = input_filename; *p; p++)
4056 if (*p == '/')
4057 input_basename = p + 1;
4058
4059 /* Find a suffix starting with the last period,
4060 and set basename_length to exclude that suffix. */
4061 basename_length = strlen (input_basename);
4062 p = input_basename + basename_length;
4063 while (p != input_basename && *p != '.') --p;
4064 if (*p == '.' && p != input_basename)
4065 {
4066 basename_length = p - input_basename;
4067 input_suffix = p + 1;
4068 }
4069 else
4070 input_suffix = "";
4071
ec32609a 4072 len = 0;
058d8521
RS
4073 for (j = 0; j < sizeof cp->spec / sizeof cp->spec[0]; j++)
4074 if (cp->spec[j])
4075 len += strlen (cp->spec[j]);
ec32609a
RS
4076
4077 p = (char *) xmalloc (len + 1);
4078
4079 len = 0;
058d8521
RS
4080 for (j = 0; j < sizeof cp->spec / sizeof cp->spec[0]; j++)
4081 if (cp->spec[j])
4082 {
4083 strcpy (p + len, cp->spec[j]);
4084 len += strlen (cp->spec[j]);
4085 }
ec32609a
RS
4086
4087 value = do_spec (p);
4088 free (p);
ed1f651b
RS
4089 if (value < 0)
4090 this_file_error = 1;
4091 }
4092
4093 /* If this file's name does not contain a recognized suffix,
4094 record it as explicit linker input. */
4095
4096 else
4097 explicit_link_files[i] = 1;
4098
4099 /* Clear the delete-on-failure queue, deleting the files in it
4100 if this compilation failed. */
4101
4102 if (this_file_error)
4103 {
4104 delete_failure_queue ();
4105 error_count++;
4106 }
4107 /* If this compilation succeeded, don't delete those files later. */
4108 clear_failure_queue ();
4109 }
4110
4111 /* Run ld to link all the compiler output files. */
4112
4113 if (error_count == 0)
4114 {
4115 int tmp = execution_count;
b3865ca9
RS
4116 int i;
4117 int first_time;
4118
4119 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
4120 for collect. */
4121 putenv_from_prefixes (&exec_prefix, "COMPILER_PATH=");
4122 putenv_from_prefixes (&startfile_prefix, "LIBRARY_PATH=");
4123
4124 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4125 the compiler. */
4126 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4127 sizeof ("COLLECT_GCC_OPTIONS=")-1);
4128
4129 first_time = TRUE;
4130 for (i = 0; i < n_switches; i++)
4131 {
4132 char **args;
4133 if (!first_time)
4134 obstack_grow (&collect_obstack, " ", 1);
4135
4136 first_time = FALSE;
4137 obstack_grow (&collect_obstack, "-", 1);
4138 obstack_grow (&collect_obstack, switches[i].part1,
4139 strlen (switches[i].part1));
4140
4141 for (args = switches[i].args; args && *args; args++)
4142 {
4143 obstack_grow (&collect_obstack, " ", 1);
4144 obstack_grow (&collect_obstack, *args, strlen (*args));
4145 }
4146 }
4147 obstack_grow (&collect_obstack, "\0", 1);
4148 putenv (obstack_finish (&collect_obstack));
4149
ed1f651b
RS
4150 value = do_spec (link_command_spec);
4151 if (value < 0)
4152 error_count = 1;
4153 linker_was_run = (tmp != execution_count);
4154 }
4155
4156 /* Warn if a -B option was specified but the prefix was never used. */
4157 unused_prefix_warnings (&exec_prefix);
4158 unused_prefix_warnings (&startfile_prefix);
4159
4160 /* If options said don't run linker,
4161 complain about input files to be given to the linker. */
4162
4163 if (! linker_was_run && error_count == 0)
4164 for (i = 0; i < n_infiles; i++)
4165 if (explicit_link_files[i])
4166 error ("%s: linker input file unused since linking not done",
4167 outfiles[i]);
4168
4169 /* Delete some or all of the temporary files we made. */
4170
4171 if (error_count)
4172 delete_failure_queue ();
4173 delete_temp_files ();
4174
3b9b4d3f 4175 exit (error_count > 0 ? (signal_count ? 2 : 1) : 0);
ed1f651b
RS
4176 /* NOTREACHED */
4177 return 0;
4178}
4179
4180/* Find the proper compilation spec for the file name NAME,
004fd4d5 4181 whose length is LENGTH. LANGUAGE is the specified language,
ed1f651b
RS
4182 or 0 if none specified. */
4183
4184static struct compiler *
4185lookup_compiler (name, length, language)
4186 char *name;
4187 int length;
4188 char *language;
4189{
4190 struct compiler *cp;
4191
4192 /* Look for the language, if one is spec'd. */
4193 if (language != 0)
4194 {
4195 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
4196 {
4197 if (language != 0)
4198 {
4199 if (cp->suffix[0] == '@'
4200 && !strcmp (cp->suffix + 1, language))
4201 return cp;
4202 }
4203 }
4204 error ("language %s not recognized", language);
4205 }
4206
4207 /* Look for a suffix. */
4208 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
4209 {
4cf3301c
RS
4210 if (/* The suffix `-' matches only the file name `-'. */
4211 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
4212 ||
4213 (strlen (cp->suffix) < length
4214 /* See if the suffix matches the end of NAME. */
4215 && !strcmp (cp->suffix,
4216 name + length - strlen (cp->suffix))))
ed1f651b 4217 {
ec32609a 4218 if (cp->spec[0][0] == '@')
ed1f651b
RS
4219 {
4220 struct compiler *new;
4221 /* An alias entry maps a suffix to a language.
4222 Search for the language; pass 0 for NAME and LENGTH
4223 to avoid infinite recursion if language not found.
4224 Construct the new compiler spec. */
ec32609a 4225 language = cp->spec[0] + 1;
ed1f651b
RS
4226 new = (struct compiler *) xmalloc (sizeof (struct compiler));
4227 new->suffix = cp->suffix;
ec32609a
RS
4228 bcopy (lookup_compiler (NULL_PTR, 0, language)->spec,
4229 new->spec, sizeof new->spec);
ed1f651b
RS
4230 return new;
4231 }
4232 /* A non-alias entry: return it. */
4233 return cp;
4234 }
4235 }
4236
4237 return 0;
4238}
4239\f
4240char *
4241xmalloc (size)
4242 unsigned size;
4243{
4244 register char *value = (char *) malloc (size);
4245 if (value == 0)
4246 fatal ("virtual memory exhausted");
4247 return value;
4248}
4249
4250char *
4251xrealloc (ptr, size)
4252 char *ptr;
4253 unsigned size;
4254{
4255 register char *value = (char *) realloc (ptr, size);
4256 if (value == 0)
4257 fatal ("virtual memory exhausted");
4258 return value;
4259}
4260
4261/* Return a newly-allocated string whose contents concatenate those of s1, s2, s3. */
4262
4263static char *
4264concat (s1, s2, s3)
4265 char *s1, *s2, *s3;
4266{
4267 int len1 = strlen (s1), len2 = strlen (s2), len3 = strlen (s3);
4268 char *result = xmalloc (len1 + len2 + len3 + 1);
4269
4270 strcpy (result, s1);
4271 strcpy (result + len1, s2);
4272 strcpy (result + len1 + len2, s3);
4273 *(result + len1 + len2 + len3) = 0;
4274
4275 return result;
4276}
4277
4278static char *
4279save_string (s, len)
4280 char *s;
4281 int len;
4282{
4283 register char *result = xmalloc (len + 1);
4284
4285 bcopy (s, result, len);
4286 result[len] = 0;
4287 return result;
4288}
4289
4290static void
4291pfatal_with_name (name)
4292 char *name;
4293{
4294 char *s;
4295
4296 if (errno < sys_nerr)
4297 s = concat ("%s: ", sys_errlist[errno], "");
4298 else
4299 s = "cannot open %s";
4300 fatal (s, name);
4301}
4302
4303static void
4304perror_with_name (name)
4305 char *name;
4306{
4307 char *s;
4308
4309 if (errno < sys_nerr)
4310 s = concat ("%s: ", sys_errlist[errno], "");
4311 else
4312 s = "cannot open %s";
4313 error (s, name);
4314}
4315
4316static void
4317perror_exec (name)
4318 char *name;
4319{
4320 char *s;
4321
4322 if (errno < sys_nerr)
4323 s = concat ("installation problem, cannot exec %s: ",
4324 sys_errlist[errno], "");
4325 else
4326 s = "installation problem, cannot exec %s";
4327 error (s, name);
4328}
4329
4330/* More 'friendly' abort that prints the line and file.
4331 config.h can #define abort fancy_abort if you like that sort of thing. */
4332
4333void
4334fancy_abort ()
4335{
4336 fatal ("Internal gcc abort.");
4337}
4338\f
4339#ifdef HAVE_VPRINTF
4340
4341/* Output an error message and exit */
4342
4343static void
4f90e4a0 4344fatal VPROTO((char *format, ...))
ed1f651b 4345{
4f90e4a0 4346#ifndef __STDC__
ed1f651b 4347 char *format;
4f90e4a0
RK
4348#endif
4349 va_list ap;
4350
4351 VA_START (ap, format);
4352
4353#ifndef __STDC__
4354 format = va_arg (ap, char*);
4355#endif
ed1f651b 4356
ed1f651b
RS
4357 fprintf (stderr, "%s: ", programname);
4358 vfprintf (stderr, format, ap);
4359 va_end (ap);
4360 fprintf (stderr, "\n");
4361 delete_temp_files ();
4362 exit (1);
4363}
4364
4365static void
4f90e4a0 4366error VPROTO((char *format, ...))
ed1f651b 4367{
4f90e4a0 4368#ifndef __STDC__
ed1f651b 4369 char *format;
4f90e4a0
RK
4370#endif
4371 va_list ap;
4372
4373 VA_START (ap, format);
4374
4375#ifndef __STDC__
4376 format = va_arg (ap, char*);
4377#endif
ed1f651b 4378
ed1f651b
RS
4379 fprintf (stderr, "%s: ", programname);
4380 vfprintf (stderr, format, ap);
4381 va_end (ap);
4382
4383 fprintf (stderr, "\n");
4384}
4385
4386#else /* not HAVE_VPRINTF */
4387
4388static void
4389fatal (msg, arg1, arg2)
4390 char *msg, *arg1, *arg2;
4391{
4392 error (msg, arg1, arg2);
4393 delete_temp_files ();
4394 exit (1);
4395}
4396
4397static void
4398error (msg, arg1, arg2)
4399 char *msg, *arg1, *arg2;
4400{
4401 fprintf (stderr, "%s: ", programname);
4402 fprintf (stderr, msg, arg1, arg2);
4403 fprintf (stderr, "\n");
4404}
4405
4406#endif /* not HAVE_VPRINTF */
4407
4408\f
4409static void
4410validate_all_switches ()
4411{
4412 struct compiler *comp;
4413 register char *p;
4414 register char c;
b3865ca9 4415 struct spec_list *spec;
ed1f651b 4416
ec32609a 4417 for (comp = compilers; comp->spec[0]; comp++)
ed1f651b 4418 {
ec32609a 4419 int i;
20eec2c2 4420 for (i = 0; i < sizeof comp->spec / sizeof comp->spec[0] && comp->spec[i]; i++)
ec32609a
RS
4421 {
4422 p = comp->spec[i];
4423 while (c = *p++)
4424 if (c == '%' && *p == '{')
4425 /* We have a switch spec. */
4426 validate_switches (p + 1);
4427 }
ed1f651b
RS
4428 }
4429
b3865ca9 4430 /* look through the linked list of extra specs read from the specs file */
ec32609a 4431 for (spec = specs; spec ; spec = spec->next)
b3865ca9
RS
4432 {
4433 p = spec->spec;
4434 while (c = *p++)
4435 if (c == '%' && *p == '{')
4436 /* We have a switch spec. */
4437 validate_switches (p + 1);
4438 }
4439
ed1f651b
RS
4440 p = link_command_spec;
4441 while (c = *p++)
4442 if (c == '%' && *p == '{')
4443 /* We have a switch spec. */
4444 validate_switches (p + 1);
4445
4446 /* Now notice switches mentioned in the machine-specific specs. */
4447
4448 p = asm_spec;
4449 while (c = *p++)
4450 if (c == '%' && *p == '{')
4451 /* We have a switch spec. */
4452 validate_switches (p + 1);
4453
4454 p = asm_final_spec;
4455 while (c = *p++)
4456 if (c == '%' && *p == '{')
4457 /* We have a switch spec. */
4458 validate_switches (p + 1);
4459
4460 p = cpp_spec;
4461 while (c = *p++)
4462 if (c == '%' && *p == '{')
4463 /* We have a switch spec. */
4464 validate_switches (p + 1);
4465
4466 p = signed_char_spec;
4467 while (c = *p++)
4468 if (c == '%' && *p == '{')
4469 /* We have a switch spec. */
4470 validate_switches (p + 1);
4471
4472 p = cc1_spec;
4473 while (c = *p++)
4474 if (c == '%' && *p == '{')
4475 /* We have a switch spec. */
4476 validate_switches (p + 1);
4477
4478 p = cc1plus_spec;
4479 while (c = *p++)
4480 if (c == '%' && *p == '{')
4481 /* We have a switch spec. */
4482 validate_switches (p + 1);
4483
4484 p = link_spec;
4485 while (c = *p++)
4486 if (c == '%' && *p == '{')
4487 /* We have a switch spec. */
4488 validate_switches (p + 1);
4489
4490 p = lib_spec;
4491 while (c = *p++)
4492 if (c == '%' && *p == '{')
4493 /* We have a switch spec. */
4494 validate_switches (p + 1);
4495
4496 p = startfile_spec;
4497 while (c = *p++)
4498 if (c == '%' && *p == '{')
4499 /* We have a switch spec. */
4500 validate_switches (p + 1);
4501}
4502
4503/* Look at the switch-name that comes after START
4504 and mark as valid all supplied switches that match it. */
4505
4506static void
4507validate_switches (start)
4508 char *start;
4509{
4510 register char *p = start;
4511 char *filter;
4512 register int i;
4513 int suffix = 0;
4514
4515 if (*p == '|')
4516 ++p;
4517
4518 if (*p == '!')
4519 ++p;
4520
4521 if (*p == '.')
4522 suffix = 1, ++p;
4523
4524 filter = p;
4525 while (*p != ':' && *p != '}') p++;
4526
4527 if (suffix)
4528 ;
4529 else if (p[-1] == '*')
4530 {
4531 /* Mark all matching switches as valid. */
4532 --p;
4533 for (i = 0; i < n_switches; i++)
4534 if (!strncmp (switches[i].part1, filter, p - filter))
4535 switches[i].valid = 1;
4536 }
4537 else
4538 {
4539 /* Mark an exact matching switch as valid. */
4540 for (i = 0; i < n_switches; i++)
4541 {
4542 if (!strncmp (switches[i].part1, filter, p - filter)
4543 && switches[i].part1[p - filter] == 0)
4544 switches[i].valid = 1;
4545 }
4546 }
4547}
This page took 0.684934 seconds and 5 git commands to generate.