* Various bug fixes.
[make/kirr.git] / main.c
blob35a388bd2417782719f77edda648d9cfcf0337eb
1 /* Argument parsing and main program of GNU Make.
2 Copyright (C) 1988,89,90,91,94,95,96,97,98,99 Free Software Foundation, Inc.
3 This file is part of GNU Make.
5 GNU Make is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2, or (at your option)
8 any later version.
10 GNU Make is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with GNU Make; see the file COPYING. If not, write to
17 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
18 MA 02111-1307, USA. */
20 #include "make.h"
21 #include "dep.h"
22 #include "filedef.h"
23 #include "variable.h"
24 #include "job.h"
25 #include "commands.h"
26 #include "rule.h"
27 #include "debug.h"
28 #include "getopt.h"
30 #include <assert.h>
31 #ifdef _AMIGA
32 # include <dos/dos.h>
33 # include <proto/dos.h>
34 #endif
35 #ifdef WINDOWS32
36 #include <windows.h>
37 #include "pathstuff.h"
38 #endif
39 #if defined(MAKE_JOBSERVER) && defined(HAVE_FCNTL_H)
40 # include <fcntl.h>
41 #endif
43 #ifdef _AMIGA
44 int __stack = 20000; /* Make sure we have 20K of stack space */
45 #endif
47 extern void init_dir PARAMS ((void));
48 extern void remote_setup PARAMS ((void));
49 extern void remote_cleanup PARAMS ((void));
50 extern RETSIGTYPE fatal_error_signal PARAMS ((int sig));
52 extern void print_variable_data_base PARAMS ((void));
53 extern void print_dir_data_base PARAMS ((void));
54 extern void print_rule_data_base PARAMS ((void));
55 extern void print_file_data_base PARAMS ((void));
56 extern void print_vpath_data_base PARAMS ((void));
58 #if defined HAVE_WAITPID || defined HAVE_WAIT3
59 # define HAVE_WAIT_NOHANG
60 #endif
62 #ifndef HAVE_UNISTD_H
63 extern int chdir ();
64 #endif
65 #ifndef STDC_HEADERS
66 # ifndef sun /* Sun has an incorrect decl in a header. */
67 extern void exit PARAMS ((int)) __attribute__ ((noreturn));
68 # endif
69 extern double atof ();
70 #endif
72 static void print_data_base PARAMS ((void));
73 static void print_version PARAMS ((void));
74 static void decode_switches PARAMS ((int argc, char **argv, int env));
75 static void decode_env_switches PARAMS ((char *envar, unsigned int len));
76 static void define_makeflags PARAMS ((int all, int makefile));
77 static char *quote_for_env PARAMS ((char *out, char *in));
79 /* The structure that describes an accepted command switch. */
81 struct command_switch
83 int c; /* The switch character. */
85 enum /* Type of the value. */
87 flag, /* Turn int flag on. */
88 flag_off, /* Turn int flag off. */
89 string, /* One string per switch. */
90 positive_int, /* A positive integer. */
91 floating, /* A floating-point number (double). */
92 ignore /* Ignored. */
93 } type;
95 char *value_ptr; /* Pointer to the value-holding variable. */
97 unsigned int env:1; /* Can come from MAKEFLAGS. */
98 unsigned int toenv:1; /* Should be put in MAKEFLAGS. */
99 unsigned int no_makefile:1; /* Don't propagate when remaking makefiles. */
101 char *noarg_value; /* Pointer to value used if no argument is given. */
102 char *default_value;/* Pointer to default value. */
104 char *long_name; /* Long option name. */
105 char *argdesc; /* Descriptive word for argument. */
106 char *description; /* Description for usage message. */
107 /* 0 means internal; don't display help. */
110 /* True if C is a switch value that corresponds to a short option. */
112 #define short_option(c) ((c) <= CHAR_MAX)
114 /* The structure used to hold the list of strings given
115 in command switches of a type that takes string arguments. */
117 struct stringlist
119 char **list; /* Nil-terminated list of strings. */
120 unsigned int idx; /* Index into above. */
121 unsigned int max; /* Number of pointers allocated. */
125 /* The recognized command switches. */
127 /* Nonzero means do not print commands to be executed (-s). */
129 int silent_flag;
131 /* Nonzero means just touch the files
132 that would appear to need remaking (-t) */
134 int touch_flag;
136 /* Nonzero means just print what commands would need to be executed,
137 don't actually execute them (-n). */
139 int just_print_flag;
141 /* Print debugging info (--debug). */
143 static struct stringlist *db_flags;
144 static int debug_flag = 0;
146 int db_level = 0;
148 #ifdef WINDOWS32
149 /* Suspend make in main for a short time to allow debugger to attach */
151 int suspend_flag = 0;
152 #endif
154 /* Environment variables override makefile definitions. */
156 int env_overrides = 0;
158 /* Nonzero means ignore status codes returned by commands
159 executed to remake files. Just treat them all as successful (-i). */
161 int ignore_errors_flag = 0;
163 /* Nonzero means don't remake anything, just print the data base
164 that results from reading the makefile (-p). */
166 int print_data_base_flag = 0;
168 /* Nonzero means don't remake anything; just return a nonzero status
169 if the specified targets are not up to date (-q). */
171 int question_flag = 0;
173 /* Nonzero means do not use any of the builtin rules (-r) / variables (-R). */
175 int no_builtin_rules_flag = 0;
176 int no_builtin_variables_flag = 0;
178 /* Nonzero means keep going even if remaking some file fails (-k). */
180 int keep_going_flag;
181 int default_keep_going_flag = 0;
183 /* Nonzero means print directory before starting and when done (-w). */
185 int print_directory_flag = 0;
187 /* Nonzero means ignore print_directory_flag and never print the directory.
188 This is necessary because print_directory_flag is set implicitly. */
190 int inhibit_print_directory_flag = 0;
192 /* Nonzero means print version information. */
194 int print_version_flag = 0;
196 /* List of makefiles given with -f switches. */
198 static struct stringlist *makefiles = 0;
200 /* Number of job slots (commands that can be run at once). */
202 unsigned int job_slots = 1;
203 unsigned int default_job_slots = 1;
205 /* Value of job_slots that means no limit. */
207 static unsigned int inf_jobs = 0;
209 /* File descriptors for the jobs pipe. */
211 static struct stringlist *jobserver_fds = 0;
213 int job_fds[2] = { -1, -1 };
214 int job_rfd = -1;
216 /* Maximum load average at which multiple jobs will be run.
217 Negative values mean unlimited, while zero means limit to
218 zero load (which could be useful to start infinite jobs remotely
219 but one at a time locally). */
220 #ifndef NO_FLOAT
221 double max_load_average = -1.0;
222 double default_load_average = -1.0;
223 #else
224 int max_load_average = -1;
225 int default_load_average = -1;
226 #endif
228 /* List of directories given with -C switches. */
230 static struct stringlist *directories = 0;
232 /* List of include directories given with -I switches. */
234 static struct stringlist *include_directories = 0;
236 /* List of files given with -o switches. */
238 static struct stringlist *old_files = 0;
240 /* List of files given with -W switches. */
242 static struct stringlist *new_files = 0;
244 /* If nonzero, we should just print usage and exit. */
246 static int print_usage_flag = 0;
248 /* If nonzero, we should print a warning message
249 for each reference to an undefined variable. */
251 int warn_undefined_variables_flag;
253 /* The table of command switches. */
255 static const struct command_switch switches[] =
257 { 'b', ignore, 0, 0, 0, 0, 0, 0,
258 0, 0,
259 N_("Ignored for compatibility") },
260 { 'C', string, (char *) &directories, 0, 0, 0, 0, 0,
261 "directory", N_("DIRECTORY"),
262 N_("Change to DIRECTORY before doing anything") },
263 { 'd', flag, (char *) &debug_flag, 1, 1, 0, 0, 0,
264 0, 0,
265 N_("Print lots of debugging information") },
266 { CHAR_MAX+1, string, (char *) &db_flags, 1, 1, 0,
267 "basic", 0,
268 "debug", N_("FLAGS"),
269 N_("Print various types of debugging information") },
270 #ifdef WINDOWS32
271 { 'D', flag, (char *) &suspend_flag, 1, 1, 0, 0, 0,
272 "suspend-for-debug", 0,
273 N_("Suspend process to allow a debugger to attach") },
274 #endif
275 { 'e', flag, (char *) &env_overrides, 1, 1, 0, 0, 0,
276 "environment-overrides", 0,
277 N_("Environment variables override makefiles") },
278 { 'f', string, (char *) &makefiles, 0, 0, 0, 0, 0,
279 "file", N_("FILE"),
280 N_("Read FILE as a makefile") },
281 { 'h', flag, (char *) &print_usage_flag, 0, 0, 0, 0, 0,
282 "help", 0,
283 N_("Print this message and exit") },
284 { 'i', flag, (char *) &ignore_errors_flag, 1, 1, 0, 0, 0,
285 "ignore-errors", 0,
286 N_("Ignore errors from commands") },
287 { 'I', string, (char *) &include_directories, 1, 1, 0, 0, 0,
288 "include-dir", N_("DIRECTORY"),
289 N_("Search DIRECTORY for included makefiles") },
290 { 'j',
291 positive_int, (char *) &job_slots, 1, 1, 0,
292 (char *) &inf_jobs, (char *) &default_job_slots,
293 "jobs", "N",
294 N_("Allow N jobs at once; infinite jobs with no arg") },
295 { CHAR_MAX+2, string, (char *) &jobserver_fds, 1, 1, 0, 0, 0,
296 "jobserver-fds", 0,
297 0 },
298 { 'k', flag, (char *) &keep_going_flag, 1, 1, 0,
299 0, (char *) &default_keep_going_flag,
300 "keep-going", 0,
301 N_("Keep going when some targets can't be made") },
302 #ifndef NO_FLOAT
303 { 'l', floating, (char *) &max_load_average, 1, 1, 0,
304 (char *) &default_load_average, (char *) &default_load_average,
305 "load-average", "N",
306 N_("Don't start multiple jobs unless load is below N") },
307 #else
308 { 'l', positive_int, (char *) &max_load_average, 1, 1, 0,
309 (char *) &default_load_average, (char *) &default_load_average,
310 "load-average", "N",
311 N_("Don't start multiple jobs unless load is below N") },
312 #endif
313 { 'm', ignore, 0, 0, 0, 0, 0, 0,
314 0, 0,
315 "-b" },
316 { 'n', flag, (char *) &just_print_flag, 1, 1, 1, 0, 0,
317 "just-print", 0,
318 N_("Don't actually run any commands; just print them") },
319 { 'o', string, (char *) &old_files, 0, 0, 0, 0, 0,
320 "old-file", N_("FILE"),
321 N_("Consider FILE to be very old and don't remake it") },
322 { 'p', flag, (char *) &print_data_base_flag, 1, 1, 0, 0, 0,
323 "print-data-base", 0,
324 N_("Print make's internal database") },
325 { 'q', flag, (char *) &question_flag, 1, 1, 1, 0, 0,
326 "question", 0,
327 N_("Run no commands; exit status says if up to date") },
328 { 'r', flag, (char *) &no_builtin_rules_flag, 1, 1, 0, 0, 0,
329 "no-builtin-rules", 0,
330 N_("Disable the built-in implicit rules") },
331 { 'R', flag, (char *) &no_builtin_variables_flag, 1, 1, 0, 0, 0,
332 "no-builtin-variables", 0,
333 N_("Disable the built-in variable settings") },
334 { 's', flag, (char *) &silent_flag, 1, 1, 0, 0, 0,
335 "silent", 0,
336 N_("Don't echo commands") },
337 { 'S', flag_off, (char *) &keep_going_flag, 1, 1, 0,
338 0, (char *) &default_keep_going_flag,
339 "no-keep-going", 0,
340 N_("Turns off -k") },
341 { 't', flag, (char *) &touch_flag, 1, 1, 1, 0, 0,
342 "touch", 0,
343 N_("Touch targets instead of remaking them") },
344 { 'v', flag, (char *) &print_version_flag, 1, 1, 0, 0, 0,
345 "version", 0,
346 N_("Print the version number of make and exit") },
347 { 'w', flag, (char *) &print_directory_flag, 1, 1, 0, 0, 0,
348 "print-directory", 0,
349 N_("Print the current directory") },
350 { CHAR_MAX+3, flag, (char *) &inhibit_print_directory_flag, 1, 1, 0, 0, 0,
351 "no-print-directory", 0,
352 N_("Turn off -w, even if it was turned on implicitly") },
353 { 'W', string, (char *) &new_files, 0, 0, 0, 0, 0,
354 "what-if", N_("FILE"),
355 N_("Consider FILE to be infinitely new") },
356 { CHAR_MAX+4, flag, (char *) &warn_undefined_variables_flag, 1, 1, 0, 0, 0,
357 "warn-undefined-variables", 0,
358 N_("Warn when an undefined variable is referenced") },
359 { '\0', }
362 /* Secondary long names for options. */
364 static struct option long_option_aliases[] =
366 { "quiet", no_argument, 0, 's' },
367 { "stop", no_argument, 0, 'S' },
368 { "new-file", required_argument, 0, 'W' },
369 { "assume-new", required_argument, 0, 'W' },
370 { "assume-old", required_argument, 0, 'o' },
371 { "max-load", optional_argument, 0, 'l' },
372 { "dry-run", no_argument, 0, 'n' },
373 { "recon", no_argument, 0, 'n' },
374 { "makefile", required_argument, 0, 'f' },
377 /* The usage message prints the descriptions of options starting in
378 this column. Make sure it leaves enough room for the longest
379 description to fit in less than 80 characters. */
381 #define DESCRIPTION_COLUMN 30
383 /* List of goal targets. */
385 static struct dep *goals, *lastgoal;
387 /* List of variables which were defined on the command line
388 (or, equivalently, in MAKEFLAGS). */
390 struct command_variable
392 struct command_variable *next;
393 struct variable *variable;
395 static struct command_variable *command_variables;
397 /* The name we were invoked with. */
399 char *program;
401 /* Our current directory before processing any -C options. */
403 char *directory_before_chdir;
405 /* Our current directory after processing all -C options. */
407 char *starting_directory;
409 /* Value of the MAKELEVEL variable at startup (or 0). */
411 unsigned int makelevel;
413 /* First file defined in the makefile whose name does not
414 start with `.'. This is the default to remake if the
415 command line does not specify. */
417 struct file *default_goal_file;
419 /* Pointer to structure for the file .DEFAULT
420 whose commands are used for any file that has none of its own.
421 This is zero if the makefiles do not define .DEFAULT. */
423 struct file *default_file;
425 /* Nonzero if we have seen the magic `.POSIX' target.
426 This turns on pedantic compliance with POSIX.2. */
428 int posix_pedantic;
430 /* Nonzero if we have seen the `.NOTPARALLEL' target.
431 This turns off parallel builds for this invocation of make. */
433 int not_parallel;
435 /* Nonzero if some rule detected clock skew; we keep track so (a) we only
436 print one warning about it during the run, and (b) we can print a final
437 warning at the end of the run. */
439 int clock_skew_detected;
441 /* Mask of signals that are being caught with fatal_error_signal. */
443 #ifdef POSIX
444 sigset_t fatal_signal_set;
445 #else
446 #ifdef HAVE_SIGSETMASK
447 int fatal_signal_mask;
448 #endif
449 #endif
451 static struct file *
452 enter_command_line_file (name)
453 char *name;
455 if (name[0] == '\0')
456 fatal (NILF, _("empty string invalid as file name"));
458 if (name[0] == '~')
460 char *expanded = tilde_expand (name);
461 if (expanded != 0)
462 name = expanded; /* Memory leak; I don't care. */
465 /* This is also done in parse_file_seq, so this is redundant
466 for names read from makefiles. It is here for names passed
467 on the command line. */
468 while (name[0] == '.' && name[1] == '/' && name[2] != '\0')
470 name += 2;
471 while (*name == '/')
472 /* Skip following slashes: ".//foo" is "foo", not "/foo". */
473 ++name;
476 if (*name == '\0')
478 /* It was all slashes! Move back to the dot and truncate
479 it after the first slash, so it becomes just "./". */
481 --name;
482 while (name[0] != '.');
483 name[2] = '\0';
486 return enter_file (xstrdup (name));
489 /* Toggle -d on receipt of SIGUSR1. */
491 static RETSIGTYPE
492 debug_signal_handler (sig)
493 int sig;
495 db_level = db_level ? DB_NONE : DB_BASIC;
498 static void
499 decode_debug_flags ()
501 char **pp;
503 if (debug_flag)
504 db_level = DB_ALL;
506 if (!db_flags)
507 return;
509 for (pp=db_flags->list; *pp; ++pp)
511 const char *p = *pp;
513 while (1)
515 switch (tolower (p[0]))
517 case 'a':
518 db_level |= DB_ALL;
519 break;
520 case 'b':
521 db_level |= DB_BASIC;
522 break;
523 case 'i':
524 db_level |= DB_BASIC | DB_IMPLICIT;
525 break;
526 case 'j':
527 db_level |= DB_JOBS;
528 break;
529 case 'm':
530 db_level |= DB_BASIC | DB_MAKEFILES;
531 break;
532 case 'v':
533 db_level |= DB_BASIC | DB_VERBOSE;
534 break;
535 default:
536 fatal (NILF, _("unknown debug level specification `%s'"), p);
539 while (*(++p) != '\0')
540 if (*p == ',' || *p == ' ')
541 break;
543 if (*p == '\0')
544 break;
546 ++p;
551 #ifdef WINDOWS32
553 * HANDLE runtime exceptions by avoiding a requestor on the GUI. Capture
554 * exception and print it to stderr instead.
556 * If ! DB_VERBOSE, just print a simple message and exit.
557 * If DB_VERBOSE, print a more verbose message.
558 * If compiled for DEBUG, let exception pass through to GUI so that
559 * debuggers can attach.
561 LONG WINAPI
562 handle_runtime_exceptions( struct _EXCEPTION_POINTERS *exinfo )
564 PEXCEPTION_RECORD exrec = exinfo->ExceptionRecord;
565 LPSTR cmdline = GetCommandLine();
566 LPSTR prg = strtok(cmdline, " ");
567 CHAR errmsg[1024];
568 #ifdef USE_EVENT_LOG
569 HANDLE hEventSource;
570 LPTSTR lpszStrings[1];
571 #endif
573 if (! ISDB (DB_VERBOSE))
575 sprintf(errmsg,
576 _("%s: Interrupt/Exception caught (code = 0x%x, addr = 0x%x)\n"),
577 prg, exrec->ExceptionCode, exrec->ExceptionAddress);
578 fprintf(stderr, errmsg);
579 exit(255);
582 sprintf(errmsg,
583 _("\nUnhandled exception filter called from program %s\nExceptionCode = %x\nExceptionFlags = %x\nExceptionAddress = %x\n"),
584 prg, exrec->ExceptionCode, exrec->ExceptionFlags,
585 exrec->ExceptionAddress);
587 if (exrec->ExceptionCode == EXCEPTION_ACCESS_VIOLATION
588 && exrec->NumberParameters >= 2)
589 sprintf(&errmsg[strlen(errmsg)],
590 (exrec->ExceptionInformation[0]
591 ? _("Access violation: write operation at address %x\n")
592 : _("Access violation: read operation at address %x\n")),
593 exrec->ExceptionInformation[1]);
595 /* turn this on if we want to put stuff in the event log too */
596 #ifdef USE_EVENT_LOG
597 hEventSource = RegisterEventSource(NULL, "GNU Make");
598 lpszStrings[0] = errmsg;
600 if (hEventSource != NULL)
602 ReportEvent(hEventSource, /* handle of event source */
603 EVENTLOG_ERROR_TYPE, /* event type */
604 0, /* event category */
605 0, /* event ID */
606 NULL, /* current user's SID */
607 1, /* strings in lpszStrings */
608 0, /* no bytes of raw data */
609 lpszStrings, /* array of error strings */
610 NULL); /* no raw data */
612 (VOID) DeregisterEventSource(hEventSource);
614 #endif
616 /* Write the error to stderr too */
617 fprintf(stderr, errmsg);
619 #ifdef DEBUG
620 return EXCEPTION_CONTINUE_SEARCH;
621 #else
622 exit(255);
623 return (255); /* not reached */
624 #endif
628 * On WIN32 systems we don't have the luxury of a /bin directory that
629 * is mapped globally to every drive mounted to the system. Since make could
630 * be invoked from any drive, and we don't want to propogate /bin/sh
631 * to every single drive. Allow ourselves a chance to search for
632 * a value for default shell here (if the default path does not exist).
636 find_and_set_default_shell(char *token)
638 int sh_found = 0;
639 char* search_token;
640 PATH_VAR(sh_path);
641 extern char *default_shell;
643 if (!token)
644 search_token = default_shell;
645 else
646 search_token = token;
648 if (!no_default_sh_exe &&
649 (token == NULL || !strcmp(search_token, default_shell))) {
650 /* no new information, path already set or known */
651 sh_found = 1;
652 } else if (file_exists_p(search_token)) {
653 /* search token path was found */
654 sprintf(sh_path, "%s", search_token);
655 default_shell = xstrdup(w32ify(sh_path,0));
656 DB (DB_VERBOSE,
657 (_("find_and_set_shell setting default_shell = %s\n"), default_shell));
658 sh_found = 1;
659 } else {
660 char *p;
661 struct variable *v = lookup_variable ("Path", 4);
664 * Search Path for shell
666 if (v && v->value) {
667 char *ep;
669 p = v->value;
670 ep = strchr(p, PATH_SEPARATOR_CHAR);
672 while (ep && *ep) {
673 *ep = '\0';
675 if (dir_file_exists_p(p, search_token)) {
676 sprintf(sh_path, "%s/%s", p, search_token);
677 default_shell = xstrdup(w32ify(sh_path,0));
678 sh_found = 1;
679 *ep = PATH_SEPARATOR_CHAR;
681 /* terminate loop */
682 p += strlen(p);
683 } else {
684 *ep = PATH_SEPARATOR_CHAR;
685 p = ++ep;
688 ep = strchr(p, PATH_SEPARATOR_CHAR);
691 /* be sure to check last element of Path */
692 if (p && *p && dir_file_exists_p(p, search_token)) {
693 sprintf(sh_path, "%s/%s", p, search_token);
694 default_shell = xstrdup(w32ify(sh_path,0));
695 sh_found = 1;
698 if (sh_found)
699 DB (DB_VERBOSE,
700 (_("find_and_set_shell path search set default_shell = %s\n"),
701 default_shell));
705 /* naive test */
706 if (!unixy_shell && sh_found &&
707 (strstr(default_shell, "sh") || strstr(default_shell, "SH"))) {
708 unixy_shell = 1;
709 batch_mode_shell = 0;
712 #ifdef BATCH_MODE_ONLY_SHELL
713 batch_mode_shell = 1;
714 #endif
716 return (sh_found);
718 #endif /* WINDOWS32 */
720 #ifdef __MSDOS__
722 static void
723 msdos_return_to_initial_directory ()
725 if (directory_before_chdir)
726 chdir (directory_before_chdir);
728 #endif
730 extern char *mktemp ();
731 extern int mkstemp ();
733 FILE *
734 open_tmpfile(name, template)
735 char **name;
736 const char *template;
738 int fd;
740 #if defined HAVE_MKSTEMP || defined HAVE_MKTEMP
741 # define TEMPLATE_LEN strlen (template)
742 #else
743 # define TEMPLATE_LEN L_tmpnam
744 #endif
745 *name = xmalloc (TEMPLATE_LEN + 1);
746 strcpy (*name, template);
748 #if defined HAVE_MKSTEMP && defined HAVE_FDOPEN
749 /* It's safest to use mkstemp(), if we can. */
750 fd = mkstemp (*name);
751 if (fd == -1)
752 return 0;
753 return fdopen (fd, "w");
754 #else
755 # ifdef HAVE_MKTEMP
756 (void) mktemp (*name);
757 # else
758 (void) tmpnam (*name);
759 # endif
761 # ifdef HAVE_FDOPEN
762 /* Can't use mkstemp(), but guard against a race condition. */
763 fd = open (*name, O_CREAT|O_EXCL|O_WRONLY, 0600);
764 if (fd == -1)
765 return 0;
766 return fdopen (fd, "w");
767 # else
768 /* Not secure, but what can we do? */
769 return fopen (*name, "w");
770 # endif
771 #endif
775 #ifndef _AMIGA
777 main (argc, argv, envp)
778 int argc;
779 char **argv;
780 char **envp;
781 #else
782 int main (int argc, char ** argv)
783 #endif
785 static char *stdin_nm = 0;
786 register struct file *f;
787 register unsigned int i;
788 char **p;
789 struct dep *read_makefiles;
790 PATH_VAR (current_directory);
791 #ifdef WINDOWS32
792 char *unix_path = NULL;
793 char *windows32_path = NULL;
795 SetUnhandledExceptionFilter(handle_runtime_exceptions);
797 /* start off assuming we have no shell */
798 unixy_shell = 0;
799 no_default_sh_exe = 1;
800 #endif
802 default_goal_file = 0;
803 reading_file = 0;
805 #if defined (__MSDOS__) && !defined (_POSIX_SOURCE)
806 /* Request the most powerful version of `system', to
807 make up for the dumb default shell. */
808 __system_flags = (__system_redirect
809 | __system_use_shell
810 | __system_allow_multiple_cmds
811 | __system_allow_long_cmds
812 | __system_handle_null_commands
813 | __system_emulate_chdir);
815 #endif
817 /* Set up gettext/internationalization support. */
818 setlocale (LC_ALL, "");
819 bindtextdomain (PACKAGE, LOCALEDIR);
820 textdomain (PACKAGE);
822 #if !defined (HAVE_STRSIGNAL) && !defined (HAVE_SYS_SIGLIST)
824 extern void signame_init ();
825 signame_init ();
827 #endif
829 #ifdef POSIX
830 sigemptyset (&fatal_signal_set);
831 #define ADD_SIG(sig) sigaddset (&fatal_signal_set, sig)
832 #else
833 #ifdef HAVE_SIGSETMASK
834 fatal_signal_mask = 0;
835 #define ADD_SIG(sig) fatal_signal_mask |= sigmask (sig)
836 #else
837 #define ADD_SIG(sig)
838 #endif
839 #endif
841 #define FATAL_SIG(sig) \
842 if (signal ((sig), fatal_error_signal) == SIG_IGN) \
843 (void) signal ((sig), SIG_IGN); \
844 else \
845 ADD_SIG (sig);
847 #ifdef SIGHUP
848 FATAL_SIG (SIGHUP);
849 #endif
850 #ifdef SIGQUIT
851 FATAL_SIG (SIGQUIT);
852 #endif
853 FATAL_SIG (SIGINT);
854 FATAL_SIG (SIGTERM);
856 #ifdef SIGDANGER
857 FATAL_SIG (SIGDANGER);
858 #endif
859 #ifdef SIGXCPU
860 FATAL_SIG (SIGXCPU);
861 #endif
862 #ifdef SIGXFSZ
863 FATAL_SIG (SIGXFSZ);
864 #endif
866 #undef FATAL_SIG
868 /* Do not ignore the child-death signal. This must be done before
869 any children could possibly be created; otherwise, the wait
870 functions won't work on systems with the SVR4 ECHILD brain
871 damage, if our invoker is ignoring this signal. */
873 #ifdef HAVE_WAIT_NOHANG
874 # if defined SIGCHLD
875 (void) signal (SIGCHLD, SIG_DFL);
876 # endif
877 # if defined SIGCLD && SIGCLD != SIGCHLD
878 (void) signal (SIGCLD, SIG_DFL);
879 # endif
880 #endif
882 /* Make sure stdout is line-buffered. */
884 #ifdef HAVE_SETLINEBUF
885 setlinebuf (stdout);
886 #else
887 #ifndef SETVBUF_REVERSED
888 setvbuf (stdout, (char *) 0, _IOLBF, BUFSIZ);
889 #else /* setvbuf not reversed. */
890 /* Some buggy systems lose if we pass 0 instead of allocating ourselves. */
891 setvbuf (stdout, _IOLBF, xmalloc (BUFSIZ), BUFSIZ);
892 #endif /* setvbuf reversed. */
893 #endif /* setlinebuf missing. */
895 /* Figure out where this program lives. */
897 if (argv[0] == 0)
898 argv[0] = "";
899 if (argv[0][0] == '\0')
900 program = "make";
901 else
903 #ifdef VMS
904 program = strrchr (argv[0], ']');
905 #else
906 program = strrchr (argv[0], '/');
907 #endif
908 #ifdef __MSDOS__
909 if (program == 0)
910 program = strrchr (argv[0], '\\');
911 else
913 /* Some weird environments might pass us argv[0] with
914 both kinds of slashes; we must find the rightmost. */
915 char *p = strrchr (argv[0], '\\');
916 if (p && p > program)
917 program = p;
919 if (program == 0 && argv[0][1] == ':')
920 program = argv[0] + 1;
921 #endif
922 if (program == 0)
923 program = argv[0];
924 else
925 ++program;
928 /* Set up to access user data (files). */
929 user_access ();
931 /* Figure out where we are. */
933 #ifdef WINDOWS32
934 if (getcwd_fs (current_directory, GET_PATH_MAX) == 0)
935 #else
936 if (getcwd (current_directory, GET_PATH_MAX) == 0)
937 #endif
939 #ifdef HAVE_GETCWD
940 perror_with_name ("getcwd: ", "");
941 #else
942 error (NILF, "getwd: %s", current_directory);
943 #endif
944 current_directory[0] = '\0';
945 directory_before_chdir = 0;
947 else
948 directory_before_chdir = xstrdup (current_directory);
949 #ifdef __MSDOS__
950 /* Make sure we will return to the initial directory, come what may. */
951 atexit (msdos_return_to_initial_directory);
952 #endif
954 /* Read in variables from the environment. It is important that this be
955 done before $(MAKE) is figured out so its definitions will not be
956 from the environment. */
958 #ifndef _AMIGA
959 for (i = 0; envp[i] != 0; ++i)
961 int do_not_define;
962 register char *ep = envp[i];
964 /* by default, everything gets defined and exported */
965 do_not_define = 0;
967 while (*ep != '=')
968 ++ep;
969 #ifdef WINDOWS32
970 if (!unix_path && strneq(envp[i], "PATH=", 5))
971 unix_path = ep+1;
972 else if (!windows32_path && !strnicmp(envp[i], "Path=", 5)) {
973 do_not_define = 1; /* it gets defined after loop exits */
974 windows32_path = ep+1;
976 #endif
977 /* The result of pointer arithmetic is cast to unsigned int for
978 machines where ptrdiff_t is a different size that doesn't widen
979 the same. */
980 if (!do_not_define)
981 define_variable (envp[i], (unsigned int) (ep - envp[i]),
982 ep + 1, o_env, 1)
983 /* Force exportation of every variable culled from the environment.
984 We used to rely on target_environment's v_default code to do this.
985 But that does not work for the case where an environment variable
986 is redefined in a makefile with `override'; it should then still
987 be exported, because it was originally in the environment. */
988 ->export = v_export;
990 #ifdef WINDOWS32
992 * Make sure that this particular spelling of 'Path' is available
994 if (windows32_path)
995 define_variable("Path", 4, windows32_path, o_env, 1)->export = v_export;
996 else if (unix_path)
997 define_variable("Path", 4, unix_path, o_env, 1)->export = v_export;
998 else
999 define_variable("Path", 4, "", o_env, 1)->export = v_export;
1002 * PATH defaults to Path iff PATH not found and Path is found.
1004 if (!unix_path && windows32_path)
1005 define_variable("PATH", 4, windows32_path, o_env, 1)->export = v_export;
1006 #endif
1007 #else /* For Amiga, read the ENV: device, ignoring all dirs */
1009 BPTR env, file, old;
1010 char buffer[1024];
1011 int len;
1012 __aligned struct FileInfoBlock fib;
1014 env = Lock ("ENV:", ACCESS_READ);
1015 if (env)
1017 old = CurrentDir (DupLock(env));
1018 Examine (env, &fib);
1020 while (ExNext (env, &fib))
1022 if (fib.fib_DirEntryType < 0) /* File */
1024 /* Define an empty variable. It will be filled in
1025 variable_lookup(). Makes startup quite a bit
1026 faster. */
1027 define_variable (fib.fib_FileName,
1028 strlen (fib.fib_FileName),
1029 "", o_env, 1)->export = v_export;
1032 UnLock (env);
1033 UnLock(CurrentDir(old));
1036 #endif
1038 /* Decode the switches. */
1040 decode_env_switches ("MAKEFLAGS", 9);
1041 #if 0
1042 /* People write things like:
1043 MFLAGS="CC=gcc -pipe" "CFLAGS=-g"
1044 and we set the -p, -i and -e switches. Doesn't seem quite right. */
1045 decode_env_switches ("MFLAGS", 6);
1046 #endif
1047 decode_switches (argc, argv, 0);
1048 #ifdef WINDOWS32
1049 if (suspend_flag) {
1050 fprintf(stderr, "%s (pid = %d)\n", argv[0], GetCurrentProcessId());
1051 fprintf(stderr, _("%s is suspending for 30 seconds..."), argv[0]);
1052 Sleep(30 * 1000);
1053 fprintf(stderr, _("done sleep(30). Continuing.\n"));
1055 #endif
1057 decode_debug_flags ();
1059 /* Print version information. */
1061 if (print_version_flag || print_data_base_flag || db_level)
1062 print_version ();
1064 /* `make --version' is supposed to just print the version and exit. */
1065 if (print_version_flag)
1066 die (0);
1068 #ifndef VMS
1069 /* Set the "MAKE_COMMAND" variable to the name we were invoked with.
1070 (If it is a relative pathname with a slash, prepend our directory name
1071 so the result will run the same program regardless of the current dir.
1072 If it is a name with no slash, we can only hope that PATH did not
1073 find it in the current directory.) */
1074 #ifdef WINDOWS32
1076 * Convert from backslashes to forward slashes for
1077 * programs like sh which don't like them. Shouldn't
1078 * matter if the path is one way or the other for
1079 * CreateProcess().
1081 if (strpbrk(argv[0], "/:\\") ||
1082 strstr(argv[0], "..") ||
1083 strneq(argv[0], "//", 2))
1084 argv[0] = xstrdup(w32ify(argv[0],1));
1085 #else /* WINDOWS32 */
1086 #ifdef __MSDOS__
1087 if (strchr (argv[0], '\\'))
1089 char *p;
1091 argv[0] = xstrdup (argv[0]);
1092 for (p = argv[0]; *p; p++)
1093 if (*p == '\\')
1094 *p = '/';
1096 /* If argv[0] is not in absolute form, prepend the current
1097 directory. This can happen when Make is invoked by another DJGPP
1098 program that uses a non-absolute name. */
1099 if (current_directory[0] != '\0'
1100 && argv[0] != 0
1101 && (argv[0][0] != '/' && (argv[0][0] == '\0' || argv[0][1] != ':')))
1102 argv[0] = concat (current_directory, "/", argv[0]);
1103 #else /* !__MSDOS__ */
1104 if (current_directory[0] != '\0'
1105 && argv[0] != 0 && argv[0][0] != '/' && strchr (argv[0], '/') != 0)
1106 argv[0] = concat (current_directory, "/", argv[0]);
1107 #endif /* !__MSDOS__ */
1108 #endif /* WINDOWS32 */
1109 #endif
1111 /* The extra indirection through $(MAKE_COMMAND) is done
1112 for hysterical raisins. */
1113 (void) define_variable ("MAKE_COMMAND", 12, argv[0], o_default, 0);
1114 (void) define_variable ("MAKE", 4, "$(MAKE_COMMAND)", o_default, 1);
1116 if (command_variables != 0)
1118 struct command_variable *cv;
1119 struct variable *v;
1120 unsigned int len = 0;
1121 char *value, *p;
1123 /* Figure out how much space will be taken up by the command-line
1124 variable definitions. */
1125 for (cv = command_variables; cv != 0; cv = cv->next)
1127 v = cv->variable;
1128 len += 2 * strlen (v->name);
1129 if (! v->recursive)
1130 ++len;
1131 ++len;
1132 len += 2 * strlen (v->value);
1133 ++len;
1136 /* Now allocate a buffer big enough and fill it. */
1137 p = value = (char *) alloca (len);
1138 for (cv = command_variables; cv != 0; cv = cv->next)
1140 v = cv->variable;
1141 p = quote_for_env (p, v->name);
1142 if (! v->recursive)
1143 *p++ = ':';
1144 *p++ = '=';
1145 p = quote_for_env (p, v->value);
1146 *p++ = ' ';
1148 p[-1] = '\0'; /* Kill the final space and terminate. */
1150 /* Define an unchangeable variable with a name that no POSIX.2
1151 makefile could validly use for its own variable. */
1152 (void) define_variable ("-*-command-variables-*-", 23,
1153 value, o_automatic, 0);
1155 /* Define the variable; this will not override any user definition.
1156 Normally a reference to this variable is written into the value of
1157 MAKEFLAGS, allowing the user to override this value to affect the
1158 exported value of MAKEFLAGS. In POSIX-pedantic mode, we cannot
1159 allow the user's setting of MAKEOVERRIDES to affect MAKEFLAGS, so
1160 a reference to this hidden variable is written instead. */
1161 (void) define_variable ("MAKEOVERRIDES", 13,
1162 "${-*-command-variables-*-}", o_env, 1);
1165 /* If there were -C flags, move ourselves about. */
1166 if (directories != 0)
1167 for (i = 0; directories->list[i] != 0; ++i)
1169 char *dir = directories->list[i];
1170 if (dir[0] == '~')
1172 char *expanded = tilde_expand (dir);
1173 if (expanded != 0)
1174 dir = expanded;
1176 if (chdir (dir) < 0)
1177 pfatal_with_name (dir);
1178 if (dir != directories->list[i])
1179 free (dir);
1182 #ifdef WINDOWS32
1184 * THIS BLOCK OF CODE MUST COME AFTER chdir() CALL ABOVE IN ORDER
1185 * TO NOT CONFUSE THE DEPENDENCY CHECKING CODE IN implicit.c.
1187 * The functions in dir.c can incorrectly cache information for "."
1188 * before we have changed directory and this can cause file
1189 * lookups to fail because the current directory (.) was pointing
1190 * at the wrong place when it was first evaluated.
1192 no_default_sh_exe = !find_and_set_default_shell(NULL);
1194 #endif /* WINDOWS32 */
1195 /* Figure out the level of recursion. */
1197 struct variable *v = lookup_variable ("MAKELEVEL", 9);
1198 if (v != 0 && *v->value != '\0' && *v->value != '-')
1199 makelevel = (unsigned int) atoi (v->value);
1200 else
1201 makelevel = 0;
1204 /* Except under -s, always do -w in sub-makes and under -C. */
1205 if (!silent_flag && (directories != 0 || makelevel > 0))
1206 print_directory_flag = 1;
1208 /* Let the user disable that with --no-print-directory. */
1209 if (inhibit_print_directory_flag)
1210 print_directory_flag = 0;
1212 /* If -R was given, set -r too (doesn't make sense otherwise!) */
1213 if (no_builtin_variables_flag)
1214 no_builtin_rules_flag = 1;
1216 /* Construct the list of include directories to search. */
1218 construct_include_path (include_directories == 0 ? (char **) 0
1219 : include_directories->list);
1221 /* Figure out where we are now, after chdir'ing. */
1222 if (directories == 0)
1223 /* We didn't move, so we're still in the same place. */
1224 starting_directory = current_directory;
1225 else
1227 #ifdef WINDOWS32
1228 if (getcwd_fs (current_directory, GET_PATH_MAX) == 0)
1229 #else
1230 if (getcwd (current_directory, GET_PATH_MAX) == 0)
1231 #endif
1233 #ifdef HAVE_GETCWD
1234 perror_with_name ("getcwd: ", "");
1235 #else
1236 error (NILF, "getwd: %s", current_directory);
1237 #endif
1238 starting_directory = 0;
1240 else
1241 starting_directory = current_directory;
1244 (void) define_variable ("CURDIR", 6, current_directory, o_default, 0);
1246 /* Read any stdin makefiles into temporary files. */
1248 if (makefiles != 0)
1250 register unsigned int i;
1251 for (i = 0; i < makefiles->idx; ++i)
1252 if (makefiles->list[i][0] == '-' && makefiles->list[i][1] == '\0')
1254 /* This makefile is standard input. Since we may re-exec
1255 and thus re-read the makefiles, we read standard input
1256 into a temporary file and read from that. */
1257 FILE *outfile;
1258 char *template, *tmpdir;
1260 if (stdin_nm)
1261 fatal (NILF, _("Makefile from standard input specified twice."));
1263 #ifdef VMS
1264 # define DEFAULT_TMPDIR "sys$scratch:"
1265 #else
1266 # ifdef P_tmpdir
1267 # define DEFAULT_TMPDIR P_tmpdir
1268 # else
1269 # define DEFAULT_TMPDIR "/tmp"
1270 # endif
1271 #endif
1272 #define DEFAULT_TMPFILE "GmXXXXXX"
1274 if (((tmpdir = getenv ("TMPDIR")) == NULL || *tmpdir == '\0')
1275 #if defined __MSDOS__ || defined(WINDOWS32)
1276 /* These are also used commonly on these platforms. */
1277 && ((tmpdir = getenv ("TEMP")) == NULL || *tmpdir == '\0')
1278 && ((tmpdir = getenv ("TMP")) == NULL || *tmpdir == '\0')
1279 #endif
1281 tmpdir = DEFAULT_TMPDIR;
1283 template = (char *) alloca (strlen (tmpdir)
1284 + sizeof (DEFAULT_TMPFILE) + 1);
1285 strcpy (template, tmpdir);
1287 #if defined __MSDOS__ || defined(WINDOWS32)
1288 if (strchr ("/\\", template[strlen (template) - 1]) == NULL)
1289 strcat (template, "/");
1290 #else
1291 #ifndef VMS
1292 if (template[strlen (template) - 1] != '/')
1293 strcat (template, "/");
1294 #endif /* !VMS */
1295 #endif /* __MSDOS__ || WINDOWS32 */
1297 strcat (template, DEFAULT_TMPFILE);
1298 outfile = open_tmpfile (&stdin_nm, template);
1299 if (outfile == 0)
1300 pfatal_with_name (_("fopen (temporary file)"));
1301 while (!feof (stdin))
1303 char buf[2048];
1304 unsigned int n = fread (buf, 1, sizeof (buf), stdin);
1305 if (n > 0 && fwrite (buf, 1, n, outfile) != n)
1306 pfatal_with_name (_("fwrite (temporary file)"));
1308 (void) fclose (outfile);
1310 /* Replace the name that read_all_makefiles will
1311 see with the name of the temporary file. */
1312 makefiles->list[i] = xstrdup (stdin_nm);
1314 /* Make sure the temporary file will not be remade. */
1315 f = enter_file (stdin_nm);
1316 f->updated = 1;
1317 f->update_status = 0;
1318 f->command_state = cs_finished;
1319 /* Can't be intermediate, or it'll be removed too early for
1320 make re-exec. */
1321 f->intermediate = 0;
1322 f->dontcare = 0;
1326 #if defined(MAKE_JOBSERVER) || !defined(HAVE_WAIT_NOHANG)
1327 /* Set up to handle children dying. This must be done before
1328 reading in the makefiles so that `shell' function calls will work.
1330 If we don't have a hanging wait we have to fall back to old, broken
1331 functionality here and rely on the signal handler and counting
1332 children.
1334 If we're using the jobs pipe we need a signal handler so that
1335 SIGCHLD is not ignored; we need it to interrupt the read(2) of the
1336 jobserver pipe in job.c if we're waiting for a token.
1338 If none of these are true, we don't need a signal handler at all. */
1340 extern RETSIGTYPE child_handler PARAMS ((int sig));
1342 # if defined HAVE_SIGACTION
1343 struct sigaction sa;
1345 bzero ((char *)&sa, sizeof (struct sigaction));
1346 sa.sa_handler = child_handler;
1347 # if defined SA_INTERRUPT
1348 /* This is supposed to be the default, but what the heck... */
1349 sa.sa_flags = SA_INTERRUPT;
1350 # endif
1351 # define HANDLESIG(s) sigaction (s, &sa, NULL)
1352 # else
1353 # define HANDLESIG(s) signal (s, child_handler)
1354 # endif
1356 /* OK, now actually install the handlers. */
1357 # if defined SIGCHLD
1358 (void) HANDLESIG (SIGCHLD);
1359 # endif
1360 # if defined SIGCLD && SIGCLD != SIGCHLD
1361 (void) HANDLESIG (SIGCLD);
1362 # endif
1364 #endif
1366 /* Let the user send us SIGUSR1 to toggle the -d flag during the run. */
1367 #ifdef SIGUSR1
1368 (void) signal (SIGUSR1, debug_signal_handler);
1369 #endif
1371 /* Define the initial list of suffixes for old-style rules. */
1373 set_default_suffixes ();
1375 /* Define the file rules for the built-in suffix rules. These will later
1376 be converted into pattern rules. We used to do this in
1377 install_default_implicit_rules, but since that happens after reading
1378 makefiles, it results in the built-in pattern rules taking precedence
1379 over makefile-specified suffix rules, which is wrong. */
1381 install_default_suffix_rules ();
1383 /* Define some internal and special variables. */
1385 define_automatic_variables ();
1387 /* Set up the MAKEFLAGS and MFLAGS variables
1388 so makefiles can look at them. */
1390 define_makeflags (0, 0);
1392 /* Define the default variables. */
1393 define_default_variables ();
1395 /* Read all the makefiles. */
1397 default_file = enter_file (".DEFAULT");
1399 read_makefiles
1400 = read_all_makefiles (makefiles == 0 ? (char **) 0 : makefiles->list);
1402 #ifdef WINDOWS32
1403 /* look one last time after reading all Makefiles */
1404 if (no_default_sh_exe)
1405 no_default_sh_exe = !find_and_set_default_shell(NULL);
1407 if (no_default_sh_exe && job_slots != 1) {
1408 error (NILF, _("Do not specify -j or --jobs if sh.exe is not available."));
1409 error (NILF, _("Resetting make for single job mode."));
1410 job_slots = 1;
1412 #endif /* WINDOWS32 */
1414 #ifdef __MSDOS__
1415 /* We need to know what kind of shell we will be using. */
1417 extern int _is_unixy_shell (const char *_path);
1418 struct variable *shv = lookup_variable ("SHELL", 5);
1419 extern int unixy_shell;
1420 extern char *default_shell;
1422 if (shv && *shv->value)
1424 char *shell_path = recursively_expand(shv);
1426 if (shell_path && _is_unixy_shell (shell_path))
1427 unixy_shell = 1;
1428 else
1429 unixy_shell = 0;
1430 if (shell_path)
1431 default_shell = shell_path;
1434 #endif /* __MSDOS__ */
1436 /* Decode switches again, in case the variables were set by the makefile. */
1437 decode_env_switches ("MAKEFLAGS", 9);
1438 #if 0
1439 decode_env_switches ("MFLAGS", 6);
1440 #endif
1442 #ifdef __MSDOS__
1443 if (job_slots != 1)
1445 error (NILF,
1446 _("Parallel jobs (-j) are not supported on this platform."));
1447 error (NILF, _("Resetting to single job (-j1) mode."));
1448 job_slots = 1;
1450 #endif
1452 #ifdef MAKE_JOBSERVER
1453 /* If the jobserver-fds option is seen, make sure that -j is reasonable. */
1455 if (jobserver_fds)
1457 char *cp;
1459 for (i=1; i < jobserver_fds->idx; ++i)
1460 if (!streq (jobserver_fds->list[0], jobserver_fds->list[i]))
1461 fatal (NILF, _("internal error: multiple --jobserver-fds options"));
1463 /* Now parse the fds string and make sure it has the proper format. */
1465 cp = jobserver_fds->list[0];
1467 if (sscanf (cp, "%d,%d", &job_fds[0], &job_fds[1]) != 2)
1468 fatal (NILF,
1469 _("internal error: invalid --jobserver-fds string `%s'"), cp);
1471 /* The combination of a pipe + !job_slots means we're using the
1472 jobserver. If !job_slots and we don't have a pipe, we can start
1473 infinite jobs. If we see both a pipe and job_slots >0 that means the
1474 user set -j explicitly. This is broken; in this case obey the user
1475 (ignore the jobserver pipe for this make) but print a message. */
1477 if (job_slots > 0)
1478 error (NILF,
1479 _("warning: -jN forced in submake: disabling jobserver mode."));
1481 /* Create a duplicate pipe, that will be closed in the SIGCHLD
1482 handler. If this fails with EBADF, the parent has closed the pipe
1483 on us because it didn't think we were a submake. If so, print a
1484 warning then default to -j1. */
1486 else if ((job_rfd = dup (job_fds[0])) < 0)
1488 if (errno != EBADF)
1489 pfatal_with_name (_("dup jobserver"));
1491 error (NILF,
1492 _("warning: jobserver unavailable: using -j1. Add `+' to parent make rule."));
1493 job_slots = 1;
1496 if (job_slots > 0)
1498 close (job_fds[0]);
1499 close (job_fds[1]);
1500 job_fds[0] = job_fds[1] = -1;
1501 free (jobserver_fds->list);
1502 free (jobserver_fds);
1503 jobserver_fds = 0;
1507 /* If we have >1 slot but no jobserver-fds, then we're a top-level make.
1508 Set up the pipe and install the fds option for our children. */
1510 if (job_slots > 1)
1512 char c = '+';
1514 if (pipe (job_fds) < 0 || (job_rfd = dup (job_fds[0])) < 0)
1515 pfatal_with_name (_("creating jobs pipe"));
1517 /* Every make assumes that it always has one job it can run. For the
1518 submakes it's the token they were given by their parent. For the
1519 top make, we just subtract one from the number the user wants. We
1520 want job_slots to be 0 to indicate we're using the jobserver. */
1522 while (--job_slots)
1523 while (write (job_fds[1], &c, 1) != 1)
1524 if (!EINTR_SET)
1525 pfatal_with_name (_("init jobserver pipe"));
1527 /* Fill in the jobserver_fds struct for our children. */
1529 jobserver_fds = (struct stringlist *)
1530 xmalloc (sizeof (struct stringlist));
1531 jobserver_fds->list = (char **) xmalloc (sizeof (char *));
1532 jobserver_fds->list[0] = xmalloc ((sizeof ("1024")*2)+1);
1534 sprintf (jobserver_fds->list[0], "%d,%d", job_fds[0], job_fds[1]);
1535 jobserver_fds->idx = 1;
1536 jobserver_fds->max = 1;
1538 #endif
1540 /* Set up MAKEFLAGS and MFLAGS again, so they will be right. */
1542 define_makeflags (1, 0);
1544 /* Make each `struct dep' point at the `struct file' for the file
1545 depended on. Also do magic for special targets. */
1547 snap_deps ();
1549 /* Convert old-style suffix rules to pattern rules. It is important to
1550 do this before installing the built-in pattern rules below, so that
1551 makefile-specified suffix rules take precedence over built-in pattern
1552 rules. */
1554 convert_to_pattern ();
1556 /* Install the default implicit pattern rules.
1557 This used to be done before reading the makefiles.
1558 But in that case, built-in pattern rules were in the chain
1559 before user-defined ones, so they matched first. */
1561 install_default_implicit_rules ();
1563 /* Compute implicit rule limits. */
1565 count_implicit_rule_limits ();
1567 /* Construct the listings of directories in VPATH lists. */
1569 build_vpath_lists ();
1571 /* Mark files given with -o flags as very old (00:00:01.00 Jan 1, 1970)
1572 and as having been updated already, and files given with -W flags as
1573 brand new (time-stamp as far as possible into the future). */
1575 if (old_files != 0)
1576 for (p = old_files->list; *p != 0; ++p)
1578 f = enter_command_line_file (*p);
1579 f->last_mtime = f->mtime_before_update = (FILE_TIMESTAMP) 1;
1580 f->updated = 1;
1581 f->update_status = 0;
1582 f->command_state = cs_finished;
1585 if (new_files != 0)
1587 for (p = new_files->list; *p != 0; ++p)
1589 f = enter_command_line_file (*p);
1590 f->last_mtime = f->mtime_before_update = NEW_MTIME;
1594 /* Initialize the remote job module. */
1595 remote_setup ();
1597 if (read_makefiles != 0)
1599 /* Update any makefiles if necessary. */
1601 FILE_TIMESTAMP *makefile_mtimes = 0;
1602 unsigned int mm_idx = 0;
1603 char **nargv = argv;
1604 int nargc = argc;
1605 int orig_db_level = db_level;
1607 if (! ISDB (DB_MAKEFILES))
1608 db_level = DB_NONE;
1610 DB (DB_BASIC, (_("Updating makefiles....\n")));
1612 /* Remove any makefiles we don't want to try to update.
1613 Also record the current modtimes so we can compare them later. */
1615 register struct dep *d, *last;
1616 last = 0;
1617 d = read_makefiles;
1618 while (d != 0)
1620 register struct file *f = d->file;
1621 if (f->double_colon)
1622 for (f = f->double_colon; f != NULL; f = f->prev)
1624 if (f->deps == 0 && f->cmds != 0)
1626 /* This makefile is a :: target with commands, but
1627 no dependencies. So, it will always be remade.
1628 This might well cause an infinite loop, so don't
1629 try to remake it. (This will only happen if
1630 your makefiles are written exceptionally
1631 stupidly; but if you work for Athena, that's how
1632 you write your makefiles.) */
1634 DB (DB_VERBOSE,
1635 (_("Makefile `%s' might loop; not remaking it.\n"),
1636 f->name));
1638 if (last == 0)
1639 read_makefiles = d->next;
1640 else
1641 last->next = d->next;
1643 /* Free the storage. */
1644 free ((char *) d);
1646 d = last == 0 ? read_makefiles : last->next;
1648 break;
1651 if (f == NULL || !f->double_colon)
1653 makefile_mtimes = (FILE_TIMESTAMP *)
1654 xrealloc ((char *) makefile_mtimes,
1655 (mm_idx + 1) * sizeof (FILE_TIMESTAMP));
1656 makefile_mtimes[mm_idx++] = file_mtime_no_search (d->file);
1657 last = d;
1658 d = d->next;
1663 /* Set up `MAKEFLAGS' specially while remaking makefiles. */
1664 define_makeflags (1, 1);
1666 switch (update_goal_chain (read_makefiles, 1))
1668 case 1:
1669 default:
1670 #define BOGUS_UPDATE_STATUS 0
1671 assert (BOGUS_UPDATE_STATUS);
1672 break;
1674 case -1:
1675 /* Did nothing. */
1676 break;
1678 case 2:
1679 /* Failed to update. Figure out if we care. */
1681 /* Nonzero if any makefile was successfully remade. */
1682 int any_remade = 0;
1683 /* Nonzero if any makefile we care about failed
1684 in updating or could not be found at all. */
1685 int any_failed = 0;
1686 register unsigned int i;
1687 struct dep *d;
1689 for (i = 0, d = read_makefiles; d != 0; ++i, d = d->next)
1691 /* Reset the considered flag; we may need to look at the file
1692 again to print an error. */
1693 d->file->considered = 0;
1695 if (d->file->updated)
1697 /* This makefile was updated. */
1698 if (d->file->update_status == 0)
1700 /* It was successfully updated. */
1701 any_remade |= (file_mtime_no_search (d->file)
1702 != makefile_mtimes[i]);
1704 else if (! (d->changed & RM_DONTCARE))
1706 FILE_TIMESTAMP mtime;
1707 /* The update failed and this makefile was not
1708 from the MAKEFILES variable, so we care. */
1709 error (NILF, _("Failed to remake makefile `%s'."),
1710 d->file->name);
1711 mtime = file_mtime_no_search (d->file);
1712 any_remade |= (mtime != (FILE_TIMESTAMP) -1
1713 && mtime != makefile_mtimes[i]);
1716 else
1717 /* This makefile was not found at all. */
1718 if (! (d->changed & RM_DONTCARE))
1720 /* This is a makefile we care about. See how much. */
1721 if (d->changed & RM_INCLUDED)
1722 /* An included makefile. We don't need
1723 to die, but we do want to complain. */
1724 error (NILF,
1725 _("Included makefile `%s' was not found."),
1726 dep_name (d));
1727 else
1729 /* A normal makefile. We must die later. */
1730 error (NILF, _("Makefile `%s' was not found"),
1731 dep_name (d));
1732 any_failed = 1;
1736 /* Reset this to empty so we get the right error message below. */
1737 read_makefiles = 0;
1739 if (any_remade)
1740 goto re_exec;
1741 if (any_failed)
1742 die (2);
1743 break;
1746 case 0:
1747 re_exec:
1748 /* Updated successfully. Re-exec ourselves. */
1750 remove_intermediates (0);
1752 if (print_data_base_flag)
1753 print_data_base ();
1755 log_working_directory (0);
1757 if (makefiles != 0)
1759 /* These names might have changed. */
1760 register unsigned int i, j = 0;
1761 for (i = 1; i < argc; ++i)
1762 if (strneq (argv[i], "-f", 2)) /* XXX */
1764 char *p = &argv[i][2];
1765 if (*p == '\0')
1766 argv[++i] = makefiles->list[j];
1767 else
1768 argv[i] = concat ("-f", makefiles->list[j], "");
1769 ++j;
1773 /* Add -o option for the stdin temporary file, if necessary. */
1774 if (stdin_nm)
1776 nargv = (char **) xmalloc ((nargc + 2) * sizeof (char *));
1777 bcopy ((char *) argv, (char *) nargv, argc * sizeof (char *));
1778 nargv[nargc++] = concat ("-o", stdin_nm, "");
1779 nargv[nargc] = 0;
1782 if (directories != 0 && directories->idx > 0)
1784 char bad;
1785 if (directory_before_chdir != 0)
1787 if (chdir (directory_before_chdir) < 0)
1789 perror_with_name ("chdir", "");
1790 bad = 1;
1792 else
1793 bad = 0;
1795 else
1796 bad = 1;
1797 if (bad)
1798 fatal (NILF, _("Couldn't change back to original directory."));
1801 #ifndef _AMIGA
1802 for (p = environ; *p != 0; ++p)
1803 if (strneq (*p, "MAKELEVEL=", 10))
1805 /* The SGI compiler apparently can't understand
1806 the concept of storing the result of a function
1807 in something other than a local variable. */
1808 char *sgi_loses;
1809 sgi_loses = (char *) alloca (40);
1810 *p = sgi_loses;
1811 sprintf (*p, "MAKELEVEL=%u", makelevel);
1812 break;
1814 #else /* AMIGA */
1816 char buffer[256];
1817 int len;
1819 len = GetVar ("MAKELEVEL", buffer, sizeof (buffer), GVF_GLOBAL_ONLY);
1821 if (len != -1)
1823 sprintf (buffer, "%u", makelevel);
1824 SetVar ("MAKELEVEL", buffer, -1, GVF_GLOBAL_ONLY);
1827 #endif
1829 if (ISDB (DB_BASIC))
1831 char **p;
1832 fputs (_("Re-executing:"), stdout);
1833 for (p = nargv; *p != 0; ++p)
1834 printf (" %s", *p);
1835 putchar ('\n');
1838 fflush (stdout);
1839 fflush (stderr);
1841 /* Close the dup'd jobserver pipe if we opened one. */
1842 if (job_rfd >= 0)
1843 close (job_rfd);
1845 #ifndef _AMIGA
1846 exec_command (nargv, environ);
1847 #else
1848 exec_command (nargv);
1849 exit (0);
1850 #endif
1851 /* NOTREACHED */
1854 db_level = orig_db_level;
1857 /* Set up `MAKEFLAGS' again for the normal targets. */
1858 define_makeflags (1, 0);
1860 /* If there is a temp file from reading a makefile from stdin, get rid of
1861 it now. */
1862 if (stdin_nm && unlink (stdin_nm) < 0 && errno != ENOENT)
1863 perror_with_name (_("unlink (temporary file): "), stdin_nm);
1866 int status;
1868 /* If there were no command-line goals, use the default. */
1869 if (goals == 0)
1871 if (default_goal_file != 0)
1873 goals = (struct dep *) xmalloc (sizeof (struct dep));
1874 goals->next = 0;
1875 goals->name = 0;
1876 goals->file = default_goal_file;
1879 else
1880 lastgoal->next = 0;
1882 if (!goals)
1884 if (read_makefiles == 0)
1885 fatal (NILF, _("No targets specified and no makefile found"));
1887 fatal (NILF, _("No targets"));
1890 /* Update the goals. */
1892 DB (DB_BASIC, (_("Updating goal targets....\n")));
1894 switch (update_goal_chain (goals, 0))
1896 case -1:
1897 /* Nothing happened. */
1898 case 0:
1899 /* Updated successfully. */
1900 status = EXIT_SUCCESS;
1901 break;
1902 case 2:
1903 /* Updating failed. POSIX.2 specifies exit status >1 for this;
1904 but in VMS, there is only success and failure. */
1905 status = EXIT_FAILURE ? 2 : EXIT_FAILURE;
1906 break;
1907 case 1:
1908 /* We are under -q and would run some commands. */
1909 status = EXIT_FAILURE;
1910 break;
1911 default:
1912 abort ();
1915 /* If we detected some clock skew, generate one last warning */
1916 if (clock_skew_detected)
1917 error (NILF,
1918 _("warning: Clock skew detected. Your build may be incomplete."));
1920 /* Exit. */
1921 die (status);
1924 return 0;
1927 /* Parsing of arguments, decoding of switches. */
1929 static char options[1 + sizeof (switches) / sizeof (switches[0]) * 3];
1930 static struct option long_options[(sizeof (switches) / sizeof (switches[0])) +
1931 (sizeof (long_option_aliases) /
1932 sizeof (long_option_aliases[0]))];
1934 /* Fill in the string and vector for getopt. */
1935 static void
1936 init_switches ()
1938 register char *p;
1939 register int c;
1940 register unsigned int i;
1942 if (options[0] != '\0')
1943 /* Already done. */
1944 return;
1946 p = options;
1948 /* Return switch and non-switch args in order, regardless of
1949 POSIXLY_CORRECT. Non-switch args are returned as option 1. */
1950 *p++ = '-';
1952 for (i = 0; switches[i].c != '\0'; ++i)
1954 long_options[i].name = (switches[i].long_name == 0 ? "" :
1955 switches[i].long_name);
1956 long_options[i].flag = 0;
1957 long_options[i].val = switches[i].c;
1958 if (short_option (switches[i].c))
1959 *p++ = switches[i].c;
1960 switch (switches[i].type)
1962 case flag:
1963 case flag_off:
1964 case ignore:
1965 long_options[i].has_arg = no_argument;
1966 break;
1968 case string:
1969 case positive_int:
1970 case floating:
1971 if (short_option (switches[i].c))
1972 *p++ = ':';
1973 if (switches[i].noarg_value != 0)
1975 if (short_option (switches[i].c))
1976 *p++ = ':';
1977 long_options[i].has_arg = optional_argument;
1979 else
1980 long_options[i].has_arg = required_argument;
1981 break;
1984 *p = '\0';
1985 for (c = 0; c < (sizeof (long_option_aliases) /
1986 sizeof (long_option_aliases[0]));
1987 ++c)
1988 long_options[i++] = long_option_aliases[c];
1989 long_options[i].name = 0;
1992 static void
1993 handle_non_switch_argument (arg, env)
1994 char *arg;
1995 int env;
1997 /* Non-option argument. It might be a variable definition. */
1998 struct variable *v;
1999 if (arg[0] == '-' && arg[1] == '\0')
2000 /* Ignore plain `-' for compatibility. */
2001 return;
2002 v = try_variable_definition (0, arg, o_command, 0);
2003 if (v != 0)
2005 /* It is indeed a variable definition. Record a pointer to
2006 the variable for later use in define_makeflags. */
2007 struct command_variable *cv
2008 = (struct command_variable *) xmalloc (sizeof (*cv));
2009 cv->variable = v;
2010 cv->next = command_variables;
2011 command_variables = cv;
2013 else if (! env)
2015 /* Not an option or variable definition; it must be a goal
2016 target! Enter it as a file and add it to the dep chain of
2017 goals. */
2018 struct file *f = enter_command_line_file (arg);
2019 f->cmd_target = 1;
2021 if (goals == 0)
2023 goals = (struct dep *) xmalloc (sizeof (struct dep));
2024 lastgoal = goals;
2026 else
2028 lastgoal->next = (struct dep *) xmalloc (sizeof (struct dep));
2029 lastgoal = lastgoal->next;
2031 lastgoal->name = 0;
2032 lastgoal->file = f;
2035 /* Add this target name to the MAKECMDGOALS variable. */
2036 struct variable *v;
2037 char *value;
2039 v = lookup_variable ("MAKECMDGOALS", 12);
2040 if (v == 0)
2041 value = f->name;
2042 else
2044 /* Paste the old and new values together */
2045 unsigned int oldlen, newlen;
2047 oldlen = strlen (v->value);
2048 newlen = strlen (f->name);
2049 value = (char *) alloca (oldlen + 1 + newlen + 1);
2050 bcopy (v->value, value, oldlen);
2051 value[oldlen] = ' ';
2052 bcopy (f->name, &value[oldlen + 1], newlen + 1);
2054 define_variable ("MAKECMDGOALS", 12, value, o_default, 0);
2059 /* Print a nice usage method. */
2061 static void
2062 print_usage (bad)
2063 int bad;
2065 register const struct command_switch *cs;
2066 FILE *usageto;
2068 if (print_version_flag)
2069 print_version ();
2071 usageto = bad ? stderr : stdout;
2073 fprintf (usageto, _("Usage: %s [options] [target] ...\n"), program);
2075 fputs (_("Options:\n"), usageto);
2076 for (cs = switches; cs->c != '\0'; ++cs)
2078 char buf[1024], shortarg[50], longarg[50], *p;
2080 if (!cs->description || cs->description[0] == '-')
2081 continue;
2083 switch (long_options[cs - switches].has_arg)
2085 case no_argument:
2086 shortarg[0] = longarg[0] = '\0';
2087 break;
2088 case required_argument:
2089 sprintf (longarg, "=%s", gettext (cs->argdesc));
2090 sprintf (shortarg, " %s", gettext (cs->argdesc));
2091 break;
2092 case optional_argument:
2093 sprintf (longarg, "[=%s]", gettext (cs->argdesc));
2094 sprintf (shortarg, " [%s]", gettext (cs->argdesc));
2095 break;
2098 p = buf;
2100 if (short_option (cs->c))
2102 sprintf (buf, " -%c%s", cs->c, shortarg);
2103 p += strlen (p);
2105 if (cs->long_name != 0)
2107 unsigned int i;
2108 sprintf (p, "%s--%s%s",
2109 !short_option (cs->c) ? " " : ", ",
2110 cs->long_name, longarg);
2111 p += strlen (p);
2112 for (i = 0; i < (sizeof (long_option_aliases) /
2113 sizeof (long_option_aliases[0]));
2114 ++i)
2115 if (long_option_aliases[i].val == cs->c)
2117 sprintf (p, ", --%s%s",
2118 long_option_aliases[i].name, longarg);
2119 p += strlen (p);
2123 const struct command_switch *ncs = cs;
2124 while ((++ncs)->c != '\0')
2125 if (ncs->description
2126 && ncs->description[0] == '-'
2127 && ncs->description[1] == cs->c)
2129 /* This is another switch that does the same
2130 one as the one we are processing. We want
2131 to list them all together on one line. */
2132 sprintf (p, ", -%c%s", ncs->c, shortarg);
2133 p += strlen (p);
2134 if (ncs->long_name != 0)
2136 sprintf (p, ", --%s%s", ncs->long_name, longarg);
2137 p += strlen (p);
2142 if (p - buf > DESCRIPTION_COLUMN - 2)
2143 /* The list of option names is too long to fit on the same
2144 line with the description, leaving at least two spaces.
2145 Print it on its own line instead. */
2147 fprintf (usageto, "%s\n", buf);
2148 buf[0] = '\0';
2151 fprintf (usageto, "%*s%s.\n",
2152 - DESCRIPTION_COLUMN,
2153 buf, gettext (cs->description));
2156 fprintf (usageto, _("\nReport bugs to <bug-make@gnu.org>.\n"));
2159 /* Decode switches from ARGC and ARGV.
2160 They came from the environment if ENV is nonzero. */
2162 static void
2163 decode_switches (argc, argv, env)
2164 int argc;
2165 char **argv;
2166 int env;
2168 int bad = 0;
2169 register const struct command_switch *cs;
2170 register struct stringlist *sl;
2171 register int c;
2173 /* getopt does most of the parsing for us.
2174 First, get its vectors set up. */
2176 init_switches ();
2178 /* Let getopt produce error messages for the command line,
2179 but not for options from the environment. */
2180 opterr = !env;
2181 /* Reset getopt's state. */
2182 optind = 0;
2184 while (optind < argc)
2186 /* Parse the next argument. */
2187 c = getopt_long (argc, argv, options, long_options, (int *) 0);
2188 if (c == EOF)
2189 /* End of arguments, or "--" marker seen. */
2190 break;
2191 else if (c == 1)
2192 /* An argument not starting with a dash. */
2193 handle_non_switch_argument (optarg, env);
2194 else if (c == '?')
2195 /* Bad option. We will print a usage message and die later.
2196 But continue to parse the other options so the user can
2197 see all he did wrong. */
2198 bad = 1;
2199 else
2200 for (cs = switches; cs->c != '\0'; ++cs)
2201 if (cs->c == c)
2203 /* Whether or not we will actually do anything with
2204 this switch. We test this individually inside the
2205 switch below rather than just once outside it, so that
2206 options which are to be ignored still consume args. */
2207 int doit = !env || cs->env;
2209 switch (cs->type)
2211 default:
2212 abort ();
2214 case ignore:
2215 break;
2217 case flag:
2218 case flag_off:
2219 if (doit)
2220 *(int *) cs->value_ptr = cs->type == flag;
2221 break;
2223 case string:
2224 if (!doit)
2225 break;
2227 if (optarg == 0)
2228 optarg = cs->noarg_value;
2230 sl = *(struct stringlist **) cs->value_ptr;
2231 if (sl == 0)
2233 sl = (struct stringlist *)
2234 xmalloc (sizeof (struct stringlist));
2235 sl->max = 5;
2236 sl->idx = 0;
2237 sl->list = (char **) xmalloc (5 * sizeof (char *));
2238 *(struct stringlist **) cs->value_ptr = sl;
2240 else if (sl->idx == sl->max - 1)
2242 sl->max += 5;
2243 sl->list = (char **)
2244 xrealloc ((char *) sl->list,
2245 sl->max * sizeof (char *));
2247 sl->list[sl->idx++] = optarg;
2248 sl->list[sl->idx] = 0;
2249 break;
2251 case positive_int:
2252 if (optarg == 0 && argc > optind
2253 && ISDIGIT (argv[optind][0]))
2254 optarg = argv[optind++];
2256 if (!doit)
2257 break;
2259 if (optarg != 0)
2261 int i = atoi (optarg);
2262 if (i < 1)
2264 if (doit)
2265 error (NILF, _("the `-%c' option requires a positive integral argument"),
2266 cs->c);
2267 bad = 1;
2269 else
2270 *(unsigned int *) cs->value_ptr = i;
2272 else
2273 *(unsigned int *) cs->value_ptr
2274 = *(unsigned int *) cs->noarg_value;
2275 break;
2277 #ifndef NO_FLOAT
2278 case floating:
2279 if (optarg == 0 && optind < argc
2280 && (ISDIGIT (argv[optind][0]) || argv[optind][0] == '.'))
2281 optarg = argv[optind++];
2283 if (doit)
2284 *(double *) cs->value_ptr
2285 = (optarg != 0 ? atof (optarg)
2286 : *(double *) cs->noarg_value);
2288 break;
2289 #endif
2292 /* We've found the switch. Stop looking. */
2293 break;
2297 /* There are no more options according to getting getopt, but there may
2298 be some arguments left. Since we have asked for non-option arguments
2299 to be returned in order, this only happens when there is a "--"
2300 argument to prevent later arguments from being options. */
2301 while (optind < argc)
2302 handle_non_switch_argument (argv[optind++], env);
2305 if (!env && (bad || print_usage_flag))
2307 print_usage (bad);
2308 die (bad ? 2 : 0);
2312 /* Decode switches from environment variable ENVAR (which is LEN chars long).
2313 We do this by chopping the value into a vector of words, prepending a
2314 dash to the first word if it lacks one, and passing the vector to
2315 decode_switches. */
2317 static void
2318 decode_env_switches (envar, len)
2319 char *envar;
2320 unsigned int len;
2322 char *varref = (char *) alloca (2 + len + 2);
2323 char *value, *p;
2324 int argc;
2325 char **argv;
2327 /* Get the variable's value. */
2328 varref[0] = '$';
2329 varref[1] = '(';
2330 bcopy (envar, &varref[2], len);
2331 varref[2 + len] = ')';
2332 varref[2 + len + 1] = '\0';
2333 value = variable_expand (varref);
2335 /* Skip whitespace, and check for an empty value. */
2336 value = next_token (value);
2337 len = strlen (value);
2338 if (len == 0)
2339 return;
2341 /* Allocate a vector that is definitely big enough. */
2342 argv = (char **) alloca ((1 + len + 1) * sizeof (char *));
2344 /* Allocate a buffer to copy the value into while we split it into words
2345 and unquote it. We must use permanent storage for this because
2346 decode_switches may store pointers into the passed argument words. */
2347 p = (char *) xmalloc (2 * len);
2349 /* getopt will look at the arguments starting at ARGV[1].
2350 Prepend a spacer word. */
2351 argv[0] = 0;
2352 argc = 1;
2353 argv[argc] = p;
2354 while (*value != '\0')
2356 if (*value == '\\' && value[1] != '\0')
2357 ++value; /* Skip the backslash. */
2358 else if (isblank (*value))
2360 /* End of the word. */
2361 *p++ = '\0';
2362 argv[++argc] = p;
2364 ++value;
2365 while (isblank (*value));
2366 continue;
2368 *p++ = *value++;
2370 *p = '\0';
2371 argv[++argc] = 0;
2373 if (argv[1][0] != '-' && strchr (argv[1], '=') == 0)
2374 /* The first word doesn't start with a dash and isn't a variable
2375 definition. Add a dash and pass it along to decode_switches. We
2376 need permanent storage for this in case decode_switches saves
2377 pointers into the value. */
2378 argv[1] = concat ("-", argv[1], "");
2380 /* Parse those words. */
2381 decode_switches (argc, argv, 1);
2384 /* Quote the string IN so that it will be interpreted as a single word with
2385 no magic by decode_env_switches; also double dollar signs to avoid
2386 variable expansion in make itself. Write the result into OUT, returning
2387 the address of the next character to be written.
2388 Allocating space for OUT twice the length of IN is always sufficient. */
2390 static char *
2391 quote_for_env (out, in)
2392 char *out, *in;
2394 while (*in != '\0')
2396 if (*in == '$')
2397 *out++ = '$';
2398 else if (isblank (*in) || *in == '\\')
2399 *out++ = '\\';
2400 *out++ = *in++;
2403 return out;
2406 /* Define the MAKEFLAGS and MFLAGS variables to reflect the settings of the
2407 command switches. Include options with args if ALL is nonzero.
2408 Don't include options with the `no_makefile' flag set if MAKEFILE. */
2410 static void
2411 define_makeflags (all, makefile)
2412 int all, makefile;
2414 static const char ref[] = "$(MAKEOVERRIDES)";
2415 static const char posixref[] = "$(-*-command-variables-*-)";
2416 register const struct command_switch *cs;
2417 char *flagstring;
2418 register char *p;
2419 unsigned int words;
2420 struct variable *v;
2422 /* We will construct a linked list of `struct flag's describing
2423 all the flags which need to go in MAKEFLAGS. Then, once we
2424 know how many there are and their lengths, we can put them all
2425 together in a string. */
2427 struct flag
2429 struct flag *next;
2430 const struct command_switch *cs;
2431 char *arg;
2433 struct flag *flags = 0;
2434 unsigned int flagslen = 0;
2435 #define ADD_FLAG(ARG, LEN) \
2436 do { \
2437 struct flag *new = (struct flag *) alloca (sizeof (struct flag)); \
2438 new->cs = cs; \
2439 new->arg = (ARG); \
2440 new->next = flags; \
2441 flags = new; \
2442 if (new->arg == 0) \
2443 ++flagslen; /* Just a single flag letter. */ \
2444 else \
2445 flagslen += 1 + 1 + 1 + 1 + 3 * (LEN); /* " -x foo" */ \
2446 if (!short_option (cs->c)) \
2447 /* This switch has no single-letter version, so we use the long. */ \
2448 flagslen += 2 + strlen (cs->long_name); \
2449 } while (0)
2451 for (cs = switches; cs->c != '\0'; ++cs)
2452 if (cs->toenv && (!makefile || !cs->no_makefile))
2453 switch (cs->type)
2455 default:
2456 abort ();
2458 case ignore:
2459 break;
2461 case flag:
2462 case flag_off:
2463 if (!*(int *) cs->value_ptr == (cs->type == flag_off)
2464 && (cs->default_value == 0
2465 || *(int *) cs->value_ptr != *(int *) cs->default_value))
2466 ADD_FLAG (0, 0);
2467 break;
2469 case positive_int:
2470 if (all)
2472 if ((cs->default_value != 0
2473 && (*(unsigned int *) cs->value_ptr
2474 == *(unsigned int *) cs->default_value)))
2475 break;
2476 else if (cs->noarg_value != 0
2477 && (*(unsigned int *) cs->value_ptr ==
2478 *(unsigned int *) cs->noarg_value))
2479 ADD_FLAG ("", 0); /* Optional value omitted; see below. */
2480 else if (cs->c == 'j')
2481 /* Special case for `-j'. */
2482 ADD_FLAG ("1", 1);
2483 else
2485 char *buf = (char *) alloca (30);
2486 sprintf (buf, "%u", *(unsigned int *) cs->value_ptr);
2487 ADD_FLAG (buf, strlen (buf));
2490 break;
2492 #ifndef NO_FLOAT
2493 case floating:
2494 if (all)
2496 if (cs->default_value != 0
2497 && (*(double *) cs->value_ptr
2498 == *(double *) cs->default_value))
2499 break;
2500 else if (cs->noarg_value != 0
2501 && (*(double *) cs->value_ptr
2502 == *(double *) cs->noarg_value))
2503 ADD_FLAG ("", 0); /* Optional value omitted; see below. */
2504 else
2506 char *buf = (char *) alloca (100);
2507 sprintf (buf, "%g", *(double *) cs->value_ptr);
2508 ADD_FLAG (buf, strlen (buf));
2511 break;
2512 #endif
2514 case string:
2515 if (all)
2517 struct stringlist *sl = *(struct stringlist **) cs->value_ptr;
2518 if (sl != 0)
2520 /* Add the elements in reverse order, because
2521 all the flags get reversed below; and the order
2522 matters for some switches (like -I). */
2523 register unsigned int i = sl->idx;
2524 while (i-- > 0)
2525 ADD_FLAG (sl->list[i], strlen (sl->list[i]));
2528 break;
2531 flagslen += 4 + sizeof posixref; /* Four more for the possible " -- ". */
2533 #undef ADD_FLAG
2535 /* Construct the value in FLAGSTRING.
2536 We allocate enough space for a preceding dash and trailing null. */
2537 flagstring = (char *) alloca (1 + flagslen + 1);
2538 bzero (flagstring, 1 + flagslen + 1);
2539 p = flagstring;
2540 words = 1;
2541 *p++ = '-';
2542 while (flags != 0)
2544 /* Add the flag letter or name to the string. */
2545 if (short_option (flags->cs->c))
2546 *p++ = flags->cs->c;
2547 else
2549 if (*p != '-')
2551 *p++ = ' ';
2552 *p++ = '-';
2554 *p++ = '-';
2555 strcpy (p, flags->cs->long_name);
2556 p += strlen (p);
2558 if (flags->arg != 0)
2560 /* A flag that takes an optional argument which in this case is
2561 omitted is specified by ARG being "". We must distinguish
2562 because a following flag appended without an intervening " -"
2563 is considered the arg for the first. */
2564 if (flags->arg[0] != '\0')
2566 /* Add its argument too. */
2567 *p++ = !short_option (flags->cs->c) ? '=' : ' ';
2568 p = quote_for_env (p, flags->arg);
2570 ++words;
2571 /* Write a following space and dash, for the next flag. */
2572 *p++ = ' ';
2573 *p++ = '-';
2575 else if (!short_option (flags->cs->c))
2577 ++words;
2578 /* Long options must each go in their own word,
2579 so we write the following space and dash. */
2580 *p++ = ' ';
2581 *p++ = '-';
2583 flags = flags->next;
2586 /* Define MFLAGS before appending variable definitions. */
2588 if (p == &flagstring[1])
2589 /* No flags. */
2590 flagstring[0] = '\0';
2591 else if (p[-1] == '-')
2593 /* Kill the final space and dash. */
2594 p -= 2;
2595 *p = '\0';
2597 else
2598 /* Terminate the string. */
2599 *p = '\0';
2601 /* Since MFLAGS is not parsed for flags, there is no reason to
2602 override any makefile redefinition. */
2603 (void) define_variable ("MFLAGS", 6, flagstring, o_env, 1);
2605 if (all && command_variables != 0)
2607 /* Now write a reference to $(MAKEOVERRIDES), which contains all the
2608 command-line variable definitions. */
2610 if (p == &flagstring[1])
2611 /* No flags written, so elide the leading dash already written. */
2612 p = flagstring;
2613 else
2615 /* Separate the variables from the switches with a "--" arg. */
2616 if (p[-1] != '-')
2618 /* We did not already write a trailing " -". */
2619 *p++ = ' ';
2620 *p++ = '-';
2622 /* There is a trailing " -"; fill it out to " -- ". */
2623 *p++ = '-';
2624 *p++ = ' ';
2627 /* Copy in the string. */
2628 if (posix_pedantic)
2630 bcopy (posixref, p, sizeof posixref - 1);
2631 p += sizeof posixref - 1;
2633 else
2635 bcopy (ref, p, sizeof ref - 1);
2636 p += sizeof ref - 1;
2639 else if (p == &flagstring[1])
2641 words = 0;
2642 --p;
2644 else if (p[-1] == '-')
2645 /* Kill the final space and dash. */
2646 p -= 2;
2647 /* Terminate the string. */
2648 *p = '\0';
2650 v = define_variable ("MAKEFLAGS", 9,
2651 /* If there are switches, omit the leading dash
2652 unless it is a single long option with two
2653 leading dashes. */
2654 &flagstring[(flagstring[0] == '-'
2655 && flagstring[1] != '-')
2656 ? 1 : 0],
2657 /* This used to use o_env, but that lost when a
2658 makefile defined MAKEFLAGS. Makefiles set
2659 MAKEFLAGS to add switches, but we still want
2660 to redefine its value with the full set of
2661 switches. Of course, an override or command
2662 definition will still take precedence. */
2663 o_file, 1);
2664 if (! all)
2665 /* The first time we are called, set MAKEFLAGS to always be exported.
2666 We should not do this again on the second call, because that is
2667 after reading makefiles which might have done `unexport MAKEFLAGS'. */
2668 v->export = v_export;
2671 /* Print version information. */
2673 static void
2674 print_version ()
2676 extern char *make_host;
2677 static int printed_version = 0;
2679 char *precede = print_data_base_flag ? "# " : "";
2681 if (printed_version)
2682 /* Do it only once. */
2683 return;
2685 printf ("%sGNU Make version %s", precede, version_string);
2686 if (remote_description != 0 && *remote_description != '\0')
2687 printf ("-%s", remote_description);
2689 printf (_(", by Richard Stallman and Roland McGrath.\n\
2690 %sBuilt for %s\n\
2691 %sCopyright (C) 1988, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 2000\n\
2692 %s\tFree Software Foundation, Inc.\n\
2693 %sThis is free software; see the source for copying conditions.\n\
2694 %sThere is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A\n\
2695 %sPARTICULAR PURPOSE.\n\n\
2696 %sReport bugs to <bug-make@gnu.org>.\n\n"),
2697 precede, make_host,
2698 precede, precede, precede, precede, precede, precede);
2700 printed_version = 1;
2702 /* Flush stdout so the user doesn't have to wait to see the
2703 version information while things are thought about. */
2704 fflush (stdout);
2707 /* Print a bunch of information about this and that. */
2709 static void
2710 print_data_base ()
2712 time_t when;
2714 when = time ((time_t *) 0);
2715 printf (_("\n# Make data base, printed on %s"), ctime (&when));
2717 print_variable_data_base ();
2718 print_dir_data_base ();
2719 print_rule_data_base ();
2720 print_file_data_base ();
2721 print_vpath_data_base ();
2723 when = time ((time_t *) 0);
2724 printf (_("\n# Finished Make data base on %s\n"), ctime (&when));
2727 /* Exit with STATUS, cleaning up as necessary. */
2729 void
2730 die (status)
2731 int status;
2733 static char dying = 0;
2735 if (!dying)
2737 int err;
2739 dying = 1;
2741 if (print_version_flag)
2742 print_version ();
2744 /* Wait for children to die. */
2745 for (err = (status != 0); job_slots_used > 0; err = 0)
2746 reap_children (1, err);
2748 /* Let the remote job module clean up its state. */
2749 remote_cleanup ();
2751 /* Remove the intermediate files. */
2752 remove_intermediates (0);
2754 if (print_data_base_flag)
2755 print_data_base ();
2757 /* Try to move back to the original directory. This is essential on
2758 MS-DOS (where there is really only one process), and on Unix it
2759 puts core files in the original directory instead of the -C
2760 directory. Must wait until after remove_intermediates(), or unlinks
2761 of relative pathnames fail. */
2762 if (directory_before_chdir != 0)
2763 chdir (directory_before_chdir);
2765 log_working_directory (0);
2768 exit (status);
2771 /* Write a message indicating that we've just entered or
2772 left (according to ENTERING) the current directory. */
2774 void
2775 log_working_directory (entering)
2776 int entering;
2778 static int entered = 0;
2779 char *msg = entering ? _("Entering") : _("Leaving");
2781 /* Print nothing without the flag. Don't print the entering message
2782 again if we already have. Don't print the leaving message if we
2783 haven't printed the entering message. */
2784 if (! print_directory_flag || entering == entered)
2785 return;
2787 entered = entering;
2789 if (print_data_base_flag)
2790 fputs ("# ", stdout);
2792 if (makelevel == 0)
2793 printf ("%s: %s ", program, msg);
2794 else
2795 printf ("%s[%u]: %s ", program, makelevel, msg);
2797 if (starting_directory == 0)
2798 puts (_("an unknown directory"));
2799 else
2800 printf (_("directory `%s'\n"), starting_directory);