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